GeneWeb

GeneWeb:
Personnalisation des pages



Cette partie indique comment personnaliser les pages d'accueil et les autres pages et mettre des pages associées. Elle s'adresse aux personnes ayant déjà un peu manipulé GeneWeb et qui veulent entrer dans les détails.
bullet Page d'accueil
bullet Macros
bullet Pages associées
bullet Personnalisation de toutes les pages

Page d'accueil

La page d'accueil est construite à partir de fichiers texte, les fichiers "start.txt" fournis avec la distribution de GeneWeb. Il est possible de modifier ces fichiers et/ou d'en faire une version spécifique pour une base de données.

Ces fichiers contiennent du HTML mélangé avec des "macros" (voir section suivante). Si vous voulez créer de tels fichiers ou les modifier, n'utilisez pas d'éditeur de HTML, mais un éditeur de textes normal.

Pour construire la page d'accueil de la base "toto", GeneWeb va chercher parmi les fichiers suivants, dans cet ordre:
bulletbdir/lang/lg/toto.txt
bullethdir/lang/lg/toto.txt
bulletbdir/lang/toto.txt
bullethdir/lang/toto.txt
bulletbdir/lang/lg/start.txt
bullethdir/lang/lg/start.txt
bulletbdir/lang/start.txt
bullethdir/lang/start.txt
où:
bullet"bdir" = valeur de "-bd" de la commande "gwd" (défaut: répertoire courant).
bullet"hdir" = valeur de "-hd" de la commande "gwd" (défaut: répertoire courant).
bullet"lg" = langue courante.

Les fichiers "hdir/lang/lg/start.txt" sont fournis avec la distribution. Pour vous faire un fichier personnalisé, le plus simple est de partir d'une copie d'un fichier "start.txt" que vous arrangerez à votre façon. Si la présentation des fichiers "start.txt" ne vous plait pas, vous pouvez aussi les changer directement.

Attention cependant: d'une version de GeneWeb à l'autre, les fichiers "start.txt" peuvent être améliorés. Si vous prenez une nouvelle version et voulez profiter des améliorations, regardez si les fichiers "start.txt" ont été modifiés et incluez leurs modifications dans vos fichiers personnalisés.

Macros

Comme indiqué précédemment, les fichiers de pages d'accueil ne sont pas du pur HTML. Ils contiennent des "macros". Ce sont des séquences commençant par le caractère "%" et suivis par une lettre. Exemples: "%s", "%x", etc.

Ces macros sont remplacées par des valeurs qui dépendent du contexte: nom de la base, langue, nombre de personnes dans la base, etc.

Il y a également un traitement particulier pour les crochets "[" et "]": s'il y a un texte entre crochets, il est traduit dans la langue courante à partir du lexique (fichier "lexicon.txt") avec les modifications suivantes:
bulletS'il y a une étoile après le crochet ouvrant, la première lettre de la traduction est convertie en majuscule.
bulletSi le crochet fermant est suivi d'un nombre, cela correspond à la n-ème occurrence de la traduction (commençant à 0), les occurrences étant séparées par des "/". Si cette occurrence n'existe pas, c'est la première qui est prise.

Pour comprendre comment les macros sont utilisées, le mieux est de regarder les fichiers "start.txt" fournis avec la distribution.

