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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    SONOFF NSPanel mit Lovelace UI

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

      @tt-tom Das hab ich gemacht. Erst das Heading dann der Text. Hab auch das Skript von Github genommen und nur die Topics angepasst. Sonst keine Änderung. Im Tutorial stand eben, dass man einen Alias und eine Page für einen Button anlegen soll. Also einfach nur die Datenpunkte schreiben hat bei mir nicht geklappt.

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

        Jetzt gehts, ich musste nicht das Heading und Text bei ScreensaveInfo, sondern im popupNotify ändern. Tut mir leid, das hatte ich dann verwechselt. Dachte das popupNotify ist nur, wenn ich schon aus dem Screensaver raus und bspw. auf einer Page eins öffne.

        ea3ae1f2-e059-4250-ab9b-84efccb1558d-image.png

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

          @theknut
          Wenn du bei Screensaverinfo, etwas rein schreibst, sollte er bei aktiven Screensaver etwas anzeigen.
          Damit der Trigger auslöst muss der Text sich immer wieder unterscheiden.

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

            @theknut
            Die popupNotify Page pop immer auf egal von wo du kommst.

            1 Reply Last reply Reply Quote 2
            • theknut
              theknut last edited by

              @tt-tom Tom, bitte auch mal Paypal geben

              1 Reply Last reply Reply Quote 1
              • D
                docf last edited by

                @tt-tom

                Hi irgendwie habe ich da einen Denkfehler
                Ich habe mit dem Wecker ein Alias für einen Shelly erstellt und diesen mit dem Wecker Script verknüpft.
                Leider lässt dieser sich nur ausschalten jedoch nicht einschalten.
                Was mache ich da denn falsch.
                Danke

                const dp_userdata: string = '0_userdata.0.NSPanel';
                const dp_alias: string = 'alias.0.NSPanel';
                
                // dpAction wird wenn der Wecker gestellt wird auf false geschaltet
                // dpAction wird wenn die Weckzeit erreicht ist auf true geschaltet
                // Der nachfolgende Datenpunkt muss manuell erstellt werden...
                const dpAction: string = 'alias.0.OG.Büro.OG_Büro_Hauptlicht.SET';
                
                const Debug = true;
                
                
                T 1 Reply Last reply Reply Quote 0
                • T
                  TT-Tom @docf last edited by TT-Tom

                  @docf kannst du bitte mal die log-meldungen posten, wenn du eine Weckzeit eingestellt hast.

                  Edit: Fehler gefunden. bitte hier eine Änderung machen. Diesen Teil ersetzen.

                  on({ id: dp_userdata + '.AlarmTime.State', change: 'ne' }, async (obj) => {
                  
                      time = getState(dp_userdata + '.AlarmTime.Time').val;
                      if (Debug) log('Uhrzeit: ' + time, 'info');
                      if ('paused' == obj.state.val) {
                          (function () { if (scheduleAlarmTime) { 
                              clearSchedule(scheduleAlarmTime); 
                              scheduleAlarmTime = null; 
                              } 
                          });
                      } else if ('active' == obj.state.val) {
                          let stunde: number = Math.floor(time / 60);
                          let minute: number = time % 60;
                          if (Debug) log('Weckzeit: ' + ('0' + stunde).slice(-2) + ':' + ('0' + minute).slice(-2), 'info');
                          scheduleAlarmTime = schedule(minute + ' ' + stunde + ' * * *', async () => {
                              await setStateAsync(dpAction, <iobJS.State>{ val: true, ack: true });
                              await setStateAsync(dp_userdata + '.AlarmTime.State', <iobJS.State>{ val: 'paused', ack: true });
                          });
                      }
                  });
                  

                  Edit: fix ist auf Github vorhanden.

                  D 1 Reply Last reply Reply Quote 1
                  • D
                    docf @TT-Tom last edited by

                    @tt-tom

                    Super Danke teste ich am Abend ; )

                    1 Reply Last reply Reply Quote 0
                    • Gargano
                      Gargano last edited by Gargano

                      Ich habe grade die v4.3.3.21 auf dem Simulator aufgespielt.
                      2 Dinge sind mir aufgefallen :
                      Er geht nicht mehr in den Screensaver Mode (auf allen Seiten und alwaysOnDisplay ist nicht gesetzt) , wo und was kann ich da nachschauen ?
                      Trotz ausgeschaltetem Update , zeigt er mir beim Start an, daß der Berry Treiber ein Update braucht.

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

                        @gargano

                        wirf mal die Datenpunkte vom Emulator weg unter:

                        • 0_userdata.0
                        • alias.0

                        Bei mir läuft der Screensaver perfekt!

                        Von welcher Version kommst du? Sind nicht viele Infos für einen Ansatz...

                        Mit dem Berry-Update kann ich mir demnächst mal ansehen

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

                          Update - v4.3.3.22

                          0c30097c-8471-4aa3-a458-a2594f86ba81-image.png

                          Es gab gestern noch ein Update:

                          Was ist neu?
                          @TT-Tom noch eine Optimierung für die Update-Benachrichtigungen eingebaut.

                          • Es wird ein neuer Datenpunkt automatisch in 0_userdata.0 und alias.0. angelegt mit dem die Update-Benachrichtigungen über das Service-Menü abgeschaltet werden können
                            49fc15cd-642d-4699-9b6e-9ead9fbc4cd7-image.png
                            b786521a-4644-40c2-a485-9fa9d29716df-image.png

                          • Außerdem sind noch eine Erweiterung für dynamische Farben der Icons in das Menü eingeflossen

                          • Dynamische Namen sind im Navigationsmenü möglich (Fix)

                          Wie kann ich das Update durchführen?

                          • Wenn aktuelle Version ab v4.3.3.10, dann unteren Teil des NSPanelTs.ts ab:
                            a8c80cdf-6f96-4a55-adaa-a27704726f9b-image.png austauschen
                          • Service-Menü ersetzen (NSPanelTS.ts - Zeilen 371 - 753)

                          https://github.com/joBr99/nspanel-lovelace-ui/blob/main/ioBroker/NsPanelTs.ts

                          Wenn aktuelle Version bis v4.3.3.9, dann Updateaneitung befolgen:
                          https://github.com/joBr99/nspanel-lovelace-ui/wiki/NSPanel-Starthilfe-FAQ#hilfe-bei-update--upgrade

                          VG
                          @TT-Tom & Armilar 😊

                          1 Reply Last reply Reply Quote 3
                          • eierfeile
                            eierfeile last edited by eierfeile

                            Hi, ich nutze die cardThermo. Leider springt die Heizung aber nicht an, wenn die Soll Temperatur unterschritten wird. Die 2 Hardwaretasten sind bei mir deaktiviert. Können also nur digital geschaltet werden...falls das etwas zur Sache tut.
                            Was mache ich falsch?

                            let Kueche_Themostat = <PageThermo>
                            {
                                'type': 'cardThermo',
                                'heading': 'Thermostat Kueche',
                                'useColor': true,
                                'subPage': false,
                                'parent': undefined,
                                'items': [<PageItem>{ 
                                            id: 'alias.0.NSPanels.Thermostat_Kueche', 
                                            minValue: 50, 
                                            maxValue: 300,
                                            stepValue: 5,
                                          //  setThermoDestTemp2: 'ACTUAL1'
                                         }]
                            };
                            
                            
                            T 1 Reply Last reply Reply Quote 0
                            • T
                              TT-Tom @eierfeile last edited by

                              @eierfeile die cradThermo steuert keine Heizung direkt sie kann nur Parameter setzen und die Solltemp. vorgeben. Die Steuerung erfolgt rein extern.

                              eierfeile 1 Reply Last reply Reply Quote 0
                              • theknut
                                theknut last edited by theknut

                                Ich versuche gerade vergeblich meine eigene Navigation aufzubauen. Leider kann ich nicht nachvollziehen wie die zustande kommt.
                                Wie komme ich denn auf die Id für die Page, zu der navigiert werden soll?

                                let NSPanel_Service_SubPage = <PageEntities>
                                {
                                    ...
                                    'items': [
                                        <PageItem>{ navigate: true, id: 'NSPanel_Infos', icon: 'information-outline', offColor: Menu, onColor: Menu, name: findLocaleServMenu('infos'), buttonText: findLocaleServMenu('more')},
                                        ...
                                    ]
                                };
                                

                                Die hier vergebene Id NSPanel_Infos kommt sonst nirgendwo mehr im ganzen Skript vor, außer als Variablenname, aber das kann es ja eigentlich auch nicht sein.

                                Mit dem Variablennamen hatte ich es auch probiert, aber hatte auch keinen Erfolg. Am Ende wird nur der Reboot Button angezeigt.

                                let wohnzimmerLicht = <PageGrid> 
                                {
                                    'type': 'cardGrid',
                                    'heading': 'Licht',
                                    'useColor': true,
                                    'subPage': true,
                                    'parent': menuPage,
                                    'items': [
                                        ...
                                    ]
                                };
                                ...
                                menuPage.items = [
                                        <PageItem>{ navigate: true, id: 'wohnzimmerLicht', icon: 'information-outline'},
                                        <PageItem>{ id: AliasPath + 'Config.rebootNSPanel', name: findLocaleServMenu('reboot') ,icon: 'refresh', offColor: MSRed, onColor: MSGreen, buttonText: findLocaleServMenu('start')}
                                    ];
                                ...
                                export const config = <Config> {
                                
                                    // Seiteneinteilung / Page division
                                    // Hauptseiten / Mainpages
                                    pages: [
                                        menuPage,
                                        NSPanel_Service         	//Auto-Alias Service Page
                                	    //Unlock_Service            //Auto-Alias Service Page (Service Pages used with cardUnlock)
                                    ],
                                
                                    // Unterseiten / Subpages
                                    subPages: [
                                	wohnzimmerLicht,
                                        wohnzimmerRollo,
                                        solarPage,
                                        spotifyPremium,
                                        wlanPage,
                                        technikraum,
                                                NSPanel_Service_SubPage, 
                                

                                Dann erhalte ich dieses Warning

                                script.js.NSPanel.Dev.Dev: Found Alias without channel: wohnzimmerLicht! Please correct the Alias
                                
                                T 1 Reply Last reply Reply Quote 0
                                • T
                                  TT-Tom @theknut last edited by TT-Tom

                                  @theknut der Eintrag kommt zusätzlich in die servicepage nspanel_info

                                  Jetzt habe ich es erst erkannt. Dein Menu Aufbau ist komplett falsch. Siehe dir die Servicestellen an. Hast du eine Mainpage. Der Rest sind SubPage.

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

                                    @tt-tom also ich muss blind sein. Ich finde im ganzen Skript (bis auf die parent-Verweise) keine weitere Id NSPanel_Infos

                                    b5185ef8-255f-4bfd-b18f-b14eff647382-image.png

                                    Die Service Page sagt sie will zu NSPanel_Infos navigieren, aber keine weitere Page oder PageItem hat diese Id vergeben bekommen. Und wenn es über den Variablennamen geht, warum geht das dann bei mir nicht? (siehe Code oben)

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

                                      @tt-tom ok dann hab ich das falsch verstanden. Aber gut, alle Daten sind ja ohnehin in iobroker vorhanden. Dann muss ich dafür noch ein mini Blockly schreiben. Wenn IstTemp < SollTemp dann relais=true und andersrum. Dann sollte es das gewesen sein.
                                      7936d6ed-f2ca-43c8-9174-2c8c6f2315b4-image.png

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

                                        @theknut bei navigate :true gibt targetPage: die Page an, also NSPanel_Infos.

                                        ‹PageItem>‹ navigate: true, id: null, targetPage: 'Erdgeschoss', name: 'Haus'}
                                        

                                        Es geht auch über id:

                                        menuPage.items = [
                                                <PageItem>{ navigate: true, id: 'wohnzimmerLicht', icon: 'information-outline'},
                                                <PageItem>{ id: AliasPath + 'Config.rebootNSPanel', name: findLocaleServMenu('reboot') ,icon: 'refresh', offColor: MSRed, onColor: MSGreen, buttonText: findLocaleServMenu('start')}
                                            ];
                                        

                                        der Teil der Page config ist falsch.
                                        Seitenpage fängt immer mit

                                        let name = <PageType>
                                        {
                                            'type': 'cardType',
                                            'heading': 'Seiten Überschrift',
                                            'useColor': true,
                                            'items': []
                                        };  
                                        

                                        hier kannst du noch mehr lesen

                                        hier ein Link zur Navigation

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

                                          @eierfeile

                                          es gibt da den PID Adapter, der einen Regler darstellt. Kann dir dazu aber kein Support geben.
                                          Oder wie du schon angemerkt hast, mit einem kleinen Script die Relais selber steuern.

                                          D 1 Reply Last reply Reply Quote 1
                                          • D
                                            docf last edited by

                                            @tt-tom
                                            Hi ich versuche gerade den Countdown Timer auf die Reihe zu bekommen.
                                            Leider habe ich da ein Problem.

                                            Ich habe gesehen, dass in den Aliasen zwei Ordner erstellt wurden.
                                            Countdown und Coutown?

                                            Im Skript wird auf diesen Ordner verwiesen.

                                              setObject(dp_alias + '.Coundown', { type: 'channel', common: { role: 'level.timer', name: 'Countdown' }, native: {} });
                                            
                                            

                                            Ich habe den PageItem dann dahingehend angepasst und kann nun meinen Countdown Test sehen.

                                                   <PageItem>{ id: "alias.0.NSPanel.Countown" , name: "ContdownTimer" , interpolateColor:true },
                                            

                                            Ich kann die Zeit einstellen jedoch funktioniert der Countdown nicht.

                                            Mache ich da etwas falsch oder muss ich da noch etwas ändern?
                                            Danke dir

                                            vg

                                            Armilar 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            387
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            lovelace ui nspanel sonoff
                                            260
                                            7128
                                            4462866
                                            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