Module:Reply to/sandbox
Appearance
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 330,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 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
[edit]This module cannot be used directly from wikitext. Please use the {{Reply to}} template instead.
Usage within templates
[edit]{{#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
local function makeLink(u, l)
return '[[User:' .. u .. '|' .. (l or u) .. ']]'
end
function p.replyto(frame)
local outArray, argIndex = {}, {}
local args = frame:getParent().args
args.label1 = args.label1 or args.label
for k, v in pairs(args) do
if type(k) == 'number' and string.match(v,'%S') then
table.insert(argIndex, k)
end
end
table.sort(argIndex)
for _, k in ipairs(argIndex) do
local title = mw.title.new(args[k])
if not title then return makeError('Input contains forbidden characters.') end
title = title.rootText
local label = args['label'..tostring(k)]
if label == '' then label = '​' end
table.insert( outArray, makeLink(title, label) )
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
outArray[1] = makeLink(frame.args.example)
else
return makeError('Username not given.')
end
end
local conjuction = (#outArray == 2 and ' ' or ', ') .. (args.c or 'and') .. ' '
local outStr = (args.c == '') and table.concat(outArray, ', ') or mw.text.listToText(outArray, ', ', conjuction)
return mw.text.tag('span', {['class']='template-ping'}, (args.prefix or '@') .. outStr .. (args.p or ':'))
end
return p