local yesno = require('Module:Yesno')
local mList = require('Module:List')
local mTableTools = require('Module:TableTools')
local mMessageBox = require('Module:Message box')
local p = {}
function p.main(frame)
local origArgs = frame:getParent().args
local args = {}
for k, v in pairs(origArgs) do
v = v:match('^%s*(.-)%s*$')
if v ~= '' then
args[k] = v
end
end
return p._main(frame, args)
end
function p._main(frame, args)
local modules = mTableTools.compressSparseArray(args)
-- 預處理:將參數統一格式為 Module:xxx
for i = 1, #modules do
modules[i] = 'Module:' .. mw.title.new(modules[i]).text
end
local box = p.renderBox(modules)
local trackingCategories = p.renderTrackingCategories(args, modules)
return box .. trackingCategories
end
-- if action=edit
function p.main2(frame)
local origArgs = frame:getParent().args
local args = {}
for k, v in pairs(origArgs) do
v = v:match('^%s*(.-)%s*$')
if v ~= '' then
args[k] = v
end
end
local modules = mTableTools.compressSparseArray(args)
return p.renderBox(modules)
end
--end
function p.renderBox(modules)
local boxArgs = {}
if #modules < 1 then
boxArgs.text = '<strong class="error">錯誤:沒有指定-{zh-hans:模塊; zh-hant:模組;}-</strong>'
else
local moduleLinks = {}
for i, module in ipairs(modules) do
moduleLinks[i] = string.format('%s', module)
moduleLinks[i] = '[[:' .. moduleLinks[i] .. ']]'
end
local moduleList = mList.makeList('bulleted', moduleLinks)
boxArgs.text = '此' ..
(mw.title.getCurrentTitle():inNamespaces(828,829) and '-{zh-hans:模塊; zh-hant:模組;}-' or '模板') ..
'使用[[Help:Lua|Lua語言]]:\n' .. moduleList
end
boxArgs.type = 'notice'
boxArgs.small = true
boxArgs.image = '[[File:Lua-logo.svg|30px|alt=|link=]]'
return mMessageBox.main('mbox', boxArgs)
end
function p.renderTrackingCategories(args, modules, titleObj)
if yesno(args.nocat) then
return ''
end
-- 子頁面標題在黑名單內則不添加分類
-- 例如{{Lua}}被嵌入到 Template:xxx/doc 時,只在 Template:xxx 添加分類,而不在 doc 添加分類
-- 不在非模板命名空間添加分類,防止Module和Template使用同一文檔
titleObj = titleObj or mw.title.getCurrentTitle()
local subpageBlacklist = {
doc = true,
sandbox = true,
sandbox2 = true,
testcases = true
}
if subpageBlacklist[titleObj.subpageText] or titleObj.nsText ~= 'Template' then
return ''
end
local cats = {}
-- 錯誤分類
if #modules < 1 then
cats[#cats + 1] = '有錯誤的Lua模板'
end
local category = args.category
-- 添加特殊分類
if not category then
local categories = {
['Module:String'] = '使用String模塊的模板',
['Module:Nav'] = '使用Nav模塊的模板',
--['Module:Math'] = '使用Math模塊的模板',
--['Module:BaseConvert'] = '使用BaseConvert模塊的模板',
--['Module:Citation'] = '使用Citation模塊的模板'
}
categories['Module:Citation/CS1'] = categories['Module:Citation']
category = modules[1] and categories[modules[1]]
category = category or 'x'
end
cats[#cats + 1] = category
for i, cat in ipairs(cats) do
cats[i] = string.gsub(string.format('[[Category:%s]]', cat), '%[%[Category:x%]%]', '')
end
-- 為防止[[Category:Lua模板]]氾濫,當只使用一個模塊且添加了特殊分類後,不再添加[[Category:Lua模板]]
-- 這尤其是為了防止上千個使用[[Module:Nav]]的模板湧入[[Category:Lua模板]](如果真的有人準備大量添加{{Lua|Nav}})
if #modules == 1 and category ~= 'x' then
return table.concat(cats)
else
return table.concat(cats) .. '[[Category:Lua模板]]'
end
end
return p