85 lines
3.1 KiB
TypeScript
85 lines
3.1 KiB
TypeScript
"use client"; // /components/main/analogeEingaenge/AnalogeEingaengeTable.tsx
|
|
import React, { useEffect } from "react";
|
|
import { useDispatch, useSelector } from "react-redux";
|
|
import { RootState, AppDispatch } from "../../../redux/store";
|
|
import { fetchAnalogeEingaengeThunk } from "../../../redux/thunks/fetchAnalogeEingaengeThunk";
|
|
import { Icon } from "@iconify/react";
|
|
import settingsIcon from "@iconify/icons-mdi/settings";
|
|
|
|
export default function AnalogeEingaengeTable({
|
|
setSelectedId,
|
|
setSelectedInput,
|
|
setIsSettingsModalOpen,
|
|
}: {
|
|
setSelectedId: (id: number) => void;
|
|
setSelectedInput: (input: any) => void;
|
|
setIsSettingsModalOpen: (open: boolean) => void;
|
|
}) {
|
|
const dispatch = useDispatch<AppDispatch>();
|
|
|
|
useEffect(() => {
|
|
dispatch(fetchAnalogeEingaengeThunk());
|
|
}, [dispatch]);
|
|
|
|
const analogeEingaenge = useSelector(
|
|
(state: RootState) => state.analogeEingaengeSlice
|
|
);
|
|
|
|
return (
|
|
<div className="w-full">
|
|
<div className="bg-white shadow-lg rounded-lg p-4 border border-gray-200">
|
|
<div className="overflow-x-auto">
|
|
<table className="w-full border-collapse border border-gray-300 text-sm md:text-base">
|
|
<thead>
|
|
<tr className="bg-gray-100 text-gray-700">
|
|
<th className="border p-1 text-left">Eingang</th>
|
|
<th className="border p-3 text-left">Messwert</th>
|
|
<th className="border p-3 text-left">Bezeichnung</th>
|
|
<th className="border p-3 text-left">Aktion</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{Object.values(analogeEingaenge)
|
|
.filter((e) => e?.id !== null && e?.id !== undefined)
|
|
.map((e, index) => (
|
|
<tr key={index} className="hover:bg-gray-100 transition">
|
|
<td
|
|
className="border p-3 cursor-pointer"
|
|
onClick={() => setSelectedId(e.id!)}
|
|
>
|
|
{e.id ?? "-"}
|
|
</td>
|
|
<td
|
|
className="border p-3 cursor-pointer"
|
|
onClick={() => setSelectedId(e.id!)}
|
|
>
|
|
{e.value ?? "-"}
|
|
</td>
|
|
<td
|
|
className="border p-3 cursor-pointer"
|
|
onClick={() => setSelectedId(e.id!)}
|
|
>
|
|
{e.name || "----"}
|
|
</td>
|
|
<td className="border p-3 text-center">
|
|
<button
|
|
onClick={() => {
|
|
setSelectedId(e.id!);
|
|
setSelectedInput(e);
|
|
setIsSettingsModalOpen(true);
|
|
}}
|
|
className="text-blue-600 hover:text-blue-800"
|
|
>
|
|
<Icon icon={settingsIcon} className="text-xl" />
|
|
</button>
|
|
</td>
|
|
</tr>
|
|
))}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|