-
Notifications
You must be signed in to change notification settings - Fork 1
Home
We hebben goed zitten brainstormen. We wilde iets leuks maken wat niet te voor de hand liggend was en wel paste bij de opdracht. We hadden eerst ideeën om de squad page te maken als een clone van Tinder of Instagram.
Wij hadden bedacht om een boekenkast in de browser te maken waar je de jaarboeken van de tweedejaars in kon bekijken. In de jaarboeken staan dan foto's van alle studenten in het tweede jaar.
[plaatje van die tekening]
Voordat er ontwepen waren van het jaarboek hebben we de basis al gemaakt in code.
Svelte installeren was geen probleem, we hadden afgesproken eerst de functionaliteiten werkend te krijgen en daarna pas de styling toe te passen. De functionaliteiten zijn. Laat een lijst met jaarboeken zien, laat de details van een jaarboek zien wanneer de gebruiker er op klikt. Dit moet allemaal data zijn die uit prismic.io komt.
De Prismic installatie was wel anders dan waar we voorheen mee gewerkt hebben. Het ging goed alleen was het wel een hele nieuwe omgeving. De slice machine was onduidelijk in het begin omdat je een beetje wordt los gelaten. Uiteindelijk kwam ik er achter dat sommige velden verplicht zijn zoals je uid.
Nadat alles geinstalleerd was konden we beginnen met het datamodel in prismic. We hadden al snel de homepage werkend gekregen. We wilde ook een detail pagina maken met de squads er in. Dit ging wat minder makkelijk. We hebben heel veel verschillende mogenlijkheden geprobeerd. Uiteindelijk was het gelukt om de juiste url te krijgen wanneer je op de overzichtspagina op een element klikte alleen werden we nog niet goed geredirect. Pas toen we sveltekit routing begrepen werkte dit pas. We hebben een volder met boek
gemaakt en daarin een volder [uid]
. Daar binnenin zit +page.svelte
en +page.server.js
.
Hier is hoe de +page.server.js
in elkaar zit
import { createClient } from "$lib/prismicio"
export async function load({fetch, request, params }){
const client = createClient({fetch, request})
const document = await client.getByUID('yearbook', params.uid)
return document.data
}
We willen natuurlijk de juiste pagina laden met de juiste data. Als de gebruiker op een jaarboek klikt in het overzicht dat klikt hij op de slug van dat boek. De slug komt overeen met het uid van de pagina yearbook. Doormiddel het woordje params
weet de server wat er aangeklikt is en kunnen we daar naartoe routen en de juiste data ophalen.
We hebben de website zo ontworpen dat er 20 members per pagina getoond kunnen worden. Omdat er meer dan 20 mensen in de prismic data zit is dit een uitdaging. We hebben nu een loop van 20 mensen. Dat doen we zo.
<div id="card-container" class="container">
{#each slice.items as item, index (item.slug.text)}
{#if index < currentItemIndex}
{:else if currentPage === 1 && index < currentItemIndex + 20}
<!-- Render the next 20 items on page 1 -->
<div class="card-item">
<div class="inner-card">
{#if !item.image.url}
<img class="yearbook-image" src="/img/placeholder-image.jpg" alt="" />
{:else}
<img class="yearbook-image" src={item.image.url} alt={item.image.alt} />
{/if}
<p>{item.name[0].text}</p>
</div>
</div>
{/if}
{/each}
</div>
Omdat we een boek maken moet de loop opgesplits worden in meerdere delen. Elk deel moet weten waar de loop is opgehouden en het hervatten waar deze gebleven is. Dit is nog een uitdaging maar we denken wel dat het moet lukken.
Doormiddel van app.netlify.com kunnen we de sveltekit omgeving hosten met sveltekit geinstalleerd.