Module:SkillResources

From August Wiki
Revision as of 00:24, 10 March 2025 by Bark (talk | contribs)
Jump to navigation Jump to search

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

-- Module:SkillResources
local p = {}
local rarityStyles = {
    Always = { 'table-bg-blue', 1 },
    Common = { 'table-bg-green', 16 },
    Uncommon = { 'table-bg-yellow', 64 },
    Rare = { 'table-bg-orange', 256 },
    ['Very rare'] = { 'table-bg-red', 1024 },
}

-- Main function to generate the item source table(s)
function p.main(frame)
    local args = frame.args
    local html = ""
    local tableCount = tonumber(args['tableCount'] or '1')
    
    -- Process each table
    for t = 1, tableCount do
        -- Start building the table HTML
        html = html .. [[
<table class="wikitable sortable filterable item-drops align-center-2 align-center-3 align-left-4 autosort=3,a jquery-tablesorter rsw-dropsline-hidealch">
  <tr>
    <th class="drop-disp-btn btn-first headerSort" tabindex="0" role="columnheader button" title="Sort ascending" colspan="5">Item</th>
    <th class="headerSort" tabindex="0" role="columnheader button" title="Sort ascending">Level</th>
    <th class="drops-rarity-header headerSort headerSortUp" tabindex="0" role="columnheader button" title="Sort ascending">Materials</th>
  </tr>
]]
        -- Table title if provided
        local tableTitle = args['tableTitle' .. t]
        if tableTitle and tableTitle ~= '' then
            html = html .. '  <tr><th colspan="7">' .. tableTitle .. '</th></tr>\n'
        end
        
        -- Generate rows dynamically for this table
        local index = 1
        while args['item' .. t .. '_' .. index] do
            -- Get parameters for this item
            local item = args['item' .. t .. '_' .. index] or ''
            local image = args['image' .. t .. '_' .. index] or ''
            local level = args['level' .. t .. '_' .. index] or ''
            local skill = args['skill' .. t .. '_' .. index] or ''
            local skillClass = ''

            -- Check for "N/A" level
            if skill:upper() == 'N/A' then
                skillClass = 'table-na'
            end
            
            -- Build the row HTML
            html = html .. '  <tr>\n'
            
            -- Item cell with image and name combined
            if image and image ~= '' then
              html = html .. '<td colspan="1">'
              html = html .. ' [[File:' .. image .. '|center|32px]]'
              html = html .. '</td>\n'
            end
            html = html .. '    <td colspan="4">'
            html = html .. '[[' .. item .. ']]'
            html = html .. '</td>\n'
                
            -- Level cell with skill information
            html = html .. '    <td class="plainlist ' .. skillClass ..'" style="text-align:center">\n'
            html = html .. '        <ul class="skills-list">\n'
            if skill == 'N/A' then
                html = html .. '            <li>N/A</li>\n'
            elseif skill ~= '' then
                html = html .. '            <li>[[File:' .. skill .. '_icon.png|20px]] ' .. level .. '</li>\n'
            end
            html = html .. '        </ul>\n'
            html = html .. '    </td>\n'
            
            -- Materials cell
            html = html .. '    <td data-sort-value="1" class="plainlist">\n'
            html = html .. '        <ul class="products-materials">\n'
            
            -- Add materials list (up to 7 materials)
            for i = 1, 7 do
                local material = args['material' .. i .. '_' .. t .. '_' .. index] or ''
                local quantity = args['quantity' .. i .. '_' .. t .. '_' .. index] or ''
                
                if material ~= '' and quantity ~= '' then
                    html = html .. '            <li>' .. quantity .. ' × ' .. material .. '</li>\n'
                end
            end
            
            html = html .. '        </ul>\n'
            html = html .. '    </td>\n'
            html = html .. '  </tr>\n'
            
            -- Move to next index
            index = index + 1
        end
        
        -- Close the table
        html = html .. '</table>\n'
        -- Add some spacing between tables if more than one
        if t < tableCount then
            html = html .. '<br/>\n'
        end
    end
    
    return html
end

-- Function to render HTML from template-style parameters
function p.render(frame)
    -- Get all arguments from parent template
    local parentArgs = frame:getParent().args
    return p.main({args = parentArgs})
end

return p