Module:CollectionLog: Difference between revisions

From Roat Pkz
Jump to navigation Jump to search
No edit summary
Tag: Reverted
No edit summary
Tag: Reverted
Line 8: Line 8:
     if args.Killcount then
     if args.Killcount then
         table.insert(output, string.format(
         table.insert(output, string.format(
             '<div class="collection-log-killcount">Killcount: %s</div>',  
             '<div class="collection-log-killcount">Killcount: %s</div>',
             mw.text.encode(args.Killcount)
             mw.text.encode(args.Killcount)
         ))
         ))
Line 24: Line 24:
         local qtySuffix = qty > 1 and (" ×" .. qty) or ""
         local qtySuffix = qty > 1 and (" ×" .. qty) or ""


         -- Hover tooltip HTML (pure HTML)
        -- Encode the page name for URL
        local pageUrl = mw.uri.encode(displayName)
 
        -- Image URL path - assuming standard File namespace URL
        local imageUrl = mw.uri.encode('File:' .. itemName .. '.png')
 
         -- Hover tooltip HTML
         local hoverHtml = string.format(
         local hoverHtml = string.format(
             '<span class="hoveritem" style="position: absolute; top: 2.5em; left: 1.8em; z-index: 1;">' ..
             '<span class="hoveritem" style="position: absolute; top: 2.5em; left: 1.8em; z-index: 1;">' ..
                 '<span style="display: block; border: 1px solid black; border-radius: 3px; background-color: #313e59; box-shadow: 0 0 4px black; padding: 5px; margin: 0 0.5em 0.5em 0.5em; white-space: nowrap;" class="hover-info-box">%s%s</span>' ..
                 '<span style="display: block; border: 1px solid black; border-radius: 3px; background-color: #313e59; box-shadow: 0 0 4px black; padding: 5px; margin: 0 0.5em 0.5em 0.5em; white-space: nowrap;" class="hover-info-box">%s%s</span>' ..
             '</span>',
             '</span>',
             displayName, qtySuffix
             mw.text.encode(displayName), qtySuffix
         )
         )


         -- Compose item html with proper link wrapping
         -- Compose the HTML: <a href="/wiki/Page_Name"><img src="/wiki/File:Image.png" ...></a>
        -- Use [[:File:...]] for image, wrapped by [[Page|...]]
         local itemHtml = string.format(
         local itemWikitext = string.format(
             '<div class="collection-log-item %s" style="position: relative;">' ..
             '<div class="collection-log-item %s" style="position: relative;">' ..
                 '<span class="hoverbox hover-info" style="position: relative;">' ..
                 '<span class="hoverbox hover-info" style="position: relative;">' ..
                     '[[%s|[[:File:%s.png|32x32px|alt=%s]]]]' ..
                     '<a href="/wiki/%s" title="%s">' ..
                        '<img src="/wiki/%s" alt="%s" width="32" height="32" />' ..
                    '</a>' ..
                     '%s' ..
                     '%s' ..
                 '</span>',
                 '</span>',
             qty > 0 and 'obtained' or 'missing',
             qty > 0 and 'obtained' or 'missing',
            pageUrl,
             mw.text.encode(displayName),
             mw.text.encode(displayName),
             mw.text.encode(itemName),
             imageUrl,
             mw.text.encode(displayName),
             mw.text.encode(displayName),
             hoverHtml
             hoverHtml
Line 49: Line 57:
         -- Add quantity badge if qty > 1
         -- Add quantity badge if qty > 1
         if qty > 1 then
         if qty > 1 then
             itemWikitext = itemWikitext .. string.format(
             itemHtml = itemHtml .. string.format(
                 '<div class="collection-log-qty-badge">%d</div>', qty
                 '<div class="collection-log-qty-badge">%d</div>', qty
             )
             )
         end
         end


         itemWikitext = itemWikitext .. '</div>'
         itemHtml = itemHtml .. '</div>'


         table.insert(output, itemWikitext)
         table.insert(output, itemHtml)
         i = i + 1
         i = i + 1
     end
     end

Revision as of 07:00, 19 May 2025

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

local p = {}

function p.render(frame)
    local args = frame:getParent().args
    local output = {}

    -- Killcount display
    if args.Killcount then
        table.insert(output, string.format(
            '<div class="collection-log-killcount">Killcount: %s</div>',
            mw.text.encode(args.Killcount)
        ))
    end

    table.insert(output, '<div class="collection-log-grid">')

    local i = 1
    while true do
        local itemName = args['item' .. i]
        if not itemName then break end

        local qty = tonumber(args['qty' .. i]) or 0
        local displayName = itemName:gsub("_", " ")
        local qtySuffix = qty > 1 and (" ×" .. qty) or ""

        -- Encode the page name for URL
        local pageUrl = mw.uri.encode(displayName)

        -- Image URL path - assuming standard File namespace URL
        local imageUrl = mw.uri.encode('File:' .. itemName .. '.png')

        -- Hover tooltip HTML
        local hoverHtml = string.format(
            '<span class="hoveritem" style="position: absolute; top: 2.5em; left: 1.8em; z-index: 1;">' ..
                '<span style="display: block; border: 1px solid black; border-radius: 3px; background-color: #313e59; box-shadow: 0 0 4px black; padding: 5px; margin: 0 0.5em 0.5em 0.5em; white-space: nowrap;" class="hover-info-box">%s%s</span>' ..
            '</span>',
            mw.text.encode(displayName), qtySuffix
        )

        -- Compose the HTML: <a href="/wiki/Page_Name"><img src="/wiki/File:Image.png" ...></a>
        local itemHtml = string.format(
            '<div class="collection-log-item %s" style="position: relative;">' ..
                '<span class="hoverbox hover-info" style="position: relative;">' ..
                    '<a href="/wiki/%s" title="%s">' ..
                        '<img src="/wiki/%s" alt="%s" width="32" height="32" />' ..
                    '</a>' ..
                    '%s' ..
                '</span>',
            qty > 0 and 'obtained' or 'missing',
            pageUrl,
            mw.text.encode(displayName),
            imageUrl,
            mw.text.encode(displayName),
            hoverHtml
        )

        -- Add quantity badge if qty > 1
        if qty > 1 then
            itemHtml = itemHtml .. string.format(
                '<div class="collection-log-qty-badge">%d</div>', qty
            )
        end

        itemHtml = itemHtml .. '</div>'

        table.insert(output, itemHtml)
        i = i + 1
    end

    table.insert(output, '</div>')

    return table.concat(output, '\n')
end

return p