Mudanças entre as edições de "Módulo:Teste"
Ir para navegação
Ir para pesquisar
m Etiqueta: Revertido |
m Etiqueta: Revertido |
||
| Linha 4: | Linha 4: | ||
local args = frame:getParent().args | local args = frame:getParent().args | ||
local html = mw.html.create('div') | local html = mw.html.create('div') | ||
local function getVideoURL(filename) | |||
return tostring(mw.uri.fullUrl('Special:FilePath/' .. filename)) | |||
end | |||
local tier = (args.tier or ""):lower() | local tier = (args.tier or ""):lower() | ||
local tierMap = { | |||
bronze = "tier-bronze", | |||
silver = "tier-silver", | |||
gold = "tier-gold", | |||
diamond = "tier-diamond" | |||
} | |||
local tierClass = tierMap[tier] | |||
local box = html:tag('div'):addClass(' | local box = html:tag('div'):addClass('character-box') | ||
if tierClass then | if tierClass then | ||
box:addClass(tierClass) | |||
end | |||
local | -- HEADER | ||
local header = box:tag('div'):addClass('character-header') | |||
local topbar = header:tag('div'):addClass('character-topbar') | |||
local nameBox = topbar:tag('div'):addClass('character-name-box') | |||
local | local medalImg = args.medal or '' | ||
if medalImg ~= '' then | |||
nameBox:wikitext(string.format('[[File:%s|class=topbar-icon|link=|alt=Medal]]', medalImg)) | |||
end | |||
local nameCat = nameBox:tag('div'):addClass('character-name-category') | |||
nameCat:tag('div'):addClass('character-name'):wikitext(args.name or 'Character Name') | |||
local classesDiv = nameCat:tag('div'):addClass('character-classes') | |||
local classString = args.class or '' | |||
for class in mw.text.gsplit(classString, '/', true) do | |||
classesDiv:tag('div'):addClass('character-class'):wikitext(class) | |||
end | |||
header:tag('div'):addClass('topbar-description') | header:tag('div'):addClass('topbar-description') | ||
:wikitext(args.desc) | :wikitext(args.desc) | ||
local tabs = header:tag('div'):addClass(' | local tabs = header:tag('div'):addClass('character-tabs') | ||
tabs:tag('div'):addClass('tab-btn'):attr('data-tab', ' | tabs:tag('div'):addClass('tab-btn'):attr('data-tab', 'weapon'):wikitext('Weapon') | ||
tabs:tag('div'):addClass('tab-btn active'):attr('data-tab', ' | tabs:tag('div'):addClass('tab-btn active'):attr('data-tab', 'skills'):wikitext('Skills') | ||
tabs:tag('div'):addClass('tab-btn'):attr('data-tab', 'skins'):wikitext('Skins') | tabs:tag('div'):addClass('tab-btn'):attr('data-tab', 'skins'):wikitext('Skins') | ||
-- | local artImg = args.image or '' | ||
local | if artImg ~= '' then | ||
local | box:tag('div'):css('text-align', 'center') | ||
local | :wikitext(string.format('[[File:%s|class=character-art|link=|alt=Character art]]', artImg)) | ||
end | |||
-- SKILLS TAB | |||
local skillsTab = box:tag('div'):addClass('tab-content active'):attr('id', 'skills') | |||
local skillIcons = skillsTab:tag('div'):addClass('skill-icons-bar') | |||
local skillsContainer = skillsTab:tag('div'):addClass('skills-container') | |||
local | local skillDetails = skillsContainer:tag('div'):addClass('skills-details') | ||
local | local descriptionContainer = skillDetails:tag('div'):addClass('description-container') | ||
for i = 1, 21 do | for i = 1, 21 do | ||
local name = args['skill' .. i .. '-name'] | |||
if name then | |||
local icon = args['skill' .. i .. '-icon'] or '' | |||
local level = args['skill' .. i .. '-level'] or '' | |||
local desc = args['skill' .. i .. '-desc'] or '' | |||
local atr = args['skill' .. i .. '-atr'] or '' | |||
local rawVideo = args['skill' .. i .. '-video'] or '' | |||
local videoURL = rawVideo ~= '' and getVideoURL(rawVideo) or '' | |||
skillIcons:tag('div') | |||
:addClass('skill-icon') | |||
:attr('data-index', i) | |||
:attr('data-name', name) | |||
:attr('data-desc', desc) | |||
:attr('data-atr', atr) | |||
:attr('data-video', videoURL) | |||
:wikitext(string.format("[[File:%s|class=skill-icon-img|link=]]", icon)) | |||
descriptionContainer:tag('div') | |||
:addClass('skill-description') | |||
:attr('data-index', i) | |||
end | |||
end | |||
skillDetails:done() | |||
skillsContainer:tag('div'):addClass('video-container'):done() | |||
skillsTab:done() | |||
-- SKINS TAB | |||
local skinsTab = box:tag('div'):addClass('tab-content'):attr('id', 'skins') | |||
local cardSkins = skinsTab:tag('div'):addClass('card-skins') | |||
cardSkins:tag('span'):addClass('card-skins-title'):wikitext('SKINS & SPOTLIGHTS') | |||
local wrapper = cardSkins:tag('div'):addClass('skins-carousel-wrapper') | |||
wrapper:tag('div'):addClass('skins-arrow left'):wikitext('«') | |||
local carousel = wrapper:tag('div'):addClass('skins-carousel') | |||
for j = 1, 11 do | |||
local image = args['skin' .. j .. '-image'] | |||
if image then | |||
local banner = args['skin' .. j .. '-banner'] or '' | |||
local tooltip = args['skin' .. j .. '-tooltip'] or '' | |||
local tooltipHtml = tooltip:gsub("'''([^']+)'''", "<b>%1</b>") | |||
tooltipHtml = tooltipHtml:gsub("\n", "<br>") | |||
local skinCard = carousel:tag('div') | |||
:addClass('skin-card tooltipstered') | |||
:attr('data-tooltip', tooltipHtml) | |||
skinCard:tag('div') | |||
:addClass('skins--imageBanner') | |||
:wikitext(string.format("[[File:%s|link=]]", banner)) | |||
:attr('alt', 'banner') | |||
skinCard:tag('div') | |||
:addClass('skins--imageSkin') | |||
:wikitext(string.format("[[File:%s|link=]]", image)) | |||
:attr('alt', 'skin') | |||
end | |||
end | |||
wrapper:tag('div'):addClass('skins-arrow right'):wikitext('»') | |||
return tostring(html) | return tostring(html) | ||
Edição das 17h10min de 8 de agosto de 2025
A documentação para este módulo pode ser criada em Módulo:Teste/doc
local p = {}
function p.generate(frame)
local args = frame:getParent().args
local html = mw.html.create('div')
local function getVideoURL(filename)
return tostring(mw.uri.fullUrl('Special:FilePath/' .. filename))
end
local tier = (args.tier or ""):lower()
local tierMap = {
bronze = "tier-bronze",
silver = "tier-silver",
gold = "tier-gold",
diamond = "tier-diamond"
}
local tierClass = tierMap[tier]
local box = html:tag('div'):addClass('character-box')
if tierClass then
box:addClass(tierClass)
end
-- HEADER
local header = box:tag('div'):addClass('character-header')
local topbar = header:tag('div'):addClass('character-topbar')
local nameBox = topbar:tag('div'):addClass('character-name-box')
local medalImg = args.medal or ''
if medalImg ~= '' then
nameBox:wikitext(string.format('[[File:%s|class=topbar-icon|link=|alt=Medal]]', medalImg))
end
local nameCat = nameBox:tag('div'):addClass('character-name-category')
nameCat:tag('div'):addClass('character-name'):wikitext(args.name or 'Character Name')
local classesDiv = nameCat:tag('div'):addClass('character-classes')
local classString = args.class or ''
for class in mw.text.gsplit(classString, '/', true) do
classesDiv:tag('div'):addClass('character-class'):wikitext(class)
end
header:tag('div'):addClass('topbar-description')
:wikitext(args.desc)
local tabs = header:tag('div'):addClass('character-tabs')
tabs:tag('div'):addClass('tab-btn'):attr('data-tab', 'weapon'):wikitext('Weapon')
tabs:tag('div'):addClass('tab-btn active'):attr('data-tab', 'skills'):wikitext('Skills')
tabs:tag('div'):addClass('tab-btn'):attr('data-tab', 'skins'):wikitext('Skins')
local artImg = args.image or ''
if artImg ~= '' then
box:tag('div'):css('text-align', 'center')
:wikitext(string.format('[[File:%s|class=character-art|link=|alt=Character art]]', artImg))
end
-- SKILLS TAB
local skillsTab = box:tag('div'):addClass('tab-content active'):attr('id', 'skills')
local skillIcons = skillsTab:tag('div'):addClass('skill-icons-bar')
local skillsContainer = skillsTab:tag('div'):addClass('skills-container')
local skillDetails = skillsContainer:tag('div'):addClass('skills-details')
local descriptionContainer = skillDetails:tag('div'):addClass('description-container')
for i = 1, 21 do
local name = args['skill' .. i .. '-name']
if name then
local icon = args['skill' .. i .. '-icon'] or ''
local level = args['skill' .. i .. '-level'] or ''
local desc = args['skill' .. i .. '-desc'] or ''
local atr = args['skill' .. i .. '-atr'] or ''
local rawVideo = args['skill' .. i .. '-video'] or ''
local videoURL = rawVideo ~= '' and getVideoURL(rawVideo) or ''
skillIcons:tag('div')
:addClass('skill-icon')
:attr('data-index', i)
:attr('data-name', name)
:attr('data-desc', desc)
:attr('data-atr', atr)
:attr('data-video', videoURL)
:wikitext(string.format("[[File:%s|class=skill-icon-img|link=]]", icon))
descriptionContainer:tag('div')
:addClass('skill-description')
:attr('data-index', i)
end
end
skillDetails:done()
skillsContainer:tag('div'):addClass('video-container'):done()
skillsTab:done()
-- SKINS TAB
local skinsTab = box:tag('div'):addClass('tab-content'):attr('id', 'skins')
local cardSkins = skinsTab:tag('div'):addClass('card-skins')
cardSkins:tag('span'):addClass('card-skins-title'):wikitext('SKINS & SPOTLIGHTS')
local wrapper = cardSkins:tag('div'):addClass('skins-carousel-wrapper')
wrapper:tag('div'):addClass('skins-arrow left'):wikitext('«')
local carousel = wrapper:tag('div'):addClass('skins-carousel')
for j = 1, 11 do
local image = args['skin' .. j .. '-image']
if image then
local banner = args['skin' .. j .. '-banner'] or ''
local tooltip = args['skin' .. j .. '-tooltip'] or ''
local tooltipHtml = tooltip:gsub("'''([^']+)'''", "<b>%1</b>")
tooltipHtml = tooltipHtml:gsub("\n", "<br>")
local skinCard = carousel:tag('div')
:addClass('skin-card tooltipstered')
:attr('data-tooltip', tooltipHtml)
skinCard:tag('div')
:addClass('skins--imageBanner')
:wikitext(string.format("[[File:%s|link=]]", banner))
:attr('alt', 'banner')
skinCard:tag('div')
:addClass('skins--imageSkin')
:wikitext(string.format("[[File:%s|link=]]", image))
:attr('alt', 'skin')
end
end
wrapper:tag('div'):addClass('skins-arrow right'):wikitext('»')
return tostring(html)
end
return p