Wenn zwei oder mehr Goobi viewer Instanzen aus einem Goobi workflow beliefert werden sollen, sind verschiedene Voraussetzungen zu erfüllen. An dieser Stelle ist die Konfiguration von gängigen Fragen für Goobi workflow und Goobi viewer beschrieben.
Erfassen und Auswerten der Instanz
Goobi workflow
In Goobi workflow muss erfasst werden in welcher Instanz das Werk angezeigt werden soll. Dafür muss im Regelsatz ein neues Metadatum ViewerInstance hinzugefügt werden. Dieses wird dann bei DocStructs, die das Metadatum CatalogIDDigital als Pflichtmetadatum konfiguriert hatten, ebenfalls hinzugefügt.
Das Metadatum ViewerInstance wird innerhalb des Solr Index in ein eigenständiges Feld geschrieben. Dafür muss in der Konfigurationsdatei config_indexer.xml folgende Felddefinition hinzugefügt werden:
Mit addToChildren=true und addToPages=true wird sichergestellt, dass nach Metadaten in Unterelementen und Seiten weiterhin gesucht werden kann, wenn die Instanz-Einschränkung gesetzt ist.
Goobi viewer Core
Pro Goobi viewer Instanz muss nun ein staticQuerySuffix definiert werden, der angibt welche Bedingung erfüllt sein muss damit Werke angezeigt werden:
Das + steht für ein "UND". Die Klammern fassen alles darin stehende zusammen. Wenn innerhalb einer Query Bedingungen nicht explizit miteinander verknüpft sind, dann entspricht das automatisch einem "ODER".
Erfassen und Anzeigen individueller Sammlungen
Goobi workflow
Um pro Goobi viewer Instanz eigene Sammlungen zu erfassen müssen diese als Metadatum eingepflegt werden. Dafür wird im Regelsatz pro Instanz ein neues Metadatum hinzugefügt.
Die relevanten Teile für einen weiteren Sammlungsbaum aus dem Regelsatz sind:
Bei Bedarf kann in der goobi_metadataDisplayRules.xml ein DropDown Menü mit vorgegebenen Sammlungsnamen und Werten definiert werden.
Goobi viewer Indexer
Zuerst müssen die exportierten Sammlungen innerhalb des Solr Index in ein eigenständiges Feld geschrieben werden. Dafür muss in der Konfigurationsdatei config_indexer.xml folgende Felddefinition hinzugefügt werden:
Dieses Feld muss nun anstelle des sonst üblichen Feldes DC in der lokalen config_viewer.xml konfiguriert werden. Zum Beispiel:
<!-- Show MD2_DC_VIEWER2 instead of DC as collection field at the metadata page -->
<metadata>
<mainMetadataList>
<template name="_DEFAULT">
<metadata label="MD2_DC_VIEWER2" value="">
<param type="translatedfield" key="MD2_DC_VIEWER2_UNTOKENIZED" />
</metadata>
</template>
</mainMetadataList>
</metadata>
<!-- Use MD2_DC_VIEWER2 instead of DC for facetting and in advanced search -->
<search>
<drillDown>
<field initialElementNumber="3">YEAR</field>
<hierarchicalField initialElementNumber="3">MD2_DC_VIEWER2</hierarchicalField>
<field initialElementNumber="3">DOCSTRCT_TOP</field>
<field initialElementNumber="3">DOCSTRCT_SUB</field>
<field initialElementNumber="3" sortOrder="alphabetical_asc">MD_PLACEPUBLISH</field>
</drillDown>
<advanced>
<searchFields>
<field>DEFAULT</field>
<field>FULLTEXT</field>
<field>CMS_TEXT_ALL</field>
<field>PI_TOPSTRUCT</field>
<field hierarchical="true">MD2_DC_VIEWER2</field>
<field>DOCSTRCT_TOP</field>
<field>DOCSTRCT_SUB</field>
<field>MD_TITLE</field>
<field>MD_CREATOR</field>
<field>MD_PUBLISHER</field>
<field>MD_PLACEPUBLISH</field>
<field>MD_YEARPUBLISH</field>
<field untokenizeForPhraseSearch="true">MD_SHELFMARK</field>
</searchFields>
</advanced>
</search>
<!-- Additional configuration such as for the breadcrumbs for MD_DC_VIEWER2 -->
<collections>
<collection field="MD2_DC_VIEWER2">
<addHierarchyToBreadcrumbs>true</addHierarchyToBreadcrumbs>
</collection>
<redirectToWork>false</redirectToWork>
</collections>
Außerdem muss der Feldname natürlich in den messages Dateien entsprechend übersetzt werden. Zum Beispiel:
MD2_DC_VIEWER2=Sammlung
Goobi viewer Backend
Für die Anzeige einer Sammlungsseite mit eigenem Baum muss nun im Goobi viewer Backend eine neue CMS Seite basierend auf dem Template "Sammlungsanzeige" angelegt, konfigurier, als überschriebene statische Seite sowie im Menü verlinken werden: