Module:Palette
La documentation pour ce module peut être créée à Module:Palette/doc
local Palette = { } local function paletteAvecParametre( i, args ) end function Palette.listePalette( frame ) local args = frame.args local parentArgs = frame:getParent().args local wikiTable = { '<div class="navbox_group" style="clear:both;">\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 = '[[Catégorie:Modèle Palette - Palette inconnue]]' local categorieTropDePalette = '[[Catégorie:Modèle Palette - Page contenant trop de palettes]]' local categories = { } local function _erreur( texte, param, ... ) if param then texte = texte:format( param, ... ) end local sep = #wikiTable > 1 and '<hr>' or '' return sep .. '<p><strong class="error" style="padding-left:.5em;">' .. texte .. '</strong></p>\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 return _erreur( 'Erreur : il n’existe pas de modèle {{[[Modèle:Palette %s|Palette %s]]}} [[Aide:Palette de navigation|(aide)]]', parentArgs[i], parentArgs[i] ) end local function _paletteAvecParametres( i ) local argsPalette = { } for n, v in pairs( parentArgs ) do if not tonumber(n) then argsPalette[n] = v if n:match( i .. '$' ) then argsPalette[ n:sub(0 - #tostring(i) ) ] = v elseif not argsPalette[n] then argsPalette[n] = v end end end return frame:expandTemplate{ title = 'Palette ' .. 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 i = 1 while parentArgs[i] and parentArgs[i] ~= '' and i <= maxPalette do local codePalette = args[i] local testCodePalette = codePalette:sub(1, 25):lower() if testCodePalette:match( '^palette verticale' ) then -- C'est une palette verticale palettesVerticales = palettesVerticales .. codePalette:sub( 18 ) elseif 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 ) ) else wikiTable:insert( (codePalette:gsub( '<div class="navbox_group"', '<div' ) ) ) -- une ancre ^ pourra être ajoutée pour gagner en performance lorsque le modèle palette ne commencera plus par {{clr}} 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 wikiTable:insert( '</div>' .. palettesVerticales ) end for i, v in pairs( categories ) do wikiTable:insert( v ) end return wikiTable:concat() end return Palette