Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. SONOFF NSPanel mit Lovelace UI

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    11
    2
    199

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    7.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.7k

SONOFF NSPanel mit Lovelace UI

SONOFF NSPanel mit Lovelace UI

Scheduled Pinned Locked Moved Hardware
lovelace uinspanelsonoff
7.7k Posts 271 Posters 6.7m Views 253 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • SternmiereS Sternmiere

    Moin und vielen Dank für die Klasse Anleitung!

    Ich habe jetzt noch zwei Fragen/Probleme:

    1. Fehlende ESP32 Temperatur

    Bei mir im Log taucht regelmäßig die folgende Warnung auf:

    javascript.0 (413513) script.js.bag-end.nspanel.NSPANEL_1_3_4_0: error with reading senor-data: Cannot read properties of undefined (reading 'Temperature')
    

    Ich vermute, dass es an diesem Datenpunkt hier liegt, welcher bei mir mit null besetzt ist.

    0_userdata.0.NSPanel.1.Sensor.ESP32.Temperature
    

    Ich habe das Panel mit tasmota32-nspanel.bin geflashed und habe dort aktuell die Version 12.2.0 laufen. Auf der Übersichtsseite sehe ich nur die Anzeige für Analog1 Temperature. Die Temperatur vom ESP32 sehe ich dort nicht. Liegt das am Tasmota-Image? Oder woran?

    1. cardQR

    Und nun noch eine Frage zum cardQR. Gibt es die Möglichkeit, die Anzeige des Passworts zu unterdrücken? Für eines meiner WLANs ist das Passwort für die Anzeige schlicht zu lang und daher macht es hier keinen Sinn, das im Display anzuzeigen.

    ArmilarA Offline
    ArmilarA Offline
    Armilar
    Most Active Forum Testing
    wrote on last edited by
    #429

    @sternmiere

    War diesmal nicht so clever bei den Tasmoter'n eine Funktion (default) wegzunehmen, die man nur manuell hinzufügen kann 😉

    Mit SetOption146 1 in der Tasmota-Konsole bekommst du es wieder. Dann ist die ESP-Temperatur auch im Hauptmenü wieder zu sehen.

    Zu 2: Sehe ich mir gleich mal an...

    VG

    Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
    https://github.com/joBr99/nspanel-lovelace-ui/wiki

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    SternmiereS 1 Reply Last reply
    0
    • ArmilarA Armilar

      @sternmiere

      War diesmal nicht so clever bei den Tasmoter'n eine Funktion (default) wegzunehmen, die man nur manuell hinzufügen kann 😉

      Mit SetOption146 1 in der Tasmota-Konsole bekommst du es wieder. Dann ist die ESP-Temperatur auch im Hauptmenü wieder zu sehen.

      Zu 2: Sehe ich mir gleich mal an...

      VG

      SternmiereS Offline
      SternmiereS Offline
      Sternmiere
      wrote on last edited by
      #430

      @armilar sagte in SONOFF NSPanel mit Lovelace UI:

      SetOption146 1

      Super, vielen Dank! Hat geklappt!

      Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
      -- Morihei Ueshiba

      ArmilarA 1 Reply Last reply
      0
      • SternmiereS Sternmiere

        @armilar sagte in SONOFF NSPanel mit Lovelace UI:

        SetOption146 1

        Super, vielen Dank! Hat geklappt!

        ArmilarA Offline
        ArmilarA Offline
        Armilar
        Most Active Forum Testing
        wrote on last edited by Armilar
        #431

        @sternmiere

        Perfekt. Das mit der cardQR klappt auch. Hab es in die v3.5.0 noch reingenommen. Falls du vorher testen möchtest:

        function GenerateQRPage austauschen (siehe Spoiler)

        function GenerateQRPage(page: PageQR): Payload[] {
            try {
                activePage = page;
        
                var id = page.items[0].id
                var out_msgs: Array<Payload> = [];
                out_msgs.push({ payload: 'pageType~cardQR' });
        
                let o = getObject(id)
        
                var heading = page.heading !== undefined ? page.heading : o.common.name.de
                var textQR = page.items[0].id + '.ACTUAL' !== undefined ? getState(page.items[0].id + '.ACTUAL').val : 'WIFI:T:undefined;S:undefined;P:undefined;H:undefined;'
                var hiddenPWD = false;
                if (page.items[0].hidePassword !== undefined && page.items[0].hidePassword == true) {
                    hiddenPWD = true
                }
        
                const tempstr = textQR.split(';');
                for (let w = 0; w < tempstr.length - 1; w++) {
                    if (tempstr[w].substring(0, 1) == 'S') {
                        var optionalValue1 = tempstr[w].slice(2);
                    }
                    if (tempstr[w].substring(0, 1) == 'P') {
                        var optionalValue2 = tempstr[w].slice(2);
                    }
                }
        
                var type1 = 'text';
                var internalName1 = 'SSID';
                var iconId1 = Icons.GetIcon('wifi');
                var displayName1 = 'SSID';
                var type2 = 'text';
                var internalName2 = 'Passwort';
                var iconId2 = Icons.GetIcon('key');
                var displayName2 = 'Passwort';
        
                if (hiddenPWD) {
                    type2 = 'disable';
                    iconId2 = '';
                    displayName2 = '';
                }
        
                out_msgs.push({
                    payload: 'entityUpd~' +                     //entityUpd
                        heading + '~' +                         //heading
                        GetNavigationString(pageId) + '~' +     //navigation
                        textQR + '~' +                          //textQR
                        type1 + '~' +                           //type
                        internalName1 + '~' +                   //internalName
                        iconId1 + '~' +                         //iconId
                        65535 + '~' +                           //iconColor
                        displayName1 + '~' +                    //displayName
                        optionalValue1 + '~' +                  //optionalValue
                        type2 + '~' +                           //type
                        internalName2 + '~' +                   //internalName
                        iconId2 + '~' +                         //iconId
                        65535 + '~' +                           //iconColor
                        displayName2 + '~' +                    //displayName
                        optionalValue2
                });                       //optionalValue
        
                //entityUpd,heading,navigation,textQR[,type,internalName,iconId,displayName,optionalValue]x2
                return out_msgs
        
            } catch (err) {
                console.warn('function GenerateQRPage: ' + err.message);
            }
        }
        

        type PageItem austauschen (siehe Spoiler) / fast am Ende des TS-Script

        type PageItem = {
            id: string,
            icon: (string | undefined),
            icon2: (string | undefined),
            onColor: (RGB | undefined),
            offColor: (RGB | undefined),
            useColor: (boolean | undefined),
            interpolateColor: (boolean | undefined),
            minValueBrightness: (number | undefined),
            maxValueBrightness: (number | undefined),
            minValueColorTemp: (number | undefined),
            maxValueColorTemp: (number | undefined),
            minValue: (number | undefined),
            maxValue: (number | undefined),
            name: (string | undefined),
            secondRow: (string | undefined),
            buttonText: (string | undefined),
            unit: (string | undefined),
            navigate: (boolean | undefined),
            colormode: (string | undefined),
            adapterPlayerInstance: (string | undefined),
            mediaDevice: (string | undefined),
            targetPage: (string | undefined),
            speakerList: (string[] | undefined),
            hidePassword: (boolean | undefined)
        }
        

        Definition cardQR im PageItem um ", hidePassword: true" erweitern

        var WLAN: PageQR = 
                {
                    "type": "cardQR",
                    "heading": "Gäste WLAN",
                    "useColor": true,
                    "subPage": true,
                    "parent": Subpages_1,
                    "items": [<PageItem>{ id: "alias.0.NSPanel_1.Guest_Wifi", hidePassword: true }]
                };
        

        Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
        https://github.com/joBr99/nspanel-lovelace-ui/wiki

        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

        SternmiereS 1 Reply Last reply
        0
        • ArmilarA Armilar

          @sternmiere

          Perfekt. Das mit der cardQR klappt auch. Hab es in die v3.5.0 noch reingenommen. Falls du vorher testen möchtest:

          function GenerateQRPage austauschen (siehe Spoiler)

          function GenerateQRPage(page: PageQR): Payload[] {
              try {
                  activePage = page;
          
                  var id = page.items[0].id
                  var out_msgs: Array<Payload> = [];
                  out_msgs.push({ payload: 'pageType~cardQR' });
          
                  let o = getObject(id)
          
                  var heading = page.heading !== undefined ? page.heading : o.common.name.de
                  var textQR = page.items[0].id + '.ACTUAL' !== undefined ? getState(page.items[0].id + '.ACTUAL').val : 'WIFI:T:undefined;S:undefined;P:undefined;H:undefined;'
                  var hiddenPWD = false;
                  if (page.items[0].hidePassword !== undefined && page.items[0].hidePassword == true) {
                      hiddenPWD = true
                  }
          
                  const tempstr = textQR.split(';');
                  for (let w = 0; w < tempstr.length - 1; w++) {
                      if (tempstr[w].substring(0, 1) == 'S') {
                          var optionalValue1 = tempstr[w].slice(2);
                      }
                      if (tempstr[w].substring(0, 1) == 'P') {
                          var optionalValue2 = tempstr[w].slice(2);
                      }
                  }
          
                  var type1 = 'text';
                  var internalName1 = 'SSID';
                  var iconId1 = Icons.GetIcon('wifi');
                  var displayName1 = 'SSID';
                  var type2 = 'text';
                  var internalName2 = 'Passwort';
                  var iconId2 = Icons.GetIcon('key');
                  var displayName2 = 'Passwort';
          
                  if (hiddenPWD) {
                      type2 = 'disable';
                      iconId2 = '';
                      displayName2 = '';
                  }
          
                  out_msgs.push({
                      payload: 'entityUpd~' +                     //entityUpd
                          heading + '~' +                         //heading
                          GetNavigationString(pageId) + '~' +     //navigation
                          textQR + '~' +                          //textQR
                          type1 + '~' +                           //type
                          internalName1 + '~' +                   //internalName
                          iconId1 + '~' +                         //iconId
                          65535 + '~' +                           //iconColor
                          displayName1 + '~' +                    //displayName
                          optionalValue1 + '~' +                  //optionalValue
                          type2 + '~' +                           //type
                          internalName2 + '~' +                   //internalName
                          iconId2 + '~' +                         //iconId
                          65535 + '~' +                           //iconColor
                          displayName2 + '~' +                    //displayName
                          optionalValue2
                  });                       //optionalValue
          
                  //entityUpd,heading,navigation,textQR[,type,internalName,iconId,displayName,optionalValue]x2
                  return out_msgs
          
              } catch (err) {
                  console.warn('function GenerateQRPage: ' + err.message);
              }
          }
          

          type PageItem austauschen (siehe Spoiler) / fast am Ende des TS-Script

          type PageItem = {
              id: string,
              icon: (string | undefined),
              icon2: (string | undefined),
              onColor: (RGB | undefined),
              offColor: (RGB | undefined),
              useColor: (boolean | undefined),
              interpolateColor: (boolean | undefined),
              minValueBrightness: (number | undefined),
              maxValueBrightness: (number | undefined),
              minValueColorTemp: (number | undefined),
              maxValueColorTemp: (number | undefined),
              minValue: (number | undefined),
              maxValue: (number | undefined),
              name: (string | undefined),
              secondRow: (string | undefined),
              buttonText: (string | undefined),
              unit: (string | undefined),
              navigate: (boolean | undefined),
              colormode: (string | undefined),
              adapterPlayerInstance: (string | undefined),
              mediaDevice: (string | undefined),
              targetPage: (string | undefined),
              speakerList: (string[] | undefined),
              hidePassword: (boolean | undefined)
          }
          

          Definition cardQR im PageItem um ", hidePassword: true" erweitern

          var WLAN: PageQR = 
                  {
                      "type": "cardQR",
                      "heading": "Gäste WLAN",
                      "useColor": true,
                      "subPage": true,
                      "parent": Subpages_1,
                      "items": [<PageItem>{ id: "alias.0.NSPanel_1.Guest_Wifi", hidePassword: true }]
                  };
          
          SternmiereS Offline
          SternmiereS Offline
          Sternmiere
          wrote on last edited by Sternmiere
          #432

          @armilar

          Diesen Fehler bekomme ich bei mir:

          (local var) iconId2: any
          Subsequent variable declarations must have the same type.  Variable 'iconId2' must be of type 'any', but here has type 'string'.(2403)
          index345678910.(2569, 13): 'iconId2' was also declared here.
          

          Wenn ich das var vor iconId2 in der Abfrage hiddenPWD entferne, dann kann ich das Skript speichern. Und dann ist das PW auch ausgeblendet!

          Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
          -- Morihei Ueshiba

          ArmilarA 1 Reply Last reply
          0
          • SternmiereS Sternmiere

            @armilar

            Diesen Fehler bekomme ich bei mir:

            (local var) iconId2: any
            Subsequent variable declarations must have the same type.  Variable 'iconId2' must be of type 'any', but here has type 'string'.(2403)
            index345678910.(2569, 13): 'iconId2' was also declared here.
            

            Wenn ich das var vor iconId2 in der Abfrage hiddenPWD entferne, dann kann ich das Skript speichern. Und dann ist das PW auch ausgeblendet!

            ArmilarA Offline
            ArmilarA Offline
            Armilar
            Most Active Forum Testing
            wrote on last edited by Armilar
            #433

            @sternmiere

            Dummer copy/paste-Fehler von mir - sorry

            Alle Variablen-Deklarationen in dem Block sollten raus. Dafür die oberen wieder rein:

                    if (hiddenPWD) {
                        type2 = 'disable';
                        iconId2 = '';
                        displayName2 = '';
                    }
            

            Ich korrigiere das gleich oben im vorherigen Post nochmal...

            Edit: Erledigt, oberer Post (Spoiler 1) korrigiert.

            Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
            https://github.com/joBr99/nspanel-lovelace-ui/wiki

            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

            SternmiereS 1 Reply Last reply
            0
            • ArmilarA Armilar

              @sternmiere

              Dummer copy/paste-Fehler von mir - sorry

              Alle Variablen-Deklarationen in dem Block sollten raus. Dafür die oberen wieder rein:

                      if (hiddenPWD) {
                          type2 = 'disable';
                          iconId2 = '';
                          displayName2 = '';
                      }
              

              Ich korrigiere das gleich oben im vorherigen Post nochmal...

              Edit: Erledigt, oberer Post (Spoiler 1) korrigiert.

              SternmiereS Offline
              SternmiereS Offline
              Sternmiere
              wrote on last edited by
              #434

              @armilar

              hatte ich bei mir lokal auch schon so eingebaut!
              Damit klappt das 1A! Super! Vielen Dank für die schnelle Umsetzung!

              Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
              -- Morihei Ueshiba

              ArmilarA 1 Reply Last reply
              0
              • SternmiereS Sternmiere

                @armilar

                hatte ich bei mir lokal auch schon so eingebaut!
                Damit klappt das 1A! Super! Vielen Dank für die schnelle Umsetzung!

                ArmilarA Offline
                ArmilarA Offline
                Armilar
                Most Active Forum Testing
                wrote on last edited by
                #435

                @sternmiere

                Gerne 👍

                Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                https://github.com/joBr99/nspanel-lovelace-ui/wiki

                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                ArmilarA 1 Reply Last reply
                0
                • ArmilarA Armilar

                  @sternmiere

                  Gerne 👍

                  ArmilarA Offline
                  ArmilarA Offline
                  Armilar
                  Most Active Forum Testing
                  wrote on last edited by
                  #436

                  Upgrade auf TS-Script 3.5.0

                  79a6678d-d98f-44d7-8628-97c3649fb2fc-image.png
                  und Neuer Parameter in zum Ausblenden des WLAN-Passwortes in der cardQR (Hotfix)

                  Ebenfalls neue TFT-Firmware v3.5.0

                  FlashNextion http://nspanel.pky.eu/lovelace-ui/github/nspanel-v3.5.0.tft
                  

                  TS-Script v3.5.0

                  • Mit Beispiel-Seiten
                    https://raw.githubusercontent.com/joBr99/nspanel-lovelace-ui/main/ioBroker/NsPanelTs.ts

                  • Ohne Beispiel-Seiten
                    https://raw.githubusercontent.com/joBr99/nspanel-lovelace-ui/main/ioBroker/NsPanelTs_without_Examples.ts

                  Änderungen

                  • Die Hintergrundfarbe lässt sich jetzt ändern:
                  export const config: Config = {
                      ...
                      defaultBackgroundColor: Black,      //New Parameter
                  
                  • cardPower (Energiefluss)
                    1ced1fec-630d-424f-a7f1-fae517b88f74-Nextion_Editor_9AYbpowjZS.gif
                    https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardpower-ab-ts-script-v341

                  • Layout 2 für popUpNotification (Skript erweitert Datenpunkte unter 0_userdata.0...)
                    821cf3f5-f750-4613-9301-f07ae2557437-image.png
                    Beschreibung in der Wiki folgt. Blockly-Emulator zum Testen im nachfolgenden Post...

                  • popUpShutter erweitert um Tilt-Funktion

                  • Direkte Navigation über Datenpunkt
                    Beschreibung in Wiki folgt...

                  Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                  https://github.com/joBr99/nspanel-lovelace-ui/wiki

                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                  ArmilarA 2 Replies Last reply
                  2
                  • ArmilarA Armilar

                    Upgrade auf TS-Script 3.5.0

                    79a6678d-d98f-44d7-8628-97c3649fb2fc-image.png
                    und Neuer Parameter in zum Ausblenden des WLAN-Passwortes in der cardQR (Hotfix)

                    Ebenfalls neue TFT-Firmware v3.5.0

                    FlashNextion http://nspanel.pky.eu/lovelace-ui/github/nspanel-v3.5.0.tft
                    

                    TS-Script v3.5.0

                    • Mit Beispiel-Seiten
                      https://raw.githubusercontent.com/joBr99/nspanel-lovelace-ui/main/ioBroker/NsPanelTs.ts

                    • Ohne Beispiel-Seiten
                      https://raw.githubusercontent.com/joBr99/nspanel-lovelace-ui/main/ioBroker/NsPanelTs_without_Examples.ts

                    Änderungen

                    • Die Hintergrundfarbe lässt sich jetzt ändern:
                    export const config: Config = {
                        ...
                        defaultBackgroundColor: Black,      //New Parameter
                    
                    • cardPower (Energiefluss)
                      1ced1fec-630d-424f-a7f1-fae517b88f74-Nextion_Editor_9AYbpowjZS.gif
                      https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardpower-ab-ts-script-v341

                    • Layout 2 für popUpNotification (Skript erweitert Datenpunkte unter 0_userdata.0...)
                      821cf3f5-f750-4613-9301-f07ae2557437-image.png
                      Beschreibung in der Wiki folgt. Blockly-Emulator zum Testen im nachfolgenden Post...

                    • popUpShutter erweitert um Tilt-Funktion

                    • Direkte Navigation über Datenpunkt
                      Beschreibung in Wiki folgt...

                    ArmilarA Offline
                    ArmilarA Offline
                    Armilar
                    Most Active Forum Testing
                    wrote on last edited by
                    #437

                    Emulations-Test-Blockly für popUpNotify (Layout 2)

                    https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#emulator-layout-2

                    Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                    https://github.com/joBr99/nspanel-lovelace-ui/wiki

                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                    1 Reply Last reply
                    0
                    • SternmiereS Offline
                      SternmiereS Offline
                      Sternmiere
                      wrote on last edited by
                      #438

                      Hab das Update inkl TFT gleich mal ausgeführt.
                      Bislang klappt alles.

                      Aber eine Frage zum Update selbst:
                      Ich finde es recht kompliziert und fehleranfällig, die einzelnen Teile rund um meine Seitengestaltung und Konfiguration herum zu kopieren.

                      Wäre es nicht möglich, den Block mit der Konfiguration (export const config: Config...) in eine eigene TS-Datei auszulagern?
                      Und kann man nicht ebenso innerhalb des nspanel-Ordners die Seitengestaltung in eigene TS-Datei(en) auszulagern?

                      Würde den Update-Vorgang wahrscheinlich vereinfachen.

                      Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
                      -- Morihei Ueshiba

                      ArmilarA 1 Reply Last reply
                      1
                      • SternmiereS Sternmiere

                        Hab das Update inkl TFT gleich mal ausgeführt.
                        Bislang klappt alles.

                        Aber eine Frage zum Update selbst:
                        Ich finde es recht kompliziert und fehleranfällig, die einzelnen Teile rund um meine Seitengestaltung und Konfiguration herum zu kopieren.

                        Wäre es nicht möglich, den Block mit der Konfiguration (export const config: Config...) in eine eigene TS-Datei auszulagern?
                        Und kann man nicht ebenso innerhalb des nspanel-Ordners die Seitengestaltung in eigene TS-Datei(en) auszulagern?

                        Würde den Update-Vorgang wahrscheinlich vereinfachen.

                        ArmilarA Offline
                        ArmilarA Offline
                        Armilar
                        Most Active Forum Testing
                        wrote on last edited by
                        #439

                        @sternmiere

                        Ist in Planung zu den kälteren und dunkleren Tagen des Jahres 😉

                        Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                        https://github.com/joBr99/nspanel-lovelace-ui/wiki

                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                        1 Reply Last reply
                        0
                        • SternmiereS Offline
                          SternmiereS Offline
                          Sternmiere
                          wrote on last edited by
                          #440

                          Cool!
                          Noch ein zwei andere Fragen:

                          Wenn ich zwischen den Hauptseiten blättere, dann kann ich aktuell nicht sauber durch die Seiten scrollen. Ich bleibe bei der zweiten Seite hängen, muss dann einmal in eine Unterscheite (oder waren bis der Screensaver angeht) und dann kann ich zur nächsten Seite blättern. Ist das ein Konfigurationsfehler bei mir?

                          Und gibt es die Möglichkeit, wenn ich bei der letzten Seite angekommen bin, mit einem Klick nach rechts dann wieder auf die erste Seite zu springen? Damit man dann quasi im Ring durch die Seiten scrollen kann.

                          Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
                          -- Morihei Ueshiba

                          ArmilarA K 2 Replies Last reply
                          0
                          • SternmiereS Sternmiere

                            Cool!
                            Noch ein zwei andere Fragen:

                            Wenn ich zwischen den Hauptseiten blättere, dann kann ich aktuell nicht sauber durch die Seiten scrollen. Ich bleibe bei der zweiten Seite hängen, muss dann einmal in eine Unterscheite (oder waren bis der Screensaver angeht) und dann kann ich zur nächsten Seite blättern. Ist das ein Konfigurationsfehler bei mir?

                            Und gibt es die Möglichkeit, wenn ich bei der letzten Seite angekommen bin, mit einem Klick nach rechts dann wieder auf die erste Seite zu springen? Damit man dann quasi im Ring durch die Seiten scrollen kann.

                            ArmilarA Offline
                            ArmilarA Offline
                            Armilar
                            Most Active Forum Testing
                            wrote on last edited by
                            #441

                            @sternmiere

                            Probleme beim Scrollen habe ich eigentlich gaaaaanz selten mal. Wenn die Seiten grundsätzlich funktionieren, würde ich einen Konfigurationsfehler ausschließen.

                            Aber die Idee am Ende auf die erste Seite weiter zu springen finde ich Mega. Sehe ich mir die Tage mal an.

                            Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                            https://github.com/joBr99/nspanel-lovelace-ui/wiki

                            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                            1 Reply Last reply
                            0
                            • SternmiereS Offline
                              SternmiereS Offline
                              Sternmiere
                              wrote on last edited by Sternmiere
                              #442

                              Moin, bzgl. meiner Scroll/Blätterproblematik mache ich, wenn ich mit allen Seiten fertig bin, mal ein kurzes Video.

                              Ansonsten habe ich aktuell ein Problem bei der Anzeige meines Garagentor-Status:
                              Ich habe das Garagentor als "Tor" unter Geräte eingerichtet. Allerdings musste ich den Datenpunkt ACTUAL von value.bind auf boolean umstellen, da ich bei mir nur via Reed-Kontakt den geschlossenen Zustand vom Garagentor abfragen kann.
                              Wenn ich nun diesen Alias als PageItem angebe, wird in der Grid kein Icon angezeigt - auch nicht, wenn ich explizit ein Icon angebe.
                              Aktuell habe ich mir jetzt als workaround damit beholfen, dass ich das Garagentor nochmals als sensor.door eingebunden habe und hier dann mit dem Icon "garage" überschreibe.
                              Ist das ein Fehler im Skript? Oder wird der Geräte-Typ "Tor" schlicht noch nicht unterstützt?

                              //Update zur Frage:

                              <PageItem>{ id: "alias.0.Kontaktsensoren.Garage", offColor: MSGreen, onColor: MSRed, name: "Garagentor", icon: "garage", icon2: "garage-open" }
                              

                              So sieht mein PageItem zum Garagentor aktuell aus. Ich dachte, mit icon2 kann ich im offenen Zustand das Icon austauschen. Falsch gedacht. Ist das Tor offen, wird das Icon nur rot, bleibt aber bei dem icon garage. Wozu ist denn dann icon2 da?

                              Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
                              -- Morihei Ueshiba

                              ArmilarA 2 Replies Last reply
                              0
                              • T Offline
                                T Offline
                                Tom_W
                                wrote on last edited by
                                #443

                                Hallo,

                                also mittlerweile bin ich durchgestiegen, vielen Dank Armilar für deine Geduld. 🙂

                                Aber eine Frage habe ich noch: Gibt es irgendwo eine Übersicht mit allen zur Verfügung stehenden Icons?

                                Gruß

                                K 1 Reply Last reply
                                0
                                • SternmiereS Offline
                                  SternmiereS Offline
                                  Sternmiere
                                  wrote on last edited by
                                  #444

                                  Die Icon-Übersicht findest Du hier:
                                  https://htmlpreview.github.io/?https://github.com/jobr99/Generate-HASP-Fonts/blob/master/cheatsheet.html

                                  Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
                                  -- Morihei Ueshiba

                                  1 Reply Last reply
                                  1
                                  • SternmiereS Sternmiere

                                    Moin, bzgl. meiner Scroll/Blätterproblematik mache ich, wenn ich mit allen Seiten fertig bin, mal ein kurzes Video.

                                    Ansonsten habe ich aktuell ein Problem bei der Anzeige meines Garagentor-Status:
                                    Ich habe das Garagentor als "Tor" unter Geräte eingerichtet. Allerdings musste ich den Datenpunkt ACTUAL von value.bind auf boolean umstellen, da ich bei mir nur via Reed-Kontakt den geschlossenen Zustand vom Garagentor abfragen kann.
                                    Wenn ich nun diesen Alias als PageItem angebe, wird in der Grid kein Icon angezeigt - auch nicht, wenn ich explizit ein Icon angebe.
                                    Aktuell habe ich mir jetzt als workaround damit beholfen, dass ich das Garagentor nochmals als sensor.door eingebunden habe und hier dann mit dem Icon "garage" überschreibe.
                                    Ist das ein Fehler im Skript? Oder wird der Geräte-Typ "Tor" schlicht noch nicht unterstützt?

                                    //Update zur Frage:

                                    <PageItem>{ id: "alias.0.Kontaktsensoren.Garage", offColor: MSGreen, onColor: MSRed, name: "Garagentor", icon: "garage", icon2: "garage-open" }
                                    

                                    So sieht mein PageItem zum Garagentor aktuell aus. Ich dachte, mit icon2 kann ich im offenen Zustand das Icon austauschen. Falsch gedacht. Ist das Tor offen, wird das Icon nur rot, bleibt aber bei dem icon garage. Wozu ist denn dann icon2 da?

                                    ArmilarA Offline
                                    ArmilarA Offline
                                    Armilar
                                    Most Active Forum Testing
                                    wrote on last edited by Armilar
                                    #445

                                    @sternmiere

                                    Das VirtualDevice "Tor" (gate) mit SET (switch.gate) ist noch nicht implementiert. Kann ich aber mit aufnehmen. Wenn ein Gerätetyp nicht im TS-Script angelegt ist, dann kann dieser auch nicht eingebunden werden.
                                    Die Wahl auf den Gerätetyp Fenster (analog Tür) ist soweit okay, jedoch sind die Icons nicht überschreibbar (noch nicht). Wäre die Bessere Wahl für einen boolschen Wert wahrscheinlich socket oder light gewesen.

                                    Ich werde das Tor heute noch testweise implementieren und informiere dich dann.

                                    Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                                    https://github.com/joBr99/nspanel-lovelace-ui/wiki

                                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                    1 Reply Last reply
                                    2
                                    • ArmilarA Armilar

                                      @gre4t0ne
                                      Geh mal in den Wetter-Alias und zeig mal den Wert

                                      4add14de-2fd3-4d51-8ef8-193639fc27ca-image.png

                                      Der ist für das Icon zuständig

                                      G Offline
                                      G Offline
                                      Gre4t0ne
                                      wrote on last edited by
                                      #446

                                      @armilar DANKE! Bei mir hing hinten noch ein 'URLS' drann...

                                      1 Reply Last reply
                                      0
                                      • SternmiereS Sternmiere

                                        Moin, bzgl. meiner Scroll/Blätterproblematik mache ich, wenn ich mit allen Seiten fertig bin, mal ein kurzes Video.

                                        Ansonsten habe ich aktuell ein Problem bei der Anzeige meines Garagentor-Status:
                                        Ich habe das Garagentor als "Tor" unter Geräte eingerichtet. Allerdings musste ich den Datenpunkt ACTUAL von value.bind auf boolean umstellen, da ich bei mir nur via Reed-Kontakt den geschlossenen Zustand vom Garagentor abfragen kann.
                                        Wenn ich nun diesen Alias als PageItem angebe, wird in der Grid kein Icon angezeigt - auch nicht, wenn ich explizit ein Icon angebe.
                                        Aktuell habe ich mir jetzt als workaround damit beholfen, dass ich das Garagentor nochmals als sensor.door eingebunden habe und hier dann mit dem Icon "garage" überschreibe.
                                        Ist das ein Fehler im Skript? Oder wird der Geräte-Typ "Tor" schlicht noch nicht unterstützt?

                                        //Update zur Frage:

                                        <PageItem>{ id: "alias.0.Kontaktsensoren.Garage", offColor: MSGreen, onColor: MSRed, name: "Garagentor", icon: "garage", icon2: "garage-open" }
                                        

                                        So sieht mein PageItem zum Garagentor aktuell aus. Ich dachte, mit icon2 kann ich im offenen Zustand das Icon austauschen. Falsch gedacht. Ist das Tor offen, wird das Icon nur rot, bleibt aber bei dem icon garage. Wozu ist denn dann icon2 da?

                                        ArmilarA Offline
                                        ArmilarA Offline
                                        Armilar
                                        Most Active Forum Testing
                                        wrote on last edited by Armilar
                                        #447

                                        @sternmiere sagte in SONOFF NSPanel mit Lovelace UI:

                                        <PageItem>{ id: "alias.0.Kontaktsensoren.Garage", offColor: MSGreen, onColor: MSRed, name: "Garagentor", icon: "garage", icon2: "garage-open" }

                                        function CreateEntity(pageItem: PageItem, placeId: number, useColors: boolean = false): string {
                                            ....
                                            ....
                                                        case 'blind':
                                                            type = 'shutter';
                                                            iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('window-open');
                                                            iconColor = GetIconColor(pageItem, existsState(pageItem.id + '.ACTUAL') ? getState(pageItem.id + '.ACTUAL').val : true, useColors);
                                        
                                                            return '~' + type + '~' + pageItem.id + '~' + iconId + '~' + iconColor + '~' + name + '~';
                                        
                                                        case 'gate':
                                                            type = 'text';
                                                            if (existsState(pageItem.id + '.ACTUAL')) {
                                                                if (getState(pageItem.id + '.ACTUAL').val == 0 || getState(pageItem.id + '.ACTUAL').val === false) {
                                                                    iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('garage');
                                                                    iconColor = GetIconColor(pageItem, false, useColors);
                                                                    var gateState = findLocale('window', 'closed');
                                                                } else {
                                                                    iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('garage-open');
                                                                    iconId = pageItem.icon2 !== undefined ? Icons.GetIcon(pageItem.icon2) : Icons.GetIcon('garage-open');
                                                                    iconColor = GetIconColor(pageItem, true, useColors);
                                                                    var gateState = findLocale('window', 'opened');
                                                                }
                                        
                                                                RegisterEntityWatcher(pageItem.id + '.ACTUAL');
                                        
                                                            }
                                        
                                                            return '~' + type + '~' + pageItem.id + '~' + iconId + '~' + iconColor + '~' + name + '~' + gateState;                   
                                        
                                                        case 'door':
                                                        case 'window':
                                                            type = 'text';
                                        

                                        Irgendwo in der "function CreateEntity" gibt es de Typen 'blind' und 'door'

                                        dazwischen (siehe oben) den case 'gate': einbauen. Dann sollte es funktionieren.

                                        Es wird auf boolean oder number geprüft, deshalb sollte auch ein Reed-Kontakt mit true/false funktionieren.

                                        Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                                        https://github.com/joBr99/nspanel-lovelace-ui/wiki

                                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                        SternmiereS 1 Reply Last reply
                                        1
                                        • ArmilarA Armilar

                                          @sternmiere sagte in SONOFF NSPanel mit Lovelace UI:

                                          <PageItem>{ id: "alias.0.Kontaktsensoren.Garage", offColor: MSGreen, onColor: MSRed, name: "Garagentor", icon: "garage", icon2: "garage-open" }

                                          function CreateEntity(pageItem: PageItem, placeId: number, useColors: boolean = false): string {
                                              ....
                                              ....
                                                          case 'blind':
                                                              type = 'shutter';
                                                              iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('window-open');
                                                              iconColor = GetIconColor(pageItem, existsState(pageItem.id + '.ACTUAL') ? getState(pageItem.id + '.ACTUAL').val : true, useColors);
                                          
                                                              return '~' + type + '~' + pageItem.id + '~' + iconId + '~' + iconColor + '~' + name + '~';
                                          
                                                          case 'gate':
                                                              type = 'text';
                                                              if (existsState(pageItem.id + '.ACTUAL')) {
                                                                  if (getState(pageItem.id + '.ACTUAL').val == 0 || getState(pageItem.id + '.ACTUAL').val === false) {
                                                                      iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('garage');
                                                                      iconColor = GetIconColor(pageItem, false, useColors);
                                                                      var gateState = findLocale('window', 'closed');
                                                                  } else {
                                                                      iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('garage-open');
                                                                      iconId = pageItem.icon2 !== undefined ? Icons.GetIcon(pageItem.icon2) : Icons.GetIcon('garage-open');
                                                                      iconColor = GetIconColor(pageItem, true, useColors);
                                                                      var gateState = findLocale('window', 'opened');
                                                                  }
                                          
                                                                  RegisterEntityWatcher(pageItem.id + '.ACTUAL');
                                          
                                                              }
                                          
                                                              return '~' + type + '~' + pageItem.id + '~' + iconId + '~' + iconColor + '~' + name + '~' + gateState;                   
                                          
                                                          case 'door':
                                                          case 'window':
                                                              type = 'text';
                                          

                                          Irgendwo in der "function CreateEntity" gibt es de Typen 'blind' und 'door'

                                          dazwischen (siehe oben) den case 'gate': einbauen. Dann sollte es funktionieren.

                                          Es wird auf boolean oder number geprüft, deshalb sollte auch ein Reed-Kontakt mit true/false funktionieren.

                                          SternmiereS Offline
                                          SternmiereS Offline
                                          Sternmiere
                                          wrote on last edited by
                                          #448

                                          @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                                          Moin,
                                          klappt soweit super. Allerdings wird bei mir bei geschlossenem Garagentor das offene Symbol gezeigt und umgedreht.
                                          Das liegt schlicht an meinem Reed-Kontakt, der bei geschlossenem Tor TRUE liefert.

                                          Kann ich das im Alias irgendwo invertieren? Oder macht es hier Sinn, noch eine Abfrage für den Status einzubauen, was das TRUE letztendlich bedeutet?

                                          IMG_2911.jpeg

                                          Do not look upon this world with fear and loathing. Bravely face whatever the gods offer.
                                          -- Morihei Ueshiba

                                          ArmilarA 2 Replies Last reply
                                          1
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          153

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe