Modulo:Partiti

Questo è un modulo scritto in Lua. Le istruzioni che seguono sono contenute nella sottopagina Modulo:Partiti/man (modifica · cronologia)
Sandbox: Modulo:Partiti/sandbox (modifica · cronologia) · Sottopagine: lista · Test: Modulo:Partiti/test (modifica · cronologia · esegui)
Questo modulo serve a gestire i colori relativi ai partiti politici.
local cfg = mw.loadData( 'Modulo:Partiti/Configurazione' );
local getArgs = require('Module:Arguments').getArgs
-- ====================================================
-- corregge un valore di ritorno se questo inizia per '#'
-- vedi bug https://phabricator.wikimedia.org/T14974
-- sostiuendo l'entità html al carattere
-- =====================================================
local function fix_return(colore)
if string.sub(colore,1,1) == '#' then
colore = "#" .. string.sub(colore, 2, 7)
end
return colore
end
-- ==========================================================
-- Consulta la tabella di configurazione e ritorna il colore
-- associato a partito. Se questo non è definito o non viene
-- trovato ritorna il valore di default.
-- Se l'opzione ombra è vera ritorna invece il colore ombra
-- associato (generalmente un colore più chiaro da usare
-- quando sul colore del partito va messo uno sfondo), se i colore
-- ombra non esiste ritorna il colore normale.
-- ==========================================================
local function _colore(partito, default, ombra)
default = default or ''
if partito == nil then return fix_return(default) end
local partito_indice = cfg.alias[partito] or partito
local color
if ombra then
color = cfg.colore_ombra[partito_indice] or cfg.colore[partito_indice] or default
else
color = cfg.colore[partito_indice] or default
end
return fix_return(color)
end
-- ==========================================================
-- Funzione di interfaccia con il codice wiki, ritorna il
-- colore associato al partito passato con il primo parametro
-- o in caso non viene trovato quello di default
-- ==========================================================
local function colore(frame)
local args = getArgs(frame, {frameOnly = True})
return _colore(args[1], args[2])
end
-- ==========================================================
-- Funzione di interfaccia con il codice wiki, ritorna il
-- colore ombra associato al partito passato con il primo parametro
-- o in caso non viene trovato un eventuale default
-- ==========================================================
local function colore_ombra(frame)
local args = getArgs(frame, {frameOnly = True})
return _colore(args[1], args[2], True)
end
local function _nome_corto(partito)
if partito == nil then return '' end
partito_indice = cfg.alias[partito] or partito
return cfg.nome_corto[partito_indice] or partito_indice
end
local function nome_corto(frame)
local args = getArgs(frame, {frameOnly = True})
return _nome_corto(args[1])
end
-- ==========================================================
-- Ritorna la tabella di configurazione dei codici colore
-- ==========================================================
local function color_table(frame)
local color_t = mw.html.create('table'):addClass('wikitable sortable')
color_t:tag('tr')
:tag('th'):attr('colspan', '2'):wikitext('Colore'):done()
:tag('th'):attr('colspan', '2'):wikitext('Ombra'):done()
:tag('th'):attr('rowspan', '2'):wikitext('Partito'):done()
color_t:tag('tr')
:tag('th'):wikitext('Esempio'):done()
:tag('th'):wikitext('Codice'):done()
:tag('th'):wikitext('Esempio'):done()
:tag('th'):wikitext('Codice'):done()
local names = {}
for k,v in pairs(cfg.colore) do
names[#names+1] = k
end
table.sort(names)
for _,name in ipairs(names) do
local tr = color_t :tag('tr')
tr:tag('td'):wikitext(' '):css('background-color', cfg.colore[name]):done()
tr:tag('td'):wikitext(cfg.colore[name]):done()
if cfg.colore_ombra[name] then
tr:tag('td'):wikitext(' '):css('background-color', cfg.colore_ombra[name]):done()
tr:tag('td'):wikitext(cfg.colore_ombra[name]):done()
else
tr:tag('td'):wikitext(' '):done()
tr:tag('td'):wikitext(' '):done()
end
tr:tag('td'):wikitext('[[' .. name .. ']]'):done()
end
return color_t
end
return {
colore = colore,
_colore = _colore,
nome_corto = nome_corto,
_nome_corto = _nome_corto,
color_table = color_table,
colore_ombra = colore_ombra
}