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