Storyblok
Aangezien ik Storyblok als CMS onderzocht heb, ben ik ook degene geweest die de connectie met Storyblok heeft opgezet. Hierna heb ik ook gelijk geprobeerd componenten met de uit Storyblok-afkomstige data te creëren zodat we de werking hiervan zo snel mogelijk aan de opdrachtgever voor konden leggen.
Storyblok koppelen
Storyblok is headless en dus volledig losgekoppeld van de website en niet samenhangt zoals met Wordpress nu wel het geval is. Nu kunnen we door middel van de Storyblok APl met onze Storyblok-omgeving praten en de data ophalen die we nodig hebben.
Gelukkig stelt Storyblok zowel de API als twee keys die we nodig hebben open zodat we er gebruik van kunnen maken. De Storyblok API kon ik eenvoudig installeren door 't volgende te doen:
Vervolgens moesten we die JS client gebruiken. Ik heb er daarom voor gekozen om een aparte `storyblok-instance` aan te maken zodat we daarna die instance overal kunnen gebruiken en maar op één plek de keys hoeven mee te geven:
Allereerst haalde ik de environment keys op die we nodig hebben. Als we niet in productie zitten willen we de PREVIEW_KEY van Storyblok gebruiken zodat we ook drafts op kunnen halen uit het CMS.
In productie wilde ik echter alleen de gepubliceerde pagina's en componenten ophalen dus gebruiken we de PUBLIC_KEY. Door dit bestandje te exporteren kunnen we precies deze instance overal gebruiken waar we data van Storyblok moeten ophalen, super handig dus!
Data van Storyblok gebruiken
Om nu daadwerkelijk de data van Storyblok te gebruiken moest ik dus de bovenstaande instance gebruiken. Dit kan eenvoudig door hem te importeren en de methods te gebruiken die erop beschikbaar zijn volgens de documentatie van Storyblok. In ons geval hebben we enkel de get
method nodig:
Omdat we Eleventy gebruiken als Static Site Generator (we hebben voor Eleventy gekozen omdat dit, nadat ik wat onderzoek deed naar soortgelijke mogelijkheden, de enige SSG is die Vanilla JavaScript gebruikt) kunnen we in een `_data` map bestanden aan maken om tijdens buildtime data op te halen.
Vervolgens wordt de opgehaalde data onder de naam van het bestand beschikbaar in je templates als volgt (dit is eveneens hoe de homepage er in eerste instantie uit zag):
De bovenstaande template markup wordt dus door Eleventy gegenereerd naar een statische index.html zodra we zeggen:
Eleventy haalt voor ons dan alle benodigde data op, schrijft die bestanden weg en klaar is Kees, je hebt een hele website.
Preview omgeving opzetten in Storyblok
Er zat wel één nadeel aan het moeten draaien van een build (zoals dat heet) om de nieuwe data te kunnen gebruiken: We kunnen onze preview omgeving niet zomaar live updaten, iets wat we idealiter wel zouden willen.
Om dit alsnog te kunnen bewerkstelligen had ik bedacht om een aparte preview omgeving te bouwen waarbij de componenten allemaal opgebouwd zijn uit JavaScript zodat we de pagina alsnog live kunnen updaten.
De connectie maken met Storyblok
Ook voor het opzetten van de preview omgeving moest ik weer allereerst een connectie maken met Storyblok. Dit konden we doen doormiddel van een soort 'bruggetje' van de preview omgeving naar onze website. Het enige wat we hiervoor hoeven te doen is een script inladen in onze website zodat we gebruik kunnen maken van de SDK van Storyblok:
Vervolgens kunnen we nu gebruik maken van een `storyblok` variabele in onze client-side code:
Het 'change' event werd afgevuurd wanneer iemand op 'Save' of cmd + s drukte binnen het CMS. Als iemand nu dus de preview omgeving opslaat halen wij de nieuwe data op en updaten we de preview omgeving met de verse data door JavaScript componenten te updaten.
De pagina wordt dus als het ware gehijacked door JavaScript wanneer iemand binnen de preview omgeving erin werkt. Hierdoor heb je dus alsnog een live updatende preview omgeving zodat de eindgebruiker zijn of haar wijzigingen kan volgen.
Last updated