その他の操作
今川 凌 (MONACA) (トーク | 投稿記録) ページの作成:「-- -- This module implements {{Navbox}} -- local p = {} local navbar = require('Module:Navbar')._navbar local getArgs -- lazily initialized local args local border local listnums local ODD_EVEN_MARKER = '\127_ODDEVEN_\127' local RESTART_MARKER = '\127_ODDEVEN0_\127' local REGEX_MARKER = '\127_ODDEVEN(%d?)_\127' local function striped(wikitext) -- Return wikitext with markers replaced for odd/even striping. -- Child (subgroup) navboxes are flagged with a catego…」 |
今川 凌 (MONACA) (トーク | 投稿記録) 編集の要約なし |
||
1行目: | 1行目: | ||
local p = {} | |||
local | --[[ | ||
Template:Tnavbar | |||
]] | |||
function p.tnavbar(frame) | |||
local r = mw.html.create() --出力用 | |||
local args = frame.args | |||
if not args[1] then return ' ' end | |||
local function tf(x) | |||
return x == '1' and true or false | |||
end | |||
args.plain = tf(args.plain) | |||
args.div = tf(args.div) | |||
args.nodiv = tf(args.nodiv) | |||
args.mini = tf(args.mini) | |||
args.viewplain = tf(args.viewplain) | |||
args.fontstyle = args.fontcolor ~= '' and ((args.fontstyle or '') .. ';color:' .. args.fontcolor .. ';') or args.fontstyle or '' | |||
local divTag = r:tag('div') | |||
:addClass('noprint') | |||
:addClass('plainlinks') | |||
:addClass('navbar') | |||
:addClass('hlist') | |||
:css('white-space', 'nowrap') | |||
:css('font-size', '60%') | |||
:css('font-weight', 'normal') | |||
if args.nodiv then | |||
divTag:css('display', 'inline') | |||
:css('padding', '0 0.5em') | |||
else | |||
divTag:css('background-color', 'transparent') | |||
:css('padding', '0') | |||
:css('color', '#000') | |||
end | |||
divTag:cssText(args.fontstyle) | |||
:cssText(args.style) | |||
if not (args.plain or args.mini or args.viewplain) then | |||
divTag:tag('span') | |||
:css('font-size', '125%') | |||
:node('このテンプレートを: ') | |||
end | |||
local disp = args.mini and {'表', '話', '編', '歴'} or {'表示', 'ノート', '編集', '履歴'} | |||
local ns = {'Template:', 'Template‐ノート:', 'Template:', 'Template:'} | |||
local query = {nil, nil, 'action=edit', 'action=history'} | |||
local title = {'このテンプレートを表示します', 'このテンプレートのノートを表示します', 'このテンプレートを編集します。保存の前にプレビューを忘れずに。', 'このテンプレートの過去の版を表示します'} | |||
local color = {'', 'color:#002bb8;', 'color:#002bb8;', 'color:#002bb8;'} | |||
local i = 0 | |||
local i_end = args.viewplain and 1 or 4 | |||
local ulTag = divTag:tag('ul') | |||
:css('display', 'inline') | |||
for i = 1, i_end do | |||
local liTag = ulTag:tag('li') | |||
local l = {open = '', link = '', close = ''} | |||
if query[i] then | |||
l.open = '[' | |||
l.link = tostring(mw.uri.canonicalUrl(ns[i] .. args[1], query[i])) .. ' ' | |||
l.close = ']' | |||
else | |||
l.open = '[[' | |||
l.link = ns[i] .. args[1] .. '|' | |||
l.close = ']]' | |||
end | |||
liTag:wikitext(l.open .. l.link) | |||
:tag('span') | |||
:attr('title', title[i]) | |||
:css('font-size', '125%') | |||
:cssText(color[i]) | |||
:cssText(args.fontstyle) | |||
:node(disp[i]) | |||
:done() | |||
:wikitext(l.close) | |||
end | |||
return tostring(r) | |||
end | |||
local args | --[[ | ||
Define Arguments | |||
]] | |||
local getArgs | |||
local args = {} | |||
local border | local border | ||
local | local child, none = false, false | ||
local | local rowspan = 0 | ||
local | local basestyle = '' | ||
local | local odd, even = 'odd', 'even' | ||
local | local list, liststyle = {}, {} | ||
local group, groupstyle = {}, {} | |||
local colheader, colheadercolspan, colheaderstyle = {}, {}, {} | |||
local col, colstyle, colwidth = {}, {}, {} | |||
local colfooter, colfootercolspan, colfooterstyle = {}, {}, {} | |||
local abbr, state = {}, {} | |||
local sect, section = {}, {} | |||
local secttitlestyle = {} | |||
local content, contentstyle = {} | |||
local image, imageleft = {}, {} | |||
local function defArgs(frame) | |||
if not getArgs then | |||
getArgs = require('Module:Arguments').getArgs | |||
end | end | ||
args = getArgs(frame, {parentOnly = true}) | |||
border = args.border or args[1] | |||
child, none = (border == 'subgroup' or border == 'child'), (border == 'none') | |||
collapsible = (args.state == 'plain' or args.state == 'off') and '' or 'mw-collapsible ' | |||
if args.basestyle then basestyle = args.basestyle .. ';' end | |||
local sortable_mt = { | |||
__lt = function(a, b) return a.index < b.index end, | |||
__concat = function(a, b) | |||
local strA = (type(a) == 'table') and a.content or a or '' | |||
local strB = (type(b) == 'table') and b.content or b or '' | |||
return strA .. strB | |||
end | end | ||
} | |||
local function sortable_args(tbl, index, content) | |||
table.insert(tbl, {index = index, content = content}) | |||
setmetatable(tbl[#tbl], sortable_mt) | |||
end | end | ||
local | local switch = { | ||
--common | |||
list = function(num, v) sortable_args(list, num, '\n' .. v) end, | |||
liststyle = function(num, v) liststyle[num] = v end, | |||
group = function(num, v) group[num] = v end, | |||
groupstyle = function(num, v) groupstyle[num] = v end, | |||
--for with_columns | |||
colheader = function(num,v) colheader[num] = v end, | |||
colheadercolspan = function(num,v) colheadercolspan[num] = v end, | |||
colheaderstyle = function(num,v) colheaderstyle[num] = v end, | |||
col = function(num, v) sortable_args(col, num, '\n' .. v) end, | |||
colstyle = function(num,v) colstyle[num] = v end, | |||
colwidth = function(num,v) colwidth[num] = v end, | |||
colfooter = function(num,v) colfooter[num] = v end, | |||
colfootercolspan = function(num,v) colfootercolspan[num] = v end, | |||
colfooterstyle = function(num,v) colfooterstyle[num] = v end, | |||
end | --for with_collapsible_groups | ||
abbr = function(num, v) abbr[num] = v end, | |||
state = function(num, v) state[num] = v end, | |||
sect = function(num, v) group[num] = v end, | |||
section = function(num, v) group[num] = v end, | |||
secttitlestyle = function(num, v) groupstyle[num] = v end, | |||
content = function(num, v) sortable_args(content, num, '\n' .. v) end, | |||
contentstyle = function(num, v) liststyle[num] = v end, | |||
image = function(num, v) image[num] = v end, | |||
imageleft = function(num, v) imageleft[num] = v end, | |||
} | |||
for k, v in pairs(args) do | |||
local str1, num, str2 = string.match(k, '(%D+)(%d+)(%D*)') | |||
str1, num, str2 = str1 or '', tonumber(num), str2 or '' | |||
if switch[str1 .. str2] and num then switch[str1 .. str2](num, v) end | |||
end | end | ||
table.sort(list) | |||
rowspan = #list | |||
end | end | ||
local function | --[[ | ||
if | top | ||
]] | |||
local function top(baseTag) | |||
local nav | |||
local bodyTable | |||
if baseTag == nil or baseTag == '' then | |||
baseTag = mw.html.create() | |||
end | end | ||
if | if child then | ||
baseTag:wikitext('</div>') | |||
nav = baseTag | |||
elseif not none then | |||
nav = baseTag:tag('div') | |||
:addClass('navbox') | |||
:addClass(args.navboxclass) | |||
:css('border-collapse', 'collapse') | |||
:cssText(args.bodystyle) | |||
:cssText(args.style) | |||
:css('padding', '3px') | |||
if args.title or args.above then | |||
nav:attr('aria-labelledby', mw.uri.anchorEncode(args.title or args.above)) | |||
else | |||
nav:attr('aria-label', 'Navbox') | |||
end | end | ||
else | |||
nav = baseTag | |||
end | end | ||
bodyTable = nav:tag('table') | |||
:addClass('nowraplinks') | |||
:addClass(args.bodyclass) | |||
if args.title and (args.state ~= 'plain' and args.state ~= 'off') then | |||
if args.state == 'collapsed' then args.state = 'mw-collapsed' end | |||
bodyTable | |||
:addClass('mw-collapsible') | |||
:addClass(args.state or 'autocollapse') | |||
end | end | ||
if child or border == 'none' then | |||
bodyTable | |||
if | :addClass('navbox-subgroup') | ||
:cssText(args.bodystyle) | |||
:cssText(args.style) | |||
else -- regular navbox - bodystyle and style will be applied to the wrapper table | |||
bodyTable | |||
:addClass('navbox-inner') | |||
:css('background', 'transparent') | |||
:css('color', 'inherit') | |||
end | end | ||
bodyTable:css('min-width', '100%') | |||
:css('border-spacing', '0px') | |||
:css('border-collapse', 'separate') | |||
:cssText(args.innerstyle) | |||
return baseTag, bodyTable | |||
end | end | ||
-- | --[[ | ||
title and navbar | |||
]] | |||
local function | local function title(tbl) | ||
if not args.title then return end | if not args.title then return tbl end | ||
local titleRow = tbl:tag('tr') | local titleRow = tbl:tag('tr') | ||
if args.titlegroup then | if args.titlegroup then | ||
titleRow | titleRow | ||
115行目: | 246行目: | ||
if args.titlegroup then | if args.titlegroup then | ||
titleCell | titleCell | ||
:css('width', '100%') | :css('width', '100%') | ||
end | end | ||
local titleColspan = 2 | local titleColspan = 2 | ||
if args.imageleft then titleColspan = titleColspan + 1 end | if args.imageleft then titleColspan = titleColspan + 1 end | ||
129行目: | 259行目: | ||
:addClass('navbox-title') | :addClass('navbox-title') | ||
:attr('colspan', titleColspan) | :attr('colspan', titleColspan) | ||
if (args.navbar == 'plain') or (not args.name and (child or none)) then | |||
titleCell | |||
:tag('div') | |||
:css('float', 'left') | |||
:css('width', '6em') | |||
:node(' ') | |||
elseif args.navbar ~= 'off' then | |||
local tbl = {args = {args.name, mini = '1', fontstyle = basestyle .. (args.titlestyle or '') .. ';border:none;', fontcolor = ''}} | |||
titleCell | |||
:tag('div') | |||
:css('float', 'left') | |||
:css('width', '6em') | |||
:css('text-align', 'left') | |||
:node(p.tnavbar(tbl)) | |||
end | |||
if child or border == 'none' then | |||
titleCell | |||
:tag('div') | |||
:attr('id', mw.uri.anchorEncode(args.title)) | |||
:addClass(args.titleclass) | |||
:css('font-size', '100%') | |||
:css('margin', '0 6em') | |||
:node(args.title) | |||
else | |||
titleCell | |||
:tag('div') | |||
:attr('id', mw.uri.anchorEncode(args.title)) | |||
:addClass(args.titleclass) | |||
:css('font-size', '110%') | |||
:css('margin', '0 6em') | |||
:node(args.title) | |||
end | |||
return tbl | |||
end | end | ||
local function getAboveBelowColspan() | local function getAboveBelowColspan() | ||
153行目: | 304行目: | ||
end | end | ||
local function | --[[ | ||
if not args.above then return end | above | ||
]] | |||
local function above(tbl) | |||
if not args.above then return tbl end | |||
tbl:tag('tr') | tbl:tag('tr') | ||
163行目: | 317行目: | ||
:cssText(args.abovestyle) | :cssText(args.abovestyle) | ||
:attr('colspan', getAboveBelowColspan()) | :attr('colspan', getAboveBelowColspan()) | ||
: | :newline() | ||
:node(args.above) | |||
return tbl | |||
end | end | ||
-- | --[[ | ||
body | |||
-- | ]] | ||
local function | --first group/list and images | ||
local function body1(tbl) | |||
local row = tbl:tag('tr') | local row = tbl:tag('tr') | ||
if args.imageleft then | |||
if | |||
row | row | ||
:tag('td') | :tag('td') | ||
:addClass('navbox-image') | :addClass('navbox-image') | ||
:addClass(args.imageclass) | :addClass(args.imageclass) | ||
:css('width', '1px') | :css('width', '1px') | ||
:css('padding', '0px 2px 0px 0px') | :css('padding', '0px 2px 0px 0px') | ||
:cssText(args.imageleftstyle) | :cssText(args.imageleftstyle) | ||
:attr('rowspan', | :attr('rowspan', rowspan) | ||
:tag('div') | :tag('div') | ||
: | :node(args.imageleft) | ||
end | end | ||
local j = list[1].index | |||
if | if group[j] then | ||
local groupCell = row:tag('th') | local groupCell = row:tag('th') | ||
groupCell | groupCell | ||
216行目: | 349行目: | ||
:addClass(args.groupclass) | :addClass(args.groupclass) | ||
:cssText(args.basestyle) | :cssText(args.basestyle) | ||
:css('width', args.groupwidth or '1%') | |||
groupCell | groupCell | ||
:cssText(args.groupstyle) | :cssText(args.groupstyle) | ||
:cssText( | :cssText(groupstyle[j]) | ||
:wikitext( | :wikitext(group[j]) | ||
end | end | ||
local listCell = row:tag('td') | local listCell = row:tag('td') | ||
if | if group[j] then | ||
listCell | listCell | ||
:css('text-align', 'left') | :css('text-align', 'left') | ||
239行目: | 372行目: | ||
end | end | ||
local rowstyle | local rowstyle | ||
if | if odd == 'odd' then | ||
rowstyle = args.oddstyle | rowstyle = args.oddstyle | ||
else | else | ||
246行目: | 379行目: | ||
end | end | ||
listCell | listCell | ||
:css('padding', '0px') | :css('padding', '0px') | ||
:cssText(args.liststyle) | :cssText(args.liststyle) | ||
:cssText(rowstyle) | :cssText(rowstyle) | ||
:cssText( | :cssText(liststyle[j]) | ||
:addClass('navbox-list') | :addClass('navbox-list') | ||
:addClass('navbox-' .. | :addClass('navbox-' .. (args.evenodd == 'swap' and even or args.evenodd or odd)) | ||
:addClass(args.listclass) | :addClass(args.listclass) | ||
:tag('div') | :tag('div') | ||
:css('padding', ( | :css('padding', (args.list1padding or args.listpadding or '0em 0.25em')) | ||
: | :node(list[1].content) | ||
:newline() | |||
if | if args.image then | ||
row | row | ||
:tag('td') | :tag('td') | ||
:addClass('navbox-image') | :addClass('navbox-image') | ||
:addClass(args.imageclass) | :addClass(args.imageclass) | ||
:css('width', '1px') | :css('width', '1px') | ||
:css('padding', '0px 0px 0px 2px') | :css('padding', '0px 0px 0px 2px') | ||
:cssText(args.imagestyle) | :cssText(args.imagestyle) | ||
:attr('rowspan', | :attr('rowspan', rowspan) | ||
:tag('div') | :tag('div') | ||
: | :node(args.image) | ||
end | end | ||
return tbl | |||
end | end | ||
--remaining groups/lists | |||
local function body2(tbl) | |||
for i = 2, #list do | |||
odd, even = even, odd | |||
local j = list[i].index | |||
local row = tbl:tag('tr') | |||
if group[j] then | |||
local groupCell = row:tag('th') | |||
groupCell | |||
:attr('scope', 'row') | |||
:addClass('navbox-group') | |||
:addClass(args.groupclass) | |||
:cssText(args.basestyle) | |||
:css('width', args.groupwidth or '1%') | |||
groupCell | |||
:cssText(args.groupstyle) | |||
:cssText(groupstyle[j]) | |||
:node(group[j]) | |||
end | |||
local listCell = row:tag('td') | |||
if group[j] then | |||
listCell | |||
:css('text-align', 'left') | |||
:css('border-left-width', '2px') | |||
:css('border-left-style', 'solid') | |||
else | |||
listCell:attr('colspan', 2) | |||
end | end | ||
if not args.groupwidth then | |||
listCell:css('width', '100%') | |||
if | |||
end | end | ||
local | local rowstyle | ||
if odd == 'odd' then | |||
rowstyle = args.oddstyle | |||
else | |||
rowstyle = args.evenstyle | |||
end | end | ||
listCell | |||
:css('padding', '0px') | |||
:cssText(args.liststyle) | |||
:cssText(rowstyle) | |||
:cssText(liststyle[j]) | |||
:addClass('navbox-list') | |||
:addClass('navbox-' .. (args.evenodd == 'swap' and even or args.evenodd or odd)) | |||
:addClass(args.listclass) | |||
:tag('div') | |||
:css('padding', (args.listpadding or '0em 0.25em')) | |||
:node(list[i].content) | |||
:newline() | |||
end | end | ||
return | return tbl | ||
end | end | ||
local function | --[[ | ||
below | |||
]] | |||
local function below(tbl) | |||
if not args.below then return tbl end | |||
return | tbl:tag('tr') | ||
:tag('td') | |||
:addClass('navbox-abovebelow') | |||
:addClass(args.belowclass) | |||
:cssText(args.basestyle) | |||
:cssText(args.belowstyle) | |||
:attr('colspan', getAboveBelowColspan()) | |||
:newline() | |||
:node(args.below) | |||
return tbl | |||
end | end | ||
--[[ | |||
local | Template:Navbox | ||
]] | |||
function p.navbox(frame) | |||
if | defArgs(frame) | ||
local res | |||
local firstTableTag | |||
res, firstTableTag = top() | |||
firstTableTag = title(firstTableTag) | |||
firstTableTag = above(firstTableTag) | |||
if list[1] then | |||
firstTableTag = body1(firstTableTag) | |||
end | |||
firstTableTag = body2(firstTableTag) | |||
firstTableTag = below(firstTableTag) | |||
if child then | |||
res:wikitext('<div>') | |||
end | end | ||
return tostring(res) | |||
end | end | ||
-- | --[[ | ||
Template:Navbox subgroup | |||
]] | |||
function p.subgroup(frame) | |||
defArgs(frame) | |||
if not border then child = true end | |||
args.groupstyle = 'padding:' .. (args.grouppadding or '0 0.75em') .. ';' .. (args.groupstyle or '') | |||
local res | |||
local firstTableTag | |||
res, firstTableTag = top() | |||
firstTableTag = title(firstTableTag) | |||
firstTableTag = above(firstTableTag) | |||
if list[1] then | |||
firstTableTag = body1(firstTableTag) | |||
end | end | ||
firstTableTag = body2(firstTableTag) | |||
firstTableTag = below(firstTableTag) | |||
if not border then res:wikitext('<div>') end | |||
return tostring(res) | |||
end | |||
--[[ | |||
Template:Navbox with columns | |||
]] | |||
:addClass('navbox- | function p.with_columns(frame) | ||
defArgs(frame) | |||
:cssText( | table.sort(col) | ||
local res | |||
local firstTableTag | |||
: | res, firstTableTag = top() | ||
:css(' | |||
:css(' | firstTableTag = title(firstTableTag) | ||
firstTableTag = above(firstTableTag) | |||
if col[1] then | |||
local j = col[1].index | |||
local cols = mw.html.create('table') | |||
:addClass('navbox-columns-table') | |||
:css('border-spacing', '0px') | |||
:css('border-collapse', 'separate') | |||
:css('text-align', 'left') | |||
:cssText((colheader[j] or args.fullwidth) and 'width:100%;' or 'margin:0 auto;') | |||
:cssText(args.coltablestyle) | |||
--Header row | |||
if colheader[j] then | |||
local headerRow = cols:tag('tr') | |||
:addClass('navbox-abovebelow') | |||
:css('font-weight', 'bold') | |||
:cssText(args.colheaderstyle) | |||
for i = 1, #col do | |||
local j = col[i].index | |||
if colheader[j] then | |||
headerRow:tag('td') | |||
:attr('colspan', colheadercolspan[j] or '1') | |||
:cssText(colheaderstyle[j]) | |||
:node(colheader[j]) | |||
end | |||
end | |||
end | |||
--Main columns | |||
local row = cols:tag('tr') | |||
:css('vertical-align', 'top') | |||
:cssText(args.colstyle) | |||
if not (colheader[j] or colfooter[j] or args.fullwidth) then | |||
local paddingoff = args.padding and string.find(args.padding, '^0[ep]?[mx]?%?;?') | |||
if not paddingoff then | |||
row:tag('td') | |||
:css('width', args.padding or '5em') | |||
:wikitext(' ') | |||
end | |||
end | |||
for i = 1, #col do | |||
local j = col[i].index | |||
row:tag('td') | |||
:css('padding', '0') | |||
:cssText(args.oddcolstyle) | |||
:cssText(colstyle[j]) | |||
:css('width', colwidth[j] or args.colwidth or '10em') | |||
:node(col[i].content) | |||
args.oddcolstyle, args.evencolstyle = args.evencolstyle, args.oddcolstyle | |||
end | |||
--Footer row | |||
if colfooter[j] then | |||
row = cols:tag('tr') | |||
:addClass('navbox-abovebelow') | |||
:css('font-weight', 'bold') | |||
:cssText(args.colfooterstyle) | |||
for i = 1, #col do | |||
local j = col[i].index | |||
if colfooter[j] then | |||
row:tag('td') | |||
:attr('colspan', colfootercolspan[j] or '1') | |||
:cssText(colfooterstyle[j]) | |||
:node(colfooter[j]) | |||
end | |||
end | |||
end | |||
cols = mw.html.create():wikitext('</div>'):wikitext(tostring(cols)):wikitext('<div>') | |||
table.insert(list, {index=1, content=cols}) | |||
rowspan = rowspan + 1 | |||
end | end | ||
firstTableTag = body1(firstTableTag) | |||
return | firstTableTag = body2(firstTableTag) | ||
firstTableTag = below(firstTableTag) | |||
return tostring(res) | |||
end | end | ||
function p. | --[[ | ||
Template:Navbox with collapsible groups | |||
]] | |||
function p.with_collapsible_groups(frame) | |||
local res | |||
local firstTableTag | |||
defArgs(frame) | |||
table.sort(content) | |||
res, firstTableTag = top() | |||
firstTableTag = title(firstTableTag) | |||
firstTableTag = above(firstTableTag) | |||
local i = 1 | |||
local function funcList(rowTag) | |||
list[i] = list[i] or content[i] | |||
local j = list[i].index | |||
args.state = state[j] or args.selected and (args.selected == abbr[j] or args.selected == group[j]) and '' or 'mw-collapsed' | |||
args.name = nil | |||
args.titlestyle = basestyle .. (args.groupstyle or '') .. ';' .. (args.secttitlestyle or '') .. ';' .. (groupstyle[j] or '') | |||
args.liststyle = (args.liststyle or '') .. ';' .. (args.contentstyle or '') .. ';' .. (liststyle[j] or '') | |||
args.title, group[j] = group[j], nil | |||
args.image = image[j] | |||
args.imageleft = imageleft[j] | |||
rowspan = 1 | |||
local baseTag = rowTag:tag('td') | |||
:cssText(args.groupwidth and '' or 'width:100%;') | |||
:css('padding', '0px') | |||
:cssText(args.liststyle) | |||
:cssText(odd == 'odd' and (args.oddstyle or '') or (args.evenstyle or '')) | |||
:cssText(liststyle[j]) | |||
:addClass('navbox-list') | |||
:addClass('navbox-' .. (args.evenodd == 'swap' and even or args.evenodd or odd)) | |||
:addClass(args.listclass) | |||
:tag('div') | |||
if args.title then | |||
local tableTag | |||
none = true | |||
baseTag, tableTag = top(baseTag) | |||
tableTag = title(tableTag) | |||
tableTag = body1(tableTag) | |||
if child then | |||
baseTag:wikitext('<div>') | |||
end | |||
else | |||
baseTag:node(list[i].content) | |||
end | end | ||
end | end | ||
--i = 1 | |||
local row = firstTableTag:tag('tr') | |||
if args.imageleft then | |||
row:tag('td') | |||
:addClass('navbox-image') | |||
:addClass(args.imageclass) | |||
:css('width', '0') | |||
:css('padding', '0 2px 0 0') | |||
:cssText(args.imageleftstyle) | |||
:attr('rowspan', rowspan) | |||
:node(args.imageleft) | |||
end | |||
funcList(row) | |||
if args.image then | |||
row:tag('td') | |||
:css('width', '0%') | |||
:css('padding', '0 0 0 2px') | |||
:cssText(args.imagestyle) | |||
:attr('rowspan', rowspan) | |||
:node(args.image) | |||
end | |||
--i > 2 | |||
for i = 2, #list do | |||
row = firstTableTag:tag('tr') | |||
list[1] = list[i] | |||
funcList(row) | |||
end | |||
firstTableTag = below(firstTableTag) | |||
if child then | |||
res:wikitext('<div>') | |||
end | end | ||
child, none = (border == 'subgroup' or border == 'child'), (border == 'none') --再定義 | |||
return tostring(res) | |||
end | |||
--[[ | |||
Template:NavboxYears | |||
Template:NavboxYears2 | |||
]] | |||
local | local function calc_years(args, fmtLink) | ||
local numtab = tonumber(args.tab) or 0 | |||
local numstart = tonumber(args.start) | |||
local numend = tonumber(args['end']) | |||
local numstep = tonumber(args.step) or 1 | |||
if numstart and numend then | |||
if | if numtab > 0 then | ||
for i = 2, numtab + 1 do | |||
args[i] = nil | |||
end | |||
end | end | ||
local numD = numend - numstart + 1 | |||
for i = 1, numD, numstep do | |||
args[i + numtab + 1] = numstart + i - 1 | |||
end | end | ||
end | end | ||
local res = mw.html.create('table') | |||
res | |||
:css('width', '100%') | |||
:css('border-spacing', '0px') | |||
:css('border-collapse', 'separate') | |||
:css('text-align', 'center') | |||
local h = 1 | |||
repeat | |||
h = h + 1 | |||
local row = res:tag('tr') | |||
for i = 2, 11 do | |||
local tdTag = row:tag('td') | |||
:css('width', '10%') | |||
if (tonumber(args[i]) or -1) > 0 then | |||
tdTag:wikitext('[[' .. fmtLink(args[1], args[i]) .. '|' .. args[i] .. ']]') | |||
else | |||
tdTag:wikitext(args[i]) | |||
end | |||
args[i], args[i + 10] = args[i + 10], args[i + h * 10] | |||
end | |||
until not args[2] | |||
return tostring(res) | |||
end | |||
if (args. | local function years(frame, fmtLink) | ||
defArgs(frame) | |||
if args.var then fmtLink = function(str, num) return str:gsub(args.var, num) end end | |||
if args.name then | |||
args.style = 'width:' .. (args.width or '38em') .. ';' .. (args.style or '') | |||
local res | |||
local firstTableTag | |||
res, firstTableTag = top() | |||
if args.title then | |||
firstTableTag = title(firstTableTag) | |||
end | |||
if args.above then | |||
firstTableTag = above(firstTableTag) | |||
end | |||
if not list[1] and args[1] then list[1] = {index = 1, content = calc_years(args, fmtLink)} end | |||
if list[1] then | |||
firstTableTag = body1(firstTableTag) | |||
end | |||
firstTableTag = body2(firstTableTag) | |||
if args.below then | |||
firstTableTag = below(firstTableTag) | |||
end | |||
return tostring(res) | |||
else | |||
return calc_years(args, fmtLink) | |||
end | end | ||
end | |||
return | function p.years(frame) | ||
local fmtLink = function(str, num) return str .. num end | |||
return years(frame, fmtLink) | |||
end | end | ||
function p. | function p.years2(frame) | ||
local fmtLink = function(str, num) return num .. str end | |||
return years(frame, fmtLink) | |||
return | |||
end | end | ||
return p | return p |
2024年2月8日 (木) 15:32時点における最新版
このモジュールについての説明文ページを モジュール:Navbox/doc に作成できます
local p = {}
--[[
Template:Tnavbar
]]
function p.tnavbar(frame)
local r = mw.html.create() --出力用
local args = frame.args
if not args[1] then return ' ' end
local function tf(x)
return x == '1' and true or false
end
args.plain = tf(args.plain)
args.div = tf(args.div)
args.nodiv = tf(args.nodiv)
args.mini = tf(args.mini)
args.viewplain = tf(args.viewplain)
args.fontstyle = args.fontcolor ~= '' and ((args.fontstyle or '') .. ';color:' .. args.fontcolor .. ';') or args.fontstyle or ''
local divTag = r:tag('div')
:addClass('noprint')
:addClass('plainlinks')
:addClass('navbar')
:addClass('hlist')
:css('white-space', 'nowrap')
:css('font-size', '60%')
:css('font-weight', 'normal')
if args.nodiv then
divTag:css('display', 'inline')
:css('padding', '0 0.5em')
else
divTag:css('background-color', 'transparent')
:css('padding', '0')
:css('color', '#000')
end
divTag:cssText(args.fontstyle)
:cssText(args.style)
if not (args.plain or args.mini or args.viewplain) then
divTag:tag('span')
:css('font-size', '125%')
:node('このテンプレートを: ')
end
local disp = args.mini and {'表', '話', '編', '歴'} or {'表示', 'ノート', '編集', '履歴'}
local ns = {'Template:', 'Template‐ノート:', 'Template:', 'Template:'}
local query = {nil, nil, 'action=edit', 'action=history'}
local title = {'このテンプレートを表示します', 'このテンプレートのノートを表示します', 'このテンプレートを編集します。保存の前にプレビューを忘れずに。', 'このテンプレートの過去の版を表示します'}
local color = {'', 'color:#002bb8;', 'color:#002bb8;', 'color:#002bb8;'}
local i = 0
local i_end = args.viewplain and 1 or 4
local ulTag = divTag:tag('ul')
:css('display', 'inline')
for i = 1, i_end do
local liTag = ulTag:tag('li')
local l = {open = '', link = '', close = ''}
if query[i] then
l.open = '['
l.link = tostring(mw.uri.canonicalUrl(ns[i] .. args[1], query[i])) .. ' '
l.close = ']'
else
l.open = '[['
l.link = ns[i] .. args[1] .. '|'
l.close = ']]'
end
liTag:wikitext(l.open .. l.link)
:tag('span')
:attr('title', title[i])
:css('font-size', '125%')
:cssText(color[i])
:cssText(args.fontstyle)
:node(disp[i])
:done()
:wikitext(l.close)
end
return tostring(r)
end
--[[
Define Arguments
]]
local getArgs
local args = {}
local border
local child, none = false, false
local rowspan = 0
local basestyle = ''
local odd, even = 'odd', 'even'
local list, liststyle = {}, {}
local group, groupstyle = {}, {}
local colheader, colheadercolspan, colheaderstyle = {}, {}, {}
local col, colstyle, colwidth = {}, {}, {}
local colfooter, colfootercolspan, colfooterstyle = {}, {}, {}
local abbr, state = {}, {}
local sect, section = {}, {}
local secttitlestyle = {}
local content, contentstyle = {}
local image, imageleft = {}, {}
local function defArgs(frame)
if not getArgs then
getArgs = require('Module:Arguments').getArgs
end
args = getArgs(frame, {parentOnly = true})
border = args.border or args[1]
child, none = (border == 'subgroup' or border == 'child'), (border == 'none')
collapsible = (args.state == 'plain' or args.state == 'off') and '' or 'mw-collapsible '
if args.basestyle then basestyle = args.basestyle .. ';' end
local sortable_mt = {
__lt = function(a, b) return a.index < b.index end,
__concat = function(a, b)
local strA = (type(a) == 'table') and a.content or a or ''
local strB = (type(b) == 'table') and b.content or b or ''
return strA .. strB
end
}
local function sortable_args(tbl, index, content)
table.insert(tbl, {index = index, content = content})
setmetatable(tbl[#tbl], sortable_mt)
end
local switch = {
--common
list = function(num, v) sortable_args(list, num, '\n' .. v) end,
liststyle = function(num, v) liststyle[num] = v end,
group = function(num, v) group[num] = v end,
groupstyle = function(num, v) groupstyle[num] = v end,
--for with_columns
colheader = function(num,v) colheader[num] = v end,
colheadercolspan = function(num,v) colheadercolspan[num] = v end,
colheaderstyle = function(num,v) colheaderstyle[num] = v end,
col = function(num, v) sortable_args(col, num, '\n' .. v) end,
colstyle = function(num,v) colstyle[num] = v end,
colwidth = function(num,v) colwidth[num] = v end,
colfooter = function(num,v) colfooter[num] = v end,
colfootercolspan = function(num,v) colfootercolspan[num] = v end,
colfooterstyle = function(num,v) colfooterstyle[num] = v end,
--for with_collapsible_groups
abbr = function(num, v) abbr[num] = v end,
state = function(num, v) state[num] = v end,
sect = function(num, v) group[num] = v end,
section = function(num, v) group[num] = v end,
secttitlestyle = function(num, v) groupstyle[num] = v end,
content = function(num, v) sortable_args(content, num, '\n' .. v) end,
contentstyle = function(num, v) liststyle[num] = v end,
image = function(num, v) image[num] = v end,
imageleft = function(num, v) imageleft[num] = v end,
}
for k, v in pairs(args) do
local str1, num, str2 = string.match(k, '(%D+)(%d+)(%D*)')
str1, num, str2 = str1 or '', tonumber(num), str2 or ''
if switch[str1 .. str2] and num then switch[str1 .. str2](num, v) end
end
table.sort(list)
rowspan = #list
end
--[[
top
]]
local function top(baseTag)
local nav
local bodyTable
if baseTag == nil or baseTag == '' then
baseTag = mw.html.create()
end
if child then
baseTag:wikitext('</div>')
nav = baseTag
elseif not none then
nav = baseTag:tag('div')
:addClass('navbox')
:addClass(args.navboxclass)
:css('border-collapse', 'collapse')
:cssText(args.bodystyle)
:cssText(args.style)
:css('padding', '3px')
if args.title or args.above then
nav:attr('aria-labelledby', mw.uri.anchorEncode(args.title or args.above))
else
nav:attr('aria-label', 'Navbox')
end
else
nav = baseTag
end
bodyTable = nav:tag('table')
:addClass('nowraplinks')
:addClass(args.bodyclass)
if args.title and (args.state ~= 'plain' and args.state ~= 'off') then
if args.state == 'collapsed' then args.state = 'mw-collapsed' end
bodyTable
:addClass('mw-collapsible')
:addClass(args.state or 'autocollapse')
end
if child or border == 'none' then
bodyTable
:addClass('navbox-subgroup')
:cssText(args.bodystyle)
:cssText(args.style)
else -- regular navbox - bodystyle and style will be applied to the wrapper table
bodyTable
:addClass('navbox-inner')
:css('background', 'transparent')
:css('color', 'inherit')
end
bodyTable:css('min-width', '100%')
:css('border-spacing', '0px')
:css('border-collapse', 'separate')
:cssText(args.innerstyle)
return baseTag, bodyTable
end
--[[
title and navbar
]]
local function title(tbl)
if not args.title then return tbl end
local titleRow = tbl:tag('tr')
if args.titlegroup then
titleRow
:tag('th')
:attr('scope', 'row')
:addClass('navbox-group')
:addClass(args.titlegroupclass)
:cssText(args.basestyle)
:cssText(args.groupstyle)
:cssText(args.titlegroupstyle)
:wikitext(args.titlegroup)
end
local titleCell = titleRow:tag('th'):attr('scope', 'col')
if args.titlegroup then
titleCell
:css('width', '100%')
end
local titleColspan = 2
if args.imageleft then titleColspan = titleColspan + 1 end
if args.image then titleColspan = titleColspan + 1 end
if args.titlegroup then titleColspan = titleColspan - 1 end
titleCell
:cssText(args.basestyle)
:cssText(args.titlestyle)
:addClass('navbox-title')
:attr('colspan', titleColspan)
if (args.navbar == 'plain') or (not args.name and (child or none)) then
titleCell
:tag('div')
:css('float', 'left')
:css('width', '6em')
:node(' ')
elseif args.navbar ~= 'off' then
local tbl = {args = {args.name, mini = '1', fontstyle = basestyle .. (args.titlestyle or '') .. ';border:none;', fontcolor = ''}}
titleCell
:tag('div')
:css('float', 'left')
:css('width', '6em')
:css('text-align', 'left')
:node(p.tnavbar(tbl))
end
if child or border == 'none' then
titleCell
:tag('div')
:attr('id', mw.uri.anchorEncode(args.title))
:addClass(args.titleclass)
:css('font-size', '100%')
:css('margin', '0 6em')
:node(args.title)
else
titleCell
:tag('div')
:attr('id', mw.uri.anchorEncode(args.title))
:addClass(args.titleclass)
:css('font-size', '110%')
:css('margin', '0 6em')
:node(args.title)
end
return tbl
end
local function getAboveBelowColspan()
local ret = 2
if args.imageleft then ret = ret + 1 end
if args.image then ret = ret + 1 end
return ret
end
--[[
above
]]
local function above(tbl)
if not args.above then return tbl end
tbl:tag('tr')
:tag('td')
:addClass('navbox-abovebelow')
:addClass(args.aboveclass)
:cssText(args.basestyle)
:cssText(args.abovestyle)
:attr('colspan', getAboveBelowColspan())
:newline()
:node(args.above)
return tbl
end
--[[
body
]]
--first group/list and images
local function body1(tbl)
local row = tbl:tag('tr')
if args.imageleft then
row
:tag('td')
:addClass('navbox-image')
:addClass(args.imageclass)
:css('width', '1px')
:css('padding', '0px 2px 0px 0px')
:cssText(args.imageleftstyle)
:attr('rowspan', rowspan)
:tag('div')
:node(args.imageleft)
end
local j = list[1].index
if group[j] then
local groupCell = row:tag('th')
groupCell
:attr('scope', 'row')
:addClass('navbox-group')
:addClass(args.groupclass)
:cssText(args.basestyle)
:css('width', args.groupwidth or '1%')
groupCell
:cssText(args.groupstyle)
:cssText(groupstyle[j])
:wikitext(group[j])
end
local listCell = row:tag('td')
if group[j] then
listCell
:css('text-align', 'left')
:css('border-left-width', '2px')
:css('border-left-style', 'solid')
else
listCell:attr('colspan', 2)
end
if not args.groupwidth then
listCell:css('width', '100%')
end
local rowstyle
if odd == 'odd' then
rowstyle = args.oddstyle
else
rowstyle = args.evenstyle
end
listCell
:css('padding', '0px')
:cssText(args.liststyle)
:cssText(rowstyle)
:cssText(liststyle[j])
:addClass('navbox-list')
:addClass('navbox-' .. (args.evenodd == 'swap' and even or args.evenodd or odd))
:addClass(args.listclass)
:tag('div')
:css('padding', (args.list1padding or args.listpadding or '0em 0.25em'))
:node(list[1].content)
:newline()
if args.image then
row
:tag('td')
:addClass('navbox-image')
:addClass(args.imageclass)
:css('width', '1px')
:css('padding', '0px 0px 0px 2px')
:cssText(args.imagestyle)
:attr('rowspan', rowspan)
:tag('div')
:node(args.image)
end
return tbl
end
--remaining groups/lists
local function body2(tbl)
for i = 2, #list do
odd, even = even, odd
local j = list[i].index
local row = tbl:tag('tr')
if group[j] then
local groupCell = row:tag('th')
groupCell
:attr('scope', 'row')
:addClass('navbox-group')
:addClass(args.groupclass)
:cssText(args.basestyle)
:css('width', args.groupwidth or '1%')
groupCell
:cssText(args.groupstyle)
:cssText(groupstyle[j])
:node(group[j])
end
local listCell = row:tag('td')
if group[j] then
listCell
:css('text-align', 'left')
:css('border-left-width', '2px')
:css('border-left-style', 'solid')
else
listCell:attr('colspan', 2)
end
if not args.groupwidth then
listCell:css('width', '100%')
end
local rowstyle
if odd == 'odd' then
rowstyle = args.oddstyle
else
rowstyle = args.evenstyle
end
listCell
:css('padding', '0px')
:cssText(args.liststyle)
:cssText(rowstyle)
:cssText(liststyle[j])
:addClass('navbox-list')
:addClass('navbox-' .. (args.evenodd == 'swap' and even or args.evenodd or odd))
:addClass(args.listclass)
:tag('div')
:css('padding', (args.listpadding or '0em 0.25em'))
:node(list[i].content)
:newline()
end
return tbl
end
--[[
below
]]
local function below(tbl)
if not args.below then return tbl end
tbl:tag('tr')
:tag('td')
:addClass('navbox-abovebelow')
:addClass(args.belowclass)
:cssText(args.basestyle)
:cssText(args.belowstyle)
:attr('colspan', getAboveBelowColspan())
:newline()
:node(args.below)
return tbl
end
--[[
Template:Navbox
]]
function p.navbox(frame)
defArgs(frame)
local res
local firstTableTag
res, firstTableTag = top()
firstTableTag = title(firstTableTag)
firstTableTag = above(firstTableTag)
if list[1] then
firstTableTag = body1(firstTableTag)
end
firstTableTag = body2(firstTableTag)
firstTableTag = below(firstTableTag)
if child then
res:wikitext('<div>')
end
return tostring(res)
end
--[[
Template:Navbox subgroup
]]
function p.subgroup(frame)
defArgs(frame)
if not border then child = true end
args.groupstyle = 'padding:' .. (args.grouppadding or '0 0.75em') .. ';' .. (args.groupstyle or '')
local res
local firstTableTag
res, firstTableTag = top()
firstTableTag = title(firstTableTag)
firstTableTag = above(firstTableTag)
if list[1] then
firstTableTag = body1(firstTableTag)
end
firstTableTag = body2(firstTableTag)
firstTableTag = below(firstTableTag)
if not border then res:wikitext('<div>') end
return tostring(res)
end
--[[
Template:Navbox with columns
]]
function p.with_columns(frame)
defArgs(frame)
table.sort(col)
local res
local firstTableTag
res, firstTableTag = top()
firstTableTag = title(firstTableTag)
firstTableTag = above(firstTableTag)
if col[1] then
local j = col[1].index
local cols = mw.html.create('table')
:addClass('navbox-columns-table')
:css('border-spacing', '0px')
:css('border-collapse', 'separate')
:css('text-align', 'left')
:cssText((colheader[j] or args.fullwidth) and 'width:100%;' or 'margin:0 auto;')
:cssText(args.coltablestyle)
--Header row
if colheader[j] then
local headerRow = cols:tag('tr')
:addClass('navbox-abovebelow')
:css('font-weight', 'bold')
:cssText(args.colheaderstyle)
for i = 1, #col do
local j = col[i].index
if colheader[j] then
headerRow:tag('td')
:attr('colspan', colheadercolspan[j] or '1')
:cssText(colheaderstyle[j])
:node(colheader[j])
end
end
end
--Main columns
local row = cols:tag('tr')
:css('vertical-align', 'top')
:cssText(args.colstyle)
if not (colheader[j] or colfooter[j] or args.fullwidth) then
local paddingoff = args.padding and string.find(args.padding, '^0[ep]?[mx]?%?;?')
if not paddingoff then
row:tag('td')
:css('width', args.padding or '5em')
:wikitext(' ')
end
end
for i = 1, #col do
local j = col[i].index
row:tag('td')
:css('padding', '0')
:cssText(args.oddcolstyle)
:cssText(colstyle[j])
:css('width', colwidth[j] or args.colwidth or '10em')
:node(col[i].content)
args.oddcolstyle, args.evencolstyle = args.evencolstyle, args.oddcolstyle
end
--Footer row
if colfooter[j] then
row = cols:tag('tr')
:addClass('navbox-abovebelow')
:css('font-weight', 'bold')
:cssText(args.colfooterstyle)
for i = 1, #col do
local j = col[i].index
if colfooter[j] then
row:tag('td')
:attr('colspan', colfootercolspan[j] or '1')
:cssText(colfooterstyle[j])
:node(colfooter[j])
end
end
end
cols = mw.html.create():wikitext('</div>'):wikitext(tostring(cols)):wikitext('<div>')
table.insert(list, {index=1, content=cols})
rowspan = rowspan + 1
end
firstTableTag = body1(firstTableTag)
firstTableTag = body2(firstTableTag)
firstTableTag = below(firstTableTag)
return tostring(res)
end
--[[
Template:Navbox with collapsible groups
]]
function p.with_collapsible_groups(frame)
local res
local firstTableTag
defArgs(frame)
table.sort(content)
res, firstTableTag = top()
firstTableTag = title(firstTableTag)
firstTableTag = above(firstTableTag)
local i = 1
local function funcList(rowTag)
list[i] = list[i] or content[i]
local j = list[i].index
args.state = state[j] or args.selected and (args.selected == abbr[j] or args.selected == group[j]) and '' or 'mw-collapsed'
args.name = nil
args.titlestyle = basestyle .. (args.groupstyle or '') .. ';' .. (args.secttitlestyle or '') .. ';' .. (groupstyle[j] or '')
args.liststyle = (args.liststyle or '') .. ';' .. (args.contentstyle or '') .. ';' .. (liststyle[j] or '')
args.title, group[j] = group[j], nil
args.image = image[j]
args.imageleft = imageleft[j]
rowspan = 1
local baseTag = rowTag:tag('td')
:cssText(args.groupwidth and '' or 'width:100%;')
:css('padding', '0px')
:cssText(args.liststyle)
:cssText(odd == 'odd' and (args.oddstyle or '') or (args.evenstyle or ''))
:cssText(liststyle[j])
:addClass('navbox-list')
:addClass('navbox-' .. (args.evenodd == 'swap' and even or args.evenodd or odd))
:addClass(args.listclass)
:tag('div')
if args.title then
local tableTag
none = true
baseTag, tableTag = top(baseTag)
tableTag = title(tableTag)
tableTag = body1(tableTag)
if child then
baseTag:wikitext('<div>')
end
else
baseTag:node(list[i].content)
end
end
--i = 1
local row = firstTableTag:tag('tr')
if args.imageleft then
row:tag('td')
:addClass('navbox-image')
:addClass(args.imageclass)
:css('width', '0')
:css('padding', '0 2px 0 0')
:cssText(args.imageleftstyle)
:attr('rowspan', rowspan)
:node(args.imageleft)
end
funcList(row)
if args.image then
row:tag('td')
:css('width', '0%')
:css('padding', '0 0 0 2px')
:cssText(args.imagestyle)
:attr('rowspan', rowspan)
:node(args.image)
end
--i > 2
for i = 2, #list do
row = firstTableTag:tag('tr')
list[1] = list[i]
funcList(row)
end
firstTableTag = below(firstTableTag)
if child then
res:wikitext('<div>')
end
child, none = (border == 'subgroup' or border == 'child'), (border == 'none') --再定義
return tostring(res)
end
--[[
Template:NavboxYears
Template:NavboxYears2
]]
local function calc_years(args, fmtLink)
local numtab = tonumber(args.tab) or 0
local numstart = tonumber(args.start)
local numend = tonumber(args['end'])
local numstep = tonumber(args.step) or 1
if numstart and numend then
if numtab > 0 then
for i = 2, numtab + 1 do
args[i] = nil
end
end
local numD = numend - numstart + 1
for i = 1, numD, numstep do
args[i + numtab + 1] = numstart + i - 1
end
end
local res = mw.html.create('table')
res
:css('width', '100%')
:css('border-spacing', '0px')
:css('border-collapse', 'separate')
:css('text-align', 'center')
local h = 1
repeat
h = h + 1
local row = res:tag('tr')
for i = 2, 11 do
local tdTag = row:tag('td')
:css('width', '10%')
if (tonumber(args[i]) or -1) > 0 then
tdTag:wikitext('[[' .. fmtLink(args[1], args[i]) .. '|' .. args[i] .. ']]')
else
tdTag:wikitext(args[i])
end
args[i], args[i + 10] = args[i + 10], args[i + h * 10]
end
until not args[2]
return tostring(res)
end
local function years(frame, fmtLink)
defArgs(frame)
if args.var then fmtLink = function(str, num) return str:gsub(args.var, num) end end
if args.name then
args.style = 'width:' .. (args.width or '38em') .. ';' .. (args.style or '')
local res
local firstTableTag
res, firstTableTag = top()
if args.title then
firstTableTag = title(firstTableTag)
end
if args.above then
firstTableTag = above(firstTableTag)
end
if not list[1] and args[1] then list[1] = {index = 1, content = calc_years(args, fmtLink)} end
if list[1] then
firstTableTag = body1(firstTableTag)
end
firstTableTag = body2(firstTableTag)
if args.below then
firstTableTag = below(firstTableTag)
end
return tostring(res)
else
return calc_years(args, fmtLink)
end
end
function p.years(frame)
local fmtLink = function(str, num) return str .. num end
return years(frame, fmtLink)
end
function p.years2(frame)
local fmtLink = function(str, num) return num .. str end
return years(frame, fmtLink)
end
return p