« Module:Biblio » : différence entre les versions

Une page de Wikipédia, l'encyclopédie libre.
Contenu supprimé Contenu ajouté
Zebulon84 (discuter | contributions)
retouche de la modification précédente
Zebulon84 (discuter | contributions)
Ajout fonction rechercheIsbn ; rechercheIssn : utilisation du nouveau paramètre 'sansLabel'
Ligne 68 : Ligne 68 :
return '<small>([[International Standard Book Number|ISBN]]&nbsp;inconnu)</small>' .. References.categorise{'ISBN nécessaire'}
return '<small>([[International Standard Book Number|ISBN]]&nbsp;inconnu)</small>' .. References.categorise{'ISBN nécessaire'}
end
end
end

Biblio.rechercheIsbn = function( frame )
local args = Outils.extractArgs( frame )
local References = require( 'Module:Biblio/Références' )
local newArgs = { isbn = args[1], sansLabel = true, categ = { isbnInvalid = false } }
local isbn = References.isbn( newArgs ) or ''
local categ = References.categorise{'Page avec ISBN invalide', newArgs.categ.isbnInvalid }
return isbn .. categ
end
end


Ligne 111 : Ligne 120 :
local args = Outils.extractArgs( frame )
local args = Outils.extractArgs( frame )
local References = require( 'Module:Biblio/Références' )
local References = require( 'Module:Biblio/Références' )
local newArgs = { issn = args[1], categ = { issnInvalid = false } }
local newArgs = { issn = args[1], sansLabel = true, categ = { issnInvalid = false } }
local issn = References.issn( newArgs ) or ''
local issn = References.issn( newArgs ) or ''
issn = issn:gsub('^.-&nbsp;', '') -- supprime le lien [[ISSN]]
local categ = References.categorise{'Page avec ISSN invalide', newArgs.categ.issnInvalid }
local categ = References.categorise{'Page avec ISSN invalide', newArgs.categ.issnInvalid }
return issn .. categ
return issn .. categ

Version du 29 mars 2016 à 15:39

 Documentation[voir] [modifier] [historique] [purger]

Ce module sert de base aux fonctions bibliographiques. Lorsqu'elles sont appelées directement par un modèle (via #invoke), les paramètres passés à ce modèle sont automatiquement transmis au module, sauf si le modèle spécifie une autre valeur pour ce paramètre.

Utilisation

Fonctions exportables :

  • ouvrage(frame) – modèle {{Ouvrage}} ;
  • chapitre(frame) – modèle {{Chapitre}} ;
  • article(frame) – modèle {{Article}} ;
  • lienWeb(frame) – modèle {{Lien web}} ;
  • lienBrise(frame) – modèle {{Lien brisé}} ;
  • dictionnaire(frame) – appelle le modèle chapitre si un paramètre titre chapitre, article ou notice est non vide, sinon appelle le modèle ouvrage ;
  • ISBN(frame) – affiche en petit et entre parenthèses ISBN suivi d'autant de codes que de paramètres non nommés, avec lien à la page ad hoc ;
  • ISSN(frame) – affiche en petit et entre parenthèses ISSN suivi d'autant de codes que de paramètres non nommés, avec lien à la page ad hoc ;
  • enLigne() – similaire au modèle {{Lire en ligne}} (le texte par défaut est « en ligne »).

Modules externes et autres éléments dont ce module a besoin pour fonctionner :

Exemples

