Module:Navbox: Difference between revisions
Jump to navigation
Jump to search
m fixed reversed logic for navbox title |
implement navbox nesting; some cleanup |
||
| Line 5: | Line 5: | ||
-- Navbox row | -- Navbox row | ||
-- The <td> cell has a div that sets padding for row content; this is omitted if | |||
-- the row content is a child navbox. | |||
function p.navbox_row(row_content, is_row_child_navbox) | function p.navbox_row(row_content, is_row_child_navbox) | ||
local row_content = row_content or { "Header", "Content" } | local row_content = row_content or { "Header", "Content" } | ||
| Line 12: | Line 14: | ||
if #row_content == 1 then | if #row_content == 1 then | ||
-- Headerless row | -- Headerless row | ||
row = row | if is_row_child_navbox then | ||
.. '<td style="width:5%; text-align:center; background-color:#eaecf0; white-space:nowrap; padding:0em; border:1px solid white" colspan="2">\n' | -- Row data is a child navbox | ||
row = row | |||
.. '<td style="width:5%; text-align:center; background-color:#eaecf0; white-space:nowrap; padding:0em; border:1px solid white" colspan="2">\n' | |||
.. row_content[1] | |||
.. '</td>\n' | |||
else | |||
-- Row data is normal data | |||
row = row | |||
.. '<td style="width:5%; text-align:center; background-color:#eaecf0; white-space:nowrap; padding:0em; border:1px solid white" colspan="2">\n' | |||
.. '<div style="padding:0.25em 0.5em">' .. row_content[1] .. '</div>\n' | |||
.. '</td>\n' | |||
end | |||
elseif #row_content == 2 then | elseif #row_content == 2 then | ||
-- Simple row with header and data | -- Simple row with header and data | ||
row = row | if is_row_child_navbox then | ||
row = row | |||
.. '<th style="width:5%; text-align:right; background-color:#eaecf0; white-space:nowrap; padding:0.25em 0.5em; border:1px solid white">' .. row_content[1] .. '</th>\n' | .. '<th style="width:5%; text-align:right; background-color:#eaecf0; white-space:nowrap; padding:0.25em 0.5em; border:1px solid white">' .. row_content[1] .. '</th>\n' | ||
.. '<td style="padding:0em">\n' | .. '<td style="padding:0em">\n' | ||
.. row_content[2] | |||
.. '</td>\n' | .. '</td>\n' | ||
else | |||
row = row | |||
.. '<th style="width:5%; text-align:right; background-color:#eaecf0; white-space:nowrap; padding:0.25em 0.5em; border:1px solid white">' .. row_content[1] .. '</th>\n' | |||
.. '<td style="padding:0em">\n' | |||
.. '<div style="padding:0.25em 0.5em">' .. row_content[2] .. '</div>\n' | |||
.. '</td>\n' | |||
end | |||
end | end | ||
local row = row .. '</tr>\n' | local row = row .. '</tr>\n' | ||
| Line 30: | Line 49: | ||
-- Navbox title | -- Navbox title | ||
function p.navbox_title(title, is_collapsible, is_collapsed | -- A title is added if it's provided. | ||
-- Child navboxes used for subcategories don't need a title or collapse options. | |||
function p.navbox_title(title, is_collapsible, is_collapsed) | |||
local is_collapsible = is_collapsible or true -- Not implemented | local is_collapsible = is_collapsible or true -- Not implemented | ||
local is_collapsed = is_collapsed or true -- Not working? | local is_collapsed = is_collapsed or true -- Not working? | ||
local navbox_title = '' | local navbox_title = '' | ||
if | if title == nil then | ||
navbox_title = '<table style="width:100%; border-spacing:0px">\n' | navbox_title = '<table style="width:100%; border-spacing:0px">\n' | ||
else | else | ||
| Line 75: | Line 94: | ||
-- Navbox to be #invoke'd | -- Navbox to be #invoke'd | ||
-- Wrapper function for template-based navboxes | |||
function p.navbox(frame) | function p.navbox(frame) | ||
local args = getArgs(frame) | local args = getArgs(frame) | ||
-- Preprocess individual entries for, headers, data, and is-row-child into | -- Preprocess individual entries for, headers, data, and is-row-child into | ||
Revision as of 10:39, 23 November 2024
- This module implements a metatemplate, and may be invoked by templates using its corresponding template Template:Navbox, or used directly from other modules.
Module:Navbox is a module that implements the {{Navbox}} template. Navbox templates can be made by using the template or by calling the _navbox function from another module.
On templates, you can create a navbox by using {{Navbox}}, which calls this module's wrapper function.
local navbox = require("Module:Navbox")._navbox to create a navbox.
| Introspection summary for Module:Navbox | ||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
| |||||||||||||||||||||
No function descriptions were provided. The Lua code may have further information.
-- Page is following provisonal style guide: User:Ganaram_inukshuk/Provisional_style_guide_for_Lua
-- Loosely modeled off of Runescape Wiki's navbox, not Wikipedia's
local getArgs = require('Module:Arguments').getArgs
local p = {}
-- Navbox row
-- The <td> cell has a div that sets padding for row content; this is omitted if
-- the row content is a child navbox.
function p.navbox_row(row_content, is_row_child_navbox)
local row_content = row_content or { "Header", "Content" }
local is_row_child_navbox = is_row_child_navbox or false -- Not implemented
local row = '<tr>\n'
if #row_content == 1 then
-- Headerless row
if is_row_child_navbox then
-- Row data is a child navbox
row = row
.. '<td style="width:5%; text-align:center; background-color:#eaecf0; white-space:nowrap; padding:0em; border:1px solid white" colspan="2">\n'
.. row_content[1]
.. '</td>\n'
else
-- Row data is normal data
row = row
.. '<td style="width:5%; text-align:center; background-color:#eaecf0; white-space:nowrap; padding:0em; border:1px solid white" colspan="2">\n'
.. '<div style="padding:0.25em 0.5em">' .. row_content[1] .. '</div>\n'
.. '</td>\n'
end
elseif #row_content == 2 then
-- Simple row with header and data
if is_row_child_navbox then
row = row
.. '<th style="width:5%; text-align:right; background-color:#eaecf0; white-space:nowrap; padding:0.25em 0.5em; border:1px solid white">' .. row_content[1] .. '</th>\n'
.. '<td style="padding:0em">\n'
.. row_content[2]
.. '</td>\n'
else
row = row
.. '<th style="width:5%; text-align:right; background-color:#eaecf0; white-space:nowrap; padding:0.25em 0.5em; border:1px solid white">' .. row_content[1] .. '</th>\n'
.. '<td style="padding:0em">\n'
.. '<div style="padding:0.25em 0.5em">' .. row_content[2] .. '</div>\n'
.. '</td>\n'
end
end
local row = row .. '</tr>\n'
return row
end
-- Navbox title
-- A title is added if it's provided.
-- Child navboxes used for subcategories don't need a title or collapse options.
function p.navbox_title(title, is_collapsible, is_collapsed)
local is_collapsible = is_collapsible or true -- Not implemented
local is_collapsed = is_collapsed or true -- Not working?
local navbox_title = ''
if title == nil then
navbox_title = '<table style="width:100%; border-spacing:0px">\n'
else
navbox_title = navbox_title
.. '<div class="wikitable">'
.. '<table class="mw-collapsible' .. (is_collapsed and ' mw-collapsed ' or '') .. 'nowraplinks" style="width: 100%; border-spacing:0px">\n'
.. '<tr>\n'
.. '<th style="width:5%; text-align:center; background-color:#eaecf0; white-space:nowrap; padding:0.25em 0.5em; border:1px solid white" colspan="2"><b>' .. title .. '</b></th>\n'
.. '</tr>\n'
end
return navbox_title
end
-- Navbox to be called by other modules; also called by wrapper function
function p._navbox(args)
local title = args["Title"]
local is_child_navbox = args["Is Child Navbox"]
local rows = args["Rows"]
local row_is_subtable = args["Is Row Child Navbox"] -- Not implemented
local is_collapsible = args["Is Collapsible"] -- Not implemented
local is_collapsed = args["Is Collapsible"] -- Not working?
-- Start of table
local navbox = p.navbox_title(title, is_collapsible, is_collapsed, is_subtable)
for i = 1, #rows do
navbox = navbox .. p.navbox_row(rows[i])
end
navbox = navbox
.. '</table>\n'
.. '</div>'
return navbox
end
-- Navbox to be #invoke'd
-- Wrapper function for template-based navboxes
function p.navbox(frame)
local args = getArgs(frame)
-- Preprocess individual entries for, headers, data, and is-row-child into
-- two separate tables.
-- Both the Wikipedia and RsWiki navboxes go up to 20 rows so follow that
local rows = {}
local is_row_child_navbox = {}
for i = 1, 20 do
local row = {}
local header = args["Header " .. i]
local data = args["Data " .. i]
local is_child_navbox = args["Is Row Child Navbox" .. i]
if header ~= nil and data ~= nil then
-- If there's both a header data, add both
table.insert(row, header)
table.insert(row, data)
elseif header == nil and data ~= nil then
-- Headerless row
table.insert(row, data)
elseif header ~= nil and data == nil then
-- Dataless row with header; this is allowed
table.insert(row, header)
table.insert(row, "")
end
if #row >= 1 then
table.insert(rows, row)
end
if is_child_navbox ~= nil then
table.insert(is_row_child_navbox, is_child_navbox)
end
args["Header " .. i] = nil
args["Data " .. i] = nil
args["Is Row Child Navbox" .. i] = nil
end
args["Rows"] = rows
args["Is Row Child Navbox"] = is_row_child_navbox
return p._navbox(args)
end
return p