« Module:TableColors » : différence entre les versions
De Nefald
Autres actions
m Avec ou sans tableau |
Auto détection tableau / texte en ligne |
||
Ligne 34 : | Ligne 34 : | ||
} | } | ||
-- Fonction principale unifiée | -- Fonction pour assombrir une couleur (pour la bordure) | ||
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 | |||
-- Détection automatique du contexte (tableau vs texte) | |||
local function isInTableContext(frame) | |||
-- Récupère le wikitext parent | |||
local parent = frame:getParent() | |||
if not parent then return false end | |||
-- Récupère le titre de la page | |||
local title = mw.title.getCurrentTitle() | |||
local content = title:getContent() | |||
if not content then return false end | |||
-- Cherche si le modèle est appelé dans un contexte de tableau | |||
-- On détecte les patterns typiques : {| ... {{Couleur ... |} | |||
local pattern = "%{%|.-%{%{[Cc]ouleur%|.-%}%}.-%|%}" | |||
return content:match(pattern) ~= nil | |||
end | |||
-- Fonction principale unifiée avec auto-détection | |||
function p.cell(frame) | 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 content = args[2 | local content = args[2] or "" | ||
-- Gestion des alias | -- Gestion des alias | ||
Ligne 50 : | Ligne 81 : | ||
colorName = aliases[colorName] or colorName | colorName = aliases[colorName] or colorName | ||
local color = colors[colorName] or colors.light | |||
-- | -- DÉTECTION AUTOMATIQUE AMÉLIORÉE | ||
local useTableMode = false | |||
-- Méthode 1 : Détection par le contenu vide (cellule de tableau) | |||
if mw.text.trim(content) == "" then | |||
useTableMode = true | |||
-- Méthode 2 : Détection par balises HTML typiques de tableaux | |||
elseif content:match("^%s*<code>") or content:match("^%s*'''") then | |||
useTableMode = true | |||
-- Méthode 3 : Contenu très court (probablement un en-tête de tableau) | |||
elseif mw.ustring.len(mw.text.trim(content)) <= 20 and not content:match("%s%s") then | |||
useTableMode = true | |||
-- Méthode 4 : Présence de syntaxe wiki spécifique aux tableaux | |||
elseif content:match("||") or content:match("!!") then | |||
useTableMode = true | |||
end | |||
-- Construction | -- Construction des styles | ||
local | local cellStyle = string.format( | ||
'background-color:%s; color:%s; padding:8px 12px;', | 'background-color:%s; color:%s; padding:8px 12px;', | ||
color.bg, | color.bg, | ||
Ligne 61 : | Ligne 110 : | ||
) | ) | ||
local borderColor = darkenColor(color.bg) | |||
local spanStyle = string.format( | |||
-- | 'background-color:%s; color:%s; padding:6px 12px; border-radius:6px; border:1.5px solid %s; display:inline-block; font-weight:500;', | ||
color.bg, | |||
color.fg, | |||
borderColor | |||
) | |||
-- | -- MODE TABLEAU | ||
if | if useTableMode then | ||
if | if mw.text.trim(content) == "" then | ||
return 'style="' .. | return 'style="' .. cellStyle .. '" | ' | ||
end | end | ||
return 'style="' .. | return 'style="' .. cellStyle .. '" | ' .. content | ||
end | end | ||
-- | -- MODE TEXTE (badge) | ||
if | if mw.text.trim(content) == "" then | ||
return '' | return '' | ||
end | end | ||
return string.format( | return string.format('<span style="%s">%s</span>', spanStyle, content) | ||
end | end | ||
Ligne 95 : | Ligne 138 : | ||
local rows = {} | local rows = {} | ||
local sorted = {} | local sorted = {} | ||
for name, _ in pairs(colors) do | for name, _ in pairs(colors) do | ||
Ligne 102 : | Ligne 144 : | ||
table.sort(sorted) | table.sort(sorted) | ||
for _, name in ipairs(sorted) do | for _, name in ipairs(sorted) do | ||
local color = colors[name] | local color = colors[name] | ||
' | -- Badge exemple | ||
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.bg, | ||
color.fg, | color.fg, | ||
borderColor, | |||
color.label | |||
) | |||
table.insert(rows, string.format( | |||
'|-\n| %s || %s || <code>{{Couleur|%s|Texte}}</code>', | |||
color.label, | color.label, | ||
badge, | |||
name | name | ||
)) | )) | ||
end | end | ||
local wikitext = '{| class="wikitable sortable"\n! Nom !! Aperçu (badge) !! Code\n' | |||
local wikitext = '{| class="wikitable sortable"\n! Nom !! Aperçu !! Code\n' | |||
.. table.concat(rows, '\n') | .. table.concat(rows, '\n') | ||
.. '\n|}' | .. '\n|}' |
Version du 9 octobre 2025 à 07:35
La documentation pour ce module peut être créée à Module:TableColors/doc
local p = {}
-- Palette inspirée de Bootstrap 5 + Citizen
local colors = {
-- Variantes de succès (vert)
success = { bg = "#d1e7dd", fg = "#0f5132", label = "Succès" },
["success-light"] = { bg = "#e8f5e9", fg = "#1b5e20", label = "Succès clair" },
-- Variantes de danger (rouge)
danger = { bg = "#f8d7da", fg = "#842029", label = "Danger" },
["danger-light"] = { bg = "#ffebee", fg = "#c62828", label = "Danger clair" },
-- Variantes d'avertissement (jaune/orange)
warning = { bg = "#fff3cd", fg = "#664d03", label = "Avertissement" },
["warning-light"] = { bg = "#fffde7", fg = "#f57f17", label = "Avertissement clair" },
-- Variantes d'information (bleu)
info = { bg = "#cfe2ff", fg = "#084298", label = "Info" },
["info-light"] = { bg = "#e3f2fd", fg = "#01579b", label = "Info clair" },
-- Variantes neutres
primary = { bg = "#cfe2ff", fg = "#052c65", label = "Primaire" },
secondary = { bg = "#e2e3e5", fg = "#41464b", label = "Secondaire" },
light = { bg = "#f8f9fa", fg = "#495057", label = "Clair" },
dark = { bg = "#ced4da", fg = "#212529", label = "Foncé" },
-- Compatibilité anciens noms
vert = { bg = "#d1e7dd", fg = "#0f5132", label = "Vert" },
rouge = { bg = "#f8d7da", fg = "#842029", label = "Rouge" },
jaune = { bg = "#fff3cd", fg = "#664d03", label = "Jaune" },
rose = { bg = "#f8d7da", fg = "#842029", label = "Rose" },
gris = { bg = "#e2e3e5", fg = "#41464b", label = "Gris" },
bleu = { bg = "#cfe2ff", fg = "#084298", label = "Bleu" },
}
-- Fonction pour assombrir une couleur (pour la bordure)
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
-- Détection automatique du contexte (tableau vs texte)
local function isInTableContext(frame)
-- Récupère le wikitext parent
local parent = frame:getParent()
if not parent then return false end
-- Récupère le titre de la page
local title = mw.title.getCurrentTitle()
local content = title:getContent()
if not content then return false end
-- Cherche si le modèle est appelé dans un contexte de tableau
-- On détecte les patterns typiques : {| ... {{Couleur ... |}
local pattern = "%{%|.-%{%{[Cc]ouleur%|.-%}%}.-%|%}"
return content:match(pattern) ~= nil
end
-- Fonction principale unifiée avec auto-détection
function p.cell(frame)
local args = frame:getParent().args
local colorName = mw.text.trim(args[1] or ""):lower()
local content = args[2] or ""
-- Gestion des alias
local aliases = {
["gris-"] = "info-light",
["gris+"] = "secondary",
["vert-clair"] = "success-light",
["rouge-clair"] = "danger-light",
}
colorName = aliases[colorName] or colorName
local color = colors[colorName] or colors.light
-- DÉTECTION AUTOMATIQUE AMÉLIORÉE
local useTableMode = false
-- Méthode 1 : Détection par le contenu vide (cellule de tableau)
if mw.text.trim(content) == "" then
useTableMode = true
-- Méthode 2 : Détection par balises HTML typiques de tableaux
elseif content:match("^%s*<code>") or content:match("^%s*'''") then
useTableMode = true
-- Méthode 3 : Contenu très court (probablement un en-tête de tableau)
elseif mw.ustring.len(mw.text.trim(content)) <= 20 and not content:match("%s%s") then
useTableMode = true
-- Méthode 4 : Présence de syntaxe wiki spécifique aux tableaux
elseif content:match("||") or content:match("!!") then
useTableMode = true
end
-- Construction des styles
local cellStyle = string.format(
'background-color:%s; color:%s; padding:8px 12px;',
color.bg,
color.fg
)
local borderColor = darkenColor(color.bg)
local spanStyle = string.format(
'background-color:%s; color:%s; padding:6px 12px; border-radius:6px; border:1.5px solid %s; display:inline-block; font-weight:500;',
color.bg,
color.fg,
borderColor
)
-- MODE TABLEAU
if useTableMode then
if mw.text.trim(content) == "" then
return 'style="' .. cellStyle .. '" | '
end
return 'style="' .. cellStyle .. '" | ' .. content
end
-- MODE TEXTE (badge)
if mw.text.trim(content) == "" then
return ''
end
return string.format('<span style="%s">%s</span>', spanStyle, content)
end
-- Fonction pour lister les couleurs disponibles
function p.list(frame)
local rows = {}
local sorted = {}
for name, _ in pairs(colors) do
table.insert(sorted, name)
end
table.sort(sorted)
for _, name in ipairs(sorted) do
local color = colors[name]
-- Badge exemple
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
)
table.insert(rows, string.format(
'|-\n| %s || %s || <code>{{Couleur|%s|Texte}}</code>',
color.label,
badge,
name
))
end
local wikitext = '{| class="wikitable sortable"\n! Nom !! Aperçu (badge) !! Code\n'
.. table.concat(rows, '\n')
.. '\n|}'
return frame:preprocess(wikitext)
end
return p