Module:TreeChart
Appearance
local p = {}
local SLD = '1px solid black'
local DSH = '1px dashed black'
local DOT = '1px dotted black'
local cells = mw.loadData('Module:Sandbox/The Mol Man/data')
function p.main(frame)
local args = frame:getParent().args
local cell_args = {}
for i, v in ipairs(args) do
local w = mw.text.trim(v)
if not w:find('%S') then
w = '$'
end
local cell_x = { }
if cells[w] then
cell_x.box = nil
cell_x.name = w
else
cell_x.name = mw.text.trim(v)
local args_v = args[cell_x.name]
cell_x.text = args_v or '{{{'..w..'}}}'
cell_x.box = true
cell_x.colspan = args['colspan_'..w] or args['colspan_ '..w] or args.colspan or '6'
cell_x.rowspan = args['rowspan_'..w] or args['rowspan_ '..w] or args.rowspan or '2'
cell_x.thick = args['border_'..w] or args['border_ '..w] or args.border or '2'
cell_x.css = args['boxstyle_'..w] or args['boxstyle_ '..w] or args.boxstyle or ''
end
table.insert(cell_args,cell_x)
end
return p._main(cell_args)
end
function p._main(cell_args)
local ret = mw.html.create('tr')
:css({ ['height'] = '1px',
['text-align'] = 'center' })
local ret2 = mw.html.create('tr')
:css({ ['height'] = '1px',
['text-align'] = 'center' })
for i, v in ipairs(cell_args) do
if v.box then
ret:node(make_box(v))
else
ret:node(make_cell(v.name,'t'))
ret2:node(make_cell(v.name,'b'))
end
end
return tostring(ret) .. tostring(ret2)
end
function make_cell(name,key)
local props = cells[name][key]
if not props then
return
end
local ret = ''
for i, v in ipairs(props) do
ret = ret .. tostring(make_tag(v))
end
return ret
end
function make_tag(tbl)
local ret = mw.html.create(tbl.tag,{selfClosing=true})
if tbl.style then
ret:css(tbl.style)
end
if tbl.attr then
ret:attr(tbl.attr)
end
return ret
end
function make_box(tbl)
local ret = mw.html.create('td')
:attr('colspan',tbl.colspan)
:attr('rowspan',tbl.rowspan)
:css({ ['padding'] = '0.2em',
['border'] = tbl.thick .. 'px solid black' })
:cssText(tbl.css)
:wikitext(tbl.text)
return ret
end
return p