Documentation for this module may be created at Module:Card/doc
local p = {}
local validTypes = {
default = true,
primary = true,
success = true,
warning = true,
destructive = true,
spacer = true,
}
function p.main(frame)
local args = frame:getParent().args
return p._main(args)
end
function p._main(args)
local cardType = args.type or 'default'
local icon = args.icon or ''
local title = args.title or ''
local content = args.content or ''
local footer = args.footer or ''
local link = args.link or ''
if not validTypes[cardType] then
cardType = 'default'
end
if cardType == 'spacer' then
return tostring(
mw.html.create('div')
:addClass('vh-card')
:css{
visibility = 'hidden',
height = '100%', -- Full height
minHeight = '200px', -- Ensure it takes space
border = 'none',
boxShadow = 'none',
background = 'transparent',
padding = '0',
margin = '0',
}
)
end
-- Build the card HTML
local html = mw.html.create('div')
:addClass('vh-card')
:addClass('vh-card--' .. cardType)
-- Add header if title or icon exists
if title ~= '' or icon ~= '' then
local header = html:tag('div')
:addClass('vh-card-header')
if icon ~= '' then
header:tag('span')
:addClass('vh-card-icon')
:wikitext(icon)
end
if title ~= '' then
local titleElement = header:tag('h3')
:addClass('vh-card-title')
if link ~= '' then
titleElement:wikitext('[[' .. link .. '|' .. title .. ']]')
else
titleElement:wikitext(title)
end
end
end
-- Add content
if content ~= '' then
html:tag('div')
:addClass('vh-card-content')
:wikitext(content)
end
-- Add footer if exists
if footer ~= '' then
html:tag('div')
:addClass('vh-card-footer')
:wikitext(footer)
end
return tostring(html)
end
function p.group(frame)
local args = frame:getParent().args
local content = args.content or args[1] or ''
local html = mw.html.create('div')
:addClass('vh-card-group')
:wikitext(content)
return tostring(html)
end
function p.quickLink(frame)
local args = frame:getParent().args
local icon = args.icon or ''
local title = args.title or ''
local link = args.link or ''
local description = args.description or ''
local html = mw.html.create('div')
:addClass('vh-quick-link-card')
if icon ~= '' then
html:tag('div')
:addClass('vh-quick-link-icon')
:wikitext(icon)
end
if title ~= '' then
local titleDiv = html:tag('div')
:addClass('vh-quick-link-title')
if link ~= '' then
titleDiv:wikitext('[[' .. link .. '|' .. title .. ']]')
else
titleDiv:wikitext(title)
end
end
if description ~= '' then
html:tag('div')
:addClass('vh-quick-link-desc')
:wikitext(description)
end
return tostring(html)
end
return p