Jump to content

Module:MonsterDrops: Difference between revisions

From Apogea Wiki
Dane (talk | contribs)
Center sprites in table column (via update-page on MediaWiki MCP Server)
Dane (talk | contribs)
Sort drops by rarity ascending (common to legendary) (via update-page on MediaWiki MCP Server)
Line 1: Line 1:
local p = {}
local p = {}
-- Rarity sort order (ascending)
local rarityOrder = {
    common = 1,
    uncommon = 2,
    rare = 3,
    epic = 4,
    legendary = 5
}


-- Get sprite for an item from Cargo, fallback to item name
-- Get sprite for an item from Cargo, fallback to item name
Line 23: Line 32:
     end
     end
     return min .. '-' .. max
     return min .. '-' .. max
end
-- Get rarity sort value
local function getRarityValue(rarity)
    if not rarity then return 99 end
    return rarityOrder[string.lower(rarity)] or 99
end
end


Line 39: Line 54:
         return ''
         return ''
     end
     end
   
    -- Sort by rarity (ascending)
    table.sort(drops, function(a, b)
        return getRarityValue(a.rarity) < getRarityValue(b.rarity)
    end)
      
      
     -- Build table
     -- Build table

Revision as of 00:56, 28 January 2026

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

local p = {}

-- Rarity sort order (ascending)
local rarityOrder = {
    common = 1,
    uncommon = 2,
    rare = 3,
    epic = 4,
    legendary = 5
}

-- Get sprite for an item from Cargo, fallback to item name
local function getItemSprite(itemName)
    local result = mw.ext.cargo.query('Items', 'sprite', {
        where = 'name="' .. itemName .. '"',
        limit = 1
    })
    
    if result and result[1] and result[1].sprite and result[1].sprite ~= '' then
        return result[1].sprite
    end
    return itemName
end

-- Format quantity display
local function formatQuantity(min, max)
    if not min or min == '' then
        return '?'
    end
    if not max or max == '' or min == max then
        return tostring(min)
    end
    return min .. '-' .. max
end

-- Get rarity sort value
local function getRarityValue(rarity)
    if not rarity then return 99 end
    return rarityOrder[string.lower(rarity)] or 99
end

-- Main function to display monster drops
function p.display(frame)
    local args = frame:getParent().args
    local source = args.source or mw.title.getCurrentTitle().text
    local sourceType = args.type or 'Monster'
    
    -- Query ItemSource for drops
    local drops = mw.ext.cargo.query('ItemSource', 'item,rarity,min,max', {
        where = 'source="' .. source .. '" AND source_type="' .. sourceType .. '"'
    })
    
    if not drops or #drops == 0 then
        return ''
    end
    
    -- Sort by rarity (ascending)
    table.sort(drops, function(a, b)
        return getRarityValue(a.rarity) < getRarityValue(b.rarity)
    end)
    
    -- Build table
    local html = {}
    table.insert(html, '{| class="wikitable"')
    table.insert(html, '|-')
    table.insert(html, '! !! Item !! Quantity !! Rarity')
    
    for _, drop in ipairs(drops) do
        local sprite = getItemSprite(drop.item)
        local quantity = formatQuantity(drop.min, drop.max)
        
        table.insert(html, '|-')
        table.insert(html, string.format('| style="text-align:center;" | {{Sprite|%s|x2}}', sprite))
        table.insert(html, string.format('| [[%s]]', drop.item))
        table.insert(html, string.format('| %s', quantity))
        table.insert(html, string.format('| %s', drop.rarity or ''))
    end
    
    table.insert(html, '|}')
    
    return frame:preprocess(table.concat(html, '\n'))
end

return p