Module:TableGenerator: Difference between revisions
Jump to navigation
Jump to search
Tag: Undo |
m bugfix, was using class instead of class_str in output |
||
(4 intermediate revisions by the same user not shown) | |||
Line 2: | Line 2: | ||
--<table class="wikitable"> | --<table class="wikitable"> | ||
--{{#invoke: TableGenerator | generateHtmlTable | cols=3 | | --{{#invoke: TableGenerator | generateHtmlTable | cols=3 | only_body=true | cell_values=Item 1, Item 20, Item 3, Item 40, Item 5 }} | ||
--</table> | --</table> | ||
Line 12: | Line 12: | ||
local args = frame.args | local args = frame.args | ||
local cols = tonumber(args['cols']) or 3 -- Default number of columns is 3 | local cols = tonumber(args['cols']) or 3 -- Default number of columns is 3 | ||
local | local only_body = args['only_body'] == 'true' -- Check if only_body is set to true | ||
local class = args['class'] | |||
local class_is_statbox = class == 'Statbox_hero' | |||
local cell_values = args['cell_values'] or "" -- Get the cell values argument | local cell_values = args['cell_values'] or "" -- Get the cell values argument | ||
local values = {} -- Table to hold the individual cell values | local values = {} -- Table to hold the individual cell values | ||
Line 24: | Line 26: | ||
local result = '' | local result = '' | ||
if not | if not only_body then | ||
result = result .. '<table class="wikitable">\n' | result = result .. '<table class="wikitable">\n' | ||
end | end | ||
Line 39: | Line 41: | ||
-- If the value contains a " 0 " then it will be colored slightly darker | -- If the value contains a " 0 " then it will be colored slightly darker | ||
local | local class_str = '' | ||
if value:find(" 0[^%.]") then | if (class_is_statbox) then | ||
if value:find(" 0[^%.]") then | |||
end | class_str = ' class="darker"' | ||
end | |||
else | |||
if (class ~= nil) then | |||
class_str = ' class="' .. class .. '"' | |||
end | |||
end | |||
-- Add the value as a table cell with the appropriate class | -- Add the value as a table cell with the appropriate class | ||
result = result .. ' <td' .. | result = result .. ' <td' .. class_str .. '>' .. value .. '</td>\n' | ||
count = count + 1 | count = count + 1 | ||
end | end | ||
Line 54: | Line 62: | ||
end | end | ||
if not | if not only_body then | ||
result = result .. '</table>' | result = result .. '</table>' | ||
end | end |
Latest revision as of 18:33, 21 September 2024
Documentation for this module may be created at Module:TableGenerator/doc
local p = {}
--<table class="wikitable">
--{{#invoke: TableGenerator | generateHtmlTable | cols=3 | only_body=true | cell_values=Item 1, Item 20, Item 3, Item 40, Item 5 }}
--</table>
-- Creates:
-- Item 1, Item 20, Item 3
-- Item 40, Item 5
function p.generateHtmlTable(frame)
-- Get the arguments passed to the template
local args = frame.args
local cols = tonumber(args['cols']) or 3 -- Default number of columns is 3
local only_body = args['only_body'] == 'true' -- Check if only_body is set to true
local class = args['class']
local class_is_statbox = class == 'Statbox_hero'
local cell_values = args['cell_values'] or "" -- Get the cell values argument
local values = {} -- Table to hold the individual cell values
-- Split the cell_values string by commas
for value in cell_values:gmatch("[^,]+") do
table.insert(values, value:match("^%s*(.-)%s*$")) -- Trim whitespace
end
-- Initialize the HTML table structure
local result = ''
if not only_body then
result = result .. '<table class="wikitable">\n'
end
local count = 0
for i, value in ipairs(values) do
-- If it's the start of a new row
if count % cols == 0 then
if count > 0 then
result = result .. ' </tr>\n'
end
result = result .. ' <tr>\n'
end
-- If the value contains a " 0 " then it will be colored slightly darker
local class_str = ''
if (class_is_statbox) then
if value:find(" 0[^%.]") then
class_str = ' class="darker"'
end
else
if (class ~= nil) then
class_str = ' class="' .. class .. '"'
end
end
-- Add the value as a table cell with the appropriate class
result = result .. ' <td' .. class_str .. '>' .. value .. '</td>\n'
count = count + 1
end
-- Close the last row if necessary
if count % cols ~= 0 then
result = result .. ' </tr>\n'
end
if not only_body then
result = result .. '</table>'
end
return result
end
return p