71 lines
2.7 KiB
TypeScript
71 lines
2.7 KiB
TypeScript
|
'use client'
|
||
|
|
||
|
import React, { useState } from "react"
|
||
|
import { TableArrangement } from '@/app/lib/definitions';
|
||
|
import { classNames } from "../components/button";
|
||
|
|
||
|
export default function ArrangementsTable ({onArrangementSelected}: {onArrangementSelected: (arrangementId: string) => void}) {
|
||
|
const [arrangements, setArrangements] = useState<Array<TableArrangement>>([]);
|
||
|
|
||
|
function loadArrangements() {
|
||
|
fetch("/api/tables_arrangements")
|
||
|
.then((response) => response.json())
|
||
|
.then((data) => {
|
||
|
setArrangements(data.map((record: any) => {
|
||
|
return ({
|
||
|
id: record.id,
|
||
|
discomfort: record.discomfort
|
||
|
});
|
||
|
}));
|
||
|
}, (error) => {
|
||
|
return [];
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function arrangementClicked(e: React.MouseEvent<HTMLElement>) {
|
||
|
onArrangementSelected(e.currentTarget.getAttribute('data-arrangement-id') || '');
|
||
|
}
|
||
|
|
||
|
arrangements.length === 0 && loadArrangements();
|
||
|
|
||
|
return(
|
||
|
<div className="w-full relative overflow-x-auto shadow-md sm:rounded-lg">
|
||
|
<table className="w-full text-sm text-left rtl:text-right text-gray-500 dark:text-gray-400">
|
||
|
<caption className="p-5 text-lg font-semibold text-left rtl:text-right text-gray-900 bg-white dark:text-white dark:bg-gray-800">
|
||
|
Simulations
|
||
|
<p className="mt-1 text-sm font-normal text-gray-500 dark:text-gray-400">
|
||
|
There are {arrangements.length} simmulations in the list
|
||
|
</p>
|
||
|
</caption>
|
||
|
<thead className="text-xs text-gray-700 uppercase bg-gray-50 dark:bg-gray-700 dark:text-gray-400">
|
||
|
<tr>
|
||
|
<th scope="col" className="px-6 py-3">
|
||
|
ID
|
||
|
</th>
|
||
|
<th scope="col" className="px-6 py-3">
|
||
|
Discomfort
|
||
|
</th>
|
||
|
<th scope="col" className="px-6 py-3">
|
||
|
Actions
|
||
|
</th>
|
||
|
</tr>
|
||
|
</thead>
|
||
|
<tbody>
|
||
|
{arrangements.map((arrangement) => (
|
||
|
<tr key={arrangement.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">
|
||
|
{arrangement.id}
|
||
|
</th>
|
||
|
<td className="px-6 py-4">
|
||
|
{arrangement.discomfort}
|
||
|
</td>
|
||
|
<td>
|
||
|
<button data-arrangement-id={arrangement.id} onClick={arrangementClicked} className={classNames('primary')}>Load</button>
|
||
|
</td>
|
||
|
</tr>
|
||
|
))}
|
||
|
</tbody>
|
||
|
</table>
|
||
|
</div>
|
||
|
);
|
||
|
}
|