Module:Caixa de navegação

local Palette = { }

function Palette.listaCaixa( 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( 'Erro na utilização de Predefinição:Caixa de navegação : parâmetro obrigatório em falta.' ) end local function _paletteInconnue( i ) categories.paletteInconnue = categoriePaletteInconnue local nomPalette = mw.text.trim( parentArgs[i] ) return _erreur( 'Erro : não existe a predefinição de caixa de navegação (ajuda)', nomPalette, nomPalette ) end

local function _paletteEnDouble ( i ) categories.paletteEnDouble = categoriePaletteEnDouble 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 = 'Caixa de navegação ' .. mw.text.trim(parentArgs[i]), args = argsPalette } end local function _tropDePalettes categories.tropDePalette = categorieTropDePalette return _erreur( 'Erro na Predefinição:Caixa de navegação : demasiadas caixas (máximo : %s)', maxPalette ) end local boite = parentArgs['titre boîte déroulante'] or parentArgs['titre boite déroulante'] if boite then wikiTable[1] = ' \n' .. '' .. boite .. ' \n \n' end local i = 1 local palettesValides = {} while parentArgs[i] and i <= maxPalette do        if parentArgs[i]:match( '%S' ) then for _, j in ipairs( palettesValides ) do               if args[i] == args[j] and not args[i]:match('^caixa de navegação ') then wikiTable:insert ( _paletteEnDouble(i)) end end table.insert( palettesValides, i ) 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( '^%[%[:predefinição:' ) then                 -- La palette n'existe pas wikiTable:insert( _paletteInconnue( i ) ) table.remove( palettesValides ) 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( '^ 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