Mudanças entre as edições de "Módulo:Gb"

De Wiki Gla
Ir para navegação Ir para pesquisar
 
(33 revisões intermediárias pelo mesmo usuário não estão sendo mostradas)
Linha 1: Linha 1:
-- Módulo:BossDisplay
-- Módulo:BossDisplay (responsivo)
 
local p = {}
local p = {}


Linha 6: Linha 7:


     local function g(k, default)
     local function g(k, default)
         local v = mw.text.trim(args[k] or "")
         return mw.text.trim(args[k] or "") ~= "" and args[k] or default
        return v ~= "" and v or default
     end
     end


     -- Dados gerais
     local img        = g("img",        "Placeholder.png")
     local nome1     = g("nome1", "Forma 1")
    local nome      = g("nome",      "Nome do Boss")
     local nome2      = g("nome2", "Forma 2")
    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 img        = g("img", "Placeholder.png")
     local html = mw.html.create()
    local nome      = g("nome", "Nome do Boss")
    local frase      = g("frase", "Frase ou lema do boss.")


     local hp        = g("hp", "???")
     html:wikitext(css)
    local exp        = g("exp", "???")
    local nivel      = g("nivel", "???")


     local necessario = g("necessario", "-")
     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"
    }


     -- Loot (agora 3 categorias)
     ----------------------------------------------------
    local dropNormal = g("normal", "")
    -- Cabeçalho
    local dropElite  = g("elite", "")
    ----------------------------------------------------
    local dropHard  = g("hard", "")
    box:tag("div")
        :css{ ["font-size"] = "1.5em", ["font-weight"] = "bold", ["margin-bottom"] = "10px" }
        :wikitext("Bosses")


    -- Montagem HTML
     local var = box:tag("div")
     local html = mw.html.create("div")
        :css("margin-bottom", "24px")
    html:addClass("bossbox")
    html:wikitext([[
<style>
.bossbox {
    background:#18181b;
    border-radius:12px;
    padding:20px;
    color:#fff;
    max-width:700px;
    margin:auto;
    font-family:Verdana,sans-serif;
}
.boss-tabs {
    display:flex;
    gap:6px;
    margin-bottom:15px;
}
.boss-tab {
    padding:7px 18px;
    border-radius:7px;
    background:#232329;
    color:#ccc;
    font-weight:600;
    text-decoration:none;
}
.boss-tab.active {
    background:#19171c;
    border:2px solid #c7a047;
    color:#fff;
}
.boss-main {
    display:flex;
    gap:15px;
    flex-wrap:wrap;
}
.boss-left img {
    border-radius:8px;
}
.boss-stats-box {
    background:#222126;
    border-radius:8px;
    padding:12px 20px;
    margin-top:6px;
}
.boss-loot {
    background:#232329;
    border-radius:10px;
    padding:18px;
    margin-top:20px;
}
@media(max-width:640px){
    .boss-main{flex-direction:column;}
}
</style>
]])


     -- SISTEMA DE ABAS (sem JS)
     var:tag("span")
    html:wikitext('<div class="boss-tabs">')
        :css{
    html:wikitext(string.format('<a href="#form1" class="boss-tab"> %s </a>', nome1))
            ["background-color"] = "#232329",
    html:wikitext(string.format('<a href="#form2" class="boss-tab"> %s </a>', nome2))
            ["border-radius"] = "7px 0 0 7px",
    html:wikitext('</div>')
            padding = "7px 20px",
            ["font-size"] = "1em",
            color = "#cbcdd7",
            ["font-weight"] = "600"
        }
        :wikitext("Mecanica Elite")


     -- CONTAINER PRINCIPAL
     var:tag("span")
    local main = html:tag("div"):addClass("boss-main")
        :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")


     -- IMAGEM
     ----------------------------------------------------
     main:tag("div"):addClass("boss-left")
    -- Corpo principal (responsivo)
         :wikitext(string.format("[[Arquivo:%s|120px]]", img))
    ----------------------------------------------------
     local main = box:tag("div")
        :addClass("boss-main")
         :css{
            display = "flex",
            gap = "20px",
            ["align-items"] = "center",
            ["justify-content"] = "space-between",
            ["flex-wrap"] = "wrap"
        }


     -- DADOS DO BOSS
     main:tag("div")
    local info = main:tag("div")
        :addClass("boss-img-box")
        :css{ ["flex"] = "none" }
        :wikitext(string.format("[[Arquivo:%s|90px]]", img))


     info:tag("div")
     local textBox = main:tag("div")
         :css{["font-size"]="1.4em",["font-weight"]="bold",color="#e82b2b"}
        :css{ ["flex"] = "1", ["min-width"] = "200px" }
 
    textBox:tag("div")
         :css{ ["font-size"] = "1.2em", ["font-weight"] = "bold", color = "#e82b2b" }
         :wikitext(nome)
         :wikitext(nome)


     info:tag("div")
     textBox:tag("div")
         :css{["font-size"]="95%",color="#eaa85d",["font-style"]="italic"}
         :css{ ["font-size"] = "95%", color = "#eaa85d", ["font-style"] = "italic" }
         :wikitext('"'..frase..'"')
         :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;">&#x2764;&#xFE0F; %s</span>', hp))
    sline:wikitext(string.format('<span style="color:#ffe568;font-weight:bold;font-size:1.08em;">&#x1F4B0; %s</span>', exp))
    sline:wikitext(string.format('<span style="color:#6ca8fb;font-weight:bold;font-size:1.04em;">&#x2694;&#xFE0F; %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 &nbsp;&nbsp; ",
            necessario, forte, reflete
        ))
 
    ----------------------------------------------------
 
    -- Espaço livre para conteúdo customizável do editor
 
    ----------------------------------------------------
 
    local conteudo = box:tag("div")
 
        :addClass("boss-custom-content")


    -- STATS
         :css{
    local statbox = info:tag("div"):addClass("boss-stats-box")
    statbox:wikitext(string.format(
         '<span style="color:#fb3d3d;font-weight:bold;">❤️ %s</span> &nbsp;&nbsp; ' ..
        '<span style="color:#ffe568;font-weight:bold;">💰 %s</span> &nbsp;&nbsp; ' ..
        '<span style="color:#6ca8fb;font-weight:bold;">⚔️ %s</span>',
        hp, exp, nivel
    ))


    -- NECESSARIO
            ["margin-top"] = "28px",
    info:tag("div")
 
        :css{["margin-top"]="8px",["font-size"]="90%",color="#cfccff"}
            background = "#232329",
         :wikitext('<b>Necessário:</b> ' .. necessario)
 
            ["border-radius"] = "10px",
 
            padding = "18px",
 
            ["min-height"] = "40px"
 
        }
 
         :wikitext(g("conteudo", "")) -- permite o uso de |conteudo= na predefinição


    -- LOOT TABLE
    local loot = html:tag("div"):addClass("boss-loot")
    loot:tag("div")
        :css{["font-size"]="1.2em","margin-bottom","10px",color="#f3e8bb"}
        :wikitext("Drops")


    local function addRow(title, color, content)
        if content ~= "" then
            loot:tag("div")
                :css{color=color,["margin-top"]="6px"}
                :wikitext(string.format("<b>%s</b>: %s", title, content))
        end
    end


    addRow("Normal", "#f3e8bb", dropNormal)
    addRow("Elite",  "#aeccff", dropElite)
    addRow("Hard",  "#f9538f", dropHard)


     return tostring(html)
     return tostring(html)end
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;">&#x2764;&#xFE0F; %s</span>', hp))
    sline:wikitext(string.format('<span style="color:#ffe568;font-weight:bold;font-size:1.08em;">&#x1F4B0; %s</span>', exp))
    sline:wikitext(string.format('<span style="color:#6ca8fb;font-weight:bold;font-size:1.04em;">&#x2694;&#xFE0F; %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 &nbsp;&nbsp; ",
            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