Module:High-use: Difference between revisions
From Rest of What I Know
m 1 revision imported |
m 1 revision imported |
||
(One intermediate revision by one other user not shown) | |||
Line 1: | Line 1: | ||
local p = {} | local p = {} | ||
local getArgs = require('Module:Arguments').getArgs | |||
-- _fetch looks at the "demo" argument. | -- _fetch looks at the "demo" argument. | ||
local _fetch = require('Module:Transclusion_count'). | local _fetch = require('Module:Transclusion_count')._fetch | ||
local yesno = require('Module:Yesno') | local yesno = require('Module:Yesno') | ||
function p. | function p._num(args, count, no_percent) | ||
if count == nil then | if count == nil then | ||
if yesno( | if yesno(args['fetch']) == false then | ||
if ( | if (args[1] or '') ~= '' then count = tonumber(args[1]) end | ||
else | else | ||
count = _fetch( | count = _fetch(args) | ||
end | end | ||
end | end | ||
Line 17: | Line 18: | ||
local return_value = "" | local return_value = "" | ||
if count == nil then | if count == nil then | ||
if | if args[1] == "risk" then | ||
return "a very large number of" | return "a very large number of" | ||
else | else | ||
Line 33: | Line 34: | ||
-- Round and insert "approximately" or "+" when appropriate | -- Round and insert "approximately" or "+" when appropriate | ||
if ( | if (args[2] == "yes") or (type(args[1]) == 'string' and (mw.ustring.sub(args[1],-1) == "+")) then | ||
-- Round down | -- Round down | ||
return_value = string.format("%s+", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) ) * (10^(f))) ) | return_value = string.format("%s+", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) ) * (10^(f))) ) | ||
Line 42: | Line 43: | ||
-- Insert percentage of pages if that is likely to be >= 1% and when |no-percent= not set to yes | -- Insert percentage of pages if that is likely to be >= 1% and when |no-percent= not set to yes | ||
if count and count > 250000 and not yesno ( | no_percent = no_percent or args['no-percent'] | ||
local | if count and count > 250000 and not yesno (no_percent) then | ||
local numpages = mw.getCurrentFrame():callParserFunction('NUMBEROFPAGES', 'R') | |||
local percent = math.floor( ( ( count/numpages ) * 100) + 0.5) | |||
if percent >= 1 then | if percent >= 1 then | ||
return_value = string.format("%s pages, or roughly %s%% of all", return_value, percent) | return_value = string.format("%s pages, or roughly %s%% of all", return_value, percent) | ||
Line 51: | Line 54: | ||
return return_value | return return_value | ||
end | |||
function p.num(frame, count) | |||
return p._num(getArgs(frame), count) | |||
end | end | ||
-- Actions if there is a large (greater than or equal to 100,000) transclusion count | -- Actions if there is a large (greater than or equal to 100,000) transclusion count | ||
function p. | function p._risk(args) | ||
if | if args[1] == "risk" then | ||
return "risk" | return "risk" | ||
else | else | ||
local count = _fetch( | local count = _fetch(args) | ||
if count and count >= 100000 then | if count and count >= 100000 then | ||
return "risk" | return "risk" | ||
Line 66: | Line 73: | ||
end | end | ||
function p. | function p.risk(frame) | ||
return p._risk(getArgs(frame)) | |||
end | |||
function p._text(args, count) | |||
-- Only show the information about how this template gets updated if someone | -- Only show the information about how this template gets updated if someone | ||
-- is actually editing the page and maybe trying to update the count. | -- is actually editing the page and maybe trying to update the count. | ||
local bot_text = ( | local bot_text = (mw.getCurrentFrame():preprocess("{{REVISIONID}}") == "") and "\n\n----\n'''Preview message''': Transclusion count updated automatically ([[Template:High-use/doc#Technical details|see documentation]])." or '' | ||
if count == nil then | if count == nil then | ||
if yesno( | if yesno(args['fetch']) == false then | ||
if ( | if (args[1] or '') ~= '' then count = tonumber(args[1]) end | ||
else | else | ||
count = _fetch( | count = _fetch(args) | ||
end | end | ||
end | end | ||
local title = mw.title.getCurrentTitle() | local title = mw.title.getCurrentTitle() | ||
if ( (args.demo or '' ~= '') and mw.title.new(args.demo, 10) ) then | |||
title = mw.title.new(args.demo, 10) | |||
end | |||
if title.subpageText == "doc" or title.subpageText == "sandbox" then | if title.subpageText == "doc" or title.subpageText == "sandbox" then | ||
title = title.basePageTitle | title = title.basePageTitle | ||
end | end | ||
local systemMessages = | local systemMessages = (args['system'] or '') ~= '' | ||
-- This retrieves the project URL automatically to simplify localization. | -- This retrieves the project URL automatically to simplify localization. | ||
local templateCount = ('on [https://linkcount.toolforge.org/?project=%s&page=%s#transclusions %s pages]'):format( | local templateCount = ('on [https://linkcount.toolforge.org/?project=%s&page=%s#transclusions %s pages]'):format( | ||
title:fullUrl():gsub('//(.-)/.*', '%1'), | |||
mw.uri.encode(title.fullText), p. | mw.uri.encode(title.fullText), p._num(args, count)) | ||
local used_on_text = "'''This " .. ( | local used_on_text = "'''This " .. (title.namespace == 828 and "Lua module" or "template") .. ' is used '; | ||
if systemMessages then | if systemMessages then | ||
used_on_text = used_on_text .. | used_on_text = used_on_text .. args['system'] .. | ||
((count and count > 2000) and ("''', and " .. templateCount) or ("'''")) | ((count and count > 2000) and ("''', and " .. templateCount) or ("'''")) | ||
else | else | ||
Line 102: | Line 114: | ||
local sandbox_text = ("%s's [[%s/sandbox|/sandbox]] or [[%s/testcases|/testcases]] subpages, or in your own [[%s]]. "):format( | local sandbox_text = ("%s's [[%s/sandbox|/sandbox]] or [[%s/testcases|/testcases]] subpages, or in your own [[%s]]. "):format( | ||
( | (title.namespace == 828 and "module" or "template"), | ||
title.fullText, title.fullText, | title.fullText, title.fullText, | ||
title.namespace == 828 and "Module:Sandbox|module sandbox" or "Wikipedia:User pages#SUB|user subpage" | |||
) | ) | ||
local infoArg = | local infoArg = args["info"] ~= "" and args["info"] | ||
if (systemMessages or | if (systemMessages or args[1] == "risk" or (count and count >= 100000) ) then | ||
local info = systemMessages and '.<br/>Changes to it can cause immediate changes to the Wikipedia user interface.' or '.' | local info = systemMessages and '.<br/>Changes to it can cause immediate changes to the Wikipedia user interface.' or '.' | ||
if infoArg then | if infoArg then | ||
Line 124: | Line 136: | ||
local discussion_text = systemMessages and 'Please discuss changes ' or 'Consider discussing changes ' | local discussion_text = systemMessages and 'Please discuss changes ' or 'Consider discussing changes ' | ||
if | if args["2"] and args["2"] ~= "" and args["2"] ~= "yes" then | ||
discussion_text = string.format("%sat [[%s]]", discussion_text, | discussion_text = string.format("%sat [[%s]]", discussion_text, args["2"]) | ||
else | else | ||
discussion_text = string.format("%son the [[%s|talk page]]", discussion_text, title.talkPageTitle.fullText ) | discussion_text = string.format("%son the [[%s|talk page]]", discussion_text, title.talkPageTitle.fullText ) | ||
Line 133: | Line 145: | ||
end | end | ||
function p. | function p.text(frame, count) | ||
return p._text(getArgs(frame), count) | |||
end | |||
function p._main(args, nocat) | |||
local count = nil | local count = nil | ||
if yesno( | if yesno(args['fetch']) == false then | ||
if ( | if (args[1] or '') ~= '' then count = tonumber(args[1]) end | ||
else | else | ||
count = _fetch( | count = _fetch(args) | ||
end | end | ||
local image = "[[File:Ambox warning yellow.svg|40px|alt=Warning|link=]]" | local image = "[[File:Ambox warning yellow.svg|40px|alt=Warning|link=]]" | ||
local type_param = "style" | local type_param = "style" | ||
local epilogue = '' | local epilogue = '' | ||
if | if args['system'] and args['system'] ~= '' then | ||
image = "[[File:Ambox important.svg|40px|alt=Warning|link=]]" | image = "[[File:Ambox important.svg|40px|alt=Warning|link=]]" | ||
type_param = "content" | type_param = "content" | ||
nocat = nocat or args['nocat'] | |||
local categorise = (nocat == '' or not yesno(nocat)) | local categorise = (nocat == '' or not yesno(nocat)) | ||
if categorise and not mw.title.getCurrentTitle().isRedirect then | if categorise and not mw.title.getCurrentTitle().isRedirect then | ||
epilogue = | epilogue = mw.getCurrentFrame():preprocess('{{Sandbox other||{{#switch:{{#invoke:Effective protection level|{{#switch:{{NAMESPACE}}|File=upload|#default=edit}}|{{FULLPAGENAME}}}}|sysop|templateeditor|interfaceadmin=|#default=[[Category:Pages used in system messages needing protection]]}}}}') | ||
end | end | ||
elseif ( | elseif (args[1] == "risk" or (count and count >= 100000)) then | ||
image = "[[File:Ambox warning orange.svg|40px|alt=Warning|link=]]" | image = "[[File:Ambox warning orange.svg|40px|alt=Warning|link=]]" | ||
type_param = "content" | type_param = "content" | ||
end | end | ||
if | if args["form"] == "editnotice" then | ||
return | return mw.getCurrentFrame():expandTemplate{ | ||
title = 'editnotice', | title = 'editnotice', | ||
args = { | args = { | ||
["image"] = image, | ["image"] = image, | ||
["text"] = p. | ["text"] = p._text(args, count), | ||
["expiry"] = ( | ["expiry"] = (args["expiry"] or "") | ||
} | } | ||
} .. epilogue | } .. epilogue | ||
Line 169: | Line 185: | ||
type = type_param, | type = type_param, | ||
image = image, | image = image, | ||
text = p. | text = p._text(args, count), | ||
expiry = ( | expiry = (args["expiry"] or "") | ||
}) .. epilogue | }) .. epilogue | ||
end | end | ||
end | end | ||
function p.main(frame) | |||
return p._main(getArgs(frame)) | |||
end | |||
return p | return p |
Latest revision as of 21:49, 15 January 2025
Documentation for this module may be created at Module:High-use/doc
local p = {}
local getArgs = require('Module:Arguments').getArgs
-- _fetch looks at the "demo" argument.
local _fetch = require('Module:Transclusion_count')._fetch
local yesno = require('Module:Yesno')
function p._num(args, count, no_percent)
if count == nil then
if yesno(args['fetch']) == false then
if (args[1] or '') ~= '' then count = tonumber(args[1]) end
else
count = _fetch(args)
end
end
-- Build output string
local return_value = ""
if count == nil then
if args[1] == "risk" then
return "a very large number of"
else
return "many"
end
else
-- Use 2 significant figures for smaller numbers and 3 for larger ones
local sigfig = 2
if count >= 100000 then
sigfig = 3
end
-- Prepare to round to appropriate number of sigfigs
local f = math.floor(math.log10(count)) - sigfig + 1
-- Round and insert "approximately" or "+" when appropriate
if (args[2] == "yes") or (type(args[1]) == 'string' and (mw.ustring.sub(args[1],-1) == "+")) then
-- Round down
return_value = string.format("%s+", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) ) * (10^(f))) )
else
-- Round to nearest
return_value = string.format("approximately %s", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) + 0.5) * (10^(f))) )
end
-- Insert percentage of pages if that is likely to be >= 1% and when |no-percent= not set to yes
no_percent = no_percent or args['no-percent']
if count and count > 250000 and not yesno (no_percent) then
local numpages = mw.getCurrentFrame():callParserFunction('NUMBEROFPAGES', 'R')
local percent = math.floor( ( ( count/numpages ) * 100) + 0.5)
if percent >= 1 then
return_value = string.format("%s pages, or roughly %s%% of all", return_value, percent)
end
end
end
return return_value
end
function p.num(frame, count)
return p._num(getArgs(frame), count)
end
-- Actions if there is a large (greater than or equal to 100,000) transclusion count
function p._risk(args)
if args[1] == "risk" then
return "risk"
else
local count = _fetch(args)
if count and count >= 100000 then
return "risk"
end
end
return ""
end
function p.risk(frame)
return p._risk(getArgs(frame))
end
function p._text(args, count)
-- Only show the information about how this template gets updated if someone
-- is actually editing the page and maybe trying to update the count.
local bot_text = (mw.getCurrentFrame():preprocess("{{REVISIONID}}") == "") and "\n\n----\n'''Preview message''': Transclusion count updated automatically ([[Template:High-use/doc#Technical details|see documentation]])." or ''
if count == nil then
if yesno(args['fetch']) == false then
if (args[1] or '') ~= '' then count = tonumber(args[1]) end
else
count = _fetch(args)
end
end
local title = mw.title.getCurrentTitle()
if ( (args.demo or '' ~= '') and mw.title.new(args.demo, 10) ) then
title = mw.title.new(args.demo, 10)
end
if title.subpageText == "doc" or title.subpageText == "sandbox" then
title = title.basePageTitle
end
local systemMessages = (args['system'] or '') ~= ''
-- This retrieves the project URL automatically to simplify localization.
local templateCount = ('on [https://linkcount.toolforge.org/?project=%s&page=%s#transclusions %s pages]'):format(
title:fullUrl():gsub('//(.-)/.*', '%1'),
mw.uri.encode(title.fullText), p._num(args, count))
local used_on_text = "'''This " .. (title.namespace == 828 and "Lua module" or "template") .. ' is used ';
if systemMessages then
used_on_text = used_on_text .. args['system'] ..
((count and count > 2000) and ("''', and " .. templateCount) or ("'''"))
else
used_on_text = used_on_text .. templateCount .. "'''"
end
local sandbox_text = ("%s's [[%s/sandbox|/sandbox]] or [[%s/testcases|/testcases]] subpages, or in your own [[%s]]. "):format(
(title.namespace == 828 and "module" or "template"),
title.fullText, title.fullText,
title.namespace == 828 and "Module:Sandbox|module sandbox" or "Wikipedia:User pages#SUB|user subpage"
)
local infoArg = args["info"] ~= "" and args["info"]
if (systemMessages or args[1] == "risk" or (count and count >= 100000) ) then
local info = systemMessages and '.<br/>Changes to it can cause immediate changes to the Wikipedia user interface.' or '.'
if infoArg then
info = info .. "<br />" .. infoArg
end
sandbox_text = info .. '<br /> To avoid major disruption' ..
(count and count >= 100000 and ' and server load' or '') ..
', any changes should be tested in the ' .. sandbox_text ..
'The tested changes can be added to this page in a single edit. '
else
sandbox_text = (infoArg and ('.<br />' .. infoArg .. ' C') or ' and c') ..
'hanges may be widely noticed. Test changes in the ' .. sandbox_text
end
local discussion_text = systemMessages and 'Please discuss changes ' or 'Consider discussing changes '
if args["2"] and args["2"] ~= "" and args["2"] ~= "yes" then
discussion_text = string.format("%sat [[%s]]", discussion_text, args["2"])
else
discussion_text = string.format("%son the [[%s|talk page]]", discussion_text, title.talkPageTitle.fullText )
end
return used_on_text .. sandbox_text .. discussion_text .. " before implementing them." .. bot_text
end
function p.text(frame, count)
return p._text(getArgs(frame), count)
end
function p._main(args, nocat)
local count = nil
if yesno(args['fetch']) == false then
if (args[1] or '') ~= '' then count = tonumber(args[1]) end
else
count = _fetch(args)
end
local image = "[[File:Ambox warning yellow.svg|40px|alt=Warning|link=]]"
local type_param = "style"
local epilogue = ''
if args['system'] and args['system'] ~= '' then
image = "[[File:Ambox important.svg|40px|alt=Warning|link=]]"
type_param = "content"
nocat = nocat or args['nocat']
local categorise = (nocat == '' or not yesno(nocat))
if categorise and not mw.title.getCurrentTitle().isRedirect then
epilogue = mw.getCurrentFrame():preprocess('{{Sandbox other||{{#switch:{{#invoke:Effective protection level|{{#switch:{{NAMESPACE}}|File=upload|#default=edit}}|{{FULLPAGENAME}}}}|sysop|templateeditor|interfaceadmin=|#default=[[Category:Pages used in system messages needing protection]]}}}}')
end
elseif (args[1] == "risk" or (count and count >= 100000)) then
image = "[[File:Ambox warning orange.svg|40px|alt=Warning|link=]]"
type_param = "content"
end
if args["form"] == "editnotice" then
return mw.getCurrentFrame():expandTemplate{
title = 'editnotice',
args = {
["image"] = image,
["text"] = p._text(args, count),
["expiry"] = (args["expiry"] or "")
}
} .. epilogue
else
return require('Module:Message box').main('ombox', {
type = type_param,
image = image,
text = p._text(args, count),
expiry = (args["expiry"] or "")
}) .. epilogue
end
end
function p.main(frame)
return p._main(getArgs(frame))
end
return p