Module:Liste1 : Différence entre versions
Ligne 15 : | Ligne 15 : | ||
supports={} | supports={} | ||
− | local result = mw.ext.cargo.query('Supports','idSupport,video',{groupBy = 'idSupport',limit= | + | local result = mw.ext.cargo.query('Supports','idSupport,video',{groupBy = 'idSupport',limit=3000}) |
for d, row in ipairs(result) do | for d, row in ipairs(result) do | ||
supports[row['idSupport']] = row['video'] | supports[row['idSupport']] = row['video'] | ||
end | end | ||
− | |||
result = mw.ext.cargo.query(query.tables, query.fields, query) | result = mw.ext.cargo.query(query.tables, query.fields, query) | ||
− | |||
if not next(result) then | if not next(result) then | ||
return frame:preprocess(args.default or '') | return frame:preprocess(args.default or '') | ||
Ligne 28 : | Ligne 26 : | ||
local tbl = {} | local tbl = {} | ||
− | |||
for _, row in ipairs(result) do | for _, row in ipairs(result) do | ||
if row['dateDebut'] and row['dateDebut'] ~= '' then | if row['dateDebut'] and row['dateDebut'] ~= '' then | ||
− | if row['dateFin'] then | + | if row['dateFin'] and row['dateFin'] ~= '' then |
local a = tonumber(string.sub(row['dateDebut'],1,4)) + tonumber(string.sub(row['dateFin'],1,4)) | local a = tonumber(string.sub(row['dateDebut'],1,4)) + tonumber(string.sub(row['dateFin'],1,4)) | ||
row['annee'] = (a-a%2)/2 | row['annee'] = (a-a%2)/2 | ||
Ligne 51 : | Ligne 48 : | ||
local outro = frame:preprocess(args.outro or '') | local outro = frame:preprocess(args.outro or '') | ||
− | return | + | return intro .. table.concat(tbl,args.delimiter or '') .. outro |
end | end | ||
return p | return p |
Version du 10 décembre 2018 à 10:21
La documentation pour ce module peut être créée à Module:Liste1/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 if row['dateDebut'] and row['dateDebut'] ~= '' then if row['dateFin'] and row['dateFin'] ~= '' then local a = tonumber(string.sub(row['dateDebut'],1,4)) + tonumber(string.sub(row['dateFin'],1,4)) row['annee'] = (a-a%2)/2 else row['annee'] = string.sub(row['dateDebut'],1,4) end elseif row['dateFin'] then row['annee'] = string.sub(row['dateFin'],1,4) else row['annee'] = '?' end if row['video'] == '' then if supports[row['idSupport']] then row['video']=supports[row['idSupport']] end end tbl[#tbl+1] = frame:expandTemplate{ title = args.template, args = row } end local intro = frame:preprocess(args.intro or '') local outro = frame:preprocess(args.outro or '') return intro .. table.concat(tbl,args.delimiter or '') .. outro end return p