Open main menu

Changes

Module:High-use

1,916 bytes added, 21:11, 1 November 2021
Link to https://linkcount.toolforge.org/ which is more detailed and mobile-friendly
local p = {}
-- _fetch looks at the "demo" argument.
local _fetch = require('Module:Transclusion_count').fetch
local yesno = require('Module:Yesno')
function p.num(frame, count)
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
-- Build output string
return_value = string.format("approximately %s", mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) + 0.5) * (10^(f))) )
end
-- Insert percent percentage of pagesif that is likely to be >= 1% and when |no-percent= not set to yes if frame.args["all-pages"] count and count > 250000 and not yesno (frame:getParent().args["all'no-pages"percent'] ~= "" ) then
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) end
end
end
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. local bot_text = (frame:preprocess("{{REVISIONID}}") == "") and "\n\n----\nTransclusion n'''Preview message''': Transclusion count updated automatically ([[Template:High-use/doc#Technical details|see documentation]])."or '' if count == nil then if yesno(frame.args["nobot"'fetch'] ) == true false then if (frame.args[1] or '') ~= '' then count = tonumber(frame.args[1]) end bot_text else count = ""_fetch(frame) end
end
if count == nil then count = _fetch(frame) end
local return_value = {}
local title = mw.title.getCurrentTitle()
if title.subpageText == "doc" or title.subpageText == "sandbox" then
end
local templatecount systemMessages = stringframe.formatargs['system'] if frame.args['system'] == '' then systemMessages = nil end -- This retrieves the project URL automatically to simplify localiation. local templateCount = ("'on [https://templatecountlinkcount.toolforge.org/index.php?langproject=en%s&namespacepage=%s&name=%s",pages]'):format( mw.title.getCurrentTitle():fullUrl():gsub('//(.namespace-)/.*', '%1'), mw.uri.encode(title.textfullText), p.num(frame, count)) local used_on_text = "'''This " .. (mw.title.getCurrentTitle().namespace == 828 and "Lua module" or "template").. ' is used '; 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]'''",
(mw.title.getCurrentTitle().namespace == 828 and "Lua module" or "template"),
templatecount,
p.num(frame, count)
)
local sandbox_text = string.format("%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 ", or in your own [[Wikipedia:SubpagesUser pages#How to create user subpagesSUB|user subpage]].")
)
local infoArg = frame.args["info"] ~= "" and frame.args["info"] if (systemMessages or frame.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 frame.args["info"] and frame.args["info"] ~= "" infoArg then info = info .. "<br />" .. frame.args["info"]infoArg
end
sandbox_text = stringinfo .format(".%s'<br /> To avoid major disruption ' .. (count and count >= 100000 and ' and server load' or '') .. ', any changes should be tested in the %sThe ' .. sandbox_text .. 'The tested changes can be added to this page in a single edit.&#x20;", info, sandbox_text )'
else
sandbox_text = string(infoArg and ('.<br />' .. infoArg .format(" . ' C') or ' and changes c') .. 'hanges may be widely noticed. Test changes in the %s", ' .. sandbox_text )
end
 
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
discussion_text = string.format("%sat [[%s]]", discussion_text, frame.args["2"])
end
return tableused_on_text ..concat({used_on_text, sandbox_text, .. discussion_text, .. " before implementing them.", .. bot_text})
end
function p.main(frame)
local count = nil if yesno(frame.args['fetch']) == false then if (frame.args[1] or '') ~= '' then count = tonumber(frame.args[1]) end else count = _fetch(frame) local return_value = ""end
local image = "[[File:Ambox warning yellow.svg|40px|alt=Warning|link=]]"
local type_param = "style"
local epilogue = '' if frame.args['system'] and frame.args['system'] ~= '' then 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=]]"
type_param = "content"
if frame.args["form"] == "editnotice" then
return_value = return frame:expandTemplate{
title = 'editnotice',
args = {
["expiry"] = (frame.args["expiry"] or "")
}
}.. epilogue
else
return_value = framereturn require('Module:expandTemplate{ title = Message box').main('ombox', args = { [" type"] = type_param, [" image"] = image, [" text"] = p.text(frame, count), [" expiry"] = (frame.args["expiry"] or "") } }) .. epilogue
end
return return_value
end
return p
Anonymous user