« Module:Liste éléments » : différence entre les versions

De Lagny-sur-Marne Wiki
Aller à la navigation Aller à la recherche
0x010D (discussion | contributions)
helper getParam() pour obtenir un paramètre s'il existe et est non vide, sinon retourne nil ou fallback optionnel ; noter la dépendance à variable locale "args"
0x010D (discussion | contributions)
m A changé le niveau de protection pour « Module:Liste éléments » ([Modifier=Autoriser uniquement les utilisateurs autopatrolled] (infini) [Renommer=Autoriser uniquement les administrateurs] (infini))
 
(3 versions intermédiaires par le même utilisateur non affichées)
Ligne 6 : Ligne 6 :
     local trimFunc = mw.text.trim -- cache accès global
     local trimFunc = mw.text.trim -- cache accès global


     function getParam(name, default)
     local function getParam(name, default)
         if args[name] ~= nil and args[name] ~= '' then
         if args[name] ~= nil and args[name] ~= '' then
             return args[name]
             return args[name]
Ligne 14 : Ligne 14 :
     end
     end


     local paramSep, espaces, glue
     local paramSep = getParam('séparateur', getParam('sép', '·'))
    local values = {}
     local espaces = tonumber(getParam('espaces', '1'))
 
    local glue
    paramSep = getParam('séparateur', getParam('sép', '·'))
     espaces = tonumber(getParam('espaces', '1'))


     if paramSep == ',' then
     if paramSep == ',' then
Ligne 45 : Ligne 43 :


     local secable = (args['sécable'] == 'oui')
     local secable = (args['sécable'] == 'oui')
    local items = {}


     for i,v in ipairs(args) do
     for i,v in ipairs(args) do
         local value = trimFunc(v)
         local item = trimFunc(v)
         if value ~= '' then
         if item ~= '' then
             if not secable then
             if not secable then
                 value = '<span class="nowrap">'..value..'</span>'
                 item = '<span class="nowrap">'..item..'</span>'
             end
             end
             values[#values+1] = value
             items[#items+1] = item
         end
         end
     end
     end


     return table.concat(values, glue)
     return table.concat(items, glue)
end
end


return z
return z

Dernière version du 17 mai 2017 à 13:45

local z = {}

function z.main(frame)

   local args = frame:getParent().args
   local trimFunc = mw.text.trim -- cache accès global
   local function getParam(name, default)
       if args[name] ~= nil and args[name] ~=  then
           return args[name]
       else
           return default -- nil si non spécifié
       end
   end
   local paramSep = getParam('séparateur', getParam('sép', '·'))
   local espaces = tonumber(getParam('espaces', '1'))
   local glue
   if paramSep == ',' then
       glue = ', '
   elseif mw.text.unstripNoWiki(paramSep) == ' ' or paramSep == ' ' then --  ,  
       glue = paramSep
   elseif paramSep == '2·' or paramSep == '·2' then
       -- '\194\160' est une espace insécable (code UTF-8 sur deux octets)
       glue = '\194\160\194\160·\194\160 '
   elseif paramSep == '2•' or paramSep == '•2' then
       glue = '\194\160\194\160•\194\160 '
   else
       if paramSep == '·' then
           paramSep = '·'
       elseif paramSep == '-' or paramSep == '−' then
           paramSep = '–' -- tiret demi-cadratin
       elseif paramSep == '--' then
           paramSep = '—' -- tiret cadratin
       end
       if espaces == 0 then
           glue = paramSep
       else
           glue = string.rep('\194\160', espaces) .. paramSep .. string.rep('\194\160', espaces-1) .. ' '
       end
   end
   local secable = (args['sécable'] == 'oui')
   local items = {}
   for i,v in ipairs(args) do
       local item = trimFunc(v)
       if item ~=  then
           if not secable then
               item = ''..item..''
           end
           items[#items+1] = item
       end
   end
   return table.concat(items, glue)

end

return z