Voici le sens des macros "%":
bulletBase.
bullet"%t" : nom de la base.
bullet"%f" : en mode serveur, nom de la base, suivi de l'eventuel mot de passe (ex: "toto_xyzzy"); en mode CGI, nom de la commande CGI (ex: "gwd.exe").
bullet"%g" : en mode serveur, comme "%f"; en mode CGI, nom de la commande CGI suivi de "?b=", du nom de la base et d'un point-virgule (ex: "gwd.exe?b=toto;").
bullet"%s" : valeur de "%f" suivi d'un point d'interrogation et des variables contextuelles (voir ci-dessous) suivies d'un point-virgule. Ex: "toto?lang=it;iz=8233;".
bulletCompte.
bullet"%c" : nombre d'accès à la page d'accueil.
bullet"%q" : nombre de requêtes.
bullet"%d" : date de la première consultation.
bulletConditionnels.
Les conditionnels commencent par "%I" suivi d'une expression booléenne (vrai ou faux) et se terminent par "%E". Le texte entre ces deux macros est affiché si et seulement si l'expression booléenne est vraie. Une expression booléenne est soit:
bullet"f" : on est "ami"
bullet"w" : on est "magicien"
bullet"j" : on est "magicien" juste "ami" (cf fichier a.gwf, "wizard_just_friend")
bullet"c" : on est en mode cgi
bullet"h" : il y a un fichier historique
bullet"l" : le navigateur ne traite pas les tables
bullet"n" : il y a des notes pour la base de données
bullet"t" : il y a une recherche par titres de noblesse
bullet"z" : il y a une personne prise comme référence Sosa (voir macro "%u")
bullet"a" : il y a une restriction globale d'accès à la base de données
bullet"N" : contraire de l'expression qui suit
bullet"|" : "ou" logique entre les deux expressions qui suivent
bullet"&" : "et" logique entre les deux expressions qui suivent
Exemples:
bullet afficher le texte s'il y a une recherche par titre: %It...%E
bullet afficher le texte si on est ni "magicien" ni "ami": %I&NwNf...%E
bulletDivers.
bullet"%r" suivi d'un nom et d'un retour-ligne : inclusion du fichier "nom.txt".
bullet"%b" : valeur de la variable "body_prop" du fichier "toto.gwf" pour la base "toto".
bullet"%h" : variables contextuelles (voir ci-dessous) sous la forme "<input type=hidden name=var value=val>".
bullet"%l" : langue.
bullet"%n" : nombre de personnes de la base.
bullet"%u" : personne prise comme référence Sosa.
bullet"%%" : un seul "%".
bullet"%[" : un "[".
bullet"%]" : un "]".

Certaines macros font références à des variables contextuelles. Ce sont:
bulletb : en mode CGI, nom de la base.
bulletlang : langue.
bulletiz : numéro de l'éventuelle personne prise comme référence Sosa.

Pages associées

Dans votre page d'accueil personnalisée, vous pouvez mettre des liens vers des fichiers associés qui seront traités par GeneWeb de la même façon: les macros y seront transformées.

Par exemple, si vous voulez mettre une page spéciale sur les personnes célèbres de votre base, faites un fichier que vous nommerez "celebres.txt" et que vous mettrez dans le répertoire "bdir/lang/lg" ou le répertoire "bdir/lang" (voir première section).

La requête d'accès à "celebres.txt" s'écrit: "m=H;v=celebres". Dans la page d'accueil, vous mettrez donc:

   Les gens <a href="%sm=H;v=celebres">célèbres</a>
   de ma base.

Dans "celebres.txt", vous pourrez mettre des liens vers des personnes de votre base, indépendamment de son nom et du contexte, en utilisant les bonnes macros.

Les macros particulièrement intéressantes sont:
bullet"%b" que vous pourrez mettre dans le tag "<body>" en l'écrivant "<body%b>".
bullet"%s" que vous pourrez mettre dans les liens.
Exemple de phrase dans "celebres.txt":

   Voyez mon cousin <a href="%sp=louis;n=de+bourbon;oc=5">
   Louis XIV</a> et mes
   <a href="%sem=R;ep=jean;en=dupont;m=NG;n=louis+xiv;t=PN">
   liens de parenté</a> avec lui.

Voyez également comment faire correctement des liens vers des pages de GeneWeb.

Remarquez que la "requête évoluée" fonctionne comme un fichier associé, de nom "advanced.txt".

Toutes les pages

Les pages, y compris la page d'accueil, peuvent être personnalisées à trois endroits:
bulletVous pouvez ajouter un fichier de nom base.hed (si "base" est le nom de votre base de données) qui sera inséré dans tous les en-têtes des pages (entre <head> et </head>). Permet d'y insérer des feuilles de style, par exemple. À mettre dans le répertoire "lang" et/ou, si vous voulez qu'il soit différent pour la langue "xy" dans le répertoire "lang/xy".
bulletDe même, vous pouvez ajouter un fichier de nom base.trl qui sera inséré derrière le copyright de GeneWeb à chaque page.
bulletEnfin, vous avez la possibilité de positionner la variable body_prop de votre fichier base.gwf qui sera inséré dans la balise "<body>" de toutes les pages. Utile pour mettre une couleur ou un motif de fond, ou pour changer les couleurs des textes affichés. Voir cette section du chapitre "comment démarrer avec GeneWeb".


Retour vers Mode d'Emploi

© Copyright 2001 INRIA - GeneWeb