モジュール:サンドボックス/しまあじ/前後年月カテゴリ
モジュールの解説[作成]
local objLINKYMCAT = {};
objLINKYMCAT.ifexist = function( frame )
local page = frame.args[1]
if not page then return "" end
if mw.title.new(page).exists then return "1" end
return ""
end
objLINKYMCAT.divdateCore = function( ymm )
local tbl = {}
local len = mw.ustring.len( ymm )
local c = ""
tbl['y'] = ""
tbl['m1'] = ""
tbl['m2'] = ""
if 5 <= len then
tbl['y'] = mw.ustring.sub( ymm, tonumber("1"), tonumber("4") )
if 5 == len then
tbl['m1'] = "1"
tbl['m2'] = "12"
elseif 7 <= len then
c = mw.ustring.sub( ymm, tonumber("7"), tonumber("7") )
if c == "月" then
tbl['m1'] = mw.ustring.sub( ymm, tonumber("6"), tonumber("6") )
tbl['m2'] = tbl['m1']
if 10 <= len then
c = mw.ustring.sub( ymm, tonumber("10"), tonumber("10") )
if c == "月" then
tbl['m2'] = mw.ustring.sub( ymm, tonumber("9"), tonumber("9") )
else
tbl['m2'] = mw.ustring.sub( ymm, tonumber("9"), tonumber("10") )
end
end
elseif c == "前" then
-- 「以前」
tbl['m1'] = "12"
tbl['m2'] = "12"
--
else
tbl['m1'] = mw.ustring.sub( ymm, tonumber("6"), tonumber("7") )
tbl['m2'] = tbl['m1']
if 11 <= len then
c = mw.ustring.sub( ymm, tonumber("11"), tonumber("11") )
if c == "月" then
tbl['m2'] = mw.ustring.sub( ymm, tonumber("10"), tonumber("10") )
else
tbl['m2'] = mw.ustring.sub( ymm, tonumber("10"), tonumber("11") )
end
end
end
end
end
return tbl
end
objLINKYMCAT.divdate = function( frame )
local sel = frame.args[2];
local tbl = objLINKYMCAT.divdateCore( frame.args[1] )
local str = ""
if sel == "y" then
str = tbl['y']
elseif sel == "m1" then
str = tbl['m1']
elseif sel == "m2" then
str = tbl['m2']
elseif sel == "年" then
str = tbl['y'] .. "年"
elseif sel == "月1" then
str = tbl['m1'] .. "月"
elseif sel == "月2" then
str = tbl['m2'] .. "月"
elseif sel == "年月1" then
str = tbl['y'] .. "年" .. tbl['m1'] .. "月"
elseif sel == "年月2" then
str = tbl['y'] .. "年" .. tbl['m2'] .. "月"
end
return str
end
objLINKYMCAT.show = function( frame )
local cat = frame.args[1]
local sep = frame.args[2]
local ym = frame.args[3]
local ymY = frame.args['当年']
local ymLL = frame.args['前年末月']
local ymL = frame.args['前月']
local ymR = frame.args['後月']
local ymRR = frame.args['後年始月']
local catinfo = objLINKYMCAT.getcatinfo( frame )
local strU = ""
local strM = ""
local strL = ""
-- 上段
if catinfo['catU1'] ~= "" then
if catinfo['catU2'] ~= "" then
strU = objLINKYMCAT.catlinkCore( catinfo['catU1'], "", "", "→ " .. catinfo['catU1'] ) .. "<br />" .. objLINKYMCAT.catlinkCore( catinfo['catU2'], "", "", "→ " .. catinfo['catU2'] ) .. "<br />"
else
strU = objLINKYMCAT.catlinkCore( catinfo['catU1'], "", "", "→ " .. catinfo['catU1'] ) .. "<br />"
end
elseif catinfo['catU2'] ~= "" then
strU = objLINKYMCAT.catlinkCore( catinfo['catU2'], "", "", "→ " .. catinfo['catU2'] ) .. "<br />"
end
-- 下段
if catinfo['catL1'] ~= "" then
if catinfo['catL2'] ~= "" then
strL = objLINKYMCAT.catlinkCore( catinfo['catL1'], "", "", "→ " .. catinfo['catL1'] ) .. "<br />" .. objLINKYMCAT.catlinkCore( catinfo['catL2'], "", "", "→ " .. catinfo['catL2'] ) .. "<br />"
else
strL = objLINKYMCAT.catlinkCore( catinfo['catL1'], "", "", "→ " .. catinfo['catL1'] ) .. "<br />"
end
elseif catinfo['catL2'] ~= "" then
strL = objLINKYMCAT.catlinkCore( catinfo['catL2'], "", "", "→ " .. catinfo['catL2'] ) .. "<br />"
end
-- 中段
strM = objLINKYMCAT.catlinkCore( cat, "", "", "→ " .. cat )
if ym ~= nil and ym ~= "" then
strM = strM .. " " .. sep .. " "
if ymL ~= nil and ymL ~= "" then
if mw.ustring.sub( ym, tonumber("6"), tonumber("7") ) ~= "以前" then
if ymLL ~= nil and ymLL ~= "" then
if mw.ustring.sub( ymL, tonumber("6"), tonumber("7") ) ~= "以前" then
strM = strM .. objLINKYMCAT.catlinkCore( cat, sep, ymLL, mw.ustring.sub(ymLL, tonumber("1"), tonumber("5")) ) .. " < "
end
end
strM = strM .. objLINKYMCAT.catlinkCore( cat, sep, ymL, ymL ) .. " < "
end
end
if ymY ~= nil and ymY ~= "" then
strM = strM .. "<b>" .. objLINKYMCAT.catlinkCore( cat, sep, ymY, ym ) .. "</b>"
else
strM = strM .. "<b>" .. ym .. "</b>"
end
if ymR ~= nil and ymR ~= "" then
strM = strM .. " > " .. objLINKYMCAT.catlinkCore( cat, sep, ymR, ymR )
if ymRR ~= nil and ymRR ~= "" then
strM = strM .. " > " .. objLINKYMCAT.catlinkCore( cat, sep, ymRR, mw.ustring.sub(ymRR, tonumber("1"), tonumber("5")) )
end
end
end
strM = strM .. "<br />"
return strU .. strM ..strL
end
objLINKYMCAT.catlink = function( frame )
return objLINKYMCAT.catlinkCore( frame.args[1], frame.args[2], frame.args[3], frame.args[4] )
end
objLINKYMCAT.catlinkCore = function( cat, sep, ym, show )
local linkstr = ""
local showstr = ""
if ym == nil or ym == "" then
linkstr = cat
else
linkstr = cat .. sep .. ym
end
if show == nil or show == "" then
showstr = linkstr
else
showstr = show
end
return "[[:Category:" .. linkstr .. "|" .. showstr.. "]]"
end
objLINKYMCAT.mboxmsg = function( frame )
local tag
local msg
if frame.args['説明'] ~= nil and frame.args['説明'] ~= "" and frame.args['説明'] ~= "1" then
msg = frame.args['説明']
else
if frame.args['タグ'] ~= nil and frame.args['タグ'] ~= "" then
tag = frame.args['タグ']
else
tag = objLINKYMCAT.taglink( frame )
end
msg = tag .. "が貼り付けられた月順に並んでいます。A は 10月、B は 11月、C は 12月 です。各同一月内については、タグにソートキーが設定されている場合を除きページ名順です。このカテゴリの期間内で異なる月の2つ以上のタグが貼られている場合、どのタグの月に分類されているかは各タグのページ内での位置によります。"
end
return msg
end
objLINKYMCAT.taglink = function( frame )
local catinfo = objLINKYMCAT.getcatinfo ( frame )
return catinfo['tag']
end
objLINKYMCAT.getcatinfo = function( frame )
local catinfo = {};
local cat = frame.args[1]
local cat2 = ""
local catU0 = "修正が必要なページ"
local catU1 = "出典を必要とする記事"
local catU2 = ""
local catL1 = ""
local catL2 = ""
local tag = "タグ"
catinfo['catU1'] = ""
catinfo['catU2'] = ""
catinfo['catL1'] = ""
catinfo['catL2'] = ""
catinfo['tag'] = tag
if cat == nil or cat == "" then
return catinfo
end
cat2 = mw.ustring.sub(cat, tonumber("1"), tonumber("1"));
if cat2 == "W" then
tag = "{{[[Template:Wikify|Wikify]]}}"
catU1 = catU0
elseif cat2 == "外" then
tag = "{{[[Template:リンク切れ|リンク切れ]]}}"
catU1 = catU0
elseif cat2 == "検" then
local catRI = "検証が求められている記事"
local catRID = "検証が求められている記述のある記事"
if cat == catRI then
tag = "{{[[Template:未検証|未検証]]}}"
catL1 = catRID
elseif cat == catRID then
tag = "{{[[Template:要検証|要検証]]}}・{{[[Template:要検証範囲|要検証範囲]]}}"
catU2 = catRI
end
elseif cat2 == "国" then
tag = "{{[[Template:国際化|国際化]]}}"
catU1 = catU0
elseif cat2 == "言" then
local catWS = "言葉を濁した記述のある記事"
if cat == catWS then
tag = "{{[[Template:言葉を濁さない|言葉を濁さない]]}}"
elseif cat == catWS .. " (誰)" then
tag = "{{[[Template:誰|誰]]}}・{{[[Template:誰範囲|誰範囲]]}}"
catU2 = catWS
elseif cat == catWS .. " (誰2)" then
tag = "{{[[Template:誰2|誰2]]}}・{{[[Template:誰2範囲|誰2範囲]]}}・{{[[Template:誰範囲2|誰範囲2]]}}"
catU2 = catWS
elseif cat == catWS .. " (いつ)" then
tag = "{{[[Template:いつ|いつ]]}}・{{[[Template:いつ範囲|いつ範囲]]}}"
catU2 = catWS
elseif cat == catWS .. " (どこ)" then
tag = "{{[[Template:どこ|どこ]]}}・{{[[Template:どこ範囲|どこ範囲]]}}"
catU2 = catWS
end
elseif cat2 == "雑" then
tag = "{{[[Template:雑多な内容の箇条書き|雑多な内容の箇条書き]]}}"
catU1 = catU0
elseif cat2 == "字" then
tag = "{{[[Template:字引|字引]]}}"
catU1 = catU0
elseif cat2 == "出" then
local catCN = catU1
local catCNS = "出典を必要とする節のある記事"
local catCND = "出典を必要とする記述のある記事"
local catBS = "出典を必要とする存命人物記事"
local catBU = "出典皆無な存命人物記事"
if cat == catCN then
tag = "{{[[Template:出典の明記|出典の明記]]}}"
catU1 = catU0
catL1 = catCNS
catL2 = catCND
elseif cat == catCNS then
tag = "{{[[Template:出典の明記|出典の明記|section=1]]}}"
elseif cat == catCND then
tag = "{{[[Template:要出典|要出典]]}}・{{[[Template:要出典範囲|要出典範囲]]}}"
elseif cat == catBS then
tag = "{{[[Template:存命人物の出典明記|存命人物の出典明記]]}}"
catL1 = catBU
elseif cat == catBU then
tag = "{{[[Template:BLP unsourced|BLP unsourced]]}}"
catU2 = catBS
end
elseif cat2 == "情" then
tag = "{{[[Template:更新|更新]]}}"
catU1 = catU0
elseif cat2 == "宣" then
tag = "{{[[Template:宣伝|宣伝]]}}"
catU1 = catU0
elseif cat2 == "独" then
local catOR = "独自研究の除去が必要な記事"
local catORS = "独自研究の除去が必要な節のある記事"
local catORD = "独自研究の除去が必要な記述のある記事"
if cat == catOR then
tag = "{{[[Template:独自研究|独自研究]]}}"
catL1 = catORS
catL2 = catORD
elseif cat == catORS then
tag = "{{[[Template:独自研究|独自研究|section=1]]}}"
catU2 = catOR
elseif cat == catORD then
tag = "{{[[Template:独自研究範囲|独自研究範囲]]}}"
catU2 = catOR
end
elseif cat2 == "特" then
tag = "{{[[Template:特筆性|特筆性]]}}"
elseif cat2 == "翻" then
tag = "{{[[Template:翻訳中途|翻訳中途]]}}"
catU1 = ""
elseif cat2 == "無" then
tag = "{{[[Template:出典無効|出典無効]]}}"
end
catinfo['catU1'] = catU1
catinfo['catU2'] = catU2
catinfo['catL1'] = catL1
catinfo['catL2'] = catL2
catinfo['tag'] = tag
return catinfo
end
return objLINKYMCAT