Mudanças entre as edições de "Módulo:Gb"
Ir para navegação
Ir para pesquisar
| (35 revisões intermediárias pelo mesmo usuário não estão sendo mostradas) | |||
| Linha 1: | Linha 1: | ||
-- | -- Módulo:BossDisplay (responsivo) | ||
local p = {} | |||
function p.bossInfo(frame) | |||
local args = frame:getParent().args | |||
local function g(k, default) | |||
return mw.text.trim(args[k] or "") ~= "" and args[k] or default | |||
end | |||
local img = g("img", "Placeholder.png") | |||
local nome = g("nome", "Nome do Boss") | |||
local frase = g("frase", "Frase ou lema do boss.") | |||
local hp = g("hp", "???") | |||
local exp = g("exp", "???") | |||
local nivel = g("nivel", "???") | |||
local necessario = g("necessario", "-") | |||
local comum = g("comum", "") | |||
local semiraro = g("semiraro", "") | |||
local raro = g("raro", "") | |||
local muitoRaro = g("muitoraro", "") | |||
---------------------------------------------------- | |||
-- CSS responsivo embutido | |||
---------------------------------------------------- | |||
local css = [[ | |||
]] | |||
local html = mw.html.create() | |||
html:wikitext(css) | |||
local box = html:tag("div") | |||
:addClass("boss-container") | |||
:css{ | |||
background = "#18181b", | |||
["border-radius"] = "12px", | |||
padding = "30px", | |||
color = "#fff", | |||
width = "100%", | |||
margin = "auto", | |||
["font-family"] = "Verdana,sans-serif", | |||
["box-sizing"] = "border-box" | |||
} | |||
---------------------------------------------------- | |||
-- Cabeçalho | |||
---------------------------------------------------- | |||
box:tag("div") | |||
:css{ ["font-size"] = "1.5em", ["font-weight"] = "bold", ["margin-bottom"] = "10px" } | |||
:wikitext("Bosses") | |||
local var = box:tag("div") | |||
:css("margin-bottom", "24px") | |||
var:tag("span") | |||
:css{ | |||
["background-color"] = "#232329", | |||
["border-radius"] = "7px 0 0 7px", | |||
padding = "7px 20px", | |||
["font-size"] = "1em", | |||
color = "#cbcdd7", | |||
["font-weight"] = "600" | |||
} | |||
:wikitext("Mecanica Elite") | |||
var:tag("span") | |||
:css{ | |||
["background-color"] = "#19171c", | |||
["border-radius"] = "0 7px 7px 0", | |||
padding = "7px 20px", | |||
["font-size"] = "1em", | |||
color = "#fff", | |||
["font-weight"] = "600", | |||
border = "2px solid #c7a047", | |||
["border-left"] = "0" | |||
} | |||
:wikitext("Mecanica Hard") | |||
---------------------------------------------------- | |||
-- Corpo principal (responsivo) | |||
---------------------------------------------------- | |||
local main = box:tag("div") | |||
:addClass("boss-main") | |||
:css{ | |||
display = "flex", | |||
gap = "20px", | |||
["align-items"] = "center", | |||
["justify-content"] = "space-between", | |||
["flex-wrap"] = "wrap" | |||
} | |||
main:tag("div") | |||
:addClass("boss-img-box") | |||
:css{ ["flex"] = "none" } | |||
:wikitext(string.format("[[Arquivo:%s|90px]]", img)) | |||
local textBox = main:tag("div") | |||
:css{ ["flex"] = "1", ["min-width"] = "200px" } | |||
textBox:tag("div") | |||
:css{ ["font-size"] = "1.2em", ["font-weight"] = "bold", color = "#e82b2b" } | |||
:wikitext(nome) | |||
textBox:tag("div") | |||
:css{ ["font-size"] = "95%", color = "#eaa85d", ["font-style"] = "italic" } | |||
:wikitext(string.format('"%s"', frase)) | |||
---------------------------------------------------- | |||
-- Stats | |||
---------------------------------------------------- | |||
local stats = main:tag("div") | |||
:addClass("boss-stats") | |||
:css{ | |||
display = "flex", | |||
["flex-direction"] = "column", | |||
["align-items"] = "flex-end", | |||
gap = "6px", | |||
["min-width"] = "160px" | |||
} | |||
local statBox = stats:tag("div") | |||
:css{ | |||
["background-color"] = "#222126", | |||
["border-radius"] = "8px", | |||
padding = "12px 20px", | |||
["min-width"] = "170px" | |||
} | |||
local sline = statBox:tag("div") | |||
:css{ | |||
display = "flex", | |||
["align-items"] = "center", | |||
["justify-content"] = "center", | |||
gap = "16px", | |||
["flex-wrap"] = "wrap" | |||
} | |||
sline:wikitext(string.format('<span style="color:#fb3d3d;font-weight:bold;font-size:1.15em;">❤️ %s</span>', hp)) | |||
sline:wikitext(string.format('<span style="color:#ffe568;font-weight:bold;font-size:1.08em;">💰 %s</span>', exp)) | |||
sline:wikitext(string.format('<span style="color:#6ca8fb;font-weight:bold;font-size:1.04em;">⚔️ %s</span>', nivel)) | |||
stats:tag("div") | |||
:css{ | |||
["margin-top"] = "5px", | |||
["font-size"] = "90%", | |||
color = "#cfccff", | |||
["text-align"] = "right" | |||
} | |||
:wikitext(string.format( | |||
"<b>Necessario:</b> %s ", | |||
necessario, forte, reflete | |||
)) | |||
---------------------------------------------------- | |||
-- | -- Espaço livre para conteúdo customizável do editor | ||
---------------------------------------------------- | |||
local conteudo = box:tag("div") | |||
local | |||
:addClass("boss-custom-content") | |||
:css{ | |||
["margin-top"] = "28px", | |||
background = "#232329", | |||
["border-radius"] = "10px", | |||
padding = "18px", | |||
["min-height"] = "40px" | |||
} | |||
:wikitext(g("conteudo", "")) -- permite o uso de |conteudo= na predefinição | |||
return tostring(html)end | |||
return p | return p | ||
Edição atual tal como às 18h27min de 5 de dezembro de 2025
A documentação para este módulo pode ser criada em Módulo:Gb/doc
-- Módulo:BossDisplay (responsivo)
local p = {}
function p.bossInfo(frame)
local args = frame:getParent().args
local function g(k, default)
return mw.text.trim(args[k] or "") ~= "" and args[k] or default
end
local img = g("img", "Placeholder.png")
local nome = g("nome", "Nome do Boss")
local frase = g("frase", "Frase ou lema do boss.")
local hp = g("hp", "???")
local exp = g("exp", "???")
local nivel = g("nivel", "???")
local necessario = g("necessario", "-")
local comum = g("comum", "")
local semiraro = g("semiraro", "")
local raro = g("raro", "")
local muitoRaro = g("muitoraro", "")
----------------------------------------------------
-- CSS responsivo embutido
----------------------------------------------------
local css = [[
]]
local html = mw.html.create()
html:wikitext(css)
local box = html:tag("div")
:addClass("boss-container")
:css{
background = "#18181b",
["border-radius"] = "12px",
padding = "30px",
color = "#fff",
width = "100%",
margin = "auto",
["font-family"] = "Verdana,sans-serif",
["box-sizing"] = "border-box"
}
----------------------------------------------------
-- Cabeçalho
----------------------------------------------------
box:tag("div")
:css{ ["font-size"] = "1.5em", ["font-weight"] = "bold", ["margin-bottom"] = "10px" }
:wikitext("Bosses")
local var = box:tag("div")
:css("margin-bottom", "24px")
var:tag("span")
:css{
["background-color"] = "#232329",
["border-radius"] = "7px 0 0 7px",
padding = "7px 20px",
["font-size"] = "1em",
color = "#cbcdd7",
["font-weight"] = "600"
}
:wikitext("Mecanica Elite")
var:tag("span")
:css{
["background-color"] = "#19171c",
["border-radius"] = "0 7px 7px 0",
padding = "7px 20px",
["font-size"] = "1em",
color = "#fff",
["font-weight"] = "600",
border = "2px solid #c7a047",
["border-left"] = "0"
}
:wikitext("Mecanica Hard")
----------------------------------------------------
-- Corpo principal (responsivo)
----------------------------------------------------
local main = box:tag("div")
:addClass("boss-main")
:css{
display = "flex",
gap = "20px",
["align-items"] = "center",
["justify-content"] = "space-between",
["flex-wrap"] = "wrap"
}
main:tag("div")
:addClass("boss-img-box")
:css{ ["flex"] = "none" }
:wikitext(string.format("[[Arquivo:%s|90px]]", img))
local textBox = main:tag("div")
:css{ ["flex"] = "1", ["min-width"] = "200px" }
textBox:tag("div")
:css{ ["font-size"] = "1.2em", ["font-weight"] = "bold", color = "#e82b2b" }
:wikitext(nome)
textBox:tag("div")
:css{ ["font-size"] = "95%", color = "#eaa85d", ["font-style"] = "italic" }
:wikitext(string.format('"%s"', frase))
----------------------------------------------------
-- Stats
----------------------------------------------------
local stats = main:tag("div")
:addClass("boss-stats")
:css{
display = "flex",
["flex-direction"] = "column",
["align-items"] = "flex-end",
gap = "6px",
["min-width"] = "160px"
}
local statBox = stats:tag("div")
:css{
["background-color"] = "#222126",
["border-radius"] = "8px",
padding = "12px 20px",
["min-width"] = "170px"
}
local sline = statBox:tag("div")
:css{
display = "flex",
["align-items"] = "center",
["justify-content"] = "center",
gap = "16px",
["flex-wrap"] = "wrap"
}
sline:wikitext(string.format('<span style="color:#fb3d3d;font-weight:bold;font-size:1.15em;">❤️ %s</span>', hp))
sline:wikitext(string.format('<span style="color:#ffe568;font-weight:bold;font-size:1.08em;">💰 %s</span>', exp))
sline:wikitext(string.format('<span style="color:#6ca8fb;font-weight:bold;font-size:1.04em;">⚔️ %s</span>', nivel))
stats:tag("div")
:css{
["margin-top"] = "5px",
["font-size"] = "90%",
color = "#cfccff",
["text-align"] = "right"
}
:wikitext(string.format(
"<b>Necessario:</b> %s ",
necessario, forte, reflete
))
----------------------------------------------------
-- Espaço livre para conteúdo customizável do editor
----------------------------------------------------
local conteudo = box:tag("div")
:addClass("boss-custom-content")
:css{
["margin-top"] = "28px",
background = "#232329",
["border-radius"] = "10px",
padding = "18px",
["min-height"] = "40px"
}
:wikitext(g("conteudo", "")) -- permite o uso de |conteudo= na predefinição
return tostring(html)end
return p