Navigation

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

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Sonoff NSPanel

    This topic has been deleted. Only users with topic management privileges can see it.
    • Atifan
      Atifan @Armilar last edited by Atifan

      Hi. Eine Sache ist mir aufgefallen die etwas komisch ist.

      Ich navigiere ja über die beiden Hardware-Buttons von links nach rechts und rechts nach links.
      Dafür wurde in Tasmota die folgende Rule angelegt
      Rule1 on Button1#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bPrev"} endon on Button2#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bNext"} endon

      Aktuell hab ich im NSPanel die folgenden Seiten konfiguriert
      Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges

      Die beide Hardware-Buttons verhalten sich aber unterschiedlich, was das hin und her scrollen angeht.
      Der rechte Button funktioniert so wie ich mir das vorstelle, d.h. ich kann den so oft drücken wie ich möchte und meine Seiten werden immer von links nach rechts durchgescrollt, also Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges -> wenn ich auf der letzten Seite "sonstiges" bin und nochmal den rechten Hardware-Button drücke, bin ich wieder vorne auf der ersten Seite "Abfallkalender"

      Der linke Button funktioniert aber irgendwie nicht so.
      Wenn ich den drücke wechselt die Ansicht immer nur zwischen Abfallkalender und Benzinpreise 1/2

      es sei denn ich scrolle vorher mit dem rechten Hardware-Button z.B. auf Seite 4 -> Strom
      wenn ich dann den linken Hardware-Button mehrmals drücke dann scrollt er Strom -> Benzinpreise 2/2 -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2

      Also irgendwie scrollt er beim linken Hardware-Button nicht einfach durch von rechts nach links.

      Ich denke mal die Funktion "bPrev" arbeitet irgendwie anders als "bNext".
      Keine Ahnung ob das evlt. ein Bug ist oder aus bestimmten Gründen so sein muss.

      K 1 Reply Last reply Reply Quote 0
      • E
        eppi @Armilar last edited by

        @armilar
        Gibt es eine Möglichkeit nach einer definierten Zeit (oder allenfalls per sofort) im ScreenSaver Modus nach dem Aufwecken wieder die erste Seite angezeigt wird?
        Herzlichen Dank und Gruss Eppi

        Armilar 1 Reply Last reply Reply Quote 0
        • D
          diwoma last edited by diwoma

          Hi an die Entwickler,

          Danke für Eure Arbeit, es ist phantatsisch. Trotzdem möchte ich ein paar Gedanken loswerden.
          Ich hoffe, meine Vorstellung ist nicht zu naiv.

          Wäre es nicht möglich, den ganzen Executiv-Code (unter der Konfiguration) in eine Klasse zu laden, die im global abgelegt wird?
          Diese Klasse wird dann in User-NSPanel.ts instantiiert. Sie stellt dann eine Config zur Verfügung, die dann vom User gefüllt wird, so wie jetzt auch, aber als Objekt.

          Ich sehe darin folgende Vorteile:

          • Update des globalen Skripts durch einfaches Copy-Paste, ohne auf die eigenen EInstellungen Rücksicht nehmen zu müssen
          • kürzeres, übersichtlicheres Skript für die individuelle Konfiguration
          • Einfachere Handhabung bei Verwendung von mehreren Panels, der Execution-Code ist ja der selbe

          Der User instantiiert nur die Klasse, befüllt die Instanz.Config und macht ein Instanz.Start() oder so was.

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

            @eppi sagte in Sonoff NSPanel:

            @armilar
            Gibt es eine Möglichkeit nach einer definierten Zeit (oder allenfalls per sofort) im ScreenSaver Modus nach dem Aufwecken wieder die erste Seite angezeigt wird?
            Herzlichen Dank und Gruss Eppi

            Ja, das geht, allerdings musst du eine Änderung im Code vornehmen:

            in der Funktion

            function HandleButtonEvent(words): void {
            

            Folgenden Part suchen und ersetzen...

            case 'bExit':
                       if (config.screenSaverDoubleClick) {
                           if (words[4] == 2) {
                               GeneratePage(config.pages[pageId]);
                           }
                       } else {
                           if (Debug) console.log('bExit: ' + words[4] + ' - ' + pageId);
                           setIfExists(NSPanel_Path + 'ScreensaverInfo.popupNotifyHeading', '');
                           setIfExists(NSPanel_Path + 'ScreensaverInfo.popupNotifyText', '');
                           GeneratePage(config.pages[0]);
                           //GeneratePage(activePage);
                       }
                       break;
            

            VG

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

              @diwoma sagte in Sonoff NSPanel:

              Hi an die Entwickler,

              Danke für Eure Arbeit, es ist phantatsisch. Trotzdem möchte ich ein paar Gedanken loswerden.
              Ich hoffe, meine Vorstellung ist nicht zu naiv.

              Wäre es nicht möglich, den ganzen Executiv-Code (unter der Konfiguration) in eine Klasse zu laden, die im global abgelegt wird?
              Diese Klasse wird dann in User-NSPanel.ts instantiiert. Sie stellt dann eine Config zur Verfügung, die dann vom User gefüllt wird, so wie jetzt auch, aber als Objekt.

              Ich sehe darin folgende Vorteile:

              • Update des globalen Skripts durch einfaches Copy-Paste, ohne auf die eigenen EInstellungen Rücksicht nehmen zu müssen
              • kürzeres, übersichtlicheres Skript für die individuelle Konfiguration
              • Einfachere Handhabung bei Verwendung von mehreren Panels, der Execution-Code ist ja der selbe

              Der User instantiiert nur die Klasse, befüllt die Instanz.Config und macht ein Instanz.Start() oder so was.

              Ich habe immer noch die naive Hoffnung, dass der Adapter irgendwann mal kommt. 😉

              Den Punkt gibt es im github ebenfalls schon und ich dachte mir, dass wäre ein schöne Beschäftigung für die Winternächte. Falls es jemand vorher machen möchte, gerne einen "Pull request" einlasten.

              Aber du hast schon recht... der ganze Code im unteren Bereich braucht nicht für jedes Panel existieren.

              VG

              1 Reply Last reply Reply Quote 0
              • K
                Kuckuckmann @Atifan last edited by

                @atifan sagte in Sonoff NSPanel:

                Hi. Eine Sache ist mir aufgefallen die etwas komisch ist.

                Ich navigiere ja über die beiden Hardware-Buttons von links nach rechts und rechts nach links.
                Dafür wurde in Tasmota die folgende Rule angelegt
                Rule1 on Button1#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bPrev"} endon on Button2#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bNext"} endon

                Aktuell hab ich im NSPanel die folgenden Seiten konfiguriert
                Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges

                Die beide Hardware-Buttons verhalten sich aber unterschiedlich, was das hin und her scrollen angeht.
                Der rechte Button funktioniert so wie ich mir das vorstelle, d.h. ich kann den so oft drücken wie ich möchte und meine Seiten werden immer von links nach rechts durchgescrollt, also Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges -> wenn ich auf der letzten Seite "sonstiges" bin und nochmal den rechten Hardware-Button drücke, bin ich wieder vorne auf der ersten Seite "Abfallkalender"

                Der linke Button funktioniert aber irgendwie nicht so.
                Wenn ich den drücke wechselt die Ansicht immer nur zwischen Abfallkalender und Benzinpreise 1/2

                es sei denn ich scrolle vorher mit dem rechten Hardware-Button z.B. auf Seite 4 -> Strom
                wenn ich dann den linken Hardware-Button mehrmals drücke dann scrollt er Strom -> Benzinpreise 2/2 -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2

                Also irgendwie scrollt er beim linken Hardware-Button nicht einfach durch von rechts nach links.

                Ich denke mal die Funktion "bPrev" arbeitet irgendwie anders als "bNext".
                Keine Ahnung ob das evlt. ein Bug ist oder aus bestimmten Gründen so sein muss.

                Kann es Sein, dass ein Teil der Seiten als Subpages angelegt sind?
                Vieleicht würde es helfen, wenn du die Konfiguration Deiner Pages mal hier in einem Spoiler einstellst?

                Atifan 1 Reply Last reply Reply Quote 0
                • K
                  Kuckuckmann @Armilar last edited by

                  @armilar

                  Tolles Update 🙂

                  1 Reply Last reply Reply Quote 0
                  • Atifan
                    Atifan @Kuckuckmann last edited by Atifan

                    @kuckuckmann sagte in Sonoff NSPanel:

                    @atifan sagte in Sonoff NSPanel:

                    Hi. Eine Sache ist mir aufgefallen die etwas komisch ist.

                    Ich navigiere ja über die beiden Hardware-Buttons von links nach rechts und rechts nach links.
                    Dafür wurde in Tasmota die folgende Rule angelegt
                    Rule1 on Button1#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bPrev"} endon on Button2#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bNext"} endon

                    Aktuell hab ich im NSPanel die folgenden Seiten konfiguriert
                    Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges

                    Die beide Hardware-Buttons verhalten sich aber unterschiedlich, was das hin und her scrollen angeht.
                    Der rechte Button funktioniert so wie ich mir das vorstelle, d.h. ich kann den so oft drücken wie ich möchte und meine Seiten werden immer von links nach rechts durchgescrollt, also Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges -> wenn ich auf der letzten Seite "sonstiges" bin und nochmal den rechten Hardware-Button drücke, bin ich wieder vorne auf der ersten Seite "Abfallkalender"

                    Der linke Button funktioniert aber irgendwie nicht so.
                    Wenn ich den drücke wechselt die Ansicht immer nur zwischen Abfallkalender und Benzinpreise 1/2

                    es sei denn ich scrolle vorher mit dem rechten Hardware-Button z.B. auf Seite 4 -> Strom
                    wenn ich dann den linken Hardware-Button mehrmals drücke dann scrollt er Strom -> Benzinpreise 2/2 -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2

                    Also irgendwie scrollt er beim linken Hardware-Button nicht einfach durch von rechts nach links.

                    Ich denke mal die Funktion "bPrev" arbeitet irgendwie anders als "bNext".
                    Keine Ahnung ob das evlt. ein Bug ist oder aus bestimmten Gründen so sein muss.

                    Kann es Sein, dass ein Teil der Seiten als Subpages angelegt sind?
                    Vieleicht würde es helfen, wenn du die Konfiguration Deiner Pages mal hier in einem Spoiler einstellst?

                    Hi, nein alle meine Seiten sind genau gleich aufgebaut.
                    Hier der Code.

                    var Abfallkalender: PageEntities =
                    {
                        "type": "cardEntities",
                        "heading": "Abfallkalender",
                        "useColor": true,
                        "subPage": false,
                        "parent": undefined,
                        "items": [
                            <PageItem>{ id: "alias.0.Abfallkalender.event1",icon: "trash-can"},
                            <PageItem>{ id: "alias.0.Abfallkalender.event2",icon: "trash-can"},
                            <PageItem>{ id: "alias.0.Abfallkalender.event3",icon: "trash-can"},
                            <PageItem>{ id: "alias.0.Abfallkalender.event4",icon: "trash-can"}
                        ]
                    };
                    
                    var Strom: PageEntities =
                    {
                        "type": "cardEntities",
                        "heading": "Strom",
                        "useColor": true,
                        "subPage": false,
                        "parent": undefined,
                        "items": [
                            <PageItem>{ id: "alias.0.PV-Anlage.aktueller_Netzbezug", name: 'Netzbezug aktuell', onColor: Red, offColor: Red, icon: "power-plug-outline"},
                            <PageItem>{ id: "alias.0.PV-Anlage.aktuelle_Erzeugung", name: 'PV-Leistung aktuell', onColor: Yellow, offColor: Yellow, icon: "solar-power"},
                            <PageItem>{ id: "alias.0.PV-Anlage.Stromerzeugung_heute", name: 'PV-Erzeugung heute', onColor: Green, offColor: Green, icon: "solar-power-variant"},
                        ]
                    };
                    
                    var Benzinpreise1: PageEntities =
                    {
                        "type": "cardEntities",
                        "heading": "Benzinpreise 1/2",
                        "useColor": true,
                        "subPage": false,
                        "parent": undefined,
                        "items": [
                            <PageItem>{ id: "alias.0.Benzinpreise.ED_Schmelz", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                            <PageItem>{ id: "alias.0.Benzinpreise.ED_Thalexweiler", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                            <PageItem>{ id: "alias.0.Benzinpreise.Globus_St-Wendel", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                            <PageItem>{ id: "alias.0.Benzinpreise.Nardi_Theley", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                        ]
                    };
                    
                    var Benzinpreise2: PageEntities =
                    {
                        "type": "cardEntities",
                        "heading": "Benzinpreise 2/2",
                        "useColor": true,
                        "subPage": false,
                        "parent": undefined,
                        "items": [
                            <PageItem>{ id: "alias.0.Benzinpreise.Schlick_Alsweiler", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                            <PageItem>{ id: "alias.0.Benzinpreise.Total_Hasborn", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                            <PageItem>{ id: "alias.0.Benzinpreise.Heizöl", onColor: Red, offColor: Red, icon: "gas-burner"},
                        ]
                    };
                    
                    var sonstiges: PageEntities =
                    {
                        "type": "cardEntities",
                        "heading": "sonstiges",
                        "useColor": true,
                        "subPage": false,
                        "parent": undefined,
                        "items": [
                            <PageItem>{ id: "alias.0.sonstige_Infos.Wasser_in_Zisterne", onColor: Blue, offColor: Blue, icon: "water"},
                            <PageItem>{ id: "alias.0.sonstige_Infos.Füllstand_Zisterne", onColor: Blue, offColor: Blue, icon: "water"},
                            <PageItem>{ id: "alias.0.sonstige_Infos.Füllstand_Öltank", onColor: Red, offColor: Red, icon: "gas-burner"},
                        ]
                    };
                    
                    Armilar 1 Reply Last reply Reply Quote 0
                    • Armilar
                      Armilar Most Active Forum Testing @Atifan last edited by Armilar

                      @atifan sagte in Sonoff NSPanel:

                      @kuckuckmann sagte in Sonoff NSPanel:

                      @atifan sagte in Sonoff NSPanel:

                      Hi. Eine Sache ist mir aufgefallen die etwas komisch ist.

                      Ich navigiere ja über die beiden Hardware-Buttons von links nach rechts und rechts nach links.
                      Dafür wurde in Tasmota die folgende Rule angelegt
                      Rule1 on Button1#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bPrev"} endon on Button2#state do Publish %topic%/tele/RESULT {"CustomRecv":"event,buttonPress2,hwbtn,bNext"} endon

                      Aktuell hab ich im NSPanel die folgenden Seiten konfiguriert
                      Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges

                      Die beide Hardware-Buttons verhalten sich aber unterschiedlich, was das hin und her scrollen angeht.
                      Der rechte Button funktioniert so wie ich mir das vorstelle, d.h. ich kann den so oft drücken wie ich möchte und meine Seiten werden immer von links nach rechts durchgescrollt, also Abfallkalender -> Benzinpreise 1/2 -> Benzinpreise 2/2 -> Strom -> sonstiges -> wenn ich auf der letzten Seite "sonstiges" bin und nochmal den rechten Hardware-Button drücke, bin ich wieder vorne auf der ersten Seite "Abfallkalender"

                      Der linke Button funktioniert aber irgendwie nicht so.
                      Wenn ich den drücke wechselt die Ansicht immer nur zwischen Abfallkalender und Benzinpreise 1/2

                      es sei denn ich scrolle vorher mit dem rechten Hardware-Button z.B. auf Seite 4 -> Strom
                      wenn ich dann den linken Hardware-Button mehrmals drücke dann scrollt er Strom -> Benzinpreise 2/2 -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2 -> Abfallkalender -> Benzinpreise 1/2

                      Also irgendwie scrollt er beim linken Hardware-Button nicht einfach durch von rechts nach links.

                      Ich denke mal die Funktion "bPrev" arbeitet irgendwie anders als "bNext".
                      Keine Ahnung ob das evlt. ein Bug ist oder aus bestimmten Gründen so sein muss.

                      Kann es Sein, dass ein Teil der Seiten als Subpages angelegt sind?
                      Vieleicht würde es helfen, wenn du die Konfiguration Deiner Pages mal hier in einem Spoiler einstellst?

                      Hi, nein alle meine Seiten sind genau gleich aufgebaut.
                      Hier der Code.

                      var Abfallkalender: PageEntities =
                      {
                          "type": "cardEntities",
                          "heading": "Abfallkalender",
                          "useColor": true,
                          "subPage": false,
                          "parent": undefined,
                          "items": [
                              <PageItem>{ id: "alias.0.Abfallkalender.event1",icon: "trash-can"},
                              <PageItem>{ id: "alias.0.Abfallkalender.event2",icon: "trash-can"},
                              <PageItem>{ id: "alias.0.Abfallkalender.event3",icon: "trash-can"},
                              <PageItem>{ id: "alias.0.Abfallkalender.event4",icon: "trash-can"}
                          ]
                      };
                      
                      var Strom: PageEntities =
                      {
                          "type": "cardEntities",
                          "heading": "Strom",
                          "useColor": true,
                          "subPage": false,
                          "parent": undefined,
                          "items": [
                              <PageItem>{ id: "alias.0.PV-Anlage.aktueller_Netzbezug", name: 'Netzbezug aktuell', onColor: Red, offColor: Red, icon: "power-plug-outline"},
                              <PageItem>{ id: "alias.0.PV-Anlage.aktuelle_Erzeugung", name: 'PV-Leistung aktuell', onColor: Yellow, offColor: Yellow, icon: "solar-power"},
                              <PageItem>{ id: "alias.0.PV-Anlage.Stromerzeugung_heute", name: 'PV-Erzeugung heute', onColor: Green, offColor: Green, icon: "solar-power-variant"},
                          ]
                      };
                      
                      var Benzinpreise1: PageEntities =
                      {
                          "type": "cardEntities",
                          "heading": "Benzinpreise 1/2",
                          "useColor": true,
                          "subPage": false,
                          "parent": undefined,
                          "items": [
                              <PageItem>{ id: "alias.0.Benzinpreise.ED_Schmelz", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                              <PageItem>{ id: "alias.0.Benzinpreise.ED_Thalexweiler", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                              <PageItem>{ id: "alias.0.Benzinpreise.Globus_St-Wendel", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                              <PageItem>{ id: "alias.0.Benzinpreise.Nardi_Theley", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                          ]
                      };
                      
                      var Benzinpreise2: PageEntities =
                      {
                          "type": "cardEntities",
                          "heading": "Benzinpreise 2/2",
                          "useColor": true,
                          "subPage": false,
                          "parent": undefined,
                          "items": [
                              <PageItem>{ id: "alias.0.Benzinpreise.Schlick_Alsweiler", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                              <PageItem>{ id: "alias.0.Benzinpreise.Total_Hasborn", onColor: Yellow, offColor: Yellow, icon: "gas-station"},
                              <PageItem>{ id: "alias.0.Benzinpreise.Heizöl", onColor: Red, offColor: Red, icon: "gas-burner"},
                          ]
                      };
                      
                      var sonstiges: PageEntities =
                      {
                          "type": "cardEntities",
                          "heading": "sonstiges",
                          "useColor": true,
                          "subPage": false,
                          "parent": undefined,
                          "items": [
                              <PageItem>{ id: "alias.0.sonstige_Infos.Wasser_in_Zisterne", onColor: Blue, offColor: Blue, icon: "water"},
                              <PageItem>{ id: "alias.0.sonstige_Infos.Füllstand_Zisterne", onColor: Blue, offColor: Blue, icon: "water"},
                              <PageItem>{ id: "alias.0.sonstige_Infos.Füllstand_Öltank", onColor: Red, offColor: Red, icon: "gas-burner"},
                          ]
                      };
                      

                      Ich kann mir aktuell nicht vorstellen, dass das am TS liegt. Es werden durch die gesonderte Tasmota-Rule1 die gleichen Nachrichten gesendet und verarbeitet wie mit der Software-Navigation.

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

                        @armilar sagte in Sonoff NSPanel:

                        Ich kann mir aktuell nicht vorstellen, dass das am TS liegt. Es werden durch die gesonderte Tasmota-Rule1 die gleichen Nachrichten gesendet und verarbeitet wie mit der Software-Navigation.

                        case 'bPrev':
                                    var pageNum = ((pageId - 1) % config.pages.length);
                                    pageId = Math.abs(pageNum);
                                    UnsubscribeWatcher();
                                    if (activePage != undefined && activePage.parent != undefined) {
                                        //update pageID
                                        for (let i = 0; i < config.pages.length; i++) {
                                            if (config.pages[i] == activePage.parent) {
                                                pageId = i;
                                                break;
                                            }
                                        }
                                        GeneratePage(activePage.parent);
                                    }
                                    else {
                                        GeneratePage(config.pages[pageId]);
                                    }
                        
                                    break;
                        

                        ich glaube es liegt doch am Code. Die erste Seite hat doch die PageId 0. Die Variable PageNum bekommt als Ergebnis -1, dann wird in der nächsten Zeile der absolut Wert gebildet, also 1. Damit springt die Seite mit PageId 1 wieder nach vorne

                        oder liege ich da falsch, den ich habe die nächsten Zeilen noch nicht ganz nachvollziehen können.

                        J Armilar 2 Replies Last reply Reply Quote 0
                        • J
                          joBr99 @TT-Tom last edited by joBr99

                          @tt-tom @Atifan

                          probiert mal so: (Disclaimer: ungetestet)

                                  case 'bNext':
                                      pageId = (((pageId + 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                      UnsubscribeWatcher();
                                      GeneratePage(config.pages[pageId]);
                                      break;
                                  case 'bPrev':
                                      pageId = (((pageId - 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                      UnsubscribeWatcher();
                          
                          Armilar 1 Reply Last reply Reply Quote 0
                          • Armilar
                            Armilar Most Active Forum Testing @TT-Tom last edited by

                            @tt-tom sagte in Sonoff NSPanel:

                            @armilar sagte in Sonoff NSPanel:

                            Ich kann mir aktuell nicht vorstellen, dass das am TS liegt. Es werden durch die gesonderte Tasmota-Rule1 die gleichen Nachrichten gesendet und verarbeitet wie mit der Software-Navigation.

                            case 'bPrev':
                                        var pageNum = ((pageId - 1) % config.pages.length);
                                        pageId = Math.abs(pageNum);
                                        UnsubscribeWatcher();
                                        if (activePage != undefined && activePage.parent != undefined) {
                                            //update pageID
                                            for (let i = 0; i < config.pages.length; i++) {
                                                if (config.pages[i] == activePage.parent) {
                                                    pageId = i;
                                                    break;
                                                }
                                            }
                                            GeneratePage(activePage.parent);
                                        }
                                        else {
                                            GeneratePage(config.pages[pageId]);
                                        }
                            
                                        break;
                            

                            ich glaube es liegt doch am Code. Die erste Seite hat doch die PageId 0. Die Variable PageNum bekommt als Ergebnis -1, dann wird in der nächsten Zeile der absolut Wert gebildet, also 1. Damit springt die Seite mit PageId 1 wieder nach vorne

                            oder liege ich da falsch, den ich habe die nächsten Zeilen noch nicht ganz nachvollziehen können.

                            Nee, macht schon was es soll. Habe zur Verdeutlichung ein paar Logs eingebaut

                            bee4db62-caef-457a-b08b-18dee20b7b03-image.png

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

                              @jobr99 sagte in Sonoff NSPanel:

                              @tt-tom @Atifan

                              probiert mal so: (Disclaimer: ungetestet)

                                      case 'bNext':
                                          pageId = (((pageId + 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                          UnsubscribeWatcher();
                                          GeneratePage(config.pages[pageId]);
                                          break;
                                      case 'bPrev':
                                          pageId = (((pageId - 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                          UnsubscribeWatcher();
                              

                              daf870b1-5d16-430e-a998-27f4c740861f-image.png

                              Der geht auf die Bretter

                              So geht es
                              9cd403d4-652d-43e6-bb4a-2022e76fde5e-image.png

                              Aber mal im Ernst. Macht das gleiche wie ursprünglich. Hat auch das gleiche Ergebnis und vorher auch funktioniert.

                              Ich hatte mit der Software-Navi noch nie einen Ausfall oder fehlende Seiten oder Sprünge

                              J 1 Reply Last reply Reply Quote 0
                              • J
                                joBr99 @Armilar last edited by joBr99

                                @armilar
                                Das war mein Gedanke dazu:

                                5 Seiten insgesammt; aktuelle Seite ist 0

                                bPrev bei disem code:

                                            var pageNum = ((pageId - 1) % config.pages.length); -> ergibt -1 (warum auch immer modulo in JS so implementiert ist ...)
                                            pageId = Math.abs(pageNum); -> ergibt 1
                                

                                Ergebnis ist 1, sollte aber 4 sein.

                                Math.abs(0-1%5)
                                vs.
                                (((0 - 1) % 5) + 5) % 5

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

                                  @jobr99 sagte in Sonoff NSPanel:

                                  @armilar
                                  Das war mein Gedanke dazu:

                                  5 Seiten insgesammt; aktuelle Seite ist 0

                                  bPrev bei disem code:

                                              var pageNum = ((pageId - 1) % config.pages.length); -> ergibt -1 (warum auch immer modulo in JS so implementiert ist ...)
                                              pageId = Math.abs(pageNum); -> ergibt 1
                                  

                                  Ergebnis ist 1, sollte aber 4 sein.

                                  Math.abs(-1%5)
                                  vs.
                                  (((0 - 1) % 5) + 5) % 5

                                  Wie auch immer 😉
                                  @Atifan soll es mal so einbauen und testen. Ist ja auch schick so...

                                  case 'bNext':
                                             var pageNum = (((pageId + 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                             pageId = pageNum;
                                             UnsubscribeWatcher();
                                             GeneratePage(config.pages[pageId]);
                                             break;
                                         case 'bPrev':
                                             var pageNum = (((pageId - 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                             pageId = pageNum;
                                             UnsubscribeWatcher();
                                             if (activePage != undefined && activePage.parent != undefined) {
                                                 //update pageID
                                                 for (let i = 0; i < config.pages.length; i++) {
                                                     if (config.pages[i] == activePage.parent) {
                                                         pageId = i;
                                                         break;
                                                     }
                                                 }
                                                 GeneratePage(activePage.parent);
                                             }
                                             else {
                                                 GeneratePage(config.pages[pageId]);
                                             }
                                             break;
                                  
                                  Atifan T 2 Replies Last reply Reply Quote 0
                                  • Atifan
                                    Atifan @Armilar last edited by Atifan

                                    Jo Leute ihr seid echt geil 🙂

                                    Also habe den neuen Code da eingebaut und damit funktioniert es 🙂 Vielen Dank!

                                    Also den Code hier mein ich

                                    case 'bNext':
                                               var pageNum = (((pageId + 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                               pageId = pageNum;
                                               UnsubscribeWatcher();
                                               GeneratePage(config.pages[pageId]);
                                               break;
                                           case 'bPrev':
                                               var pageNum = (((pageId - 1) % config.pages.length) + config.pages.length) % config.pages.length;
                                               pageId = pageNum;
                                               UnsubscribeWatcher();
                                               if (activePage != undefined && activePage.parent != undefined) {
                                                   //update pageID
                                                   for (let i = 0; i < config.pages.length; i++) {
                                                       if (config.pages[i] == activePage.parent) {
                                                           pageId = i;
                                                           break;
                                                       }
                                                   }
                                                   GeneratePage(activePage.parent);
                                               }
                                               else {
                                                   GeneratePage(config.pages[pageId]);
                                               }
                                               break;
                                    
                                    Armilar 1 Reply Last reply Reply Quote 0
                                    • Armilar
                                      Armilar Most Active Forum Testing @Atifan last edited by

                                      @atifan sagte in Sonoff NSPanel:

                                      Jo Leute ihr seid echt geil 🙂

                                      Also habe den neuen Code da eingebaut und damit funktioniert es 🙂 Vielen Dank!

                                      Echt jetzt?

                                      @joBr99 👍 😊

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

                                        @armilar sagte in Sonoff NSPanel:

                                        @atifan sagte in Sonoff NSPanel:

                                        Jo Leute ihr seid echt geil 🙂

                                        Also habe den neuen Code da eingebaut und damit funktioniert es 🙂 Vielen Dank!

                                        Echt jetzt?

                                        @joBr99 👍 😊

                                        Lass es jetzt so drin

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

                                          @armilar sagte in Sonoff NSPanel:

                                          @armilar sagte in Sonoff NSPanel:

                                          @atifan sagte in Sonoff NSPanel:

                                          Jo Leute ihr seid echt geil 🙂

                                          Also habe den neuen Code da eingebaut und damit funktioniert es 🙂 Vielen Dank!

                                          Echt jetzt?

                                          @joBr99 👍 😊

                                          Lass es jetzt so drin

                                          Bugfix v3.4.0.3 ist auf github

                                          Gerne den unteren Teil austauschen...

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

                                          Atifan 1 Reply Last reply Reply Quote 0
                                          • Atifan
                                            Atifan @Armilar last edited by

                                            @armilar 👍
                                            Was man evtl. auch noch machen könnte, im Script ganz oben bei der Dokumentation und den Changenotes eine Zeile mit dem Hinweis, wo man die Iconsymbole findet. Dann muss man nicht immer hier im Forum nach dem Link suchen 🙂

                                            Also z.B. so:
                                            // Icons unter: https://htmlpreview.github.io/?https://github.com/jobr99/Generate-HASP-Fonts/blob/master/cheatsheet.html

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            723
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            78
                                            1548
                                            398057
                                            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