Basculer le menu
Changer de menu des préférences
Basculer le menu personnel
Non connecté(e)
Votre adresse IP sera visible au public si vous faites des modifications.

« Module:TableColors » : différence entre les versions

De Nefald
Hiob (discussion | contributions)
création
 
Hiob (discussion | contributions)
amélioration
 
(7 versions intermédiaires par le même utilisateur non affichées)
Ligne 34 : Ligne 34 :
}
}


-- Fonction principale
-- Fonction pour assombrir une couleur (pour la bordure)
function p.style(frame)
local function darkenColor(hex)
    local r = tonumber(hex:sub(2, 3), 16)
    local g = tonumber(hex:sub(4, 5), 16)
    local b = tonumber(hex:sub(6, 7), 16)
   
    r = math.floor(r * 0.7)
    g = math.floor(g * 0.7)
    b = math.floor(b * 0.7)
   
    return string.format("#%02x%02x%02x", r, g, b)
end
 
-- Fonction principale unifiée avec auto-détection AMÉLIORÉE
function p.cell(frame)
     local args = frame:getParent().args
     local args = frame:getParent().args
     local colorName = mw.text.trim(args[1] or ""):lower()
     local colorName = mw.text.trim(args[1] or ""):lower()
     local customLabel = args[2]
     local content = args[2] or ""
      
      
     -- Gestion des alias
     -- Gestion des alias
Ligne 49 : Ligne 62 :
      
      
     colorName = aliases[colorName] or colorName
     colorName = aliases[colorName] or colorName
    local color = colors[colorName] or colors.light
      
      
     -- Récupération de la couleur
     -- DÉTECTION AUTOMATIQUE STRICTE
     local color = colors[colorName] or colors.light
    local useTableMode = false
    local trimmedContent = mw.text.trim(content)
   
    -- Indicateurs de contexte TABLEAU
    local hasTableSyntax = content:match("%|%|") or content:match("!!") or content:match("%|-")
    local startsWithCode = trimmedContent:match("^<code>")
    local isShortLabel = mw.ustring.len(trimmedContent) <= 20 and not trimmedContent:match("%s%s")
   
    -- Indicateurs de contexte TEXTE (badge inline)
     local hasEmoji = trimmedContent:match("[💡⚠️🔥ℹ️✓✗🎯📌❌✅⭐🎨]")
    local hasBoldWithColon = trimmedContent:match("'''[^']+'''%s*:")
    local hasLongText = mw.ustring.len(trimmedContent) > 40
    local hasPunctuation = trimmedContent:match("[%.%,%;%!%?]") and mw.ustring.len(trimmedContent) > 15
   
    -- DÉCISION : MODE TABLEAU si critères stricts
    if hasTableSyntax or startsWithCode then
        useTableMode = true
    elseif trimmedContent == "" then
        useTableMode = true
    elseif isShortLabel and not hasEmoji and not hasBoldWithColon then
        useTableMode = true
    end
   
    -- FORCER MODE TEXTE si indicateurs clairs
    if hasEmoji or hasBoldWithColon or hasLongText or hasPunctuation then
        useTableMode = false
    end
      
      
     -- Construction du style avec classes CSS
     -- Construction des styles
     local style = string.format(
     local cellStyle = string.format(
         'class="table-color-cell table-color-%s" style="background-color: %s; color: %s"',
         'background-color:%s; color:%s; padding:8px 12px;',
        colorName:gsub("%W", "-"),
         color.bg,
         color.bg,
         color.fg
         color.fg
     )
     )
      
      
     -- Ajout du label si fourni
     local borderColor = darkenColor(color.bg)
     local label = customLabel and mw.text.trim(customLabel) or ""
     local spanStyle = string.format(
     if label ~= "" then
        'background-color:%s; color:%s; padding:6px 12px; border-radius:6px; border:1.5px solid %s; display:inline-block; font-weight:500;',
         return style .. ' | ' .. label
        color.bg,
     else
        color.fg,
         return style
        borderColor
    )
      
    -- MODE TABLEAU
    if useTableMode then
        if trimmedContent == "" then
            return 'style="' .. cellStyle .. '" | '
        end
         return 'style="' .. cellStyle .. '" | ' .. content
    end
   
    -- MODE TEXTE (badge)
     if trimmedContent == "" then
         return ''
     end
     end
   
    return string.format('<span style="%s">%s</span>', spanStyle, content)
end
end


-- Fonction pour lister les couleurs disponibles
-- Fonction pour lister les couleurs disponibles
function p.list(frame)
function p.list(frame)
     local output = '{| class="wikitable sortable"\n! Nom !! Aperçu !! Code\n'
     local rows = {}
      
      
     local sorted = {}
     local sorted = {}
Ligne 82 : Ligne 136 :
     for _, name in ipairs(sorted) do
     for _, name in ipairs(sorted) do
         local color = colors[name]
         local color = colors[name]
         output = output .. string.format(
          
             '|-\n| %s || style="background:%s; color:%s; padding:5px 10px;" | %s || <code>{{Couleur|%s}}</code>\n',
        -- Badge exemple
             color.label,
        local borderColor = darkenColor(color.bg)
        local badge = string.format(
             '<span style="background-color:%s; color:%s; padding:6px 12px; border-radius:6px; border:1.5px solid %s; display:inline-block; font-weight:500;">%s</span>',
            color.bg,
            color.fg,
            borderColor,
             color.label
        )
       
        -- Cellule exemple
        local cell = string.format(
            'style="background-color:%s; color:%s; padding:8px 12px;" | %s',
             color.bg,
             color.bg,
             color.fg,
             color.fg,
            color.label
        )
       
        table.insert(rows, string.format(
            '|-\n| %s || %s || %s || <code>{{Couleur|%s|...}}</code>',
             color.label,
             color.label,
            badge,
            cell,
             name
             name
         )
         ))
     end
     end
      
      
     return output .. '|}'
     local wikitext = '{| class="wikitable sortable"\n! Nom !! Badge (texte) !! Cellule (tableau) !! Code\n'
        .. table.concat(rows, '\n')
        .. '\n|}'
   
    return frame:preprocess(wikitext)
end
end


return p
return p