Utilisation de la fonction ouvrage dans un modèle pour afficher une référence :

  • {{#invoke:Biblio |ouvrage |auteur=Martine Michu |titre=Mes vacances à la mer}}
  • Martine Michu, Mes vacances à la mer

Une page utilisant ce modèle avec le paramètre « passage = 28 » affichera :

  • Martine Michu, Mes vacances à la mer, p. 28
-- Le module biblio centralise les différentes fonctions utiles pour les bibliographie et références.

local Biblio = {  }


local Outils = require( 'Module:Outils' )


Biblio.ouvrage = function ( frame )
	local args = Outils.extractArgs( frame )
	local Ouvrage = require( 'Module:Biblio/Ouvrage' )
	return Ouvrage.ouvrage( args ) 
end


Biblio.chapitre = function ( frame )
	local args = Outils.extractArgs( frame )
	local Ouvrage = require( 'Module:Biblio/Ouvrage' )
	return Ouvrage.chapitre( args ) 
end


Biblio.article = function ( frame )
	local args = Outils.extractArgs( frame )
	local Ouvrage = require( 'Module:Biblio/Article' )
	return Ouvrage.article( args ) 
end


Biblio.lienWeb = function( frame )
	local args = Outils.extractArgs( frame )
	local Ouvrage = require( 'Module:Biblio/Lien web' )
	return Ouvrage.lienWeb( args ) 
end


Biblio.dictionnaire = function( frame )
	local args = Outils.extractArgs( frame )
	local article = Outils.validTextArg( args, 'notice', 'article', 'titre chapitre' )
	local Ouvrage = require( 'Module:Biblio/Ouvrage' )
	if article then
		args['titre chapitre'] = article
		return Ouvrage.chapitre( args ) 
	else
		args.titre = args['titre ouvrage']
		args['sous-titre'] = args['sous-titre ouvrage']
		args.auteur1 = args['auteur ouvrage']
		args.auteurs = args['auteurs ouvrage']
		return Ouvrage.ouvrage( args )
	end
end


Biblio.ISBN = function ( frame )
	local args = Outils.extractArgs( frame )
	local References = require( 'Module:Biblio/Références' )
	if Outils.trim(args[1]) then
		local newArgs = { isbn = args[1], categ = { isbnInvalid = false } }
		local i = 2
		while args[i] do
			newArgs['isbn' .. i] = args[i]
			i = i + 1
		end
		local listeISBN = References.isbn( newArgs )
		local categ = References.categorise{'Ouvrage avec ISBN invalide', newArgs.categ.isbnInvalid }
		return '<small>(' .. listeISBN .. ')</small>' .. categ
	else 
		return '<small>([[International Standard Book Number|ISBN]]&nbsp;inconnu)</small>' .. References.categorise{'ISBN nécessaire'}
	end
end

Biblio.rechercheIsbn = function( frame )
	local args = Outils.extractArgs( frame )
	local References = require( 'Module:Biblio/Références' )
	local newArgs = { isbn = args[1], sansLabel = true, categ = { isbnInvalid = false } }
	local isbn = References.isbn( newArgs ) or ''
	local categ = References.categorise{'Page avec ISBN invalide', newArgs.categ.isbnInvalid }
	return isbn .. categ
end


Biblio.EAN = function ( frame )
	local args = Outils.extractArgs( frame )
	local References = require( 'Module:Biblio/Références/Bac à sable' )
	if Outils.trim(args[1]) then
		local newArgs = { ean = args[1], categ = { eanInvalid = false } }
		local i = 2
		while args[i] do
			newArgs['ean' .. i] = args[i]
			i = i + 1
		end
		local listeEAN = References.ean( newArgs )
		local categ = References.categorise{'Page avec EAN invalide', newArgs.categ.eanInvalid }
		return '<small>(' .. listeEAN .. ')</small>' .. categ
	else 
		return '<small>([[EAN 13|EAN]]&nbsp;inconnu)</small>' .. References.categorise{'EAN nécessaire'}
	end
end


Biblio.ISSN = function ( frame )
	local args = Outils.extractArgs( frame )
	local References = require( 'Module:Biblio/Références' )
	if Outils.trim(args[1]) then
		local newArgs = { issn = args[1], categ = { issnInvalid = false } }
		local i = 2
		while args[i] do
			newArgs['issn' .. i] = args[i]
			i = i + 1
		end
		local listeISSN = References.issn( newArgs )
		local categ = References.categorise{'Page avec ISSN invalide', newArgs.categ.issnInvalid }
		return '<small>(' .. listeISSN .. ')</small>' .. categ
	else 
		return '<small>(inconnu)</small>' .. References.categorise{'ISSN nécessaire'}
	end
end

Biblio.rechercheIssn = function( frame )
	local args = Outils.extractArgs( frame )
	local References = require( 'Module:Biblio/Références' )
	local newArgs = { issn = args[1], sansLabel = true, categ = { issnInvalid = false } }
	local issn = References.issn( newArgs ) or ''
	local categ = References.categorise{'Page avec ISSN invalide', newArgs.categ.issnInvalid }
	return issn .. categ
end

Biblio.enLigne = function ( frame )
	local args = Outils.extractArgs( frame )
	local References = require( 'Module:Biblio/Références' )
	return '<small>[' .. References.enLigne( args )  .. ']</small>'
end


return Biblio