Aller au contenu

Module:Biblio

Une nouvelle de Wikinews, la source d'informations que vous pouvez écrire.

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.

Fonctions exportables :

  • ouvrage(frame) – modèle {{Ouvrage}} ;
  • chapitre(frame) – modèle {{Chapitre}} ;
  • article(frame) – modèle {{Article}} ;
  • lienWeb(frame) – modèle {{Lien web}} ;
  • 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 :


-- 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' )
    local newArgs = { categIsbnInvalid = false }
    
    if Outils.trim(args[1]) then
	    newArgs.isbn1 = args[1]
	    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.categIsbnInvalid }
	    return '<small>(' .. listeISBN .. ')</small>' .. categ
	else 
		return '<small>([[International Standard Book Number|ISBN]]&nbsp;inconnu)</small>' .. References.categorise{'ISBN nécessaire'}
	end
end


Biblio.ISSN = function ( frame )
    local args = Outils.extractArgs( frame )
    local References = require( 'Module:Biblio/Références' )
    return References.ISSN( args ) 
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