Module:Wt/lij/Fonte


-- Moduli utili per il template Fonte divisi per dizionario
local p = {}
local titolo = mw.title.getCurrentTitle().subpageText

--[[ Funzione che toglie gli accenti "normalizzando" le lettere, usato nei template:
Fonte/sin-co;
Fonte/Sabco;
Fonte/dem;
--]]

function p.senzaccenti(arg)
	if type(arg) ~= 'string' and arg.args ~= nil and arg.args[1] ~= nil then
		arg = arg.args[1]
	end
	if type(arg) ~= 'string' then
		error('Specificare un parametro di tipo stringa')
		return nil
	end
	arg = mw.ustring.gsub(arg, '[àáäãâåāăą]', 'a')
	arg = mw.ustring.gsub(arg, '[èéêëēěĕėę]', 'e')
	arg = mw.ustring.gsub(arg, '[ìíîïĩīĭį]', 'i')
	arg = mw.ustring.gsub(arg, '[òóôõöōŏőø]', 'o')
	arg = mw.ustring.gsub(arg, '[ùúûüūŭů]', 'u')
	return arg
end

--[[ encode_url: 
Sostituisce le lettere accentate con l'equivalente UTF-8 (es: "%EO" per "à"). Usato da:
 Fonte/italwn
--]]
function p.encode_url(arg)
	local accenti = require('Modulo:Fonte/Accenti UTF-8')
	arg = arg.args[1]
	return accenti.accenti(arg)

end	

--[[ encode_HEXA: 
Sostituisce le lettere accentate con l'equivalente in esadecimale. Usato da:
 -
 preso da http://lua-users.org/wiki/StringRecipes
--]]
function p.encode_HEXA(arg)
	arg = arg.args[1]
	
	if arg then
      arg = arg:gsub("\n", "\r\n")
      arg = arg:gsub("([^%w %-%_%.%~])", function(c)
         return ("%%%02X"):format(string.byte(c))
      end)
      arg = arg:gsub(" ", "+")
   end
   return arg
end

--[[ Hoep: 
sostituisce il testo racchidendolo tra i caratteri" +(...)", indispensabile in caso di omonimie
 Nel caso sia scritto un parametro con una cifra, esempio "parametro2", questa funzione permette di isolare le lettere, sostituire i "_" con i "+" e cancellare i numeri. Usato nei template:
 Fonte/hoep
--]]

function p.hoepTesto(frame)
	local par1 = frame.args[1]
	local par2 = mw.ustring.gsub(par1, '%d', '') -- Cancella i numeri
	local res = titolo -- Se non ci sono lettere mostra il titolo della pagina

	if par2 ~= "" then -- Controlla se ci sono delle lettere 
		res = par2 -- Se ci sono lettere vuol dire che è stato specificato il primo parametro, quindi lo mostra
	end
	return mw.ustring.sub(res, 0, 1):upper() .. '/' .. mw.uri.encode(res, 'PATH') -- Appropriata codifica dell'indirizzo
end

function p.hoepNum(frame)
	par1 = frame.args[1]
	par3 = mw.ustring.gsub(par1, '%d', '') -- Cancella tutti i numeri
	par2 = mw.ustring.gsub(par1, '%a', '') -- Cancella tutte le lettere

	if par3 ~= "" then  --se ci sono delle lettere
		if par2 > "0" then  
			return mw.uri.encode(par3 .. ' (' .. par2 ..  ')')
		else
			return mw.uri.encode(par3)
		end
	else
		if par2 > "0" then -- se non ci sono lettere 
			return mw.uri.encode(titolo .. ' (' .. par2 ..  ')')
		else
			return mw.uri.encode(titolo)
		end
	end
end

--[[ Sabco: 
sostituisce tutte le lettere accentate con le rispettive lettere private dell'accento e sostituisce tutti gli spazi con il "_" necessario per linkare correttamente. Usato nei template:
Fonte/sin-co;
Fonte/Sabco;
--]]

function p.SabCo(frame)
	t2 = p.senzaccenti(titolo)
	t2 = mw.ustring.gsub(t2, ' ', '_') -- Sostituisce i "_" se non è specificata la pagina
	par = p.senzaccenti(frame.args[1])
	par = mw.ustring.gsub(par, ' ', '_') -- Sostituisce i "_" al primo parametro

	lett = mw.ustring.gsub(par, '%d', '') -- Cancella tutti i numeri
	num  = mw.ustring.gsub(par, '%a', '') -- Cancella tutte le lettere

	if lett ~= "" then  --se ci sono delle lettere
		if num > "0" then  
			return   lett , '_' .. num ..  ''
		else
			return  lett
		end
	else
		if num > "0" then -- se non ci sono lettere 
			return  t2 , '_' .. num ..  ''
		else
			return  t2
		end
	end
