Module:Sidebar: Difference between revisions
tableless layout (div instead of table) |
self rv per trouble reports |
||
Line 31: | Line 31: | ||
if not child then | if not child then | ||
root = root | root = root | ||
:tag(' | :tag('table') | ||
:addClass('vertical-navbox') | :addClass('vertical-navbox') | ||
:addClass(args.wraplinks ~= 'true' and 'nowraplinks' or nil) | :addClass(args.wraplinks ~= 'true' and 'nowraplinks' or nil) | ||
:addClass(args.bodyclass or args.class) | :addClass(args.bodyclass or args.class) | ||
:css('float', args.float or 'right') | :css('float', args.float or 'right') | ||
:css(' | :css('clear', (args.float == 'none' and 'both') or args.float or 'right') | ||
:css('width', args.width or '22.0em') | :css('width', args.width or '22.0em') | ||
:css('margin', args.float == 'left' and '0 1.0em 1.0em 0' or '0 0 1.0em 1.0em') | |||
:css('background', '#f9f9f9') | |||
:css('border', '1px solid #aaa') | :css('border', '1px solid #aaa') | ||
:css('padding', '0. | :css('padding', '0.2em') | ||
:css(' | :css('border-spacing', '0.4em 0') | ||
:css('text-align', 'center') | |||
:css('line-height', '1.4em') | :css('line-height', '1.4em') | ||
:css('font-size', '88%') | :css('font-size', '88%') | ||
:cssText(args.bodystyle or args.style) | :cssText(args.bodystyle or args.style) | ||
if args.outertitle then | if args.outertitle then | ||
root | root | ||
:tag('caption') | |||
:tag(' | |||
:addClass(args.outertitleclass) | :addClass(args.outertitleclass) | ||
:css(' | :css('padding-bottom', '0.2em') | ||
:css('font-size', '125%') | :css('font-size', '125%') | ||
:css('line-height', '1.2em') | :css('line-height', '1.2em') | ||
Line 72: | Line 61: | ||
if args.topimage then | if args.topimage then | ||
local | local imageCell = root:tag('tr'):tag('td') | ||
imageCell | |||
:addClass(args.topimageclass) | :addClass(args.topimageclass) | ||
:css('padding', '0.4em 0') | :css('padding', '0.4em 0') | ||
Line 81: | Line 70: | ||
if args.topcaption then | if args.topcaption then | ||
imageCell | |||
:tag('div') | :tag('div') | ||
:css('padding-top', '0.2em') | :css('padding-top', '0.2em') | ||
Line 92: | Line 81: | ||
if args.pretitle then | if args.pretitle then | ||
root | root | ||
:tag(' | :tag('tr') | ||
:addClass(args.pretitleclass) | :tag('td') | ||
:addClass(args.pretitleclass) | |||
:cssText(args.basestyle) | |||
:css('padding-top', args.topimage and '0.2em' or '0.4em') | |||
:css('line-height', '1.2em') | |||
:cssText(args.pretitlestyle) | |||
:wikitext(args.pretitle) | |||
end | end | ||
Line 107: | Line 97: | ||
root | root | ||
:wikitext(args.title) | :wikitext(args.title) | ||
:wikitext('</th></tr>') -- @todo replace this with unclosed again once mw.html gets it | |||
else | else | ||
root | root | ||
:tag(' | :tag('tr') | ||
: | :tag('th') | ||
:addClass(args.titleclass) | |||
:cssText(args.basestyle) | |||
:css('padding', '0.2em 0.4em 0.2em') | |||
:css('padding-top', args.pretitle and 0) | |||
:css('font-size', '145%') | |||
:css('line-height', '1.2em') | |||
:cssText(args.titlestyle) | |||
:wikitext(args.title) | |||
end | end | ||
end | end | ||
if args.image then | if args.image then | ||
local | local imageCell = root:tag('tr'):tag('td') | ||
imageCell | |||
:addClass(args.imageclass) | :addClass(args.imageclass) | ||
:css('padding', '0.2em 0 0.4em') | :css('padding', '0.2em 0 0.4em') | ||
Line 133: | Line 123: | ||
if args.caption then | if args.caption then | ||
imageCell | |||
:tag('div') | :tag('div') | ||
:css('padding-top', '0.2em') | :css('padding-top', '0.2em') | ||
Line 144: | Line 134: | ||
if args.above then | if args.above then | ||
root | root | ||
:tag(' | :tag('tr') | ||
:addClass(args.aboveclass) | :tag('td') | ||
:addClass(args.aboveclass) | |||
:css('padding', '0.3em 0.4em 0.3em') | |||
:css('font-weight', 'bold') | |||
:cssText(args.abovestyle) | |||
:newline() -- newline required for bullet-points to work | |||
:wikitext(args.above) | |||
end | end | ||
local | local rowNums = {} | ||
for k, | for k, v in pairs(args) do | ||
k = '' .. k | k = '' .. k | ||
local num = k:match('^heading(%d+)$') or k:match('^content(%d+)$') | local num = k:match('^heading(%d+)$') or k:match('^content(%d+)$') | ||
if num then table.insert( | if num then table.insert(rowNums, tonumber(num)) end | ||
end | end | ||
table.sort( | table.sort(rowNums) | ||
-- remove duplicates from the list (e.g. 3 will be duplicated if both heading3 and content3 are specified) | -- remove duplicates from the list (e.g. 3 will be duplicated if both heading3 and content3 are specified) | ||
for i = # | for i = #rowNums, 1, -1 do | ||
if | if rowNums[i] == rowNums[i - 1] then | ||
table.remove( | table.remove(rowNums, i) | ||
end | end | ||
end | end | ||
for i, num in ipairs( | for i, num in ipairs(rowNums) do | ||
local heading = args['heading' .. num] | local heading = args['heading' .. num] | ||
if heading then | if heading then | ||
root | root | ||
:tag(' | :tag('tr') | ||
:addClass(args.headingclass) | :tag('th') | ||
:addClass(args.headingclass) | |||
:css('padding', '0.1em') | |||
:cssText(args.basestyle) | |||
:cssText(args.headingstyle) | |||
:cssText(args['heading' .. num .. 'style']) | |||
:newline() | |||
:wikitext(heading) | |||
end | end | ||
Line 185: | Line 176: | ||
if content then | if content then | ||
root | root | ||
:tag(' | :tag('tr') | ||
:addClass(args.contentclass) | :tag('td') | ||
:addClass(args.contentclass) | |||
:css('padding', '0 0.1em 0.4em') | |||
:cssText(args.contentstyle) | |||
:cssText(args['content' .. num .. 'style']) | |||
:newline() | |||
:wikitext(content) | |||
:done() | |||
:newline() -- Without a linebreak after the </td>, a nested list like "* {{hlist| ...}}" doesn't parse correctly. | |||
end | end | ||
end | end | ||
Line 199: | Line 191: | ||
if args.below then | if args.below then | ||
root | root | ||
:tag(' | :tag('tr') | ||
: | :tag('td') | ||
:addClass(args.belowclass) | |||
:css('padding', '0.3em 0.4em 0.3em') | |||
:css('font-weight', 'bold') | |||
:cssText(args.belowstyle) | |||
:newline() | |||
:wikitext(args.below) | |||
end | end | ||
Line 213: | Line 205: | ||
if navbarArg ~= 'none' and navbarArg ~= 'off' and (args.name or frame:getParent():getTitle():gsub('/sandbox$', '') ~= 'Template:Sidebar') then | if navbarArg ~= 'none' and navbarArg ~= 'off' and (args.name or frame:getParent():getTitle():gsub('/sandbox$', '') ~= 'Template:Sidebar') then | ||
root | root | ||
:tag(' | :tag('tr') | ||
:css('text-align', 'right') | :tag('td') | ||
:css('text-align', 'right') | |||
:css('font-size', '115%') | |||
:cssText(args.navbarstyle or args.tnavbarstyle) | |||
:wikitext(navbar{ | |||
args.name, | |||
mini = 1, | |||
fontstyle = args.navbarfontstyle or args.tnavbarfontstyle | |||
}) | |||
end | end | ||
end | end |