Module:CollectionLog: Difference between revisions
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 | -- 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 | -- Compose the HTML: <a href="/wiki/Page_Name"><img src="/wiki/File:Image.png" ...></a> | ||
local itemHtml = string.format( | |||
local | |||
'<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;">' .. | ||
' | '<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), | ||
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 | ||
itemHtml = itemHtml .. string.format( | |||
'<div class="collection-log-qty-badge">%d</div>', qty | '<div class="collection-log-qty-badge">%d</div>', qty | ||
) | ) | ||
end | end | ||
itemHtml = itemHtml .. '</div>' | |||
table.insert(output, | 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