Module:Navbox: Difference between revisions

Ganaram inukshuk (talk | contribs)
more bugfixing
Ganaram inukshuk (talk | contribs)
rollback; limit refactoring to main navbox code
Line 6: Line 6:
local yesno = require("Module:Yesno")
local yesno = require("Module:Yesno")


-- TODO: add option for dataless header row, to complement the existence of
-- TODO: add an option for a dataless header row, to mirror the option of having
-- a headerless data row.
-- a headerless data row


-- Navbox header/footer row
-- Header/footer row
function p.navbox_header_footer(row_content)
function p.navbox_header_footer(row_content)
local lines = {}
local row = "|-\n"
table.insert(lines, "|-")
.. '| colspan="2" style="font-size: 0.8em; text-align: center; background-color: #eaecf0; padding: 0em; border: 1px solid white;" | '
table.insert(lines, '| colspan="2" style="font-size: 0.8em; text-align: center; background-color: #eaecf0; padding: 0em; border: 1px solid white;" | ' .. row_content)
.. row_content .. "\n"
 
return table.concat(lines, "\n")
return row
end
end


-- Navbox row
-- Navbox row
function p.navbox_row(row_content, is_navbox)
function p.navbox_row(row_content, is_navbox)
local is_navbox = is_navbox or false
local is_navbox = (is_navbox ~= nil and is_navbox or false)
local lines = {}
table.insert(lines, "|-")
-- TODO: add option for a dataless header row


local row = "|-\n"
if #row_content == 1 then
if #row_content == 1 then
-- Headerless row; holds data for simple navboxes or a nested navbox
-- Headerless row; takes up two cells
if is_navbox then
if is_navbox then
table.insert(lines, '| style="padding: 0;" colspan="2" | ' .. row_content[1])
-- Row data is a child navbox; data cell has no padding
row = row
.. '| style="padding: 0;" colspan="2" | \n'
.. row_content[1] .. "\n"
else
else
table.insert(lines, '| style="font-size: 0.9em; padding: 0.25em 0.5em;" colspan="2" | ' .. row_content[1])
-- Row data is normal data
end
row = row .. '| style="font-size: 0.9em; padding: 0.25em 0.5em;" colspan="2" | ' .. row_content[1] .. "\n"
    end
else
else
-- Header + Data row; typical usecase for a row
-- Row with header and data
table.insert(lines, '! style="white-space: nowrap; font-size: 0.9em; width: 5%; text-align: right; background-color: #eaecf0; padding: 0.25em 0.5em; border: 1px solid white;" | ' .. row_content[1])
if is_navbox then
if is_navbox then
table.insert(lines, '| style="padding: 0;" | ' .. row_content[2])
-- Row data is a child navbox; data cell has no padding
row = row
.. '! style="white-space: nowrap; font-size: 0.9em; width: 5%; text-align: right; background-color: #eaecf0; padding: 0.25em 0.5em; border: 1px solid white;" |'
..  row_content[1] .. "\n"
.. '| style="padding: 0;" |\n'  
.. row_content[2] .. "\n"
else
else
table.insert(lines, '| style="font-size: 0.9em; padding: 0.25em 0.5em;" | ' .. row_content[2])
-- Row data is normal data
row = row
.. '! style="white-space: nowrap; font-size: 0.9em; width: 5%; text-align: right; background-color: #eaecf0; padding: 0.25em 0.5em; border: 1px solid white;" |'
..  row_content[1] .. "\n"
.. '| style="font-size: 0.9em; padding: 0.25em 0.5em;" | ' .. row_content[2] .. "\n"
end
end
end
end
 
return table.concat(lines, "\n")
return row
end
end


-- Navbox title
-- Navbox title
function p.navbox_title(title, is_collapsible, name)
function p.navbox_title(title, is_collapsible, name)
if not title then return "" end
local is_root_navbox = (is_root_navbox == nil and is_root_navbox or true) -- If not specified, default to TRUE
local has_navbar = name ~= nil
local has_navbar = name ~= nil
local navbox_title = ''
-- Assemble boilerplate lines separately
if title ~= nil then
local boilerplate_lines = {}
navbox_title = "|-\n"
table.insert(boilerplate_lines, '! style="text-align: center; background-color: #eaecf0; white-space: nowrap; margin: 0em 4em 0em 4em; padding: 0.25em 0.5em; border: 1px solid white;" colspan="2" | ')
.. '! style="text-align: center; background-color: #eaecf0; white-space: nowrap; margin: 0em 4em 0em 4em;'
table.insert(boilerplate_lines, '<span style="display: inline-block; float: left; text-align: left; font-weight: normal; font-style: normal; min-width: 4em; padding: 0px; margin: 0px;">')
.. 'padding: 0.25em 0.5em; border: 1px solid white;" colspan="2" | '  
table.insert(boilerplate_lines, (has_navbar and navbar(name, "mini", "") or "") .. '</span>')
.. '<span style="display: inline-block; float: left; text-align: left; font-weight: normal; font-style: normal; min-width: 4em; padding: 0px; margin: 0px;">'
table.insert(boilerplate_lines, '<span style="font-size: 1.05em;">' .. title .. '</span>')
.. (has_navbar and navbar(name, "mini", "") or "") .. '</span>'
table.insert(boilerplate_lines, (is_collapsible and '' or '<span style="display: inline-block; float: right; font-size: 0.8em; width: 5em;">&nbsp;</span>'))
.. '<span style="font-size: 1.05em;">' .. title .. "</span>"
 
.. (is_collapsible and '' or '<span style="display: inline-block; float: right; font-size: 0.8em; width: 5em;">&nbsp;</span>')
-- Then assemble lines, adding the boilerplate among those lines
.. '\n'
local lines = {}
end
table.insert(lines, "|-")
return navbox_title
table.insert(lines, table.concat(boilerplate_lines, ""))
 
return table.concat(lines, "\n")
end
end


-- Navbox title for nested navboxes
-- Navbox title for nested navboxes
--[[
function p.nested_navbox_title(title, is_collapsible)
function p.nested_navbox_title(title, is_collapsible)
local navbox_title = ''
local navbox_title = ''
Line 81: Line 85:
end
end
return navbox_title
return navbox_title
end
]]--
function p.nested_navbox_title(title, is_collapsible)
if not title then return "" end
-- Assemble boilerplate lines separately
local boilerplate_lines = {}
table.insert(boilerplate_lines, '! style="text-align: center; background-color: #eaecf0; white-space: nowrap; margin: 0em 4em 0em 4em; padding: 0.25em 0.5em; border: 1px solid white;" colspan="2" | ')
if is_collapsible then table.insert(boilerplate_lines, '<span style="display: inline-block; float: left; min-width: 4em; padding: 0px; margin: 0px;">&nbsp;</span>') end
table.insert(boilerplate_lines, '<span style="font-size: 0.9em;">' .. title .. '</span>')
-- Then assemble lines, adding the boilerplate among those lines
local lines = {}
table.insert(lines, "|-")
table.insert(lines, table.concat(boilerplate_lines, ""))
return table.concat(lines, "\n")
end
end