Twig Templates and Archipelago
Archipelago uses a fast, cached templating system that is core to Drupal, called Twig. In its guts (or its heart?) Archipelago uses this system to transform the close to your needs open schema metadata that lives in every strawberryfield as JSON into close to other one's fixed schema needs metadata. This is quite simple, but it is an essential component of our vision of how a repository should manage metadata.
What is Twig?
Twig is a template engine for PHP part of Symfony framework.
- Twig in Symfony
- Twig in Drupal
- A template engine is a processor. It allows you to mix and process templates or "blue prints" with data to generate an output document.- Template: Some type of static Document using, in our case the Twig Pseudo coding language (we name this a “Frame”)
- Data: Your Archipelago Digital Object (ADO) info and your Metadata
- Processor: Allows you to use a rich and expressive language from the Template to pick, check, iterate, transform and output your data inside the Template. We refer to this as “casting”.
 
Where is Twig used in Archipelago?
This templating system is exposed to Archipelago users through the UI, and is stored in the repository as content. This setup empowers users to fully control how metadata is transformed and published without touching their individual sources or needing to manage hard-coded configurations. We named these readily accessible and powerful templates Metadata Display entities, but they serve more than just display needs.
Twig drives every Page in a Drupal 9/10 environment.
- Twig templates are normally files (.twig.html) that live in your Code.
- Modules provide Templates, Themes provide Templates
Twig drives every aspect of your ADO exposure to the world in Archipelago and even batch Ingest.
- Strawberryfield Metadata (JSON, your Data) is passed through a Metadata Display Entity which holds:- A Twig template (so you do not need to edit Files)
- A desired output serialization format (the Output Document)
 
Twig Templates as Metadata Display Entities
Templates or recipes can be shared, exported, ingested, updated, and adapted in many ways. This means you can make changes quickly without having to wait for the next major release of Archipelago or your favorite Metadata Schema Specs Committee’s agreement to implement the next or the last version. This module not only handles metadata but media assets as well. It will extract local or remote URIs and files from your metadata and render them as media viewers: books, 3D models, images, panoramas, A/V, all with IIIF in its soul.
Metadata Display Entities are used for:
- Display:- ADO landing pages (via Drupal Field Formatter)
- IIIF or JSON driven viewers (via Drupal Field Formatter and using Exposed Metadata Endpoints)
- Map Formatter (Drupal Field Formatter)
- Custom Blocks (Drupal Views)
- Search Result Displays (Drupal Views)
- Collection and Creative Work Series (old compound) displays (Drupal Views)
 
- Machinable Output- Exposed Metadata Endpoints (Standalone URLs to access metadata)
- Metadata API, both Open API Wrapper and per Record Templates
 
- Batch Ingest- AMI Ingest: To transform your CSV data (one row == DATA) to Strawberry field JSON to generate an ADO
 
Twig Templates Shipped with Archipelago
Archipelago Ships with:
- IIIF Manifest V3 for Images (JSON-LD) Metadata Display
- IIIF Manifest V2 for Images and Documents (JSON-LD) Metadata Display
- IIIF Manifest V3 for Collections (JSON-LD) Metadata Display
- IIIF Manifest V3 for Creative Work Series/Compound Objects Parent and Children (JSON-LD) Metadata Displays
- A General ADO Description (HTML) Metadata Display
- A Linked Data Display (HTML) Metadata Display
- GEOJSON (JSON) Metadata Display
- An AMI (JSON) Ingest Template
- A Multiple Thumbnails via IIIF and Fontawesome (HTML) Metadata Display
- A Metadata Abstract for Search Results (HTML) Metadata Display
- A Simple Dublin Core (XML) Metadata Display
- MODS 3.7 (XML) Metadata Display
- A Schema.org (JSON-LD) Metadata Display
- An Open API (OAI-PMH) wrapper Metadata Display
- An Open API (OAI-PMH, Unqualified DC) per Record Metadata Display
- Carousel (in Bootstrap) for Images (HTML) Metadata Display
You can find these templates here:
- On Github:
- In your local instance: http://localhost:8001/metadatadisplay/list
- In your live instance: https://yourdomain.org/metadatadisplay/list
Archipelago (the humans) will keep adding and refining these with every release.
Instructions and Examples
While a lot of core needs and use cases are covered with the Twig Templates shipped with Archipelago, you may want to add more Input elements to your Webforms, which in turn will generate new JSON Values, which in turn you may want to show/expose to end users.
Knowing (even if you do not plan to) how to edit or create your own Twig templates is important.
- This guide covers the Basics of Working With Twig in Archipelago
- And this section of the above guide contains Full Examaples of Common Use Cases
- We also have two separate guide pages for Twig Recipe Cards for Common Use Cases and more Advanced Twig Recipe Cards
- This guide covers a Recommended Workflow
- You may also want learn more about what format_strawberryfieldcan do and what many other possibilities are exposed through our templating system in this guide: Strawberryfield Formatters.
- Metadata Display Preview: use Preview to check your template outputs against Archipelago Digital Objects or AMI Sets.
- Metadata Display Usage: use the Usage tab to check where a Metadata Display Template is currently being used across your Archipelago.
Thank you for reading! Please contact us on our Archipelago Commons Google Group with any questions or feedback.
Return to the Archipelago Documentation main page.
