Difference between revisions of "Module:Aligned table"
From MINR.ORG WIKI
(rowstyle and rowclass) |
(start conversion to mw.html) |
||
Line 17: | Line 17: | ||
colstyle[1] = 'text-align:left;' | colstyle[1] = 'text-align:left;' | ||
colstyle[2] = 'text-align:right;' | colstyle[2] = 'text-align:right;' | ||
− | + | end | |
+ | |||
+ | local root = mw.html.create('table') | ||
+ | |||
if fullwidth ~= '' then | if fullwidth ~= '' then | ||
− | + | root | |
+ | :css('width', '100%') | ||
+ | :css('border-collapse', 'collapse') | ||
+ | :css('border-spacing', '0px') | ||
+ | :css('border', 'none') | ||
end | end | ||
if class ~= '' then | if class ~= '' then | ||
− | class | + | root:addClass(class) |
end | end | ||
if style ~= '' then | if style ~= '' then | ||
− | style | + | root:cssText(style) |
end | end | ||
− | |||
for i = 1,cols do | for i = 1,cols do | ||
colclass[ i ] = colclass[ i ] or '' | colclass[ i ] = colclass[ i ] or '' | ||
Line 73: | Line 79: | ||
end | end | ||
end | end | ||
− | + | root:wikitext(table.concat( entries, '\n' )) | |
− | + | ||
+ | return tostring(root) | ||
end | end | ||
return p | return p |
Revision as of 20:27, 22 April 2014
Documentation for this module may be created at Module:Aligned table/doc
-- This module implements {{aligned table}} local p = {} function p.table(frame) local args = (frame.args[3] ~= nil) and frame.args or frame:getParent().args local entries = {} local colclass = {} local colstyle = {} local cols = tonumber(args['cols']) or 2 local class = args['class'] or '' local style = args['style'] or '' local leftright = args['leftright'] or '' local fullwidth = args['fullwidth'] or '' if leftright ~= '' then colstyle[1] = 'text-align:left;' colstyle[2] = 'text-align:right;' end local root = mw.html.create('table') if fullwidth ~= '' then root :css('width', '100%') :css('border-collapse', 'collapse') :css('border-spacing', '0px') :css('border', 'none') end if class ~= '' then root:addClass(class) end if style ~= '' then root:cssText(style) end for i = 1,cols do colclass[ i ] = colclass[ i ] or '' colstyle[ i ] = colstyle[ i ] or '' if args['align' .. tostring(i)] then colstyle[ i ] = 'text-align:' .. args['align' .. tostring(i)] .. ';' .. colstyle[ i ] end if args['nowrap' .. tostring(i)] and args['nowrap' .. tostring(i)] ~= '' then colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ] end if args['style' .. tostring(i)] then colstyle[ i ] = colstyle[ i ] .. args['style' .. tostring(i)] end if args['class' .. tostring(i)] then colclass[ i ] = args['class' .. tostring(i)] end end for k, v in pairs( args ) do if type( k ) == 'number' then i = math.fmod(k-1,cols) + 1 local j = (k - i) / cols + 1 local tdstyle = '' if args['class' .. tostring(j) .. '.' .. tostring(i)] then tdstyle = tdstyle .. ' class="' .. args['class' .. tostring(j) .. '.' .. tostring(i)] .. '"' elseif args['rowclass' .. tostring(j)] then tdstyle = tdstyle .. ' class="' .. args['rowclass' .. tostring(j)] .. '"' elseif colclass[i] ~= '' then tdstyle = tdstyle .. ' class="' .. colclass[i] .. '"' end if args['style' .. tostring(j) .. '.' .. tostring(i)] then tdstyle = tdstyle .. ' style="' .. args['style' .. tostring(j) .. '.' .. tostring(i)] .. '"' elseif args['rowstyle' .. tostring(j)] then tdstyle = tdstyle .. ' style="' .. args['rowstyle' .. tostring(j)] .. '"' elseif colstyle[i] ~= '' then tdstyle = tdstyle .. ' style="' .. colstyle[i] .. '"' end entries[ k ] = '<td' .. tdstyle .. '>' .. v .. '</td>' if i == 1 then entries[ k ] = '<tr style="vertical-align:top">' .. entries[ k ] end if i == cols then entries[ k ] = entries[k] .. '</tr>' end end end root:wikitext(table.concat( entries, '\n' )) return tostring(root) end return p