Module:High-use: Difference between revisions
Content deleted Content added
change bot text to make it look less like a vanity tag |
Johnrdorazio (talk | contribs) m 1 revision imported |
||
(14 intermediate revisions by 8 users not shown) | |||
Line 1: | Line 1: | ||
local p = {} |
local p = {} |
||
-- _fetch looks at the "demo" argument. |
|||
local _fetch = require('Module:Transclusion_count').fetch |
local _fetch = require('Module:Transclusion_count').fetch |
||
local yesno = require('Module:Yesno') |
|||
function p.num(frame, count) |
function p.num(frame, count) |
||
if count == nil then |
if count == nil then |
||
⚫ | |||
⚫ | |||
else |
|||
count = _fetch(frame) |
|||
⚫ | |||
end |
|||
-- Build output string |
-- Build output string |
||
Line 32: | Line 40: | ||
return_value = string.format("approximately %s", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) + 0.5) * (10^(f))) ) |
return_value = string.format("approximately %s", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) + 0.5) * (10^(f))) ) |
||
end |
end |
||
-- Insert |
-- Insert percentage of pages if that is likely to be >= 1% and when |no-percent= not set to yes |
||
if |
if count and count > 250000 and not yesno (frame:getParent().args['no-percent']) then |
||
local percent = math.floor( ( (count/frame:callParserFunction('NUMBEROFPAGES', 'R') ) * 100) + 0.5) |
local percent = math.floor( ( (count/frame:callParserFunction('NUMBEROFPAGES', 'R') ) * 100) + 0.5) |
||
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) |
||
⚫ | |||
end |
end |
||
end |
end |
||
Line 42: | Line 52: | ||
return return_value |
return return_value |
||
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.risk(frame) |
function p.risk(frame) |
||
Line 55: | Line 66: | ||
function p.text(frame, count) |
function p.text(frame, 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. |
|||
⚫ | |||
⚫ | |||
bot_text = "" |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
if count == nil then |
|||
if yesno(frame.args['fetch']) == false then |
|||
if (frame.args[1] or '') ~= '' then count = tonumber(frame.args[1]) end |
|||
else |
|||
count = _fetch(frame) |
|||
end |
|||
end |
|||
local title = mw.title.getCurrentTitle() |
local title = mw.title.getCurrentTitle() |
||
if title.subpageText == "doc" or title.subpageText == "sandbox" then |
if title.subpageText == "doc" or title.subpageText == "sandbox" then |
||
Line 68: | Line 82: | ||
end |
end |
||
local systemMessages = frame.args['system'] |
|||
local templatecount = string.format("https://templatecount.toolforge.org/index.php?lang=en&namespace=%s&name=%s",mw.title.getCurrentTitle().namespace,mw.uri.encode(title.text)) |
|||
if frame.args['system'] == '' then |
|||
systemMessages = nil |
|||
end |
|||
⚫ | |||
-- This retrieves the project URL automatically to simplify localiation. |
|||
local templateCount = ('on [https://linkcount.toolforge.org/index.php?project=%s&page=%s %s pages]'):format( |
|||
mw.title.getCurrentTitle():fullUrl():gsub('//(.-)/.*', '%1'), |
|||
mw.uri.encode(title.fullText), p.num(frame, count)) |
|||
⚫ | |||
if systemMessages then |
|||
used_on_text = used_on_text .. systemMessages .. |
|||
((count and count > 2000) and ("''', and " .. templateCount) or ("'''")) |
|||
else |
|||
used_on_text = used_on_text .. templateCount .. "'''" |
|||
end |
|||
local used_on_text = string.format("'''This %s is used on [%s %s pages]'''", |
|||
⚫ | |||
templatecount, |
|||
⚫ | |||
) |
|||
local sandbox_text = |
local sandbox_text = ("%s's [[%s/sandbox|/sandbox]] or [[%s/testcases|/testcases]] subpages, or in your own [[%s]]. "):format( |
||
(mw.title.getCurrentTitle().namespace == 828 and "module" or "template"), |
|||
title.fullText, title.fullText, |
|||
mw.title.getCurrentTitle().namespace == 828 and "Module:Sandbox|module sandbox" or "Wikipedia:User pages#SUB|user subpage" |
|||
) |
) |
||
local infoArg = frame.args["info"] ~= "" and frame.args["info"] |
|||
⚫ | |||
local info = "" |
|||
local info = systemMessages and '.<br/>Changes to it can cause immediate changes to the Wikipedia user interface.' or '.' |
|||
⚫ | |||
if infoArg then |
|||
info = "<br />" .. |
info = info .. "<br />" .. infoArg |
||
end |
end |
||
sandbox_text = |
sandbox_text = info .. '<br /> To avoid major disruption' .. |
||
(count and count >= 100000 and ' and server load' or '') .. |
|||
info, sandbox_text |
|||
', any changes should be tested in the ' .. sandbox_text .. |
|||
) |
|||
'The tested changes can be added to this page in a single edit. ' |
|||
else |
else |
||
sandbox_text = |
sandbox_text = (infoArg and ('.<br />' .. infoArg .. ' C') or ' and c') .. |
||
'hanges may be widely noticed. Test changes in the ' .. sandbox_text |
|||
) |
|||
end |
end |
||
local discussion_text = |
local discussion_text = systemMessages and 'Please discuss changes ' or 'Consider discussing changes ' |
||
if frame.args["2"] and frame.args["2"] ~= "" and frame.args["2"] ~= "yes" then |
if frame.args["2"] and frame.args["2"] ~= "" and frame.args["2"] ~= "yes" then |
||
discussion_text = string.format("%sat [[%s]]", discussion_text, frame.args["2"]) |
discussion_text = string.format("%sat [[%s]]", discussion_text, frame.args["2"]) |
||
Line 103: | Line 129: | ||
end |
end |
||
return |
return used_on_text .. sandbox_text .. discussion_text .. " before implementing them." .. bot_text |
||
end |
end |
||
function p.main(frame) |
function p.main(frame) |
||
local count = |
local count = nil |
||
if yesno(frame.args['fetch']) == false then |
|||
local return_value = "" |
|||
if (frame.args[1] or '') ~= '' then count = tonumber(frame.args[1]) end |
|||
else |
|||
count = _fetch(frame) |
|||
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" |
||
⚫ | |||
⚫ | |||
⚫ | |||
image = "[[File:Ambox important.svg|40px|alt=Warning|link=]]" |
|||
type_param = "content" |
|||
local nocat = frame:getParent().args['nocat'] or frame.args['nocat'] |
|||
local categorise = (nocat == '' or not yesno(nocat)) |
|||
if categorise then |
|||
epilogue = frame: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 (frame.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" |
||
Line 117: | Line 156: | ||
if frame.args["form"] == "editnotice" then |
if frame.args["form"] == "editnotice" then |
||
return frame:expandTemplate{ |
|||
title = 'editnotice', |
title = 'editnotice', |
||
args = { |
args = { |
||
Line 124: | Line 163: | ||
["expiry"] = (frame.args["expiry"] or "") |
["expiry"] = (frame.args["expiry"] or "") |
||
} |
} |
||
} .. epilogue |
|||
} |
|||
else |
else |
||
return require('Module:Message box').main('ombox', { |
|||
return_value = frame:expandTemplate{ |
|||
type = type_param, |
|||
image = image, |
|||
⚫ | |||
["type"] = type_param, |
|||
expiry = (frame.args["expiry"] or "") |
|||
}) .. epilogue |
|||
["text"] = p.text(frame, count), |
|||
["expiry"] = (frame.args["expiry"] or "") |
|||
⚫ | |||
} |
|||
end |
end |
||
return return_value |
|||
end |
end |
||