Modulo:Demografia/sandbox: differenze tra le versioni

Contenuto cancellato Contenuto aggiunto
Moroboshi (discussione | contributi)
ottimizzazioni al codice
use require("strict") instead of require("Module:No globals")
 
(21 versioni intermedie di 2 utenti non mostrate)
Riga 1:
require("Module:No globalsstrict")
local getArgs = require('Module:Arguments').getArgs
local p = {}
 
local minimo, massimo
 
-- =====================================================================
Riga 38 ⟶ 40:
-- =====================================================================
local function merge_years_population(years, populations)
local values = { }
local t
for i =1,#populations do
for values[i] = { year = years[i]1, population = #populations[i] }do
if (minimo == nil or years[i] < minimo) then minimo = years[i] end
end
if (massimo == nil or years[i] > massimo) then massimo = years[i] end
return values
t = string.format("%g",math.floor(populations[i]+0.5))
t = t:gsub('%.',',')
values[i] = { year = years[i], population = populations[i], num = i, txt = t }
end
return values
end
 
-- =====================================================================
-- Crea tabella laterale
-- =====================================================================
local function formato(a)
local k
local s = ''..a
while true do
s, k = s:gsub("^(-?%d+)(%d%d%d)", '%1&nbsp;%2')
if (k==0) then break end
end
return s
end
 
local function mostraTabella(a,b,f)
local ss = {}
table.insert(ss,'</td><td style="vertical-align:top"><table class="wikitable" style="font-size:smaller;text-align:right"><tr><th>Anno</th><th>Abitanti</th>')
if #b > 12 then
table.insert(ss,'<th>Anno</th><th>Abitanti</th></tr>')
local c = math.floor(0.5+#b/2)
for i =1,c do
table.insert(ss,string.format('<tr><th>%s</th><td>%s</td>',a[i],formato(math.floor(b[i]*f+0.5))))
if b[i+c] then table.insert(ss,string.format('<th>%s</th><td>%s</td>',a[i+c],formato(math.floor(b[i+c]*f+0.5)))) end
table.insert(ss,'</tr>')
end
else
table.insert(ss,'</tr>')
for i =1,#populationsb do
table.insert(ss,string.format('<tr><th>%s</th><td>%s</td></tr>',a[i],formato(math.floor(b[i]*f+0.5))))
end
end
table.insert(ss,'</table></td></tr></table>')
return table.concat(ss)
end
 
-- =====================================================================
Riga 50 ⟶ 90:
-- =====================================================================
function p._demografia(args)
-- Definizione base del grafico
local graph = {
version = 2,
Riga 97 ⟶ 137:
title = "Anno",
grid = true,
properties = {
labels = { font = { value = "Helvetica" } },
title = { font = { value = "Helvetica" } }
}
},
{
Riga 103 ⟶ 147:
title = "Abitanti",
grid = true,
layer = "back",
properties = {
labels = { font = { value = "Helvetica" } },
title = { font = { value = "Helvetica" } }
}
}
},
Riga 115 ⟶ 163:
x = {scale = "x",field = "year"},
y = {scale = "y",field = "population"},
stroke = {value = "#fc81f77b4"},
strokeWidth = {value = 34},
opacity = {value = 0.5}
}
}
Riga 127 ⟶ 176:
x = {scale = "x",field = "year"},
y = {scale = "y",field = "population"},
stroke = {value = "#f801f77b4"},
fill = {value = "#fff"},
size = {value = 1218}
}
}
Riga 140 ⟶ 189:
x = {scale = "x",field = "year"},
y = {scale = "y",field = "population"},
stroke = {value = "#8001f77b4"},
fill = {value = "#fff"},
size = {value = 30}
Riga 155 ⟶ 204:
align = {value = "center"},
fill = {value = "#000"},
text = {field = "populationtxt" },
font = {value = "Helvetica"},
}
}
Riga 178 ⟶ 228:
},
fill = {value = "black"},
fontSize = {value = 1614},
font = {value = "Helvetica"},
align = {value = "center"},
fontWeight = {value = "bold"}
Riga 186 ⟶ 237:
}
}
local titolo = args.titolo or args[1] or "Abitanti censiti<br />"
if args.fonte then
titolo = titolo .. '<ref>' .. args.fonte .. '</ref>'
end
titolo = titolo .. '\n\n'
local populations = read_array(args, "p", "popolazione")
local years = read_array(args, "a", "anni")
Riga 192 ⟶ 247:
local years2 = read_array(args, "b", "anni2")
graph['data'][1]['values'] = merge_years_population(years, populations)
graph['data'][2]['values'] = merge_years_population(years2, populations2)
graph['width'] = args.dimx and tonumber(args.dimx) and tonumber(args.dimx)
graph['height'] = args.dimy and tonumber(args.dimy) and tonumber(args.dimy)
local tabella1 = ''
local tabella2 = ''
local fattore = args.fattore and tonumber(args.fattore) and tonumber(args.fattore) or 1
if fattore == 1000 then
graph['axes'][2]['title'] = 'Abitanti (migliaia)'
elseif fattore == 1000000 then
graph['axes'][2]['title'] = 'Abitanti (milioni)'
end
if args.etichette then
if args.etichette == "dispari" then
-- mostra solo etichette dispari
graph['marks'][4]['from']['transform'] = {{ type = "filter", test = "datum.num % 2 == 1"}}
elseif args.etichette == "pari" then
-- mostra solo etichette pari
graph['marks'][4]['from']['transform'] = {{ type = "filter", test = "datum.num % 2 == 0"}}
elseif args.etichette == "tabella" then
-- nasconde etichette e crea tabella a fianco
graph['marks'][4]['from']['transform'] = {{ type = "filter", test = "datum.num < 1"}}
tabella1 = '<table><tr><td style="vertical-align:top">'
tabella2 = mostraTabella(years, populations, fattore)
end
end
--if true then return mw.text.jsonEncode(graph) end
local template_text = "Censimenti dal {{datum.min_year}} al {{datum.max_year}}"
Riga 202 ⟶ 279:
graph['marks'][5]['properties']['enter']['text']['template'] = template_text
end
return titolo .. mw.getCurrentFrame():extensionTag('graph', mw.text.jsonEncode(graph))
if (massimo - minimo > 1) then
graph['scales'][1]['domainMin'] = minimo - (massimo-minimo)*0.04
graph['scales'][1]['domainMax'] = massimo + (massimo-minimo)*0.04
end
local ris = {}
table.insert(ris,titolo)
table.insert(ris,tabella1)
return titolo table.. insert(ris,mw.getCurrentFrame():extensionTag('graph', mw.text.jsonEncode(graph)))
table.insert(ris,tabella2)
return table.concat(ris)
end
 
-- ======================================================================================================
-- Funzione di intefaccia con template:Demografia
-- ======================================================================================================
function p.demografia(frame)
local args = getArgs(frame)