« WATERBEAR:Collections » : différence entre les versions

De WIKI sur Linux (ADB)
Aller à la navigation Aller à la recherche
Aucun résumé des modifications
Aucun résumé des modifications
Ligne 13 : Ligne 13 :
* Créer des entrées dans le registre pour les collections comme pour les autres objets (villes, rues, abonnements,...). Le registre en sera plus clair.
* Créer des entrées dans le registre pour les collections comme pour les autres objets (villes, rues, abonnements,...). Le registre en sera plus clair.


=Mise en oeuvre=
Toutes les modifications se font dans le registre.
Toutes les modifications se font dans le registre.
Nous n'allons pas passer en revue détaillée toute cette implémentation. Cela serait trop fastidieux.
Mais il y a un très gros problème dont il faut tenir compte. Habituellement toute entrée principale dans le registre comme les villes, les rues, les prêts fait correspondre cette entrée avec un objet. Par exemple, une entrée "ville" se lie toujours implicitement à l'objet "ville" et donc aux tables "obj_ville_acces" et "obj_ville_liens". Mais ici cette entrée "collection" devra être liée à l'objet "biblio" et donc aux tables "obj_biblio_acces" et "obj_biblio_liens". Et cette table de liens comprendra des liens vers sa propre table des données "obj_biblio_acces" alors qu'habituellement elle se lie à un autre objet.
De prime abord cela semble simple; il suffit pour tout noeud "type_obj" de mettre comme valeur "biblio" et non "collection". Mais le problème survient quand on veut utiliser les menus contextuels dans la gestion d'autres objets qui pointent vers les collections ou quand à partir des écrans de la recherche dans les collections, on veut les éditer (cataloguer). Dans ces cas, on est renvoyé d'office vers les écrans de l'objet "biblio".
Petit préambule. Comment fait-on pour repérer un enregistrement de type collection dans la table "obj_biblio_acces" parmi les livres, périodiques,... ?
Il existe trois champs:
*




Le premier problème est résolu par un nouveau script PHP de redirection décrit dans l'article "[[WATERBEAR:Menus contextuels rediriges|Menus contextuels redirigés]]".





Version du 9 janvier 2021 à 19:32

But

Cette article a pour but de réviser complètement les écrans liés à la gestion des collections afin de les dissocier des écrans actuels faits pour les documents.


Contexte

Dans la base de données, on constate qu'il existe des tables pour les collections: "obj_collection_acces" et "obj_collection_liens" comme la majorité des autres thèmes principaux (éditeurs, lecteurs, villes, ...). Mais on constate ensuite que ces tables sont vides, inutilisées.

En fait ces données traitant des collections sont mélangées avec les documents (livres, périodiques, CD, DVD,...). Les écrans utilisés pour le catalogage et la recherche sont ceux des livres en général. Ces écrans sont incohérents et remplis d'onglets vides, inutiles.

Notre but est double:

  • Créer des écrans spécifiques aux collections
  • Créer des entrées dans le registre pour les collections comme pour les autres objets (villes, rues, abonnements,...). Le registre en sera plus clair.


Mise en oeuvre

Toutes les modifications se font dans le registre. Nous n'allons pas passer en revue détaillée toute cette implémentation. Cela serait trop fastidieux.

Mais il y a un très gros problème dont il faut tenir compte. Habituellement toute entrée principale dans le registre comme les villes, les rues, les prêts fait correspondre cette entrée avec un objet. Par exemple, une entrée "ville" se lie toujours implicitement à l'objet "ville" et donc aux tables "obj_ville_acces" et "obj_ville_liens". Mais ici cette entrée "collection" devra être liée à l'objet "biblio" et donc aux tables "obj_biblio_acces" et "obj_biblio_liens". Et cette table de liens comprendra des liens vers sa propre table des données "obj_biblio_acces" alors qu'habituellement elle se lie à un autre objet.

De prime abord cela semble simple; il suffit pour tout noeud "type_obj" de mettre comme valeur "biblio" et non "collection". Mais le problème survient quand on veut utiliser les menus contextuels dans la gestion d'autres objets qui pointent vers les collections ou quand à partir des écrans de la recherche dans les collections, on veut les éditer (cataloguer). Dans ces cas, on est renvoyé d'office vers les écrans de l'objet "biblio".

Petit préambule. Comment fait-on pour repérer un enregistrement de type collection dans la table "obj_biblio_acces" parmi les livres, périodiques,... ?

Il existe trois champs:


Le premier problème est résolu par un nouveau script PHP de redirection décrit dans l'article "Menus contextuels redirigés".



Aspect

Voici quelques écrans relatifs aux collections.

  • Catalogage:
    • Ecran du catalogage simple:


WATERBEAR:Collection.cataloguer.simple.png


    • Ecran révélant les masques lors du catalogage:


WATERBEAR:Collection.cataloguer.masque.png

    • Ecran du catalogage sans filtre:


WATERBEAR:Collection.cataloguer.sansfiltre.png


  • Recherche:
    • Ecran de la définition des critères de recherche:


WATERBEAR:Collection.recherche.critere.png


    • Ecran du résultat de la recherche sous forme de liste:


WATERBEAR:Collection.recherche.liste.png


    • Ecran du résultat de la recherche sous forme notice individuelle avec la fenêtre pop-up de rebondissement:


WATERBEAR:Collection.recherche.notice.png


Intégration dans le registre

Ces corrections sont à faire dans le registre. A ce stade, vous pouvez les personnaliser. Pour les appliquer, vous pouvez soit les intégrer dans l'écran d'importation au niveau de l'administration du registre, soit exécuter, en commande de ligne sous Linux, le script contenu dans le fichier zippé ci-dessous:

Télécharger le fichier ZIP

Ce fichier est à dézipper sous Linux dans un répertoire de travail quelconque sur la machine où se trouve les sources du site WEB de Waterbear:

unzip collection.maj.registre.zip

Dans ce répertoire généré, se trouvent un sous-répertoire "registre" contenant les fichiers texte (.txt) où se trouvent les enregistrements à injecter dans le registre. Ce contenu a le format de celui utilisé dans l'interface d'exportation et d'importation de l'administration du registre de Waterbear. On trouve également un fichier de script PHP. Dans ce fichier, il faut adapter la variable "$racinewaterbear" qui doit contenir le chemin de la racine du logiciel WEB de Waterbear où on retrouve le fichier "bib.php". Par exemple, si ce chemin est "/web/waterbear" comme dans notre exemple d'installation, la variable devient (ne pas oublier la barre oblique finale "/"):

$racinewaterbear = "/web/waterbear/";

Ensuite, en commande de ligne sous Linux, positionnez-vous dans le répertoire du script et exécutez-le:

php ./maj.registre.liste.fichier.php



->retour à la personnalisation de Waterbear