end

--[[ Dem: 
sostituisce tutte le lettere accentate con le rispettive lettere private dell'accento e sostituisce tutti gli spazi con il "-" necessario per linkare correttamente. Usato nei template:
Fonte/dem;
--]]

function p.dem(frame)
	titolo2 = p.senzaccenti(titolo)
	titolo2 = mw.ustring.gsub(titolo2, '%s', '-') -- Sostituisce gli spazi nel titolo senza accenti con i "_"
	parametro = p.senzaccenti(frame.args[1])
	parametro = mw.ustring.gsub(parametro, '%s', '-') -- Sostituisce gli spazi nel parametro arbitrario con i "_"

	lettere = mw.ustring.gsub(parametro, '%d', '') -- Cancella tutti i numeri
	numeri  = mw.ustring.gsub(parametro, '%a', '') -- Cancella tutte le lettere

	if lettere ~= "" then  --se ci sono delle lettere
		if numeri > "0" then  
			return   lettere , '_' .. numeri ..  ''
		else
			return  lettere
		end
	else
		if numeri > "0" then -- se non ci sono lettere ma numeri sì 
			return  titolo2 , '_' .. numeri ..  ''
		else
			return  titolo2
		end
	end
end

--[[ Dizit: 
sostituisce tutte le lettere accentate con le rispettive lettere private dell'accento e costruisce il link tenendo conto anche delle omonimie. Usato nei template:
Fonte/dizit;
--]]

function p.dizit(frame)
	titolo2 = p.senzaccenti(titolo)
	titolo2 = titolo2:upper()
	parametro = p.senzaccenti(frame.args[1])
	parametro = parametro:upper()

	lettere = mw.ustring.gsub(parametro, '%d', '') -- Mantiene solo le lettere
	numeri  = mw.ustring.gsub(parametro, '%a', '') -- Cancella tutte le lettere
	
	if numeri ~= '' then
		numero = numeri..'00'
	else
		numero = '100'
	end
	
	-- Se il parametro non è vuoto e ci sono lettere
	if lettere ~= '' then
		return lettere..''..numero
	else
		return titolo2..''..numero
	end
	
end

--[[ Trec: 
sostituisce tutte le lettere accentate con le rispettive lettere private dell'accento e sostituisce tutti gli spazi con il "-" necessario per linkare correttamente. Usato nei template:
Fonte/trec;
--]]

function p.trec(frame)
	titolo2 = p.senzaccenti(titolo)
	titolo2 = mw.ustring.gsub(titolo2, '%s', '-') -- Sostituisce gli spazi nel titolo senza accenti con i "-"
	parametro = p.senzaccenti(frame.args[1])
	parametro = mw.ustring.gsub(parametro, '%s', '-') -- Sostituisce gli spazi nel parametro arbitrario con i "-"

	lettere = mw.ustring.gsub(parametro, '%d', '') -- Cancella tutti i numeri
	numeri  = mw.ustring.gsub(parametro, '%a', '') -- Cancella tutte le lettere

	if lettere ~= "" then  --se ci sono delle lettere
		if numeri > "0" then  
			return   lettere , numeri
		else
			return  lettere
		end
	else
		if numeri > "0" then -- se non ci sono lettere ma numeri sì 
			return  titolo2 , numeri 
		else
			return  titolo2
		end
	end
end

--[[ mdbg: 
Analizza il testo inserito e taglia l'eventuale testo "zh-tc" dal parametro inserito e poi smista il testo in base al risultato. Usato nei template:
Fonte/mdgb;
--]]

function p.mdbgTesto(frame)
    par1=frame.args[1]
    par2 = mw.ustring.gsub(par1, '([%a0-9]+)(-([a-z]+-[a-z]+))', '%1'); 
    
	if par1 ~= "" then
		if par1 == "zh-tc" then  -- Controlla se è stato specificato soltanto "zh-tc"
			return titolo -- se non è stato specificato niente restituisce il titolo della pagina
		else
			return par2 -- se è stato specificato altro lo visualizza
		end
	else
		return titolo -- se è stato specificato altro lo visualizza
	end
end
 

function p.mdbgSuff(frame)
    par1=frame.args[1]
    par2 = mw.ustring.gsub(par1, '([%a0-9]+)(-([a-z]+-[a-z]+))', '%3'); 
    
	if par1 ~= "" then
		if par2 == "zh-tc" then  -- Controlla se è stato specificato soltanto "zh-tc"
			return '1' -- se non è stato specificato niente restituisce il titolo della pagina
		else
			return '0' -- se è stato specificato altro lo visualizza
		end
	else
		return '0' -- se è stato specificato altro lo visualizza
	end
end

return p