Module:TableGenerator: Difference between revisions

From Deadlock Wiki
Jump to navigation Jump to search
Sur (talk | contribs)
m onlyBody
Sur (talk | contribs)
m Undo revision 5291 by Sur (talk)
Tag: Undo
 
(24 intermediate revisions by the same user not shown)
Line 1: Line 1:
local p = {}
local p = {}


--{{#invoke: TableGenerator | generateWikiTable | cols=3 | Item 1 | Item 2 | Item 3 | Item 4 | Item 5 }}
--<table class="wikitable">
--creates
--{{#invoke: TableGenerator | generateHtmlTable | cols=3 | onlyBody=true | cell_values=Item 1, Item 20, Item 3, Item 40, Item 5 }}
--Item 1, Item 2, Item 3
--</table>
--Item 4, item 5
 
function p.generateWikiTable(frame)
-- Creates:
-- Item 1, Item 20, Item 3
-- Item 40, Item 5
function p.generateHtmlTable(frame)
     -- Get the arguments passed to the template
     -- Get the arguments passed to the template
     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 onlyBody = args['onlyBody'] == 'true'  -- Check if onlyBody is set to true
    -- Initialize the table structure
     local cell_values = args['cell_values'] or ""  -- Get the cell values argument
     local result = '{| class="wikitable"\n'
    local values = {}  -- Table to hold the individual cell values
   
     local count = 0
    for i, value in ipairs(args) do
        -- If the first argument is 'cols', skip it
        if i > 1 then
            -- If it's the start of a new row
            if count % cols == 0 then
                result = result .. '|-\n'
            end
 
            -- Add the value as a table cell
            result = result .. '| ' .. value .. '\n'
            count = count + 1
        end
    end
      
      
     -- Close any unfilled row
     -- Split the cell_values string by commas
     if count % cols ~= 0 then
     for value in cell_values:gmatch("[^,]+") do
         result = result .. '|-\n'
         table.insert(values, value:match("^%s*(.-)%s*$"))  -- Trim whitespace
     end
     end
    -- Close the table
    result = result .. '|}'
    return result
end
--{{#invoke: TableGenerator | generateHtmlTable | cols=3 | onlyBody=true | Item 1 | Item 2 | Item 3 | Item 4 | Item 5 }}
--creates the <td> and <tr>'s that would create:
--Item 1, Item 2, Item 3
--Item 4, item 5
--, allowing it to be wrapped in a chosen class instead
function p.createHtmlTable(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 onlyBody = args['onlyBody'] == 'true'  -- Check if onlyBody is set to true
      
      
     -- Initialize the HTML table structure
     -- Initialize the HTML table structure
     local result = ''
     local result = ''
 
   
     if not onlyBody then
     if not onlyBody then
         result = result .. '<table class="wikitable">\n'
         result = result .. '<table class="wikitable">\n'
Line 58: Line 29:
      
      
     local count = 0
     local count = 0
     for i, value in ipairs(args) do
     for i, value in ipairs(values) do
         -- If the first argument is 'cols', skip it
         -- If it's the start of a new row
        if i > 1 then
        if count % cols == 0 then
            -- If it's the start of a new row
            if count > 0 then
            if count % cols == 0 then
                 result = result .. '  </tr>\n'
                 result = result .. '  <tr>\n'
             end
             end
            result = result .. '  <tr>\n'
        end


            -- Add the value as a table cell
        -- If the value contains a " 0 " then it will be colored slightly darker
            result = result .. '   <td>' .. value .. '</td>\n'
        local class = ''
            count = count + 1
        if value:find(" 0[^%.]") then
            class = ' class="darker"'
        end


            -- Close the row if we reached the end of a column set
        -- Add the value as a table cell with the appropriate class
            if count % cols == 0 then
        result = result .. '   <td' .. class .. '>' .. value .. '</td>\n'
                result = result .. ' </tr>\n'
         count = count + 1
            end
         end
     end
     end
      
      
     -- Close any unfilled row
     -- Close the last row if necessary
     if count % cols ~= 0 then
     if count % cols ~= 0 then
         result = result .. '  </tr>\n'
         result = result .. '  </tr>\n'

Latest revision as of 04:05, 15 September 2024

Documentation for this module may be created at Module:TableGenerator/doc

local p = {}

--<table class="wikitable">
--{{#invoke: TableGenerator | generateHtmlTable | cols=3 | onlyBody=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 onlyBody = args['onlyBody'] == 'true'  -- Check if onlyBody is set to true
    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 onlyBody 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 = ''
        if value:find(" 0[^%.]") then
            class = ' class="darker"'
        end

        -- Add the value as a table cell with the appropriate class
        result = result .. '    <td' .. class .. '>' .. 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 onlyBody then
        result = result .. '</table>'
    end

    return result
end

return p