local getArgs = require('Module:Arguments').getArgs
local numero_romano = require('Module:Numero romano').main
local p = {}
local tab_genere = {
["[[romanzo]]"] = "Romanzi",
["romanzo"] = "Romanzi",
["[[racconto]]"] = "Racconti",
["racconti"] = "Racconti",
["[[racconti]]"] = "Racconti",
["[[racconto|racconti]]"] = "Racconti",
["racconto"] = "Racconti",
["[[trattato]]"] = "Saggi",
["[[trattato (opera)|trattato]]"] = "Saggi",
["trattato"] = "Saggi",
["[[saggistica]]"] = "Saggi",
["saggistica"] = "Saggi",
["[[saggi]]"] = "Saggi",
["saggi"] = "Saggi",
["[[saggio]]"] = "Saggi",
["saggio"] = "Saggi"
}
local function get_genere(args)
local gen_txt = args.genere or ''
gen_txt = mw.ustring.lower(gen_txt)
return tab_genere[gen_txt] or "Opere letterarie"
end
local function get_categories(year, args)
if year_number then
if year_number < 1 then
return "Categoria:Scheda libro con anno di prima pubblicazione non riconosciuto| numero negativo"
elseif year_number > 1800 then
if year_number >= os.date("*t").year + 3 then
return "Categoria:Scheda libro con anno di prima pubblicazione non riconosciuto| opera letteraria futura"
else
return mw.ustring.format("Categoria:%s del %s", get_genere(args), year)
end
else -- secoli dopo Cristo
local century = numero_romano({math.floor( (year+99)/100 )})
local preposizione = "del "
if century == "VIII" or century == "XI" then
preposizione = "dell'"
end
return mw.ustring.format("Categoria:%s %s%s secolo", get_genere(args), preposizione, century)
end
end
return "Categoria:Scheda libro con anno di prima pubblicazione non riconosciuto"
end
function p.categories(frame)
local args = getArgs(frame)
local current_namespace = mw.title.getCurrentTitle().namespace
local cat = ''
local force_year = args.forza_cat_anno
local period = args.periodo
local year = args.annoorig
-- disattiva la categorizzazione automatica fuori da ns0
if current_namespace ~= 0 and not args.debug then
return period or year or ''
end
local wrap_category = "[[%s]]"
if args.debug == "s" then
wrap_category = ' [[:%s]]'
end
-- non definito ne periodo, ne annoorig
if not (period or year) then
return mw.ustring.format(wrap_category, "Categoria:Scheda libro con anno di prima pubblicazione mancante")
end
-- definito forza_cat_anno
if force_year then
-- disattivo la categorizzazione automatica se force_year = no
if force_year:lower() == 'no' then
return period or year
end
local cat = get_categories(force_year, args)
return (period or year) .. mw.ustring.format(wrap_category, cat)
end
-- definito periodo
if period then
return period
end
local year_number = tonumber(year)
if not(year_number) then
_,_,year = mw.ustring.find(year, "^%[%[%d+%]%]$", "%1")
if year == nil then
return year .. mw.ustring.format(wrap_category, "Categoria:Scheda libro con anno di prima pubblicazione non riconosciuto")
end
year_number = tonumber(year)
end
local cat = get_categories(year_number, args)
return "[[" .. year .. "]]" .. mw.ustring.format(wrap_category, cat)
end
return p