Modulo:Sito ufficiale

Versione del 3 set 2017 alle 13:15 di Rotpunkt (discussione | contributi) (è Wikipedia, non è un blog umoristico)
Info Istruzioni per l'uso
Questo è un modulo scritto in Lua. Le istruzioni che seguono sono contenute nella sottopagina Modulo:Sito ufficiale/man (modifica · cronologia)
Sandbox: Modulo:Sito ufficiale/sandbox (modifica · cronologia) · Sottopagine: lista · Test: Modulo:Sito ufficiale/test (modifica · cronologia · esegui)

Modulo che implementa il template {{Sito ufficiale}} (verifica).

Uso

Il modulo non va utilizzato direttamente, ma per implementare un template per i collegamenti esterni che debba ottenere il collegamento esterno esclusivamente da una proprietà Wikidata di tipo URL e di tipo "valore singolo". Possono esserci eccezioni che sono gestite automaticamente dal template visualizzando una lista. Se su Wikidata è stato utilizzato il qualificatore lingua dell'opera o del nome (P407) sarà anche indicata la lingua del sito web. Se il qualificatore ha più valori verrà visualizzata ciascuna lingua.

{{#invoke:Sito ufficiale|main|pid=|title=}}
  • pid: identificativo della proprietà Wikidata, il valore di default è "P856"
  • title: titolo del {{Cita web}}, il valore di default è "Sito ufficiale"

--[[
* Modulo che implementa il template {{Sito ufficiale}} ed altri template molto simili
]]
 
require('Modulo:No globals')

local mWikidata = require('Modulo:Wikidata')
local mEditAtWikidata = require('Modulo:Modifica su Wikidata').showMessage

-- Titolo predefinito per il {{Cita web}}
local defaultTitle = 'Sito ufficiale'

-- Categoria adattata.           ↓ Valore identico al {{Controllo Wikidata}}
local wdCategory = '[[Categoria:%s letto da Wikidata]]'

-- Categoria adattata.                               ↓ Titolo del template corrente
local errorCategory = '[[Categoria:Voci con template %s e senza dati da recuperare da Wikidata]]'

-- Quanti byte occupa la parola "Template:" + 1
local STRIP_BYTES = 10

local p = {}

local function formatWebsite(website, titolo)
	return mw.getCurrentFrame():expandTemplate {
		title = 'Cita web',
		args = {
			url = website.url,
			titolo = titolo,
			lingua = table.concat(website.langs, ' ')
		}
	}
end

--[[
 * @param int pid Wikidata Property ID
]]
local function getWebsites(pid, from)
	local claims
	local websites = {}

	claims = mWikidata._getClaims(pid, {from = from}) or {}
	for idx, claim in ipairs(claims) do
		local langs = mWikidata._formatQualifiers(claim, 'P407', { formatting = 'raw' }, true)
		langs = (#langs == 1 and langs[1] == 'Q652') and {} or langs
		for i, lang in ipairs(langs) do
			langs[i] = mWikidata._getLabel({ lang })
		end
		websites[idx] = {
			url = mWikidata._formatStatement(claim),
			langs = langs
		}
	end

	return websites
end

--[[
 * Entry-point per il template {{Sito ufficiale}}
]]
function p.main(frame)
	local parent = frame:getParent()

	-- Proprietà generica (è letta da mEditAtWikidata):
	frame.args.pid = frame.args and frame.args.pid or 'P856'

	-- Elemento Wikidata generico (sempre nil, usato solo nel /man) (è letto da mEditAtWikidata):
	frame.args.qid = parent     and parent.args and parent.args.qid

	local template_title = string.sub(parent:getTitle(), STRIP_BYTES)

	-- Titolo per il cita web
	local title    = frame.args and frame.args.title or template_title

	-- Categoria adattata al titolo del template padre
	errorCategory = string.format(errorCategory, template_title)

	-- Categoria adattata per essere identica a quella del Template:Controllo Wikidata
	wdCategory    = string.format(wdCategory, frame.args.catpart or template_title)

	local websites = getWebsites(frame.args.pid, frame.args.qid)
	for idx, website in ipairs(websites) do
		-- P856 è di tipo "valore singolo", aggiunge l'elenco puntato solo per le eccezioni
		websites[idx] = (idx > 1 and '*' or '') .. formatWebsite(website, title) .. mEditAtWikidata(frame)
	end
	return #websites > 0 and
		   (table.concat(websites, '\n') .. wdCategory) or
		   (mw.title.getCurrentTitle().namespace == 0 and errorCategory or nil)
end

return p