Display a tree with the groups of guests (with mocked data) #2

Merged
bustikiller merged 2 commits from feature/categories-tree into main 2024-08-11 15:28:07 +00:00
2 changed files with 37 additions and 77 deletions
Showing only changes of commit 9c2c84a45b - Show all commits

View File

@ -1,89 +1,49 @@
'use client' 'use client'
import React, { useState, useEffect } from 'react'; import React, { useState, useEffect, Suspense } from 'react';
import { Tree } from 'primereact/tree'; import { Tree } from 'primereact/tree';
import { PrimeIcons } from 'primereact/api'; import { PrimeIcons } from 'primereact/api';
import { debug } from 'console';
export default function AffinityGroupsTree() { export default function AffinityGroupsTree() {
const [nodes, setNodes] = useState( const [nodes, setNodes] = useState([]);
[ const parseNode = (record: any, included: any[]) => {
{ if (!record.attributes) {
key: 1, record = included.find((a) => a.id === record.id);
label: "Lilly's guests", }
icon: PrimeIcons.HEART,
draggable: false, const children = (record?.relationships?.children?.data || []).map((child: any) => {
children: [ return (parseNode(child, included));
{ });
key: 11,
label: "Family",
icon: PrimeIcons.HOME,
leaf: true,
className: "px-4",
},
{
key: 12,
label: "Country club",
icon: PrimeIcons.SUN,
className: "px-4",
}, return ({
{ key: record.id,
key: 13, label: record.attributes.name,
label: "Work", icon: record.attributes.icon,
icon: PrimeIcons.DESKTOP, children: children,
className: "px-4", className: "px-4",
}, })
] }
},
{
key: 2, useEffect(() => {
label: "Dave's guests", if (nodes.length > 0) {
icon: PrimeIcons.HEART_FILL, return;
draggable: false, }
children: [ fetch("http://localhost:3001/groups.json")
{ .then((response) => response.json())
key: 21, .then((data) => {
label: "Family", setNodes(data.data.map((record: any) => {
icon: PrimeIcons.HOME, return (parseNode(record, data.included));
leaf: true, }))
className: "px-4", });
}, });
{
key: 22,
label: "College friends",
icon: PrimeIcons.GRADUATION_CAP,
leaf: true,
className: "px-4",
},
]
},
{
key: 3,
label: "Common guests",
icon: PrimeIcons.USERS,
draggable: false,
children: [
{
key: 31,
label: "Common workplace",
icon: PrimeIcons.BRIEFCASE,
leaf: true,
className: "px-4",
},
{
key: 32,
label: "Lifetime friends",
icon: PrimeIcons.STAR,
leaf: true,
className: "px-4",
},
]
}
]);
return ( return (
<div className="card flex justify-content-center"> <div className="card flex justify-content-center">
<Tree value={nodes} dragdropScope="affinity-groups" onDragDrop={(e) => setNodes(e.value)} className="w-full md:w-30rem" /> <Suspense>
<Tree value={nodes} dragdropScope="affinity-groups" onDragDrop={(e) => setNodes(e.value)} className="w-full md:w-30rem" />
</Suspense>
</div> </div>
) )
} }

View File

@ -42,7 +42,7 @@ export default function guestsTable() {
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<Suspense fallback="<tr><td colspan=3> Loading data</td></tr>"> <Suspense>
{guests.map((guest) => ( {guests.map((guest) => (
<tr key={guest.id} className="bg-white border-b odd:bg-white odd:dark:bg-gray-900 even:bg-gray-50 even:dark:bg-gray-800"> <tr key={guest.id} className="bg-white border-b odd:bg-white odd:dark:bg-gray-900 even:bg-gray-50 even:dark:bg-gray-800">
<th scope="row" className="px-6 py-4 font-medium text-gray-900 whitespace-nowrap dark:text-white"> <th scope="row" className="px-6 py-4 font-medium text-gray-900 whitespace-nowrap dark:text-white">