Module:Liste éléments : Différence entre versions

De Lagny-sur-Marne Wiki
Aller à : navigation, rechercher
(Remplacement "drop-in" pour l'actuel modèle qui est horriblement lent. Voir notamment Discussion Projet:Modèle#Performances Modèle:Liste éléments.)
 
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)))
 
(12 révisions intermédiaires par 2 utilisateurs non affichées)
Ligne 4 : Ligne 4 :
  
 
     local args = frame:getParent().args
 
     local args = frame:getParent().args
 +
    local trimFunc = mw.text.trim -- cache accès global
  
     local paramSep, espaces, glue
+
     local function getParam(name, default)
    local values = {}
+
        if args[name] ~= nil and args[name] ~= '' then
 
+
            return args[name]
    if args['séparateur'] ~= nil and args['séparateur'] ~= '' then
+
         else
        paramSep = args['séparateur']
+
            return default -- nil si non spécifié
    elseif args['sép'] ~= nil and args['sép'] ~= '' then
+
         end
         paramSep = args['sép']
 
    else
 
         paramSep = '·'
 
 
     end
 
     end
  
     if args['espaces'] ~= nil and args['espaces'] ~= '' then
+
     local paramSep = getParam('séparateur', getParam('sép', '·'))
        espaces = tonumber(args['espaces'])
+
    local espaces = tonumber(getParam('espaces', '1'))
     else
+
     local glue
        espaces = 1
 
    end
 
  
 
     if paramSep == ',' then
 
     if paramSep == ',' then
 
         glue = ', '
 
         glue = ', '
     elseif mw.text.unstripNoWiki(paramSep) == ' ' or paramSep == ' ' then
+
     elseif mw.text.unstripNoWiki(paramSep) == ' ' or paramSep == ' ' then -- {{espace}},  
 
         glue = paramSep
 
         glue = paramSep
 
     elseif paramSep == '2·' or paramSep == '·2' then
 
     elseif paramSep == '2·' or paramSep == '·2' then
         glue = '&nbsp;&nbsp;<span style="font-weight:bold">·</span>&nbsp; '
+
        -- '\194\160' est une espace insécable (code UTF-8 sur deux octets)
 +
         glue = '\194\160\194\160<span style="font-weight:bold">·</span>\194\160 '
 
     elseif paramSep == '2•' or paramSep == '•2' then
 
     elseif paramSep == '2•' or paramSep == '•2' then
         glue = '&nbsp;&nbsp;•&nbsp; '
+
         glue = '\194\160\194\160•\194\160 '
 
     else
 
     else
 
         if paramSep == '·' then
 
         if paramSep == '·' then
Ligne 41 : Ligne 38 :
 
             glue = paramSep
 
             glue = paramSep
 
         else
 
         else
             glue = string.rep('&nbsp;', espaces) .. paramSep .. string.rep('&nbsp;', espaces-1)..' '
+
             glue = string.rep('\194\160', espaces) .. paramSep .. string.rep('\194\160', espaces-1) .. ' '
 
         end
 
         end
 
     end
 
     end
  
     local secable = false
+
     local secable = (args['sécable'] == 'oui')
    if args['sécable'] == 'oui' then secable = true end
+
    local items = {}
  
 
     for i,v in ipairs(args) do
 
     for i,v in ipairs(args) do
         local value = mw.text.trim(v)
+
         local item = trimFunc(v)
         if value ~= '' then
+
         if item ~= '' then
             if not secable then value = '<span class="nowrap">'..value..'</span>' end
+
             if not secable then
             values[#values+1] = value
+
                item = '<span class="nowrap">'..item..'</span>'
 +
            end
 +
             items[#items+1] = item
 
         end
 
         end
 
     end
 
     end
  
     return table.concat(values, glue)
+
     return table.concat(items, glue)
 
end
 
end
  
 
return z
 
return z

Version actuelle datée du 17 mai 2017 à 13:45

La documentation pour ce module peut être créée à Module:Liste éléments/doc

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 == '&nbsp;' then -- {{espace}}, &nbsp;
        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<span style="font-weight:bold">·</span>\194\160 '
    elseif paramSep == '2•' or paramSep == '•2' then
        glue = '\194\160\194\160•\194\160 '
    else
        if paramSep == '·' then
            paramSep = '<span style="font-weight:bold">·</span>'
        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 = '<span class="nowrap">'..item..'</span>'
            end
            items[#items+1] = item
        end
    end

    return table.concat(items, glue)
end

return z