Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Hardware
    4. SONOFF NSPanel mit Lovelace UI

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    SONOFF NSPanel mit Lovelace UI

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      TT-Tom @Marko1974 last edited by

      @marko1974
      das Blockly ist nicht vom mir. Hast du das Script von Github neu aufgesetzt.

      Marko1974 1 Reply Last reply Reply Quote 0
      • Marko1974
        Marko1974 @TT-Tom last edited by

        @tt-tom ja ich habe nun NUR Dein script genommen

        T 1 Reply Last reply Reply Quote 0
        • T
          TT-Tom @Marko1974 last edited by

          @marko1974
          okay dann setze bitte im Script mal debug auf true.
          zeige mal den Config vom Script.

          Marko1974 1 Reply Last reply Reply Quote 0
          • Marko1974
            Marko1974 @TT-Tom last edited by Marko1974

            @tt-tom

            avascript.0 (1379) script.js.common.Abfallkalender: Rohdaten von Instanz ical: [{"date":"In 4 Tagen ","event":"USB Abfuhr Blau - Altpapier","_class":"ical_Müllkalender ical_4days","_date":"2024-01-18T23:00:00.000Z","_end":"2024-01-19T23:00:00.000Z","_section":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","_IDID":"170526840926@muellmax.de","_allDay":true,"_private":false,"_rule":" ","location":"4481","_calName":"Müllkalender","_calColor":"#000000","_object":{"type":"VEVENT","params":[],"start":"2024-01-18T23:00:00.000Z","datetype":"date","end":"2024-01-19T23:00:00.000Z","dtstamp":"2024-01-15T22:30:07.000Z","uid":"170526840926@muellmax.de","url":"http://www.muellmax.de","class":"PUBLIC","created":"2024-01-14T21:40:09.000Z","description":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","lastmodified":"2024-01-15T20:21:38.000Z","location":"448xxx31","sequence":"0","status":"CONFIRMED","summary":"USB Abfuhr Blau - Altpapier","transparency":"TRANSPARENT","method":"PUBLISH"}},{"date":"In einer Woche ","event":"USB Abfuhr Grau - Restmüll","_class":"ical_Müllkalender ical_oneweek","_date":"2024-01-21T23:00:00.000Z","_end":"2024-01-22T23:00:00.000Z","_section":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","_IDID":"17052684091@muellmax.de","_allDay":true,"_private":false,"_rule":" ","location":"44879 Bochum-Dahlhausen, ","_calName":"Müllkalender","_calColor":"#000000","_object":{"type":"VEVENT","params":[],"start":"2024-01-21T23:00:00.000Z","datetype":"date","end":"2024-01-22T23:00:00.000Z","dtstamp":"2024-01-15T22:30:07.000Z","uid":"17052684091@muellmax.de","url":"http://www.muellmax.de","class":"PUBLIC","created":"2024-01-14T21:40:09.000Z","description":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","lastmodified":"2024-01-15T20:21:38.000Z","location":"431","sequence":"0","status":"CONFIRMED","summary":"USB Abfuhr Grau - Restmüll","transparency":"TRANSPARENT","method":"PUBLISH"}},{"date":"In einer Woche ","event":"USB Abfuhr Gelb - kombinierte Wertstofftonne","_class":"ical_Müllkalender ical_oneweek","_date":"2024-01-21T23:00:00.000Z","_end":"2024-01-22T23:00:00.000Z","_section":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","_IDID":"170526840939@muellmax.de","_allDay":true,"_private":false,"_rule":" ","location":"448","_calName":"Müllkalender","_calColor":"#000000","_object":{"type":"VEVENT","params":[],"start":"2024-01-21T23:00:00.000Z","datetype":"date","end":"2024-01-22T23:00:00.000Z","dtstamp":"2024-01-15T22:30:07.000Z","uid":"170526840939@muellmax.de","url":"http://www.muellmax.de","class":"PUBLIC","created":"2024-01-14T21:40:09.000Z","description":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","lastmodified":"2024-01-15T20:21:38.000Z","location":"31","sequence":"0","status":"CONFIRMED","summary":"USB Abfuhr Gelb - kombinierte Wertstofftonne","transparency":"TRANSPARENT","method":"PUBLISH"}},{"date":"05.02.2024 ","event":"USB Abfuhr Grau - Restmüll","_class":"ical_Müllkalender ","_date":"2024-02-04T23:00:00.000Z","_end":"2024-02-05T23:00:00.000Z","_section":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","_IDID":"17052684092@muellmax.de","_allDay":true,"_private":false,"_rule":" ","location":"44879 1","_calName":"Müllkalender","_calColor":"#000000","_object":{"type":"VEVENT","params":[],"start":"2024-02-04T23:00:00.000Z","datetype":"date","end":"2024-02-05T23:00:00.000Z","dtstamp":"2024-01-15T22:30:07.000Z","uid":"17052684092@muellmax.de","url":"http://www.muellmax.de","class":"PUBLIC","created":"2024-01-14T21:40:09.000Z","description":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","lastmodified":"2024-01-15T20:21:38.000Z","location":"31","sequence":"0","status":"CONFIRMED","summary":"USB Abfuhr Grau - Restmüll","transparency":"TRANSPARENT","method":"PUBLISH"}},{"date":"05.02.2024 ","event":"USB Abfuhr Gelb - kombinierte Wertstofftonne","_class":"ical_Müllkalender ","_date":"2024-02-04T23:00:00.000Z","_end":"2024-02-05T23:00:00.000Z","_section":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","_IDID":"170526840940@muellmax.de","_allDay":true,"_private":false,"_rule":" ","location":"4487","_calName":"Müllkalender","_calColor":"#000000","_object":{"type":"VEVENT","params":[],"start":"2024-02-04T23:00:00.000Z","datetype":"date","end":"2024-02-05T23:00:00.000Z","dtstamp":"2024-01-15T22:30:07.000Z","uid":"170526840940@muellmax.de","url":"http://www.muellmax.de","class":"PUBLIC","created":"2024-01-14T21:40:09.000Z","description":"USB Umweltservice Bochum GmbH\nHanielstraße 1\n44801 Bochum\n\nTelefon: 0234/33 36-0\nFax: 0234/33 36-109","lastmodified":"2024-01-15T20:21:38.000Z","location":"431","sequence":"0","status":"CONFIRMED","summary":"USB Abfuhr Gelb - kombinierte Wertstofftonne","transparency":"TRANSPARENT","method":"PUBLISH"}}]
            23:30:07.724	info	javascript.0 (1379) script.js.common.Abfallkalender: Anzahl Trash - Daten: 5
            23:30:07.724	info	javascript.0 (1379) script.js.common.Abfallkalender: Daten vom ical Adapter werden ausgewertet
            23:30:07.724	info	javascript.0 (1379) script.js.common.Abfallkalender: --------- Nächster Termin wird geprüft ---------
            23:30:07.724	info	javascript.0 (1379) script.js.common.Abfallkalender: Startdatum UTC: 2024-01-18T23:00:00.000Z
            23:30:07.725	info	javascript.0 (1379) script.js.common.Abfallkalender: Datum: In 4 Tagen
            23:30:07.725	info	javascript.0 (1379) script.js.common.Abfallkalender: Event: USB Abfuhr Blau - Altpapier
            23:30:07.725	info	javascript.0 (1379) script.js.common.Abfallkalender: Kontrolle Leerzeichen %USB Abfuhr Blau - Altpapier%
            23:30:07.725	warn	javascript.0 (1379) script.js.common.Abfallkalender: Kein Abfalltermin => Event passt mit keinem Abfallnamen überein.
            23:30:07.725	info	javascript.0 (1379) script.js.common.Abfallkalender: Daten vom ical Adapter werden ausgewertet
            23:30:07.725	info	javascript.0 (1379) script.js.common.Abfallkalender: --------- Nächster Termin wird geprüft ---------
            23:30:07.725	info	javascript.0 (1379) script.js.common.Abfallkalender: Startdatum UTC: 2024-01-21T23:00:00.000Z
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: Datum: In einer Woche
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: Event: USB Abfuhr Grau - Restmüll
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: Kontrolle Leerzeichen %USB Abfuhr Grau - Restmüll%
            23:30:07.726	warn	javascript.0 (1379) script.js.common.Abfallkalender: Kein Abfalltermin => Event passt mit keinem Abfallnamen überein.
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: Daten vom ical Adapter werden ausgewertet
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: --------- Nächster Termin wird geprüft ---------
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: Startdatum UTC: 2024-01-21T23:00:00.000Z
            23:30:07.726	info	javascript.0 (1379) script.js.common.Abfallkalender: Datum: In einer Woche
            23:30:07.727	info	javascript.0 (1379) script.js.common.Abfallkalender: Event: USB Abfuhr Gelb - kombinierte Wertstofftonne
            23:30:07.727	info	javascript.0 (1379) script.js.common.Abfallkalender: Kontrolle Leerzeichen %USB Abfuhr Gelb - kombinierte Wertstofftonne%
            23:30:07.727	warn	javascript.0 (1379) script.js.common.Abfallkalender: Kein Abfalltermin => Event passt mit keinem Abfallnamen überein.
            23:30:07.727	info	javascript.0 (1379) script.js.common.Abfallkalender: Daten vom ical Adapter werden ausgewertet
            23:30:07.727	info	javascript.0 (1379) script.js.common.Abfallkalender: --------- Nächster Termin wird geprüft ---------
            23:30:07.727	info	javascript.0 (1379) script.js.common.Abfallkalender: Startdatum UTC: 2024-02-04T23:00:00.000Z
            23:30:07.727	info	javascript.0 (1379) script.js.common.Abfallkalender: Datum: 05.02.2024
            23:30:07.728	info	javascript.0 (1379) script.js.common.Abfallkalender: Event: USB Abfuhr Grau - Restmüll
            23:30:07.728	info	javascript.0 (1379) script.js.common.Abfallkalender: Kontrolle Leerzeichen %USB Abfuhr Grau - Restmüll%
            23:30:07.728	warn	javascript.0 (1379) script.js.common.Abfallkalender: Kein Abfalltermin => Event passt mit keinem Abfallnamen überein.
            23:30:07.728	info	javascript.0 (1379) script.js.common.Abfallkalender: Daten vom ical Adapter werden ausgewertet
            23:30:07.728	info	javascript.0 (1379) script.js.common.Abfallkalender: --------- Nächster Termin wird geprüft ---------
            23:30:07.728	info	javascript.0 (1379) script.js.common.Abfallkalender: Startdatum UTC: 2024-02-04T23:00:00.000Z
            23:30:07.728	info	javascript.0 (1379) script.js.common.Abfallkalender: Datum: 05.02.2024
            23:30:07.729	info	javascript.0 (1379) script.js.common.Abfallkalender: Event: USB Abfuhr Gelb - kombinierte Wertstofftonne
            23:30:07.729	info	javascript.0 (1379) script.js.common.Abfallkalender: Kontrolle Leerzeichen %USB Abfuhr Gelb - kombinierte Wertstofftonne%
            23:30:07.729	warn	javascript.0 (1379) script.js.common.Abfallkalender: Kein Abfalltermin => Event passt mit keinem Abfallnamen überein.
            
            T 1 Reply Last reply Reply Quote 0
            • T
              TT-Tom @Marko1974 last edited by

              @marko1974 zeige mal die Einstellungen im Script sprich den oberen Teil.

              Marko1974 1 Reply Last reply Reply Quote 0
              • Marko1974
                Marko1974 @TT-Tom last edited by

                @tt-tom

                /*
                 * @author 2023 @tt-tom
                 * 
                 * Version 5.1.0
                 * 
                 * Das Script erstellt die Datenpunkte und Alias für den Abfallkalender im Sonoff NSPanel
                 * Es wird der iCal Adapter benötigt und eine URL mit Terminen vom Entsorger bzw. eine .ics-Datei mit den Terminen.
                 * Das Script triggert auf dem bereitgestellten JSON im iCal adapter und füllt die 0_userdata.0 Datenpunkte
                 * Weitere Informationen findest du in der FAQ auf Github https://github.com/joBr99/nspanel-lovelace-ui/wiki
                 * 
                 * changelog
                 *  - 06.12.2023 - v5.0.2 add custom name for trashtype
                 *  - 06.12.2023 - v5.1.0 Refactoring
                 * 
                 * 
                */
                
                
                const idTrashData: string = 'ical.0.data.table'; // Datenpunkt mit Daten im JSON Format
                const idUserdataAbfallVerzeichnis: string = '0_userdata.0.Abfallkalender'; // Name des Datenpunktverzeichnis unter 0_userdata.0 -> Strandard = 0_userdata.0.Abfallkalender
                const idAliasPanelVerzeichnis: string = 'alias.0.NSPanel.allgemein'; //Name PanelVerzeichnis unter alias.0. Standard = alias.0.NSPanel.1
                const idAliasAbfallVerzeichnis: string = 'Abfall'; //Name Verzeichnis unterhalb der idPanelverzeichnis  Standard = Abfall
                
                const anzahlZeichenLoeschen: number = 0; // x Zeichen links vom String abziehen, wenn vor dem Eventname noch Text steht z.B. Strassenname; Standard = 0
                const jsonEventName1: string = 'Gelbe Tonne, Biotonne, Restmülltonne'; // Vergleichstring für Schwarze Tonne
                const customEventName1: string = 'Ohne Papiertonne';        // benutzerdefinierter Text für schwarze Tonne
                const jsonEventName2: string = 'Gelbe Sack'; // Vergleichstring für Gelbe Tonne / Sack
                const customEventName2: string = '';        // benutzerdefinierter Text für gelbe Tonne
                const jsonEventName3: string = 'Gelbe Tonne, Biotonne, Restmülltonne, Blaue Papiertonne, Restmülltonne 4-wöchentlich';    // Vergleichstring für Blaue Tonne
                const customEventName3: string = 'Mit Papiertonne';       // benutzerdefinierter Text für blaue Tonne
                const jsonEventName4: string = 'Biomüll';   // Vergleichstring für Braune Tonne
                const customEventName4: string = '';        // benutzerdefinierter Text für braune Tonne
                
                
                const Debug: boolean = true;
                
                // ------------------------- Trigger zum füllen der 0_userdata Datenpunkte aus dem json vom ical Adapter -------------------------------
                
                
                T 1 Reply Last reply Reply Quote 0
                • T
                  TT-Tom @Marko1974 last edited by TT-Tom

                  @marko1974
                  du musst die Variable jsonEventNameX anpassen an deine Gegebenheiten / Namen.
                  mit cutomEventNameX kannst du einen eigen Namen vergeben, der angezeigt werden soll. Ich habe die Variablen mal angepasst, probiere sie mal. Wenn du noch eine Biotonne hast musst die auch noch anpassen.

                  const jsonEventName1: string = 'USB Abfuhr Grau - Restmüll'; // Vergleichstring für Schwarze Tonne
                  const customEventName1: string = 'Restmüll';        // benutzerdefinierter Text für schwarze Tonne
                  const jsonEventName2: string = 'USB Abfuhr Gelb - kombinierte Wertstofftonne'; // Vergleichstring für Gelbe Tonne / Sack
                  const customEventName2: string = 'Gelbe Tonne';        // benutzerdefinierter Text für gelbe Tonne
                  const jsonEventName3: string = 'USB Abfuhr Blau - Altpapier';    // Vergleichstring für Blaue Tonne
                  const customEventName3: string = 'Papiertonne';       // benutzerdefinierter Text für blaue Tonne
                  const jsonEventName4: string = 'Biomüll';   // Vergleichstring für Braune Tonne
                  const customEventName4: string = '';        // benutzerdefinierter Text für braune Tonne
                  
                  
                  Marko1974 1 Reply Last reply Reply Quote 0
                  • theknut
                    theknut last edited by

                    Wie genau funktioniert denn die LChart Karte? Ich habe ein Thermostat und möchte dafür verschiedene Diagramme erstellen, bspw. Temperatur und Luftfeuchte. Das Problem ist schon erstmal, dass er den Alias immer nach .ACTUAL abfragt, also kann ich schon mal nicht HUMIDITY anzeigen, sondern müsste es noch mal in einen separaten Alias packen, wo ich es dann auf ACTUAL legen muss.
                    Sei's drum. Ich habe jetzt erstmal mit der Temperatur gestartet und erhalte aber kein Diagramm, was genau mach ich falsch? Ich logge alle Änderungen in meine InfluxDB Instanz, aber ich sehe auch nirgendwo wo das abgefragt wird.

                    let diagrammeGaesteZimmerTemperatur : PageType =
                    {
                        'type': 'cardLChart',
                        'heading': 'Gästezimmer',
                        'subPage': true,
                        'parent': diagramme,
                        'home': Object.keys({diagramme})[0], 
                        'items': [{ 
                            id: 'alias.0.Rooms.Gästezimmer.Heizung',
                            yAxis: 'Temperatur [°C]',
                            yAxisTicks: [-250, -200, -150, -100,-50, 0, 50, 100, 150, 200, 250, 300],
                            onColor: Yellow
                         }]
                    };
                    

                    12e6d3f6-c737-4d21-862f-4d27d00f6718-image.png
                    Leider konnte ich auch nirgendwo eine Dokumentation dazu finden. Kann mir das jemand erklären? Ich könnte dann die Doku dazu schreiben.

                    T 1 Reply Last reply Reply Quote 0
                    • Marko1974
                      Marko1974 @TT-Tom last edited by

                      @tt-tom said in SONOFF NSPanel mit Lovelace UI:

                      const jsonEventName1: string = 'USB Abfuhr Grau - Restmüll'; // Vergleichstring für Schwarze Tonne
                      const customEventName1: string = 'Restmüll'; // benutzerdefinierter Text für schwarze Tonne
                      const jsonEventName2: string = 'USB Abfuhr Gelb - kombinierte Wertstofftonne'; // Vergleichstring für Gelbe Tonne / Sack
                      const customEventName2: string = 'Gelbe Tonne'; // benutzerdefinierter Text für gelbe Tonne
                      const jsonEventName3: string = 'USB Abfuhr Blau - Altpapier'; // Vergleichstring für Blaue Tonne
                      const customEventName3: string = 'Papiertonne'; // benutzerdefinierter Text für blaue Tonne
                      const jsonEventName4: string = 'Biomüll'; // Vergleichstring für Braune Tonne
                      const customEventName4: string = ''; // benutzerdefinierter Text für braune Tonne

                      Du bist ein Goldstück!!! Vielen Dank!

                      abfall12.png

                      1 Reply Last reply Reply Quote 0
                      • T
                        TT-Tom last edited by

                        @marko1974 na dann weiter viel Spass mit dem Panel 😊

                        Marko1974 1 Reply Last reply Reply Quote 0
                        • T
                          TT-Tom @theknut last edited by

                          @theknut

                          hier ist eine Beschreibung inkl. Script für Influx2

                          theknut 1 Reply Last reply Reply Quote 1
                          • Marko1974
                            Marko1974 @TT-Tom last edited by

                            @tt-tom Im Moment ist es kaputt 🙂 Meine Mutter hat sich gefönt und die Sicherung ist rausgeflogen. Warum auch immer. Nach dem Einschalten war es tot.

                            In 2. Instanz muss ich mal den Page Aufbau hinbekommen. Habe da im Moment nur Heizungen und Fenster drin.

                            Hätte gern ein grid mit 6 Buttons überschrift Heizungen -> / Wohnzimmer / bad / flur ..... etc als Button und dann soll der auf die Unterpages Thermostate.
                            Da bin ich dann irgendwie gescheitert.

                            Ihr habt das hier immer so schön als Video mit dem Mauszeiger auf dem Panel. Kann man das emulieren, wenn es physisch nicht vorhanden ist?

                            theknut T 2 Replies Last reply Reply Quote 0
                            • theknut
                              theknut @TT-Tom last edited by

                              @tt-tom said in SONOFF NSPanel mit Lovelace UI:

                              @theknut

                              hier ist eine Beschreibung inkl. Script für Influx2

                              Oha, da muss man ja doch noch einiges drum herum machen. Ich bin davon ausgegangen, dass er über den Alias schaut, ob es ein Custom Setting dafür gibt und wenn ja, dann liest er das aus dem Adapter aus (bspw. Influx). Aber gut, dann werd ich mich da morgen mal dran machen. Danke dir!

                              1 Reply Last reply Reply Quote 0
                              • F
                                Frosti last edited by Frosti

                                Hey, ich hoffe, ich bin hier richtig - ich habe eine CardUnlock als SubPage (als Schutz vor dem versehentlichen Ausschalten einer Steckdosenleiste). Diese hat bisher immer super funktioniert, nur irgendwann, aus dem Nichts heraus, verschwand der Button "Entriegeln" ca. eine halbe Sekunde nachdem man auf die Unlock-Seite (zum Code eingeben), wechselt.

                                Habe nun heute alles geupdatet (System sowie Skript), aber es hat nicht geholfen.

                                So sieht es im Skript hinsichtlich der MainPage und der UnlockPage aus.

                                let Buero_Seite_1 : PageType =
                                {
                                    'type': 'cardEntities',
                                    'heading': 'Büro',
                                    'useColor': true,
                                    'next': 'Haus_Seite_1',
                                    'items': [
                                        //<PageItem>{ id: 'alias.0.NSPanel.Makerspace.Büro.Steckdosenleiste_Schreibtisch', name: 'Schreibtisch', icon: 'power', icon2: 'power',offColor: MSRed, onColor: MSGreen},
                                        { id: 'alias.0.NSPanel.Makerspace.Büro.Schreibtischlampe', name: 'Ultra coole Lampe', interpolateColor: true},
                                        { id: 'alias.0.NSPanel.Makerspace.Werkstatt.Wall_Light_Werkstatt', name: 'Wall Light', interpolateColor: true},
                                        { navigate: true, id: 'alias.0.NSPanel.General.Unlock' , targetPage: 'Unlock_Steckdosenleiste_Schreibtisch', name: 'Steckdosenleiste', buttonText: 'weiter...'},
                                        //<PageItem>{ id: 'alias.0.NSPanel_1.Deckenbeleuchtung', interpolateColor: true},
                                        //<PageItem>{ id: 'alias.0.NSPanel_1.ShellyDuoTest', name: 'Shelly Duo GU10', minValueBrightness: 0, maxValueBrightness: 100, minValueColorTemp: 6465, maxValueColorTemp: 3000, interpolateColor: true, modeList: ['Color','White'], inSel_ChoiceState: true},
                                        //<PageItem>{ id: 'alias.0.NSPanel_1.Luftreiniger', icon: 'power', icon2: 'power',offColor: MSRed, onColor: MSGreen}
                                    ]
                                };
                                
                                                //Level 1
                                                let Unlock_Steckdosenleiste_Schreibtisch: PageType   =
                                                {
                                                    'type': 'cardUnlock',
                                                    'heading': 'Steckdosenleiste',
                                                    'useColor': true,
                                                    'subPage': true,
                                                    'parent': Buero_Seite_1,
                                                    'items': [{ id: 'alias.0.NSPanel.General.Unlock', targetPage: 'Steckdosenleiste_Schreibtisch_Seite',  autoCreateALias: true }
                                                    ]
                                                };
                                

                                Weiß jemand von euch weiter?

                                Liebe Grüße und vielen Dank!

                                1 Reply Last reply Reply Quote 0
                                • theknut
                                  theknut @Marko1974 last edited by

                                  @marko1974
                                  Emulator: https://github.com/joBr99/nspanel-lovelace-ui/wiki/NSPanel-Nextion-Editor

                                  Das mit der Struktur fand ich sehr verwirrend, ich zeig dir mal wie ich es gemacht habe, der Variablenname ist entscheidend, das war mir unklar.

                                  let menuPage: PageType = 
                                  {
                                      'type': 'cardGrid',
                                      'heading': 'Menü',
                                      'useColor': false,
                                      'items': []
                                  };
                                  let menuPage2: PageType = 
                                  {
                                      'type': 'cardGrid',
                                      'heading': 'Menü', 
                                      'useColor': false,   
                                      'items': []
                                  };
                                  
                                  ...
                                  
                                  // das kommt auf die erste Page
                                  
                                  // Wohnzimmer
                                  let wohnzimmerLicht : PageType =
                                  {
                                      'type': 'cardGrid',
                                      'heading': 'Licht',
                                      'useColor': true,
                                      'subPage': true,
                                      'parent': menuPage,
                                      'home': Object.keys({menuPage})[0], 
                                      'items': [
                                          { id: 'alias.0.Rooms.Wohnzimmer.HueGradientLightStrips', icon: "led-strip-variant", offColor: White, onColor: White, name: 'Lightstrips'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Stehlampe', icon: "lightbulb-outline", offColor: White, onColor: White, name: 'Stehlampe'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Stern', icon: "star-outline", offColor: White, onColor: White, name: 'Stern'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Lichterketten', icon: "lightbulb-outline", offColor: White, onColor: White, name: 'Lichterketten'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Kinomodus', icon: "projector", offColor: White, onColor: White, name: 'Kino'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Lichter_Aus', icon: "lightbulb-group-off-outline", offColor: White, onColor: White, name: 'Alle aus'}
                                      ]
                                  };
                                  
                                  let wohnzimmerRollo : PageType =
                                  {
                                      'type': 'cardEntities',
                                      'heading': 'Rollo',
                                      'useColor': true,
                                      'subPage': true,
                                      'parent': menuPage,
                                      'home': Object.keys({menuPage})[0], 
                                      'items': [
                                          { id: 'alias.0.Rooms.Wohnzimmer.Fenster.Wohnen.Rollo', icon: "blinds-horizontal", offColor: White, onColor: White, name: 'Raffstore Wohnen'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Fenster.Arbeiten.Rollo', icon: "blinds-horizontal", offColor: White, onColor: White, name: 'Raffstore Arbeiten'},
                                          { id: 'alias.0.Rooms.Wohnzimmer.Leinwand', icon: "blinds-horizontal", offColor: White, onColor: White, name: 'Leinwand'}
                                      ]
                                  };
                                  
                                  ....
                                  
                                  // das kommt auf die zweite Page
                                  let technikraum : PageType =
                                  {
                                      'type': 'cardEntities',
                                      'heading': 'Technik',
                                      'useColor': true,
                                      'subPage': true,
                                      'parent': menuPage2,
                                      'home': Object.keys({menuPage2})[0], 
                                      'items': [
                                          ...
                                      ]
                                  };
                                  
                                  ...
                                  
                                  // am Ende die Items hinzufügen
                                  
                                  
                                  menuPage.items = [
                                      <PageItem> { navigate: true, id: null, targetPage: Object.keys({wohnzimmerLicht})[0], name: 'Lichter', icon: 'lightbulb-outline', onColor: White, offColor: White },
                                      <PageItem> { navigate: true, id: null, targetPage: Object.keys({wohnzimmerRollo})[0], name: 'Rolläden', icon: 'blinds-horizontal', onColor: White, offColor: White },
                                  ...
                                  ]
                                  menuPage2.items = [
                                      <PageItem> { navigate: true, id: null, targetPage: Object.keys({technikraum})[0], name: 'Technik', icon: 'meter-electric-outline', onColor: White, offColor: White },
                                  ...
                                  ]
                                  
                                  // und dann noch in der Struktur hinzufügen
                                  
                                  export const config: Config = {
                                      // Seiteneinteilung / Page division
                                      // Hauptseiten / Mainpages
                                      pages: [
                                          menuPage,
                                          menuPage2
                                      ],
                                      // Unterseiten / Subpages
                                      subPages: [	    
                                          wohnzimmerLicht,
                                          wohnzimmerRollo,
                                          technikraum,
                                          ...
                                  

                                  Btw, ich hab mich hier auch mit viel Hilfe eingefuchst, die Entwickler sind sehr hilfsbereit. Ich würde empfehlen mal was per Paypal zu schicken *hust

                                  T 1 Reply Last reply Reply Quote 0
                                  • Armilar
                                    Armilar Most Active Forum Testing last edited by Armilar

                                    @theknut

                                    Die vollständige Beschreibung der cardLChart mit Skripten:

                                    https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardlchart-line-charts-ab-ts-script-v390

                                    Oh ha - da hing aber mein Browser 😁

                                    1 Reply Last reply Reply Quote 1
                                    • T
                                      TT-Tom @Marko1974 last edited by

                                      @marko1974

                                      Dafür musst du dir im Wiki das Thema Navigation anschauen. Dort sind Möglichkeiten beschrieben, wie man mit einem Button zur nächsten Seite kommt.

                                      1 Reply Last reply Reply Quote 1
                                      • T
                                        TT-Tom @theknut last edited by

                                        @theknut kann man so machen, ist aber nicht Standard. Siehe Wiki Navigation.

                                        Warum schreibst du die PageItem separat, welchen Vorteil hat dies?

                                        theknut 1 Reply Last reply Reply Quote 0
                                        • theknut
                                          theknut @TT-Tom last edited by theknut

                                          @tt-tom das hat den Vorteil, dass ich den String für home nicht mehr händisch tippen muss, sondern 'home': Object.keys({menuPage})[0] machen kann. Heißt, falls ich mal den Variablennamen für menuPage ändere, dann bekomme ich einen Kompilierfehler und merke es sofort. Andernfalls würde er es erstmal schlucken und die Navigation geht dann einfach nicht mehr. Daher muss ich die Deklaration der Variable und das Hinzufügen der Items trennen.
                                          Muss man nicht so machen, aber beugt eben Fehler vor, die bisschen hässlich zu finden sind.

                                          C 1 Reply Last reply Reply Quote 2
                                          • C
                                            cdn @theknut last edited by

                                            Gibt es eigentlich ein best practice zum Updaten der nspanelts.ts? Stand jetzt kopiere ich per Hand immer alle meine Änderungen herein. Ist bei einigen TSPanels schon echt aufwändig.

                                            T Armilar 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            716
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            lovelace ui nspanel sonoff
                                            260
                                            7128
                                            4289925
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo