From 567ce207cf9028e6aff3ffc82357af0d08d987ff Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Sat, 16 Nov 2024 00:45:45 +0100 Subject: [PATCH 1/3] Adapt the guests table to use the new API format --- app/lib/definitions.ts | 2 +- app/ui/guests/table.tsx | 24 ++++++++++++------------ 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/app/lib/definitions.ts b/app/lib/definitions.ts index 572914b..f1d3641 100644 --- a/app/lib/definitions.ts +++ b/app/lib/definitions.ts @@ -23,7 +23,7 @@ export type Guest = { name: string; group_name?: string; color?: string; - status?: 'Considered' | 'Invited' | 'Confirmed' | 'Declined' | 'Tentative'; + status?: 'considered' | 'invited' | 'confirmed' | 'declined' | 'tentative'; } export type Expense = { diff --git a/app/ui/guests/table.tsx b/app/ui/guests/table.tsx index 6e8d5ad..6d93e3b 100644 --- a/app/ui/guests/table.tsx +++ b/app/ui/guests/table.tsx @@ -17,12 +17,12 @@ export default function guestsTable() { fetch("/api/guests.json") .then((response) => response.json()) .then((data) => { - setGuests(data.data.map((record: any) => { + setGuests(data.map((record: any) => { return ({ id: record.id, - name: record.attributes.name, - group_name: record.attributes.group_name, - status: record.attributes.status + name: record.name, + status: record.status, + group_name: record.group.name, }); })); }, (error) => { @@ -82,11 +82,11 @@ export default function guestsTable() { @@ -94,13 +94,13 @@ export default function guestsTable() { - {guest.status === 'Considered' && ()} - {(guest.status === 'Invited' || guest.status === 'Tentative') && ( + {(guest.status === 'invited' || guest.status === 'tentative') && ( <> - {guest.status != 'Tentative' && } + {guest.status != 'tentative' && } )} From 6fcf7d87a860161ce8efe00cc9f20da271269b50 Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Sat, 16 Nov 2024 00:49:04 +0100 Subject: [PATCH 2/3] Adapt guest spec tests to the new API format --- tests/guests.spec.ts | 46 +++++++++++++++++++------------------------- 1 file changed, 20 insertions(+), 26 deletions(-) diff --git a/tests/guests.spec.ts b/tests/guests.spec.ts index d34ab37..cabc6ad 100644 --- a/tests/guests.spec.ts +++ b/tests/guests.spec.ts @@ -2,32 +2,26 @@ import { test, expect, Page } from '@playwright/test' const mockGuestsAPI = ({ page }: { page: Page }) => { page.route('*/**/api/guests.json', async route => { - const json = { - data: [ - { - "id": "f4a09c28-40ea-4553-90a5-96935a59cac6", - "type": "guest", - "attributes": { - "id": "f4a09c28-40ea-4553-90a5-96935a59cac6", - "group_id": "2fcb8b22-6b07-4c34-92e3-a2535dbc5b14", - "status": "Tentative", - "name": "Kristofer Rohan DVM", - "group_name": "Childhood friends" - } - }, - { - "id": "bd585c40-0937-4cde-960a-bb23acfd6f18", - "type": "guest", - "attributes": { - "id": "bd585c40-0937-4cde-960a-bb23acfd6f18", - "group_id": "da8edf26-3e1e-4cbb-b985-450c49fffe01", - "status": "Invited", - "name": "Olevia Quigley Jr.", - "group_name": "Work" - } - }, - ] - }; + const json = [ + { + "id": "f4a09c28-40ea-4553-90a5-96935a59cac6", + "status": "Tentative", + "name": "Kristofer Rohan DVM", + "group": { + "id": "2fcb8b22-6b07-4c34-92e3-a2535dbc5b14", + "name": "Childhood friends", + } + }, + { + "id": "bd585c40-0937-4cde-960a-bb23acfd6f18", + "status": "Invited", + "name": "Olevia Quigley Jr.", + "group": { + "id": "da8edf26-3e1e-4cbb-b985-450c49fffe01", + "name": "Work", + } + }, + ]; await route.fulfill({ json }) }) From 7b62992a5f0f37ffc236bd7a6659e26c7ebe60a7 Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Sun, 17 Nov 2024 11:39:56 +0100 Subject: [PATCH 3/3] Fix lowercase issues in API mocks for playwright --- tests/guests.spec.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/guests.spec.ts b/tests/guests.spec.ts index cabc6ad..5fc76bc 100644 --- a/tests/guests.spec.ts +++ b/tests/guests.spec.ts @@ -5,7 +5,7 @@ const mockGuestsAPI = ({ page }: { page: Page }) => { const json = [ { "id": "f4a09c28-40ea-4553-90a5-96935a59cac6", - "status": "Tentative", + "status": "tentative", "name": "Kristofer Rohan DVM", "group": { "id": "2fcb8b22-6b07-4c34-92e3-a2535dbc5b14", @@ -14,7 +14,7 @@ const mockGuestsAPI = ({ page }: { page: Page }) => { }, { "id": "bd585c40-0937-4cde-960a-bb23acfd6f18", - "status": "Invited", + "status": "invited", "name": "Olevia Quigley Jr.", "group": { "id": "da8edf26-3e1e-4cbb-b985-450c49fffe01",