|
|
Ligne 12 : |
Ligne 12 : |
| local categoriePaletteInconnue = '[[Catégorie:Modèle Palette - Palette inconnue]]' | | local categoriePaletteInconnue = '[[Catégorie:Modèle Palette - Palette inconnue]]' |
| local categorieTropDePalette = '[[Catégorie:Modèle Palette - Page contenant trop de palettes]]' | | local categorieTropDePalette = '[[Catégorie:Modèle Palette - Page contenant trop de palettes]]' |
| | local categoriePaletteEnDouble = '[[Catégorie:Modèle Palette - Palette affichée en double]]' |
| | | |
| local categories = { } | | local categories = { } |
Ligne 29 : |
Ligne 30 : |
| local nomPalette = mw.text.trim( parentArgs[i] ) | | local nomPalette = mw.text.trim( parentArgs[i] ) |
| return _erreur( 'Erreur : il n’existe pas de modèle {{[[Modèle:Palette %s|Palette %s]]}} [[Aide:Palette de navigation|(aide)]]', nomPalette, nomPalette ) | | return _erreur( 'Erreur : il n’existe pas de modèle {{[[Modèle:Palette %s|Palette %s]]}} [[Aide:Palette de navigation|(aide)]]', nomPalette, nomPalette ) |
| | end |
| | |
| | local function _paletteEnDouble ( i ) |
| | categories.paletteEnDouble = categoriePaletteEnDouble |
| | local nomPalette = mw.text.trim (parentArgs[i] ) |
| | return "" -- inutile d'afficher une erreur visible pour ce cas puisque la mise en page n'est pas cassée |
| end | | end |
| | | |
Ligne 51 : |
Ligne 58 : |
| return _erreur( 'Erreur dans le [[Modèle:Palette]] : trop de palettes (maximum : %s)', maxPalette ) | | return _erreur( 'Erreur dans le [[Modèle:Palette]] : trop de palettes (maximum : %s)', maxPalette ) |
| end | | end |
| | |
| | | |
| local boite = parentArgs['titre boîte déroulante'] or parentArgs['titre boite déroulante'] | | local boite = parentArgs['titre boîte déroulante'] or parentArgs['titre boite déroulante'] |
Ligne 65 : |
Ligne 73 : |
| while parentArgs[i] and i <= maxPalette do | | while parentArgs[i] and i <= maxPalette do |
| if parentArgs[i]:match( '%S' ) then | | if parentArgs[i]:match( '%S' ) then |
| | local j |
| | for j = 1, i - 1 do |
| | if args[i] == args[j] then |
| | wikiTable:insert ( _paletteEnDouble(i)) |
| | end |
| | end |
| if parentArgs[i]:match( '<table class="navbox' ) or parentArgs[i]:match( '{| ?class="navbox' ) then | | if parentArgs[i]:match( '<table class="navbox' ) or parentArgs[i]:match( '{| ?class="navbox' ) then |
| wikiTable:insert( parentArgs[i] ) | | wikiTable:insert( parentArgs[i] ) |
local Palette = { }
function Palette.listePalette( frame )
local args = frame.args
local parentArgs = frame:getParent().args
local wikiTable = { '
\n' }
setmetatable( wikiTable, { __index = table } ) -- permet d'utiliser les fonctions de table comme des méthodes
local palettesVerticales =
local maxPalette = tonumber( args.maxPalette ) or 4
local categoriePaletteInconnue =
local categorieTropDePalette =
local categoriePaletteEnDouble =
local categories = { }
local function _erreur( texte, param, ... )
if param then texte = texte:format( param, ... )
end
local sep = #wikiTable > 1 and '
' or
return sep .. '
' .. texte .. '
\n'
end
local function _pasDePalette()
return _erreur( 'Erreur dans l’utilisation du Modèle:Palette : paramètre obligatoire absent.' )
end
local function _paletteInconnue( i )
categories.paletteInconnue = categoriePaletteInconnue
local nomPalette = mw.text.trim( parentArgs[i] )
return _erreur( 'Erreur : il n’existe pas de modèle {{Palette %s}} (aide)', nomPalette, nomPalette )
end
local function _paletteEnDouble ( i )
categories.paletteEnDouble = categoriePaletteEnDouble
local nomPalette = mw.text.trim (parentArgs[i] )
return "" -- inutile d'afficher une erreur visible pour ce cas puisque la mise en page n'est pas cassée
end
local function _paletteAvecParametres( i )
local argsPalette = { }
for n, v in pairs( parentArgs ) do
if not tonumber(n) then
if n:match( ' ' .. i .. '$' ) then
argsPalette[ n:sub(1, n:len() - 1 - tostring(i):len() ) ] = v
elseif n == 'nocat' .. i then
argsPalette.nocat = v
elseif not argsPalette[n] and n ~= 'stylecorps' then
argsPalette[n] = v
end
end
end
return frame:expandTemplate{ title = 'Palette ' .. mw.text.trim(parentArgs[i]), args = argsPalette }
end
local function _tropDePalettes()
categories.tropDePalette = categorieTropDePalette
return _erreur( 'Erreur dans le Modèle:Palette : trop de palettes (maximum : %s)', maxPalette )
end
local boite = parentArgs['titre boîte déroulante'] or parentArgs['titre boite déroulante']
if boite then
wikiTable[1] = '
\n'
.. '
\n
\n'
end
local i = 1
while parentArgs[i] and i <= maxPalette do
if parentArgs[i]:match( '%S' ) then
local j
for j = 1, i - 1 do
if args[i] == args[j] then
wikiTable:insert ( _paletteEnDouble(i))
end
end
if parentArgs[i]:match( '<table class="navbox' ) or parentArgs[i]:match( '{| ?class="navbox' ) then
wikiTable:insert( parentArgs[i] )
else
local codePalette = args[i]
local testCodePalette = codePalette:lower()
if testCodePalette:match( '^%[%[:modèle:' ) then -- La palette n'existe pas
wikiTable:insert( _paletteInconnue( i ) )
elseif testCodePalette:match( '^palette avec paramètres' ) then -- C'est une palette nécessitant des paramètres nommés
wikiTable:insert( _paletteAvecParametres( i ) )
elseif testCodePalette:match( '^palette verticale avec paramètres' ) then -- C'est une palette verticale nécessitant des paramètres nommés
palettesVerticales = palettesVerticales .. ( _paletteAvecParametres( i ) )
elseif testCodePalette:match( '^palette verticale' ) then -- C'est une palette verticale
palettesVerticales = palettesVerticales .. codePalette:sub( 18 )
else
wikiTable:insert( (codePalette:gsub( '^<div class="navbox_group"', '<div' ) ) )
end
end
end
i = i + 1
end
if i == 1 then
wikiTable:insert( _pasDePalette() )
elseif i > maxPalette and parentArgs[i] and parentArgs[i] ~= then
wikiTable:insert( _tropDePalettes() )
end
if #wikiTable == 1 then
wikiTable[1] = palettesVerticales
else
if boite then
wikiTable:insert( '
' )
end
wikiTable:insert( '
' .. palettesVerticales )
end
if mw.title.getCurrentTitle().namespace == 0 then
for i, v in pairs( categories ) do
wikiTable:insert( v )
end
end
return wikiTable:concat()
end
return Palette