Aller au contenu

Module:Sit ofisyèl

Depi Wikipedya, ansiklopedi lib

La documentation pour ce module peut être créée à Module:Sit ofisyèl/doc

local Lien = { }

local Verif = require "Module:Correction syntaxique"
local defaultLang = 'ht'
local maxLang = 3

local function caterreur(param)
	if mw.title.getCurrentTitle().namespace == 0 then
		return '[[Kategori:Page du modèle Site officiel comportant une erreur|' .. string.upper(param or '?') .. ']]'
	else
		return ''
	end
end

function Lien.sitOfisyel( frame )
	local templateargs = frame:getParent().args
	local args = {}
	for k, v in pairs(templateargs) do
		if type(k) == 'number' then
			v = mw.text.trim(v)
		end
		if v ~= '' then
			args[k] = v
		end
	end
	maxLang = args.maxLang or maxLang
	local nocaturl = args.nocaturl

	local erreurs = '' -- les messages d'erreurs sont ajoutés ici

	local erreursarguments = Verif.verif(args, {'tit', 'titre', 'title', 1, 2, 'langue', 'lang', 'url', 'wikidata', 'entity', 'id', 'maxLang', 'nocaturl'}, 'Modèle Site officiel avec un paramètre inconnu‎')
	if erreursarguments then
		erreurs = erreurs .. erreursarguments
	end

	local titredefaut = 'Sit ofisyèl'
	local titre = args['titre'] or args['title'] or titredefaut
	local langue = args['langue'] or args['lang']
	local url = args['url'] or args[2] or args[1]

	if (not langue) and (args[2]) then
		langue = args[1]
	end
	local id = args.id or args.entity or args.wikidata
	if url and url:sub(1, 1) == 'Q' then
		id = url
		url = nil
	end
	
	-- si pas d'URL, essayer Wikidata, et si ça marche, sortir de ce module
	if not url and (id ~= '-') then
		local Wikidata = require "Module:Wikidata"
		local isinlang = defaultLang
		local links = Wikidata.getClaims{entity = id, property = 'P856', excludespecial = true, isinlang = isinlang}
		if not links then
			links = Wikidata.getClaims{entity = id, property = 'P856', excludespecial = true}
			isinlang = null
		end
		local Weblink = require 'Module:Weblink'
		local statementformat = function(statement, args)
			if statement.mainsnak.snaktype == 'value' then
				local value = statement.mainsnak.datavalue.value
				local title = Wikidata.getFormattedQualifiers(statement, {'P1476'}, {isinlang = 'fr'})
				if not title then
					title = Wikidata.getFormattedQualifiers(statement, {'P1476'})
				end
				if not title then
					title = args.text
				end
				return Weblink.makelink(value, title)
			else
				return Wikidata.formatSnak( statement.mainsnak, args )
			end
		end
		if links and (#links > 1) then
			return '<cite class="ouvrage" id="site_officiel" style="font-style: normal;">' .. "Sit Ofisyèl: " .. Wikidata.formatAndCat{claims = links, property = 'P856', displayformat = 'weblink', showlang = true, excludespecial = true, isinlang = isinlang, maxLang = maxLang, statementformat = statementformat} .. '</cite>' .. erreurs
		elseif links then
			if not (titre == titredefaut) then
				statementformat = nil
			end
			return '<cite class="ouvrage" id="site_officiel" style="font-style: normal;">' .. Wikidata.formatAndCat{claims = links, property = 'P856', displayformat = 'weblink', showlang = true, text = titre, isinlang = isinlang, maxLang = maxLang, statementformat = statementformat} .. '</cite>' .. erreurs
		end
	end
	
	-- si toujours pas, ajouter les catégories d'erreur et sortir
	if not url then
		if not nocaturl then
			erreurs = erreurs .. caterreur('url')
		end
		return erreurs
	end

	-- nettoyage de l'URL
	url = url:gsub( '%[', '%%5B' ):gsub( '%]', '%%5D' )
	if not ( url:match( '^http' ) or url:match( '^//' ) ) then
			url = 'http://' .. url
	end
	
	-- formatage de la langue
	local indicLangue = ''  -- langue telle qu'affichée dans le rendu final
	if langue then
		if langue ~= 'ht' then
			local Langue = require "Module:Langue"
			indicLangue = Langue.indicationMultilingue{ langue } .. ' '
			if indicLangue:find('class="error"', nil, true) then
				erreurs = erreurs .. caterreur('langue')
			end
		end
	end

	return '<cite class="ouvrage" id="site_officiel" style="font-style: normal;">' .. indicLangue .. '[' .. url .. ' ' .. titre .. ']' .. '</cite>' .. erreurs
end

return Lien