From 2985c8b73f48b10a77c3613405cff1045f326af6 Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Wed, 13 Nov 2024 08:16:10 +0100 Subject: [PATCH 1/4] Display a tab with information about groups --- app/dashboard/guests/page.tsx | 28 ++++++++----- app/lib/definitions.ts | 11 +++++ app/ui/groups/table.tsx | 75 +++++++++++++++++++++++++++++++++++ 3 files changed, 105 insertions(+), 9 deletions(-) create mode 100644 app/ui/groups/table.tsx diff --git a/app/dashboard/guests/page.tsx b/app/dashboard/guests/page.tsx index 2b65f56..2ce7335 100644 --- a/app/dashboard/guests/page.tsx +++ b/app/dashboard/guests/page.tsx @@ -1,24 +1,34 @@ /* Copyright (C) 2024 Manuel Bustillo*/ -import { lusitana } from '@/app/ui/fonts'; import AffinityGroupsTree from '@/app/ui/guests/affinity-groups-tree'; import GuestsTable from '@/app/ui/guests/table'; import React, { Suspense } from 'react'; import SkeletonTable from '@/app/ui/guests/skeleton-row'; - - +import { TabView, TabPanel } from 'primereact/tabview'; +import GroupsTable from '@/app/ui/groups/table'; export default function Page() { return (
-

Guests

-
- }> - - -
+ + +
+ }> + + +
+ + +
+ }> + + +
+ +
+ ); } \ No newline at end of file diff --git a/app/lib/definitions.ts b/app/lib/definitions.ts index 07eef8b..3ea3fe1 100644 --- a/app/lib/definitions.ts +++ b/app/lib/definitions.ts @@ -47,8 +47,19 @@ export type Group = { guest_count: number; icon: string; children: Group[]; + color: string; + attendance?: AttendanceSummary }; +export type AttendanceSummary = { + considered: number; + invited: number; + confirmed: number; + declined: number; + tentative: number; + total: number; +} + export type Invoice = { id: string; customer_id: string; diff --git a/app/ui/groups/table.tsx b/app/ui/groups/table.tsx new file mode 100644 index 0000000..387c7ea --- /dev/null +++ b/app/ui/groups/table.tsx @@ -0,0 +1,75 @@ +/* Copyright (C) 2024 Manuel Bustillo*/ + +'use client'; + +import TableOfContents from '../components/table-of-contents'; +import React, { useState } from 'react'; +import { Group } from '@/app/lib/definitions'; + +export default function GroupsTable() { + const [groups, setGroups] = useState>([]); + const [groupsLoaded, setGroupsLoaded] = useState(false); + + function loadGroups() { + fetch("/api/groups") + .then((response) => response.json()) + .then((data) => { + setGroups(data.map((record: any) => { + return ({ + id: record.id, + name: record.name, + color: record.color, + attendance: { + considered: record.considered, + invited: record.invited, + confirmed: record.confirmed, + tentative: record.tentative, + declined: record.declined, + total: record.total, + } + }); + })); + setGroupsLoaded(true); + }, (error) => { + return []; + }); + } + + !groupsLoaded && loadGroups(); + + return ( + ( + + + {group.name} + + +
+ + + {group.attendance?.confirmed} + + + {group.attendance?.tentative} + + + {group.attendance?.invited} + + + {group.attendance?.declined} + + + {group.attendance?.considered} + + + {group.attendance?.total} + + + )} + /> + ) +} -- 2.47.1 From a6c517f8a10399dd4024d4c659777b2fb4aef058 Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Wed, 13 Nov 2024 08:47:50 +0100 Subject: [PATCH 2/4] Adjust styles of confirmed column --- app/ui/groups/table.tsx | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/app/ui/groups/table.tsx b/app/ui/groups/table.tsx index 387c7ea..9b4e76b 100644 --- a/app/ui/groups/table.tsx +++ b/app/ui/groups/table.tsx @@ -50,22 +50,22 @@ export default function GroupsTable() {
- + {group.attendance?.confirmed} - + {group.attendance?.tentative} - + {group.attendance?.invited} - + {group.attendance?.declined} - + {group.attendance?.considered} - + {group.attendance?.total} -- 2.47.1 From 3e9775af9967019c64be6926b5ef6e0fe3c0856d Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Wed, 13 Nov 2024 08:58:55 +0100 Subject: [PATCH 3/4] Make color optional in a group --- app/lib/definitions.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/lib/definitions.ts b/app/lib/definitions.ts index 3ea3fe1..572914b 100644 --- a/app/lib/definitions.ts +++ b/app/lib/definitions.ts @@ -47,7 +47,7 @@ export type Group = { guest_count: number; icon: string; children: Group[]; - color: string; + color?: string; attendance?: AttendanceSummary }; -- 2.47.1 From 39907b0105d16d2d6837df155ed1d8b9f30312d4 Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Wed, 13 Nov 2024 19:09:50 +0100 Subject: [PATCH 4/4] Fix tests --- app/dashboard/layout.tsx | 2 +- tests/guests.spec.ts | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/app/dashboard/layout.tsx b/app/dashboard/layout.tsx index d179387..69055f9 100644 --- a/app/dashboard/layout.tsx +++ b/app/dashboard/layout.tsx @@ -8,7 +8,7 @@ export default function Layout({ children }: { children: React.ReactNode }) {
-
{children}
+
{children}
); } \ No newline at end of file diff --git a/tests/guests.spec.ts b/tests/guests.spec.ts index 05e7215..02a8bc7 100644 --- a/tests/guests.spec.ts +++ b/tests/guests.spec.ts @@ -1,7 +1,8 @@ import { test, expect } from '@playwright/test' - + test('should navigate to the guests page', async ({ page }) => { await page.goto('/dashboard/guests') - await expect(page.getByRole('heading', { name: 'Guests' })).toContainText('Guests') + await expect(page.getByRole('tab', { name: 'Groups' })).toContainText('Groups') + await expect(page.getByRole('tab', { name: 'Guests' })).toContainText('Guests') }) \ No newline at end of file -- 2.47.1