feat: KVZ JSON Daten für mock auf CPL hochgeladen und getestet

This commit is contained in:
ISA
2025-07-31 14:32:52 +02:00
parent 90b9616d50
commit 46ba692af0
7 changed files with 75 additions and 18 deletions

View File

@@ -6,6 +6,6 @@ NEXT_PUBLIC_USE_MOCK_BACKEND_LOOP_START=false
NEXT_PUBLIC_EXPORT_STATIC=false NEXT_PUBLIC_EXPORT_STATIC=false
NEXT_PUBLIC_USE_CGI=false NEXT_PUBLIC_USE_CGI=false
# App-Versionsnummer # App-Versionsnummer
NEXT_PUBLIC_APP_VERSION=1.6.664 NEXT_PUBLIC_APP_VERSION=1.6.665
NEXT_PUBLIC_CPL_MODE=json # json (Entwicklungsumgebung) oder jsSimulatedProd (CPL ->CGI-Interface-Simulator) oder production (CPL-> CGI-Interface Platzhalter) NEXT_PUBLIC_CPL_MODE=json # json (Entwicklungsumgebung) oder jsSimulatedProd (CPL ->CGI-Interface-Simulator) oder production (CPL-> CGI-Interface Platzhalter)

View File

@@ -5,5 +5,5 @@ NEXT_PUBLIC_CPL_API_PATH=/CPL
NEXT_PUBLIC_EXPORT_STATIC=true NEXT_PUBLIC_EXPORT_STATIC=true
NEXT_PUBLIC_USE_CGI=true NEXT_PUBLIC_USE_CGI=true
# App-Versionsnummer # App-Versionsnummer
NEXT_PUBLIC_APP_VERSION=1.6.664 NEXT_PUBLIC_APP_VERSION=1.6.665
NEXT_PUBLIC_CPL_MODE=production NEXT_PUBLIC_CPL_MODE=production

View File

@@ -1,3 +1,8 @@
## [1.6.665] 2025-07-31
- style: KVZ LEDs style
---
## [1.6.664] 2025-07-31 ## [1.6.664] 2025-07-31
- style: LEDs style - style: LEDs style

4
package-lock.json generated
View File

@@ -1,12 +1,12 @@
{ {
"name": "cpl-v4", "name": "cpl-v4",
"version": "1.6.664", "version": "1.6.665",
"lockfileVersion": 3, "lockfileVersion": 3,
"requires": true, "requires": true,
"packages": { "packages": {
"": { "": {
"name": "cpl-v4", "name": "cpl-v4",
"version": "1.6.664", "version": "1.6.665",
"dependencies": { "dependencies": {
"@fontsource/roboto": "^5.1.0", "@fontsource/roboto": "^5.1.0",
"@headlessui/react": "^2.2.4", "@headlessui/react": "^2.2.4",

View File

@@ -1,6 +1,6 @@
{ {
"name": "cpl-v4", "name": "cpl-v4",
"version": "1.6.664", "version": "1.6.665",
"private": true, "private": true,
"scripts": { "scripts": {
"dev": "next dev", "dev": "next dev",

View File

@@ -0,0 +1,24 @@
{
"kvzPresence": [
1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0
],
"kvzActive": [
1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0
],
"kvzStatus": [
1, 0, 2, 1, 2, 0, 1, 0, 2, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0
],
"timestamp": "2025-07-31T11:39:22.951Z",
"description": {
"kvzPresence": "32 Slots: 1=KVZ Gerät vorhanden, 0=nicht vorhanden. Slots 0,2 haben KVZ-Geräte",
"kvzActive": "32 Slots: 1=KVZ aktiviert, 0=deaktiviert. Nur Slot 0 ist aktiviert",
"kvzStatus": "128 LEDs: 4 LEDs pro Slot. Slot 0: [1,0,1,0], Slot 2: [1,1,0,1] (aber Slot 2 ist deaktiviert)"
}
}

View File

@@ -1,12 +1,27 @@
// services/fetchKvzDataService.ts // services/fetchKvzDataService.ts
import { KvzData } from "../pages/api/kvz/data"; import { KvzData } from "../pages/api/kvz/data";
/**
* Überprüft, ob wir in der Entwicklungsumgebung sind
*/
const isDevelopment = process.env.NODE_ENV === "development";
/** /**
* Holt KVZ-Daten vom Server * Holt KVZ-Daten vom Server
* In der Entwicklungsumgebung: API-Route verwenden
* In der Produktionsumgebung: Direkt JSON-Datei laden
*/ */
export const fetchKvzData = async (): Promise<KvzData> => { export const fetchKvzData = async (): Promise<KvzData> => {
try { try {
const response = await fetch("/api/kvz/data"); let response: Response;
if (isDevelopment) {
// Entwicklungsumgebung: API-Route verwenden
response = await fetch("/api/kvz/data");
} else {
// Produktionsumgebung: Direkt JSON-Datei aus public laden
response = await fetch("/CPL/kvz/kvzData.json");
}
if (!response.ok) { if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`); throw new Error(`HTTP error! status: ${response.status}`);
@@ -22,6 +37,8 @@ export const fetchKvzData = async (): Promise<KvzData> => {
/** /**
* Aktualisiert KVZ-Einstellungen auf dem Server * Aktualisiert KVZ-Einstellungen auf dem Server
* In der Entwicklungsumgebung: API-Route verwenden
* In der Produktionsumgebung: Nur lokale Aktualisierung (keine Persistierung)
*/ */
export const updateKvzSettings = async ( export const updateKvzSettings = async (
updates: Array<{ updates: Array<{
@@ -32,20 +49,31 @@ export const updateKvzSettings = async (
}> }>
): Promise<KvzData> => { ): Promise<KvzData> => {
try { try {
const response = await fetch("/api/kvz/updateSettings", { if (isDevelopment) {
method: "POST", // Entwicklungsumgebung: API-Route verwenden
headers: { const response = await fetch("/api/kvz/updateSettings", {
"Content-Type": "application/json", method: "POST",
}, headers: {
body: JSON.stringify({ updates }), "Content-Type": "application/json",
}); },
body: JSON.stringify({ updates }),
});
if (!response.ok) { if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`); throw new Error(`HTTP error! status: ${response.status}`);
}
const data: KvzData = await response.json();
return data;
} else {
// Produktionsumgebung: Warnung ausgeben und aktuelle Daten zurückgeben
console.warn(
"KVZ-Updates sind in der Produktionsumgebung nicht verfügbar. Änderungen werden nur lokal gespeichert."
);
// Aktuelle Daten laden und zurückgeben
return await fetchKvzData();
} }
const data: KvzData = await response.json();
return data;
} catch (error) { } catch (error) {
console.error("Fehler beim Update der KVZ-Einstellungen:", error); console.error("Fehler beim Update der KVZ-Einstellungen:", error);
throw error; throw error;