Module:High-use: Difference between revisions
Appearance
	
	
Nazarzadeh (talk | contribs) m 1 revision imported  | 
				 Pass args to functions instead of frame, to allow them to be called from another module  | 
				||
| Line 2: | Line 2: | ||
-- _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 17: | ||
	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 33: | ||
		-- 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 42: | ||
		-- 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 53: | ||
	return return_value  | 	return return_value  | ||
end  | |||
function p.num(frame, count)  | |||
	return p._num(frame.args, count, frame:getParent().args['no-percent'] or frame.args['no-percent'])  | |||
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 72: | ||
end  | end  | ||
function p.  | function p.risk(frame)  | ||
	return p._risk(frame.args)  | |||
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 113: | ||
	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 135: | ||
	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 144: | ||
end  | end  | ||
function p.  | function p.text(frame, count)  | ||
	return p._text(frame.args, 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 184: | ||
			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(frame.args, frame:getParent().args['nocat'] or frame.args['nocat'])  | |||
end  | |||
return p  | return p  | ||
Revision as of 07:18, 2 December 2024
Documentation for this module may be created at Module:High-use/doc
local p = {}
-- _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(frame.args, count, frame:getParent().args['no-percent'] or frame.args['no-percent'])
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(frame.args)
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(frame.args, 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(frame.args, frame:getParent().args['nocat'] or frame.args['nocat'])
end
return p