Module:Liste3 : Différence entre versions

Ligne 57 : Ligne 57 :
  
 
epoques = {}
 
epoques = {}
epoque = d .. ' - ' .. f
+
epoques[1] = {d .. ' - ' .. f}
epoques[epoque] = {}
 
 
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
epoque = d..' - '..f
+
epoques[n] = {d..' - '..f}
epoques[epoque] = {}
 
 
end
 
end
table.insert(epoques[epoque],row)
+
table.insert(epoques[n],row)
 
end
 
end
 
 
for epoque,films in pairs(epoques) do
+
for n,epoque in ipairs(epoques) do
retour = retour .. epoque ..' - ' .. #epoques[epoque] .. '<br>'
+
retour = retour .. epoque[1] ..' - ' .. #epoque .. '<br>'
for _,film in ipairs(films) do
+
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