Module:Liste3 : Différence entre versions
Ligne 57 : | Ligne 57 : | ||
epoques = {} | epoques = {} | ||
− | + | epoques[1] = {d .. ' - ' .. f} | |
− | |||
for _,row in ipairs(result) do | for _,row in ipairs(result) do | ||
if row['annee'] >= f + 1 then | if row['annee'] >= f + 1 then | ||
Ligne 64 : | Ligne 63 : | ||
d,f = f,f+periode | d,f = f,f+periode | ||
end | end | ||
− | d,f = f,f+periode | + | d,f,n = f,f+periode,n+1 |
− | + | epoques[n] = {d..' - '..f} | |
− | |||
end | end | ||
− | table.insert(epoques[ | + | table.insert(epoques[n],row) |
end | end | ||
− | for epoque | + | for n,epoque in ipairs(epoques) do |
− | retour = retour .. epoque ..' - ' .. # | + | retour = retour .. epoque[1] ..' - ' .. #epoque .. '<br>' |
− | for _,film in ipairs( | + | for _,film in ipairs(epoque[2]) do |
retour = retour .. frame:expandTemplate{ title = args.template, args = film} | retour = retour .. frame:expandTemplate{ title = args.template, args = film} | ||
end | end |
Version du 14 décembre 2018 à 16:17
La documentation pour ce module peut être créée à Module:Liste3/doc
local p = {} function p.main(frame) if frame == mw.getCurrentFrame() then args = require('Module:ProcessArgs').merge(true) else frame = mw.getCurrentFrame() end local query = {} for k, v in pairs(args) do if string.sub(k, 0, 2) == 'q?' then query[string.sub(k, 3)] = v end end supports={} local result = mw.ext.cargo.query('Supports','idSupport,video',{groupBy = 'idSupport',limit=3000}) for d, row in ipairs(result) do supports[row['idSupport']] = row['video'] end result = mw.ext.cargo.query(query.tables, query.fields, query) if not next(result) then return frame:preprocess(args.default or '') end local tbl = {} for _, row in ipairs(result) do row['annee'] = tonumber(row['annee']) if row['video'] == '' then if supports[row['idSupport']] then row['video']=supports[row['idSupport']] end end end local debut = 1904 local periode,nb = 7,0 local d,f = debut,debut+periode local texte_periode = '\n <div class="collapsible"> '.. d+1 ..'-'..f .. '</div><div class="content"> ' local retour, tbl = '',{''} --[[ for _,row in ipairs(result) do if not tbl[2] then retour = retour .. '\n <div class="collapsible"> '.. d+1 .. '-' .. f .. '</div><div class="content"><br> ' end if row['annee'] >= f + 1 then while row['annee'] > f + periode do d,f = f,f+periode end retour = retour .. table.concat(tbl,args.delimiter or '') .. '</div><br>' tbl = {} d,f = f,f+periode end tbl[#tbl+1] = frame:expandTemplate{ title = args.template, args = row } end retour = retour .. table.concat(tbl,args.delimiter or '') .. '</div><br>' ]]-- epoques = {} epoques[1] = {d .. ' - ' .. f} for _,row in ipairs(result) do if row['annee'] >= f + 1 then while row['annee'] > f + periode do d,f = f,f+periode end d,f,n = f,f+periode,n+1 epoques[n] = {d..' - '..f} end table.insert(epoques[n],row) end for n,epoque in ipairs(epoques) do retour = retour .. epoque[1] ..' - ' .. #epoque .. '<br>' for _,film in ipairs(epoque[2]) do retour = retour .. frame:expandTemplate{ title = args.template, args = film} end end --retour = 'aa' local intro = frame:preprocess(args.intro or '') local outro = frame:preprocess(args.outro or '') return intro .. retour .. outro end return p