Module:Reply to/sandbox: Difference between revisions
Appearance
Content deleted Content added
remove unneeded check |
experimental edit to discuss at Template talk:Reply to#Rewrite; revert when done |
||
Line 10: | Line 10: | ||
local outArray, outStr = {}, "" |
local outArray, outStr = {}, "" |
||
args.label1 = args.label1 or args.label |
args.label1 = args.label1 or args.label |
||
local argIndex = {} |
|||
for |
for i, v in ipairs(args) do |
||
if |
if string.match(v,'%S') then |
||
⚫ | |||
table.insert(argIndex, k) |
|||
⚫ | |||
⚫ | |||
table.sort(argIndex) |
|||
for _, k in ipairs(argIndex) do |
|||
if string.match(args[k],'%S') then |
|||
⚫ | |||
if not title then return makeError('Input contains forbidden characters.') end |
if not title then return makeError('Input contains forbidden characters.') end |
||
title = title.rootText |
title = title.rootText |
||
local label = args['label'..tostring( |
local label = args['label'..tostring(i)] |
||
if label == '' then |
if label == '' then |
||
label = '​' |
label = '​' |
||
end |
end |
||
Line 32: | Line 26: | ||
if #outArray > (tonumber(frame.args.max) or 50) then |
if #outArray > (tonumber(frame.args.max) or 50) then |
||
return makeError('More than ' .. tostring(frame.args.max or 50) .. ' names specified.') |
return makeError('More than ' .. tostring(frame.args.max or 50) .. ' names specified.') |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
else |
else |
||
⚫ | |||
⚫ | |||
⚫ | |||
end |
|||
⚫ | |||
⚫ | |||
else |
|||
⚫ | |||
end |
|||
⚫ | |||
end |
end |
||
⚫ | |||
end |
end |
||
Revision as of 02:05, 1 April 2022
![]() | This is the module sandbox page for Module:Reply to (diff). See also the companion subpage for test cases (run). |
![]() | This Lua module is used on approximately 341,000 pages, or roughly 1% of all pages. To avoid major disruption and server load, any changes should be tested in the module's /sandbox or /testcases subpages, or in your own module sandbox. The tested changes can be added to this page in a single edit. Consider discussing changes on the talk page before implementing them. |
![]() | This module is rated as ready for general use. It has reached a mature form and is thought to be relatively bug-free and ready for use wherever appropriate. It is ready to mention on help pages and other Wikipedia resources as an option for new users to learn. To reduce server load and bad output, it should be improved by sandbox testing rather than repeated trial-and-error editing. |
![]() | This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
![]() | This module is rated as ready for general use. It has reached a mature form and is thought to be relatively bug-free and ready for use wherever appropriate. It is ready to mention on help pages and other Wikipedia resources as an option for new users to learn. To reduce server load and bad output, it should be improved by sandbox testing rather than repeated trial-and-error editing. |
![]() | This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
This module is used by {{Reply to}} to trigger a notification to one or several registered user(s) you are replying to in a discussion.
Usage from wikitext
This module cannot be used directly from wikitext. Please use the {{Reply to}} template instead.
Usage within templates
{{#invoke:Reply to|replyto|<noinclude>example=example name</noinclude>|max=maximum number of names}}
- The
|example=
parameter sets the name that will show when the template page is viewed. This parameter should be surrounded by<noinclude>...</noinclude>
so that it is not transcluded with the parent template, and the parent template will show an error message if no names are specified. - The
|max=
parameter sets the maximum number of names that the template will accept. If not specified, it defaults to 50 (which is the maximum number that Echo currently supports as of August 2015[update]). If this number of names is exceeded, the parent template will return an error message.
local p = {}
local function makeError(msg)
msg ='Error in [[Template:Reply to]]: ' .. msg
return mw.text.tag('strong', {['class']='error'}, msg)
end
function p.replyto(frame)
local args = frame:getParent().args
local outArray, outStr = {}, ""
args.label1 = args.label1 or args.label
for i, v in ipairs(args) do
if string.match(v,'%S') then
local title = mw.title.new(v)
if not title then return makeError('Input contains forbidden characters.') end
title = title.rootText
local label = args['label'..tostring(i)]
if label == '' then
label = '​'
end
table.insert(outArray, '[[User:' .. title .. '|' .. (label or title) .. ']]')
end
end
if #outArray > (tonumber(frame.args.max) or 50) then
return makeError('More than ' .. tostring(frame.args.max or 50) .. ' names specified.')
end
if #outArray < 1 then
if frame.args.example then args[1] = frame.args.example else return makeError('Username not given.') end
end
if args.c == '' then
outStr = table.concat(outArray, ", ")
else
outStr = mw.text.listToText(outArray, ', ', (#outArray == 2 and ' ' or ', ') .. (args.c or 'and') .. ' ')
end
return mw.text.tag('span', {['class']='template-ping'}, (args.prefix or '@') .. outStr .. (args.p or ':'))
end
return p