Mòdulu:Partiti

Dâ Wikipedia, la nciclupidìa lìbbira.

La ducumintazzioni di stu mòdulu si pò criari nta Mòdulu:Partiti/doc

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] or '', 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
}