feat: Send only updated system settings on submit

- Implemented logic to compare current input values with original values.
- Only changed fields are now sent to the server on form submission.
- Improved efficiency by avoiding unnecessary API calls.
- Updated the "Systemzeit übernehmen" button to update the system time correctly.
- Added reboot and clear database functionalities with confirmation dialogs.
This commit is contained in:
ISA
2024-10-18 10:32:52 +02:00
parent f0c490df5b
commit 0a4cb1567a

View File

@@ -17,7 +17,26 @@ function SettingModal({ showModal, onClose }) {
const [zeitzone, setZeitzone] = useState("2");
const [active, setActive] = useState("1");
const [showRebootModal, setShowRebootModal] = useState(false);
// Originalwerte speichern
const [originalValues, setOriginalValues] = useState({});
useEffect(() => {
// Initialisiere die Originalwerte beim ersten Laden des Modals
const initialValues = {
name,
mac1,
mac2,
ip,
subnet,
gateway,
systemUhr,
ntp1,
ntp2,
ntp3,
zeitzone,
active,
};
setOriginalValues(initialValues);
}, [showModal]);
useEffect(() => {
if (window.deviceName) setName(window.deviceName);
if (window.mac1) setMac1(window.mac1);
@@ -65,10 +84,46 @@ function SettingModal({ showModal, onClose }) {
};
const handleSubmit = () => {
if (window.confirm("Möchten Sie die Änderungen wirklich übernehmen?")) {
const url = `CPL?KUEdetail.ACP&SNNA=${name}&SEI01=${ip}&SEI02=${subnet}&SEI03=${gateway}&SNIP1=${ntp1}&SNIP2=${ntp2}&SNIP3=${ntp3}&SNTZ=${zeitzone}&SNAC=${active}`;
const changes = {};
fetch(url)
// Überprüfe, welche Werte sich geändert haben
if (name !== originalValues.name) {
changes.SNNA = name;
}
if (ip !== originalValues.ip) {
changes.SEI01 = ip;
}
if (subnet !== originalValues.subnet) {
changes.SEI02 = subnet;
}
if (gateway !== originalValues.gateway) {
changes.SEI03 = gateway;
}
if (ntp1 !== originalValues.ntp1) {
changes.SNIP1 = ntp1;
}
if (ntp2 !== originalValues.ntp2) {
changes.SNIP2 = ntp2;
}
if (ntp3 !== originalValues.ntp3) {
changes.SNIP3 = ntp3;
}
if (zeitzone !== originalValues.zeitzone) {
changes.SNTZ = zeitzone;
}
if (active !== originalValues.active) {
changes.SNAC = active;
}
// Falls Änderungen vorhanden sind, sende die neuen Daten
if (Object.keys(changes).length > 0) {
let url = `CPL?KUEdetail.ACP`;
Object.keys(changes).forEach((paramKey) => {
url += `&${paramKey}=${encodeURIComponent(changes[paramKey])}`;
});
fetch(url, { method: "GET" })
.then((response) => {
if (response.ok) {
alert("Daten erfolgreich gesendet!");
@@ -80,6 +135,8 @@ function SettingModal({ showModal, onClose }) {
console.error("Fehler:", error);
alert("Fehler beim Senden der Daten!");
});
} else {
alert("Keine Änderungen vorgenommen.");
}
};
@@ -208,7 +265,7 @@ function SettingModal({ showModal, onClose }) {
{/* Button für Systemzeit übernehmen */}
<div className="flex w-full mt-1 justify-end">
<button
className="bg-green-500 text-white px-4 py-2 rounded"
className="bg-blue-500 text-white px-4 py-2 rounded"
onClick={() => console.log("Systemzeit übernehmen")}
>
Systemzeit übernehmen