From 28abb23a771aa908cd713084dfdc8c5d192bc92c Mon Sep 17 00:00:00 2001 From: Manuel Bustillo Date: Sun, 17 Nov 2024 16:45:42 +0100 Subject: [PATCH] Extract a table simulations API --- app/api/tableSimulations.tsx | 17 ++++++++++++++++ app/ui/arrangements/arrangements-table.tsx | 23 ++++++++-------------- 2 files changed, 25 insertions(+), 15 deletions(-) create mode 100644 app/api/tableSimulations.tsx diff --git a/app/api/tableSimulations.tsx b/app/api/tableSimulations.tsx new file mode 100644 index 0000000..51e1fff --- /dev/null +++ b/app/api/tableSimulations.tsx @@ -0,0 +1,17 @@ +import { TableArrangement } from '@/app/lib/definitions'; + +export function loadTableSimulations(onLoad?: (tableSimulations: TableArrangement[]) => void) { + fetch('/api/tables_arrangements') + .then((response) => response.json()) + .then((data) => { + onLoad && onLoad(data.map((record: any) => { + return ({ + id: record.id, + name: record.name, + discomfort: record.discomfort, + }); + })); + }, (error) => { + return []; + }); +} \ No newline at end of file diff --git a/app/ui/arrangements/arrangements-table.tsx b/app/ui/arrangements/arrangements-table.tsx index 66e41d4..57dd67d 100644 --- a/app/ui/arrangements/arrangements-table.tsx +++ b/app/ui/arrangements/arrangements-table.tsx @@ -6,31 +6,24 @@ import React, { useState } from "react" import { TableArrangement } from '@/app/lib/definitions'; import { classNames } from "../components/button"; import TableOfContents from "../components/table-of-contents"; +import { loadTableSimulations } from "@/app/api/tableSimulations"; export default function ArrangementsTable ({onArrangementSelected}: {onArrangementSelected: (arrangementId: string) => void}) { const [arrangements, setArrangements] = useState>([]); + const [arrangementsLoaded, setArrangementsLoaded] = useState(false); - function loadArrangements() { - fetch("/api/tables_arrangements") - .then((response) => response.json()) - .then((data) => { - setArrangements(data.map((record: any) => { - return ({ - id: record.id, - name: record.name, - discomfort: record.discomfort - }); - })); - }, (error) => { - return []; - }); + function refreshSimulations() { + loadTableSimulations((arrangements) => { + setArrangements(arrangements); + setArrangementsLoaded(true); + }); } function arrangementClicked(e: React.MouseEvent) { onArrangementSelected(e.currentTarget.getAttribute('data-arrangement-id') || ''); } - arrangements.length === 0 && loadArrangements(); + !arrangementsLoaded && refreshSimulations(); return(