跳转到内容

模块:High-use:修订间差异

来自代码酷
*>蕭漫
无编辑摘要
 
Admin留言 | 贡献
导入1个版本
 
(未显示2个用户的2个中间版本)
第1行: 第1行:
local p = {}
local p = {}
local getArgs = require('Module:Arguments').getArgs


local _fetch = require('Module:Transclusion_count').fetch
-- _fetch looks at the "demo" argument.
local nspn = mw.getCurrentFrame():preprocess('{{Namespace pagename}}')
local _fetch = require('Module:Transclusion_count')._fetch
local _separated_entries = require('Module:Separated entries').main
local yesno = require('Module:Yesno')


function p.num(frame, count)
function p._num(args, count, no_percent)
if count == nil then count = _fetch(frame) end
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
-- Build output string
local return_value = ""
local return_value = ""
if count == nil then
if count == nil then
if frame.args[1] == "risk" then
if args[1] == "risk" then
return_value = "大量頁面"
return "a very large number of"
else
else
return_value = "許多頁面"
return "many"
end
end
else
else
第27行: 第34行:
-- Round and insert "approximately" or "+" when appropriate
-- Round and insert "approximately" or "+" when appropriate
if (frame.args[2] == "yes") or (mw.ustring.sub(frame.args[1],-1) == "+") then
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))) )
else
else
-- Round to nearest
-- Round to nearest
return_value = string.format("%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 percent of pages
-- Insert percentage of pages if that is likely to be >= 1% and when |no-percent= not set to yes
if frame.args["all-pages"] and frame.args["all-pages"] ~= "" then
no_percent = no_percent or args['no-percent']
local percent = math.floor( ( (count/frame:callParserFunction('NUMBEROFPAGES', 'R') ) * 100) + 0.5)
if count and count > 250000 and not yesno (no_percent) then
return_value = string.format("%s,佔全部頁面的%s%%", return_value, percent)
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
end
end
第44行: 第55行:
return return_value
return return_value
end
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
-- Actions if there is a large (greater than or equal to 100,000) transclusion count
function p.risk(frame)
function p._risk(args)
local return_value = ""
if args[1] == "risk" then
if frame.args[1] == "risk" then
return "risk"
return_value = "risk"
else
else
local count = _fetch(frame)
local count = _fetch(args)
if count and count >= 100000 then return_value = "risk" end
if count and count >= 100000 then
return "risk"
end
end
end
return return_value
return ""
end
 
function p.risk(frame)
return p._risk(getArgs(frame))
end
end


function p.text(frame, count)
function p._text(args, count)
local bot_text = "\n\n----\n<small>模板引用數量會自動更新。</small>"
-- Only show the information about how this template gets updated if someone
if frame.args["nobot"] == "true" then
-- is actually editing the page and maybe trying to update the count.
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 yesno(args['fetch']) == false then
if (args[1] or '') ~= '' then count = tonumber(args[1]) end
else
count = _fetch(args)
end
end
end
if count == nil then count = _fetch(frame) end
local return_value = {}
local title = mw.title.getCurrentTitle()
local title = mw.title.getCurrentTitle()
local isdemo = false
if ( (args.demo or '' ~= '') and mw.title.new(args.demo, 10) ) then
if frame.args["demo"] and frame.args["demo"] ~= "" then
title = mw.title.new(args.demo, 10)
isdemo = true
title = mw.title.new(frame.args["demo"], "Template")
end
end
if title.subpageText == "doc" or title.subpageText == "sandbox" or title.subpageText == "testcases" then
 
if title.subpageText == "doc" or title.subpageText == "sandbox" then
title = title.basePageTitle
title = title.basePageTitle
end
end
local templatecount = string.format("https://templatecount.toolforge.org/index.php?lang=zh&namespace=%s&name=%s", title.namespace,mw.uri.encode(title.text))
local used_on_text = string.format("'''%s被引用於[%s %s]'''",
local systemMessages = (args['system'] or '') ~= ''
(isdemo and "[["..title.fullText.."]]") or (""..nspn),
templatecount,
-- This retrieves the project URL automatically to simplify localization.
p.num(frame, count)
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 sandbox_text = _separated_entries({
local infoArg = args["info"] ~= "" and args["info"]
string.format("[[%s/sandbox|'''沙盒''']]", title.fullText),
if (systemMessages or args[1] == "risk" or (count and count >= 100000) ) then
string.format("[[%s/testcases|'''測試樣例''']]", title.fullText),
local info = systemMessages and '.<br/>Changes to it can cause immediate changes to the Wikipedia user interface.' or '.'
(title.namespace == 828 and "" or "[[Special:Mypage/沙盒|'''您的沙盒''']]"),
if infoArg then
separator="、",
info = info .. "<br />" .. infoArg
conjunction="或"
end
})
sandbox_text = info .. '<br /> To avoid major disruption' ..
(count and count >= 100000 and ' and server load' or '') ..
local info = ""
', any changes should be tested in the ' .. sandbox_text ..
if frame.args["info"] and frame.args["info"] ~= "" then
'The tested changes can be added to this page in a single edit. '
info = "<br />" .. frame.args["info"]
else
sandbox_text = (infoArg and ('.<br />' .. infoArg .. ' C') or ' and c') ..
'hanges may be widely noticed. Test changes in the ' .. sandbox_text
end
end
sandbox_text = string.format("。%s<br /><small>為了避免造成大規模的影響,所有對此%s的編輯應先於%s上測試。</small>",
 
info, nspn, sandbox_text
)
local discussion_text = string.format("<br /><small>測試後無誤的版本可以一次性地加入此%s中,但是修改前請務必於", nspn)
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 args["2"] and args["2"] ~= "" and args["2"] ~= "yes" then
discussion_text = string.format("%s'''[[%s]]'''", discussion_text, frame.args["2"])
discussion_text = string.format("%sat [[%s]]", discussion_text, args["2"])
else
else
discussion_text = string.format("%s[[%s|'''討論頁''']]", discussion_text, title.talkPageTitle.fullText )
discussion_text = string.format("%son the [[%s|talk page]]", discussion_text, title.talkPageTitle.fullText )
end
end
return table.concat({used_on_text, sandbox_text, discussion_text, "發起討論。</small>", bot_text})
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
end


function p.main(frame)
function p._main(args, nocat)
local count = _fetch(frame)
local count = nil
local return_value = ""
if yesno(args['fetch']) == false then
local image = "[[File:Ambox warning yellow.svg|40px|alt=警告|link=]]"
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 type_param = "style"
if (frame.args[1] == "risk" or (count and count >= 100000) ) then
local epilogue = ''
image = "[[File:Ambox warning orange.svg|40px|alt=警告|link=]]"
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"
type_param = "content"
end
end
if frame.args["form"] == "editnotice" then
if args["form"] == "editnotice" then
return_value = frame:expandTemplate{
return mw.getCurrentFrame():expandTemplate{
title = 'editnotice',
title = 'editnotice',
args = {
args = {
["image"] = image,
["image"] = image,
["text"] = p.text(frame, count),
["text"] = p._text(args, count),
["expiry"] = (frame.args["expiry"] or "")
["expiry"] = (args["expiry"] or "")
}
}
}
} .. epilogue
else
else
return_value = frame:expandTemplate{
return require('Module:Message box').main('ombox', {
title = 'ombox',
type = type_param,
args = {
image = image,
["type"] = type_param,
text = p._text(args, count),
["image"] = image,
expiry = (args["expiry"] or "")
["text"] = p.text(frame, count),
}) .. epilogue
["expiry"] = (frame.args["expiry"] or "")
}
}
end
end
return return_value
end
end


function p.main(frame)
return p._main(getArgs(frame))
end
return p
return p

2025年5月1日 (四) 02:59的最新版本

此模块的文档可以在模块: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&#x20;%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&#x20;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