feat: Redux-Thunk für analoge Eingänge integriert & useFetchAnalogeEingaenge entfernt
- `fetchAnalogeEingaengeThunk` in `AnalogeEingaengeTable.tsx` verwendet, um API-Daten in Redux zu speichern.
- `useFetchAnalogeEingaenge` entfernt, um doppelte API-Aufrufe zu vermeiden.
- Sicherstellung, dass Redux-Thunk nur im Client (`useEffect`) ausgeführt wird.
- Automatische Aktualisierung der API-Daten alle 10 Sekunden über Redux-Thunk.
- Code-Optimierungen für eine stabilere Client-Side-Architektur mit Next.js.
✅ Jetzt läuft Redux-Thunk stabil & effizient in der Next.js-Anwendung!
This commit is contained in:
@@ -1,19 +1,20 @@
|
||||
"use client"; // components/main/analogeEingaenge/AnalogeEingaengeTable.tsx
|
||||
import React, { useState } from "react";
|
||||
import { useSelector } from "react-redux";
|
||||
import { RootState } from "../../../redux/store";
|
||||
import { useFetchAnalogeEingaenge } from "./hooks/useFetchAnalogeEingaenge";
|
||||
import React, { useEffect, useState } from "react";
|
||||
import { useDispatch, useSelector } from "react-redux";
|
||||
import { RootState, AppDispatch } from "../../../redux/store";
|
||||
import { fetchAnalogeEingaengeThunk } from "../../../redux/thunks/fetchAnalogeEingaengeThunk";
|
||||
|
||||
export default function AnalogeEingaengeTable() {
|
||||
useFetchAnalogeEingaenge();
|
||||
const dispatch = useDispatch<AppDispatch>();
|
||||
|
||||
useEffect(() => {
|
||||
dispatch(fetchAnalogeEingaengeThunk()); // ✅ Holt die API-Daten nur im Client
|
||||
}, [dispatch]);
|
||||
|
||||
const analogeEingaenge = useSelector(
|
||||
(state: RootState) => state.analogeEingaenge
|
||||
);
|
||||
|
||||
console.log("Aktuelle Redux-Daten:", analogeEingaenge);
|
||||
|
||||
// State für das geöffnete Modal
|
||||
const [selectedEingang, setSelectedEingang] = useState(null);
|
||||
|
||||
const openSettingsModal = (eingang: any) => {
|
||||
@@ -115,71 +116,6 @@ export default function AnalogeEingaengeTable() {
|
||||
defaultValue="Spg."
|
||||
readOnly
|
||||
/>
|
||||
|
||||
<div className="grid grid-cols-4 gap-2 mt-4">
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">uG:</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">uW:</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">oW:</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">oG:</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="grid grid-cols-3 gap-2 mt-4">
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">Faktor:</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">Offset:</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
<div>
|
||||
<label className="block text-sm text-gray-700">
|
||||
Filterzeit:
|
||||
</label>
|
||||
<input
|
||||
type="number"
|
||||
className="w-full border px-2 py-1 rounded"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<label className="block text-sm text-gray-700 mt-2">
|
||||
Datenlogger:
|
||||
</label>
|
||||
<select className="w-full border px-2 py-1 rounded">
|
||||
<option>aus</option>
|
||||
<option>ein</option>
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<div className="flex justify-end mt-4">
|
||||
|
||||
Reference in New Issue
Block a user