Vai al contenuto

Modulo:Immagine sinottico: differenze tra le versioni

Da Wikicord.
Pagina svuotata
Etichette: Svuotamento Annullato
m Annullata la modifica di Coccopuffo2018 (discussione), riportata alla versione precedente di Ropentiumal
Etichetta: Rollback
 
Riga 1: Riga 1:
--[[
* Modulo che implementa il template Immagine sinottico.
]]--


require('strict')
local getArgs = require('Modulo:Arguments').getArgs
local mWikidata = require('Modulo:Wikidata')
local catCompatibile = '[[Categoria:Sinottici con immagini formattate a mano]]'
local catNonCompatibile = '[[Categoria:Sinottici con immagini con formattazione ridondante]]'
local catDidascalia = '[[Categoria:Voci con template Immagine sinottico con didascalia e immagine letta da Wikidata]]'
local p = {}
local function formatImage(file, args)
local dim = args.dim_utente and
math.min(args.dim_utente, args.dim_max or args.dim or 260) or
(args.dim or 260)
return string.format('[[File:%s|frameless|center|%sx%spx%s%s]]',
  file, dim, args.dim_vert_max or 300,
  args.alt and '|alt=' .. args.alt or '',
  args.desc and '|' .. args.desc or '')
end
-- Per l'utilizzo da altro modulo
function p._main(args)
local userval, wdval, ret
-- evita letture indesiderate da wikidata
if args[1] == 'no' then return '' end
-- controllo quadre in eccesso
if args[1] and args[1]:sub(1, 1) == '[' then
local ns0 = mw.title.getCurrentTitle().namespace == 0
-- con args.compatibile restituisce direttamente args[1] e args[2]
if args.compatibile then
local cat = ns0 and catCompatibile or ''
return args[1] .. (args[2] and ('<br />' .. args[2]) or '') .. cat
elseif ns0 then
ret = catNonCompatibile
end
end
args.dim = tonumber(args.dim)
args.dim_max = tonumber(args.dim_max)
args.dim_utente = args.dim_utente and tonumber(mw.text.split(args.dim_utente, 'px')[1])
args.dim_vert_max = tonumber(args.dim_vert_max)
-- valore utente e wikidata
userval = args[1]
if not userval and args['proprietà'] then
wdval = mWikidata._getProperty({ args['proprietà'], n = 1 })
end
-- formatta l'immagine
if userval or wdval then
ret = (ret or '') .. formatImage(userval or wdval, args)
end
-- didascalia
if userval then
ret = ret .. (args[2] or (args.didascalia_default or ''))
elseif wdval then
-- se l'immagine è letta da Wikidata la didascalia può essere ottenuta
-- solo dal qualificatore P2096, altrimenti restituirà una categoria di errore
ret = ret .. (mWikidata._getQualifier({ args['proprietà'], 'P2096', includelang = 'it', n = 1 }) or (args.didascalia_default or ''))
end
return (ret or '') .. ((args[2] and wdval and not userval) and catDidascalia or '')
end
-- Funzione per il template {{Immagine sinottico}}
function p.main(frame)
return p._main(getArgs(frame, { parentOnly = true }))
end
return p

Versione attuale delle 14:46, 28 dic 2024

La documentazione per questo modulo può essere creata in Modulo:Immagine sinottico/man

--[[
* Modulo che implementa il template Immagine sinottico.
]]--

require('strict')

local getArgs = require('Modulo:Arguments').getArgs
local mWikidata = require('Modulo:Wikidata')
local catCompatibile = '[[Categoria:Sinottici con immagini formattate a mano]]'
local catNonCompatibile = '[[Categoria:Sinottici con immagini con formattazione ridondante]]'
local catDidascalia = '[[Categoria:Voci con template Immagine sinottico con didascalia e immagine letta da Wikidata]]'
local p = {}

local function formatImage(file, args)
	local dim = args.dim_utente and
				math.min(args.dim_utente, args.dim_max or args.dim or 260) or
				(args.dim or 260)
	return string.format('[[File:%s|frameless|center|%sx%spx%s%s]]',
						  file, dim, args.dim_vert_max or 300,
						  args.alt and '|alt=' .. args.alt or '',
						  args.desc and '|' .. args.desc or '')
end

-- Per l'utilizzo da altro modulo
function p._main(args)
	local userval, wdval, ret

	-- evita letture indesiderate da wikidata
	if args[1] == 'no' then return '' end

	-- controllo quadre in eccesso
	if args[1] and args[1]:sub(1, 1) == '[' then
		local ns0 = mw.title.getCurrentTitle().namespace == 0
		-- con args.compatibile restituisce direttamente args[1] e args[2]
		if args.compatibile then
			local cat = ns0 and catCompatibile or ''
			return args[1] .. (args[2] and ('<br />' .. args[2]) or '') .. cat
		elseif ns0 then
			ret = catNonCompatibile
		end
	end

	args.dim = tonumber(args.dim)
	args.dim_max = tonumber(args.dim_max)
	args.dim_utente	= args.dim_utente and tonumber(mw.text.split(args.dim_utente, 'px')[1])
	args.dim_vert_max = tonumber(args.dim_vert_max)

	-- valore utente e wikidata
	userval = args[1]
	if not userval and args['proprietà'] then
		wdval = mWikidata._getProperty({ args['proprietà'], n = 1 })
	end

	-- formatta l'immagine
	if userval or wdval then
		ret = (ret or '') .. formatImage(userval or wdval, args)
	end

	-- didascalia
	if userval then
		ret = ret .. (args[2] or (args.didascalia_default or ''))
	elseif wdval then
		-- se l'immagine è letta da Wikidata la didascalia può essere ottenuta
		-- solo dal qualificatore P2096, altrimenti restituirà una categoria di errore
		ret = ret .. (mWikidata._getQualifier({ args['proprietà'], 'P2096', includelang = 'it', n = 1 }) or (args.didascalia_default or ''))
	end

	return (ret or '') .. ((args[2] and wdval and not userval) and catDidascalia or '')
end

-- Funzione per il template {{Immagine sinottico}}
function p.main(frame)
	return p._main(getArgs(frame, { parentOnly = true }))
end

return p
I cookie ci aiutano a fornire i nostri servizi. Utilizzando i nostri servizi, accetti il nostro utilizzo dei cookie.