"use client"; // pages/einausgaenge.tsx import React, { useState } from "react"; import DigitalOutputs from "../components/main/einausgaenge/DigitalOutputs"; import DigitalInputs from "../components/main/einausgaenge/DigitalInputs"; import InputModal from "../components/main/einausgaenge/modals/InputModal"; import OutputModal from "../components/main/einausgaenge/modals/OutputModal"; import { useDigitalInputData } from "../hooks/einausgaenge/useDigitalInputsData"; import { useDigitalOutputs } from "../hooks/einausgaenge/useDigitalOutputsData"; function EinAusgaenge() { // Verwendung des benutzerdefinierten Hooks für digitale Ausgänge const { digitalOutputs, isLoading: isLoadingOutputs, setDigitalOutputs, } = useDigitalOutputs(); // Zustand für Modale const [selectedInput, setSelectedInput] = useState(null); const [selectedOutput, setSelectedOutput] = useState(null); const [isInputModalOpen, setIsInputModalOpen] = useState(false); const [isOutputModalOpen, setIsOutputModalOpen] = useState(false); // Laden der digitalen Eingänge const { mockData, isLoading: isLoadingInputs } = useDigitalInputData(); // Funktion zum Umschalten des Ausgangs const toggleSwitch = (id: number) => { setDigitalOutputs((prevOutputs) => prevOutputs.map((output) => output.id === id ? { ...output, toggle: !output.toggle } : output ) ); }; // Funktionen zum Öffnen und Schließen der Modale const openInputModal = (input: any) => { setSelectedInput(input); setIsInputModalOpen(true); }; const closeInputModal = () => { setSelectedInput(null); setIsInputModalOpen(false); }; const openOutputModal = (output: any) => { setSelectedOutput(output); setIsOutputModalOpen(true); }; const closeOutputModal = () => { setSelectedOutput(null); setIsOutputModalOpen(false); }; // Digitale Eingänge aus Mock-Daten generieren const digitalInputs = mockData.win_de.map( (status: number, index: number) => ({ id: index + 1, status: status === 1 ? "active" : "inactive", description: `DE${index + 1}`, isInverted: false, }) ); const inputsGroup1 = digitalInputs.slice(0, 16); const inputsGroup2 = digitalInputs.slice(16); return (