Skip to content
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. SONOFF NSPanel mit Lovelace UI

NEWS

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

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

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.1k

SONOFF NSPanel mit Lovelace UI

Geplant Angeheftet Gesperrt Verschoben Hardware
lovelace uinspanelsonoff
7.7k Beiträge 271 Kommentatoren 6.7m Aufrufe 253 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • arteckA arteck

    kann ich die fonst grösse hier beeinflussen
    d20735a6-29d5-42b3-a959-f188f9ad81dd-grafik.png

    ArmilarA Offline
    ArmilarA Offline
    Armilar
    Most Active Forum Testing
    schrieb am zuletzt editiert von
    #7282

    @arteck

    nein, an der Stelle nicht... Nur den Wert selbst

    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.

    teletapiT arteckA 2 Antworten Letzte Antwort
    0
    • ArmilarA Armilar

      @arteck

      nein, an der Stelle nicht... Nur den Wert selbst

      teletapiT Online
      teletapiT Online
      teletapi
      schrieb am zuletzt editiert von teletapi
      #7283

      Morjen, ich hab da noch Fragen ;-), ich hab mir mit eurer Hilfe Anleitungen und ein wenig Chatgpt versucht ein JS script zu basteln um mal mit der Powercard zu spielen und einen Teil meiner PV Anlage wiederzugeben.
      Da wird das batteriesymbol jetzt im Moment grün dargestellt könnte man diese farbe dynamisch oder ggf. auch statisch ändern lassen wenn Voll dann grün wenn geladen wird Rot..?

      Hier Das Script:

      schedule("* * * * *", function () {
          var powerCardJson = "0_userdata.0.NSPanel.Powercard";
      
          var pwr1Raw = getState("0_userdata.0.PV.now.Battery_Power").val || 0;
          var pwr1 = Math.abs(Math.round(pwr1Raw));  // Betrag für Anzeige
          var pwr2 = Math.round(getState("modbus.0.holdingRegisters._Total_Active_power_(Grid_Meter)").val);
          var pwr3 = "";
          var pwr4 = "";
          var pwr5 = Math.round(getState("sonoff.0.Tasmota Energie LG E320.E320_Power_in").val);
          var pwr6 = 0;
          var pwrHome = Math.round(getState("0_userdata.0.PV.now.Load_Total_Power").val || 0);
      
          var keys = ["id", "value", "unit", "icon", "iconColor", "speed"];
          var helperBase = "0_userdata.0.NSPanel.PowercardHelper";
      
          if (!existsObject(helperBase)) {
              createState(helperBase, null, { type: "channel", common: { name: "PowercardHelper" }, native: {} });
          }
      
          function createStateIfNotExists(id, initialValue = 0) {
              if (!existsState(id)) {
                  createState(id, initialValue, {
                      name: "Last Power Wert",
                      role: "value",
                      type: "number",
                      unit: "W",
                      read: true,
                      write: false
                  });
              }
          }
      
          createStateIfNotExists(helperBase + ".PWR1_Last");
          createStateIfNotExists(helperBase + ".PWR2_Last");
          createStateIfNotExists(helperBase + ".PWR5_Last");
      
          function getLastValue(id) {
              var s = getState(id);
              return s ? s.val : 0;
          }
      
          function setLastValue(id, val) {
              setState(id, val, true);
          }
      
          function calcSpeed(current, last) {
              if (current > last) return 2;
              else if (current < last) return -2;
              else return 0;
          }
      
          var pwr1Last = getLastValue(helperBase + ".PWR1_Last");
          var pwr2Last = getLastValue(helperBase + ".PWR2_Last");
          var pwr5Last = getLastValue(helperBase + ".PWR5_Last");
      
          var speedPwr1 = calcSpeed(pwr1Raw, pwr1Last);  // Richtung basiert auf Originalwert
          var speedPwr2 = calcSpeed(pwr2, pwr2Last);
          var speedPwr5 = calcSpeed(pwr5, pwr5Last);
      
          setLastValue(helperBase + ".PWR1_Last", pwr1Raw);
          setLastValue(helperBase + ".PWR2_Last", pwr2);
          setLastValue(helperBase + ".PWR5_Last", pwr5);
      
          var home = [0, pwrHome, "W", "home-lightning-bolt-outline", 0, 0];
      
          // Batterie → ID 1
          var item1 = [1, pwr1, "W", "battery-high", 3, speedPwr1];
      
          var item2 = [2, pwr2, "W", "solar-power-variant-outline", 3, speedPwr2];
          var item3 = [3, pwr3, "", "", 0, 0];
          var item4 = [4, pwr4, "", "", 0, 0];
          var item5 = [5, pwr5, "W", "transmission-tower", 10, speedPwr5];
          var item6 = [6, pwr6, "kW", "", 0, 0];
      
          function func(tags, values) {
              return tags.reduce((acc, tag, index) => {
                  acc[tag] = values[index];
                  return acc;
              }, {});
          }
      
          setState(
              powerCardJson,
              JSON.stringify([
                  func(keys, home),
                  func(keys, item1),
                  func(keys, item2),
                  func(keys, item3),
                  func(keys, item4),
                  func(keys, item5),
                  func(keys, item6),
              ])
          );
      });
      

      Hier meine Powercard:

      let CardPower: PageType =
              {
                  "type": "cardPower",
                  "heading": "Energiefluss",
      //          "useColor": true,
                  "subPage": false,
                  "parent": undefined,
                  "items": [
                      {id: "alias.0.NSPanel.PowerCard", alwaysOnDisplay: true}
                       //   interpolateColor: true}
               ]
      };
      

      Und hier ein Bild wie es derzeit aussieht:
      WhatsApp Bild 2025-06-23 um 14.41.49_67dd7821.jpg

      T 1 Antwort Letzte Antwort
      0
      • teletapiT teletapi

        Morjen, ich hab da noch Fragen ;-), ich hab mir mit eurer Hilfe Anleitungen und ein wenig Chatgpt versucht ein JS script zu basteln um mal mit der Powercard zu spielen und einen Teil meiner PV Anlage wiederzugeben.
        Da wird das batteriesymbol jetzt im Moment grün dargestellt könnte man diese farbe dynamisch oder ggf. auch statisch ändern lassen wenn Voll dann grün wenn geladen wird Rot..?

        Hier Das Script:

        schedule("* * * * *", function () {
            var powerCardJson = "0_userdata.0.NSPanel.Powercard";
        
            var pwr1Raw = getState("0_userdata.0.PV.now.Battery_Power").val || 0;
            var pwr1 = Math.abs(Math.round(pwr1Raw));  // Betrag für Anzeige
            var pwr2 = Math.round(getState("modbus.0.holdingRegisters._Total_Active_power_(Grid_Meter)").val);
            var pwr3 = "";
            var pwr4 = "";
            var pwr5 = Math.round(getState("sonoff.0.Tasmota Energie LG E320.E320_Power_in").val);
            var pwr6 = 0;
            var pwrHome = Math.round(getState("0_userdata.0.PV.now.Load_Total_Power").val || 0);
        
            var keys = ["id", "value", "unit", "icon", "iconColor", "speed"];
            var helperBase = "0_userdata.0.NSPanel.PowercardHelper";
        
            if (!existsObject(helperBase)) {
                createState(helperBase, null, { type: "channel", common: { name: "PowercardHelper" }, native: {} });
            }
        
            function createStateIfNotExists(id, initialValue = 0) {
                if (!existsState(id)) {
                    createState(id, initialValue, {
                        name: "Last Power Wert",
                        role: "value",
                        type: "number",
                        unit: "W",
                        read: true,
                        write: false
                    });
                }
            }
        
            createStateIfNotExists(helperBase + ".PWR1_Last");
            createStateIfNotExists(helperBase + ".PWR2_Last");
            createStateIfNotExists(helperBase + ".PWR5_Last");
        
            function getLastValue(id) {
                var s = getState(id);
                return s ? s.val : 0;
            }
        
            function setLastValue(id, val) {
                setState(id, val, true);
            }
        
            function calcSpeed(current, last) {
                if (current > last) return 2;
                else if (current < last) return -2;
                else return 0;
            }
        
            var pwr1Last = getLastValue(helperBase + ".PWR1_Last");
            var pwr2Last = getLastValue(helperBase + ".PWR2_Last");
            var pwr5Last = getLastValue(helperBase + ".PWR5_Last");
        
            var speedPwr1 = calcSpeed(pwr1Raw, pwr1Last);  // Richtung basiert auf Originalwert
            var speedPwr2 = calcSpeed(pwr2, pwr2Last);
            var speedPwr5 = calcSpeed(pwr5, pwr5Last);
        
            setLastValue(helperBase + ".PWR1_Last", pwr1Raw);
            setLastValue(helperBase + ".PWR2_Last", pwr2);
            setLastValue(helperBase + ".PWR5_Last", pwr5);
        
            var home = [0, pwrHome, "W", "home-lightning-bolt-outline", 0, 0];
        
            // Batterie → ID 1
            var item1 = [1, pwr1, "W", "battery-high", 3, speedPwr1];
        
            var item2 = [2, pwr2, "W", "solar-power-variant-outline", 3, speedPwr2];
            var item3 = [3, pwr3, "", "", 0, 0];
            var item4 = [4, pwr4, "", "", 0, 0];
            var item5 = [5, pwr5, "W", "transmission-tower", 10, speedPwr5];
            var item6 = [6, pwr6, "kW", "", 0, 0];
        
            function func(tags, values) {
                return tags.reduce((acc, tag, index) => {
                    acc[tag] = values[index];
                    return acc;
                }, {});
            }
        
            setState(
                powerCardJson,
                JSON.stringify([
                    func(keys, home),
                    func(keys, item1),
                    func(keys, item2),
                    func(keys, item3),
                    func(keys, item4),
                    func(keys, item5),
                    func(keys, item6),
                ])
            );
        });
        

        Hier meine Powercard:

        let CardPower: PageType =
                {
                    "type": "cardPower",
                    "heading": "Energiefluss",
        //          "useColor": true,
                    "subPage": false,
                    "parent": undefined,
                    "items": [
                        {id: "alias.0.NSPanel.PowerCard", alwaysOnDisplay: true}
                         //   interpolateColor: true}
                 ]
        };
        

        Und hier ein Bild wie es derzeit aussieht:
        WhatsApp Bild 2025-06-23 um 14.41.49_67dd7821.jpg

        T Offline
        T Offline
        TT-Tom
        schrieb am zuletzt editiert von
        #7284

        @teletapi Mach doch aus dem iconColor eine variable und setze den Wert je nach Wunsch.

        ["id", "value", "unit", "icon", "iconColor", "speed"]
        [1, pwr1, "W", "battery-high", 3, speedPwr1]
        

        Gruß Tom
        https://github.com/tt-tom17
        Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

        NSPanel Script Wiki
        https://github.com/joBr99/nspanel-lovelace-ui/wiki

        NSPanel Adapter Wiki
        https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

        teletapiT 1 Antwort Letzte Antwort
        0
        • ArmilarA Armilar

          @arteck

          nein, an der Stelle nicht... Nur den Wert selbst

          arteckA Offline
          arteckA Offline
          arteck
          Developer Most Active
          schrieb am zuletzt editiert von
          #7285

          @armilar sagte in SONOFF NSPanel mit Lovelace UI:

          @arteck

          nein, an der Stelle nicht... Nur den Wert selbst

          Andere Möglichkeiten?
          Zeilenumbruch vielleicht?

          zigbee hab ich, zwave auch, nuc's genauso und HA auch

          ArmilarA 1 Antwort Letzte Antwort
          0
          • T TT-Tom

            @teletapi Mach doch aus dem iconColor eine variable und setze den Wert je nach Wunsch.

            ["id", "value", "unit", "icon", "iconColor", "speed"]
            [1, pwr1, "W", "battery-high", 3, speedPwr1]
            
            teletapiT Online
            teletapiT Online
            teletapi
            schrieb am zuletzt editiert von teletapi
            #7286

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

            [1, pwr1, "W", "battery-high", 3, speedPwr1]

            Wenn du mir jetzt noch sagen würdest wie, dann wäre ich dabei. Das sind alles spanische Dörfer für mich die verursachen bei mir Knoten im Kopf... 😉

            T 1 Antwort Letzte Antwort
            0
            • teletapiT teletapi

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

              [1, pwr1, "W", "battery-high", 3, speedPwr1]

              Wenn du mir jetzt noch sagen würdest wie, dann wäre ich dabei. Das sind alles spanische Dörfer für mich die verursachen bei mir Knoten im Kopf... 😉

              T Offline
              T Offline
              TT-Tom
              schrieb am zuletzt editiert von
              #7287

              @teletapi

              Gib mir die Datenpunkte welche die Farben ändern sollen oder Grenzwerte, die die Farben ändern.

              Gruß Tom
              https://github.com/tt-tom17
              Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

              NSPanel Script Wiki
              https://github.com/joBr99/nspanel-lovelace-ui/wiki

              NSPanel Adapter Wiki
              https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

              teletapiT 1 Antwort Letzte Antwort
              0
              • arteckA arteck

                @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                @arteck

                nein, an der Stelle nicht... Nur den Wert selbst

                Andere Möglichkeiten?
                Zeilenumbruch vielleicht?

                ArmilarA Offline
                ArmilarA Offline
                Armilar
                Most Active Forum Testing
                schrieb am zuletzt editiert von
                #7288

                @arteck

                Text abkürzen würde mir aktuell nur einfallen...

                Kurzer Blick auf das Layout der cardGrid2:

                60a654f8-7f30-4bc2-b4da-0aee5d7f77f1-image.png

                8 Entitäten, wobei bereits der Bezeichner in der kleinsten Schriftgröße ( Fontsize 0 ) ist. Jetzt könnte man denken, da wäre noch Platz - aber mit dem Zeilenumbruch landest du mit dem Text im nächsten Icon...

                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.

                arteckA 1 Antwort Letzte Antwort
                0
                • T TT-Tom

                  @teletapi

                  Gib mir die Datenpunkte welche die Farben ändern sollen oder Grenzwerte, die die Farben ändern.

                  teletapiT Online
                  teletapiT Online
                  teletapi
                  schrieb am zuletzt editiert von teletapi
                  #7289

                  @tt-tom Danke dir, ich hab als Datenpunkt derzeit: 0_userdata.0.PV.now.Battery_Power als lade/entlade datenpunkt müsste ja auch: modbus.0.holdingRegisters._BatterySOC funktionieren. Als möglichen Alias für Battery_soc hab ich diesen Alias angelegt: alias.0.NSPanel.PV_Anlage.Battery_Soc.SET

                  Eigentlich geht es mir nur darum wenn Voll dann grün, beim Laden Rot und wenns möglich wäre fürs entladen gelb.

                  Ich habe jetzt auch nochmal ChatGPT gefragt wegen der Variable für das iconColor.
                  Da wurde mir das folgende angepasste script erzeugt.

                  schedule("* * * * *", function () {
                      var powerCardJson = "0_userdata.0.NSPanel.Powercard";
                  
                      var pwr1Raw = getState("0_userdata.0.PV.now.Battery_Power").val || 0;
                      var pwr1 = Math.abs(Math.round(pwr1Raw));  // Betrag für Anzeige
                      var pwr2 = Math.round(getState("modbus.0.holdingRegisters._Total_Active_power_(Grid_Meter)").val);
                      var pwr3 = "";
                      var pwr4 = "";
                      var pwr5 = Math.round(getState("sonoff.0.Tasmota Energie LG E320.E320_Power_in").val);
                      var pwr6 = 0;
                      var pwrHome = Math.round(getState("0_userdata.0.PV.now.Load_Total_Power").val || 0);
                  
                      var keys = ["id", "value", "unit", "icon", "iconColor", "speed"];
                      var helperBase = "0_userdata.0.NSPanel.PowercardHelper";
                  
                      if (!existsObject(helperBase)) {
                          createState(helperBase, null, { type: "channel", common: { name: "PowercardHelper" }, native: {} });
                      }
                  
                      function createStateIfNotExists(id, initialValue = 0) {
                          if (!existsState(id)) {
                              createState(id, initialValue, {
                                  name: "Last Power Wert",
                                  role: "value",
                                  type: "number",
                                  unit: "W",
                                  read: true,
                                  write: false
                              });
                          }
                      }
                  
                      createStateIfNotExists(helperBase + ".PWR1_Last");
                      createStateIfNotExists(helperBase + ".PWR2_Last");
                      createStateIfNotExists(helperBase + ".PWR5_Last");
                  
                      function getLastValue(id) {
                          var s = getState(id);
                          return s ? s.val : 0;
                      }
                  
                      function setLastValue(id, val) {
                          setState(id, val, true);
                      }
                  
                      function calcSpeed(current, last) {
                          if (current > last) return 2;
                          else if (current < last) return -2;
                          else return 0;
                      }
                  
                      var pwr1Last = getLastValue(helperBase + ".PWR1_Last");
                      var pwr2Last = getLastValue(helperBase + ".PWR2_Last");
                      var pwr5Last = getLastValue(helperBase + ".PWR5_Last");
                  
                      var speedPwr1 = calcSpeed(pwr1Raw, pwr1Last);  // Richtung basiert auf Originalwert
                      var speedPwr2 = calcSpeed(pwr2, pwr2Last);
                      var speedPwr5 = calcSpeed(pwr5, pwr5Last);
                  
                      setLastValue(helperBase + ".PWR1_Last", pwr1Raw);
                      setLastValue(helperBase + ".PWR2_Last", pwr2);
                      setLastValue(helperBase + ".PWR5_Last", pwr5);
                  
                      // Dynamische iconColor für Batterie
                      var iconColorBatt;
                      if (pwr1Raw > 50) {
                          iconColorBatt = 3;  // rot → Laden
                      } else if (pwr1Raw < -50) {
                          iconColorBatt = 4;  // gelb → Entladen
                      } else if (Math.abs(pwr1Raw) <= 50) {
                          iconColorBatt = 7;  // grün → Voll
                      } else {
                          iconColorBatt = 1;  // grau → fallback
                      }
                  
                      var home = [0, pwrHome, "W", "home-lightning-bolt-outline", 0, 0];
                  
                      // Batterie → ID 1
                      var item1 = [1, pwr1, "W", "battery-high", iconColorBatt, speedPwr1];
                  
                      var item2 = [2, pwr2, "W", "solar-power-variant-outline", 3, speedPwr2];
                      var item3 = [3, pwr3, "", "", 0, 0];
                      var item4 = [4, pwr4, "", "", 0, 0];
                      var item5 = [5, pwr5, "W", "transmission-tower", 10, speedPwr5];
                      var item6 = [6, pwr6, "kW", "", 0, 0];
                  
                      function func(tags, values) {
                          return tags.reduce((acc, tag, index) => {
                              acc[tag] = values[index];
                              return acc;
                          }, {});
                      }
                  
                      setState(
                          powerCardJson,
                          JSON.stringify([
                              func(keys, home),
                              func(keys, item1),
                              func(keys, item2),
                              func(keys, item3),
                              func(keys, item4),
                              func(keys, item5),
                              func(keys, item6),
                          ])
                      );
                  });
                  
                  
                  T 1 Antwort Letzte Antwort
                  0
                  • teletapiT teletapi

                    @tt-tom Danke dir, ich hab als Datenpunkt derzeit: 0_userdata.0.PV.now.Battery_Power als lade/entlade datenpunkt müsste ja auch: modbus.0.holdingRegisters._BatterySOC funktionieren. Als möglichen Alias für Battery_soc hab ich diesen Alias angelegt: alias.0.NSPanel.PV_Anlage.Battery_Soc.SET

                    Eigentlich geht es mir nur darum wenn Voll dann grün, beim Laden Rot und wenns möglich wäre fürs entladen gelb.

                    Ich habe jetzt auch nochmal ChatGPT gefragt wegen der Variable für das iconColor.
                    Da wurde mir das folgende angepasste script erzeugt.

                    schedule("* * * * *", function () {
                        var powerCardJson = "0_userdata.0.NSPanel.Powercard";
                    
                        var pwr1Raw = getState("0_userdata.0.PV.now.Battery_Power").val || 0;
                        var pwr1 = Math.abs(Math.round(pwr1Raw));  // Betrag für Anzeige
                        var pwr2 = Math.round(getState("modbus.0.holdingRegisters._Total_Active_power_(Grid_Meter)").val);
                        var pwr3 = "";
                        var pwr4 = "";
                        var pwr5 = Math.round(getState("sonoff.0.Tasmota Energie LG E320.E320_Power_in").val);
                        var pwr6 = 0;
                        var pwrHome = Math.round(getState("0_userdata.0.PV.now.Load_Total_Power").val || 0);
                    
                        var keys = ["id", "value", "unit", "icon", "iconColor", "speed"];
                        var helperBase = "0_userdata.0.NSPanel.PowercardHelper";
                    
                        if (!existsObject(helperBase)) {
                            createState(helperBase, null, { type: "channel", common: { name: "PowercardHelper" }, native: {} });
                        }
                    
                        function createStateIfNotExists(id, initialValue = 0) {
                            if (!existsState(id)) {
                                createState(id, initialValue, {
                                    name: "Last Power Wert",
                                    role: "value",
                                    type: "number",
                                    unit: "W",
                                    read: true,
                                    write: false
                                });
                            }
                        }
                    
                        createStateIfNotExists(helperBase + ".PWR1_Last");
                        createStateIfNotExists(helperBase + ".PWR2_Last");
                        createStateIfNotExists(helperBase + ".PWR5_Last");
                    
                        function getLastValue(id) {
                            var s = getState(id);
                            return s ? s.val : 0;
                        }
                    
                        function setLastValue(id, val) {
                            setState(id, val, true);
                        }
                    
                        function calcSpeed(current, last) {
                            if (current > last) return 2;
                            else if (current < last) return -2;
                            else return 0;
                        }
                    
                        var pwr1Last = getLastValue(helperBase + ".PWR1_Last");
                        var pwr2Last = getLastValue(helperBase + ".PWR2_Last");
                        var pwr5Last = getLastValue(helperBase + ".PWR5_Last");
                    
                        var speedPwr1 = calcSpeed(pwr1Raw, pwr1Last);  // Richtung basiert auf Originalwert
                        var speedPwr2 = calcSpeed(pwr2, pwr2Last);
                        var speedPwr5 = calcSpeed(pwr5, pwr5Last);
                    
                        setLastValue(helperBase + ".PWR1_Last", pwr1Raw);
                        setLastValue(helperBase + ".PWR2_Last", pwr2);
                        setLastValue(helperBase + ".PWR5_Last", pwr5);
                    
                        // Dynamische iconColor für Batterie
                        var iconColorBatt;
                        if (pwr1Raw > 50) {
                            iconColorBatt = 3;  // rot → Laden
                        } else if (pwr1Raw < -50) {
                            iconColorBatt = 4;  // gelb → Entladen
                        } else if (Math.abs(pwr1Raw) <= 50) {
                            iconColorBatt = 7;  // grün → Voll
                        } else {
                            iconColorBatt = 1;  // grau → fallback
                        }
                    
                        var home = [0, pwrHome, "W", "home-lightning-bolt-outline", 0, 0];
                    
                        // Batterie → ID 1
                        var item1 = [1, pwr1, "W", "battery-high", iconColorBatt, speedPwr1];
                    
                        var item2 = [2, pwr2, "W", "solar-power-variant-outline", 3, speedPwr2];
                        var item3 = [3, pwr3, "", "", 0, 0];
                        var item4 = [4, pwr4, "", "", 0, 0];
                        var item5 = [5, pwr5, "W", "transmission-tower", 10, speedPwr5];
                        var item6 = [6, pwr6, "kW", "", 0, 0];
                    
                        function func(tags, values) {
                            return tags.reduce((acc, tag, index) => {
                                acc[tag] = values[index];
                                return acc;
                            }, {});
                        }
                    
                        setState(
                            powerCardJson,
                            JSON.stringify([
                                func(keys, home),
                                func(keys, item1),
                                func(keys, item2),
                                func(keys, item3),
                                func(keys, item4),
                                func(keys, item5),
                                func(keys, item6),
                            ])
                        );
                    });
                    
                    
                    T Offline
                    T Offline
                    TT-Tom
                    schrieb am zuletzt editiert von
                    #7290

                    @teletapi
                    Ja sieht gut aus, so ähnlich hätte ich es auch gemacht.

                    Gruß Tom
                    https://github.com/tt-tom17
                    Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                    NSPanel Script Wiki
                    https://github.com/joBr99/nspanel-lovelace-ui/wiki

                    NSPanel Adapter Wiki
                    https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                    teletapiT 1 Antwort Letzte Antwort
                    0
                    • T TT-Tom

                      @teletapi
                      Ja sieht gut aus, so ähnlich hätte ich es auch gemacht.

                      teletapiT Online
                      teletapiT Online
                      teletapi
                      schrieb am zuletzt editiert von
                      #7291

                      @tt-tom Danke dir dann werde ich das mal so testen

                      1 Antwort Letzte Antwort
                      0
                      • ArmilarA Armilar

                        @arteck

                        Text abkürzen würde mir aktuell nur einfallen...

                        Kurzer Blick auf das Layout der cardGrid2:

                        60a654f8-7f30-4bc2-b4da-0aee5d7f77f1-image.png

                        8 Entitäten, wobei bereits der Bezeichner in der kleinsten Schriftgröße ( Fontsize 0 ) ist. Jetzt könnte man denken, da wäre noch Platz - aber mit dem Zeilenumbruch landest du mit dem Text im nächsten Icon...

                        arteckA Offline
                        arteckA Offline
                        arteck
                        Developer Most Active
                        schrieb am zuletzt editiert von
                        #7292

                        @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                        Text abkürzen würde mir aktuell nur einfallen...

                        das hab ich schon ... sieht nur bähh aus

                        zigbee hab ich, zwave auch, nuc's genauso und HA auch

                        1 Antwort Letzte Antwort
                        0
                        • MichaelFM MichaelF

                          @armilar Danke, das war es.

                          Grüße

                          MichaelFM Offline
                          MichaelFM Offline
                          MichaelF
                          schrieb am zuletzt editiert von MichaelF
                          #7293

                          @michaelf sagte in SONOFF NSPanel mit Lovelace UI:

                          @armilar Danke, das war es.

                          Grüße

                          Hi, ein kleines Problem gibt es leider noch das Display schaltet sich nicht mehr nach der eingestellten Nachtzeit ab.

                          Dimmer Nacht steht auf 0

                          Gibt es vielleicht ein Tipp wo ich schauen muss ?

                          Grade noch entdeckt:

                          web.0
                          2025-06-26 15:03:44.677	error	Error on "subscribeForeignStates": Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target
                          
                          web.0
                          2025-06-26 15:03:44.676	warn	Alias alias.0.NSPanel.1.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                          
                          web.0
                          2025-06-26 15:03:44.676	warn	Alias alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                          
                          web.0
                          2025-06-26 15:03:44.675	warn	Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target 5
                          
                          web.0
                          2025-06-26 15:03:42.347	info	==> Connected system.user.admin from ::ffff:192.168.178.252
                          
                          web.0
                          2025-06-26 15:03:39.697	info	<== Disconnect system.user.admin from ::ffff:192.168.178.252 vis.0
                          
                          web.0
                          2025-06-26 15:02:52.997	error	Error on "subscribeForeignStates": Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target
                          
                          web.0
                          2025-06-26 15:02:52.996	warn	Alias alias.0.NSPanel.1.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                          
                          web.0
                          2025-06-26 15:02:52.996	warn	Alias alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                          
                          web.0
                          2025-06-26 15:02:52.995	warn	Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target 5
                          

                          Allerdings Funktioniert das Dimmen am Tag, meine ich zumindest.

                          Grüße

                          arteckA ArmilarA 2 Antworten Letzte Antwort
                          0
                          • MichaelFM MichaelF

                            @michaelf sagte in SONOFF NSPanel mit Lovelace UI:

                            @armilar Danke, das war es.

                            Grüße

                            Hi, ein kleines Problem gibt es leider noch das Display schaltet sich nicht mehr nach der eingestellten Nachtzeit ab.

                            Dimmer Nacht steht auf 0

                            Gibt es vielleicht ein Tipp wo ich schauen muss ?

                            Grade noch entdeckt:

                            web.0
                            2025-06-26 15:03:44.677	error	Error on "subscribeForeignStates": Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target
                            
                            web.0
                            2025-06-26 15:03:44.676	warn	Alias alias.0.NSPanel.1.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                            
                            web.0
                            2025-06-26 15:03:44.676	warn	Alias alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                            
                            web.0
                            2025-06-26 15:03:44.675	warn	Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target 5
                            
                            web.0
                            2025-06-26 15:03:42.347	info	==> Connected system.user.admin from ::ffff:192.168.178.252
                            
                            web.0
                            2025-06-26 15:03:39.697	info	<== Disconnect system.user.admin from ::ffff:192.168.178.252 vis.0
                            
                            web.0
                            2025-06-26 15:02:52.997	error	Error on "subscribeForeignStates": Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target
                            
                            web.0
                            2025-06-26 15:02:52.996	warn	Alias alias.0.NSPanel.1.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                            
                            web.0
                            2025-06-26 15:02:52.996	warn	Alias alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                            
                            web.0
                            2025-06-26 15:02:52.995	warn	Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target 5
                            

                            Allerdings Funktioniert das Dimmen am Tag, meine ich zumindest.

                            Grüße

                            arteckA Offline
                            arteckA Offline
                            arteck
                            Developer Most Active
                            schrieb am zuletzt editiert von
                            #7294

                            @michaelf sagte in SONOFF NSPanel mit Lovelace UI:

                            alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL

                            da ist das problem

                            alias.0.alias.0.
                            

                            ist falsch

                            zigbee hab ich, zwave auch, nuc's genauso und HA auch

                            MichaelFM 1 Antwort Letzte Antwort
                            0
                            • arteckA arteck

                              @michaelf sagte in SONOFF NSPanel mit Lovelace UI:

                              alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL

                              da ist das problem

                              alias.0.alias.0.
                              

                              ist falsch

                              MichaelFM Offline
                              MichaelFM Offline
                              MichaelF
                              schrieb am zuletzt editiert von MichaelF
                              #7295

                              @arteck Ist das Falsch im Skript oder im Objekt ?

                              Update, habe es im Objektbaum gefunden und gelöscht. Aber für das nicht abschalten war das nicht verantwortlich, oder ?

                              Grüße und Danke

                              arteckA 1 Antwort Letzte Antwort
                              0
                              • MichaelFM MichaelF

                                @arteck Ist das Falsch im Skript oder im Objekt ?

                                Update, habe es im Objektbaum gefunden und gelöscht. Aber für das nicht abschalten war das nicht verantwortlich, oder ?

                                Grüße und Danke

                                arteckA Offline
                                arteckA Offline
                                arteck
                                Developer Most Active
                                schrieb am zuletzt editiert von
                                #7296

                                @michaelf da ist noch ein fehler

                                NSPanel..Dimmode
                                

                                da ist ein punkt zu viel

                                zigbee hab ich, zwave auch, nuc's genauso und HA auch

                                MichaelFM 1 Antwort Letzte Antwort
                                0
                                • arteckA arteck

                                  @michaelf da ist noch ein fehler

                                  NSPanel..Dimmode
                                  

                                  da ist ein punkt zu viel

                                  MichaelFM Offline
                                  MichaelFM Offline
                                  MichaelF
                                  schrieb am zuletzt editiert von
                                  #7297

                                  @arteck In den Objekten nicht zu finden?

                                  1 Antwort Letzte Antwort
                                  0
                                  • MichaelFM MichaelF

                                    @michaelf sagte in SONOFF NSPanel mit Lovelace UI:

                                    @armilar Danke, das war es.

                                    Grüße

                                    Hi, ein kleines Problem gibt es leider noch das Display schaltet sich nicht mehr nach der eingestellten Nachtzeit ab.

                                    Dimmer Nacht steht auf 0

                                    Gibt es vielleicht ein Tipp wo ich schauen muss ?

                                    Grade noch entdeckt:

                                    web.0
                                    2025-06-26 15:03:44.677	error	Error on "subscribeForeignStates": Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target
                                    
                                    web.0
                                    2025-06-26 15:03:44.676	warn	Alias alias.0.NSPanel.1.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                                    
                                    web.0
                                    2025-06-26 15:03:44.676	warn	Alias alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                                    
                                    web.0
                                    2025-06-26 15:03:44.675	warn	Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target 5
                                    
                                    web.0
                                    2025-06-26 15:03:42.347	info	==> Connected system.user.admin from ::ffff:192.168.178.252
                                    
                                    web.0
                                    2025-06-26 15:03:39.697	info	<== Disconnect system.user.admin from ::ffff:192.168.178.252 vis.0
                                    
                                    web.0
                                    2025-06-26 15:02:52.997	error	Error on "subscribeForeignStates": Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target
                                    
                                    web.0
                                    2025-06-26 15:02:52.996	warn	Alias alias.0.NSPanel.1.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                                    
                                    web.0
                                    2025-06-26 15:02:52.996	warn	Alias alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL has no target 5
                                    
                                    web.0
                                    2025-06-26 15:02:52.995	warn	Alias alias.0.alias.0.NSPanel..Dimmode.brightnessDay.ACTUAL has no target 5
                                    

                                    Allerdings Funktioniert das Dimmen am Tag, meine ich zumindest.

                                    Grüße

                                    ArmilarA Offline
                                    ArmilarA Offline
                                    Armilar
                                    Most Active Forum Testing
                                    schrieb am zuletzt editiert von Armilar
                                    #7298

                                    @michaelf

                                    wieso "web.0" ???

                                    javascript.0 würde ich im Zusammenhang mit dem Script ja noch verstehen... Ich denke da musst du an einer völlig anderen Stelle suchen...

                                    Der zu visualisierende Alias wäre dann sicherlich

                                    alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL
                                    

                                    Sieht für mich aus, als wäre in vis.0 ein Fehler der diese Meldung wirft

                                    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.

                                    MichaelFM 1 Antwort Letzte Antwort
                                    0
                                    • ArmilarA Armilar

                                      @michaelf

                                      wieso "web.0" ???

                                      javascript.0 würde ich im Zusammenhang mit dem Script ja noch verstehen... Ich denke da musst du an einer völlig anderen Stelle suchen...

                                      Der zu visualisierende Alias wäre dann sicherlich

                                      alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL
                                      

                                      Sieht für mich aus, als wäre in vis.0 ein Fehler der diese Meldung wirft

                                      MichaelFM Offline
                                      MichaelFM Offline
                                      MichaelF
                                      schrieb am zuletzt editiert von MichaelF
                                      #7299

                                      @armilar
                                      was ich grade gefunden habe:

                                      {
                                        "common": {
                                          "name": "alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL",
                                          "desc": "Manuell erzeugt",
                                          "role": "state",
                                          "type": "number",
                                          "read": true,
                                          "write": true,
                                          "def": 0
                                        },
                                        "type": "state",
                                        "native": {},
                                        "from": "system.adapter.admin.0",
                                        "user": "system.user.admin",
                                        "ts": 1750409085470,
                                        "_id": "alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL",
                                        "acl": {
                                          "object": 1636,
                                          "state": 1636,
                                          "owner": "system.user.admin",
                                          "ownerGroup": "system.group.administrator"
                                        }
                                      }
                                      

                                      Wie passiert das denn ?

                                      Kann ich das einfach löschen ?

                                      ArmilarA 1 Antwort Letzte Antwort
                                      0
                                      • MichaelFM MichaelF

                                        @armilar
                                        was ich grade gefunden habe:

                                        {
                                          "common": {
                                            "name": "alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL",
                                            "desc": "Manuell erzeugt",
                                            "role": "state",
                                            "type": "number",
                                            "read": true,
                                            "write": true,
                                            "def": 0
                                          },
                                          "type": "state",
                                          "native": {},
                                          "from": "system.adapter.admin.0",
                                          "user": "system.user.admin",
                                          "ts": 1750409085470,
                                          "_id": "alias.0.alias.0.NSPanel.1.Dimmode.brightnessDay.ACTUAL",
                                          "acl": {
                                            "object": 1636,
                                            "state": 1636,
                                            "owner": "system.user.admin",
                                            "ownerGroup": "system.group.administrator"
                                          }
                                        }
                                        

                                        Wie passiert das denn ?

                                        Kann ich das einfach löschen ?

                                        ArmilarA Offline
                                        ArmilarA Offline
                                        Armilar
                                        Most Active Forum Testing
                                        schrieb am zuletzt editiert von
                                        #7300

                                        @michaelf

                                        So eine doppelte alias.0 - Verkettung habe ich auch noch nie gesehen?

                                        Irgendwann mal den Alias-Path im Script geändert?

                                        Du kannst jederzeit die erstellten Verzeichnisse eines NSPanel unter 0_userdata.NSPanel.X und alias.0.NSPanel.X löschen.

                                        Mit Scriptstart werden die wieder sauber erzeugt... Bis auf die paar individuellen Anpassungen...

                                        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.

                                        MichaelFM 2 Antworten Letzte Antwort
                                        0
                                        • ArmilarA Armilar

                                          @michaelf

                                          So eine doppelte alias.0 - Verkettung habe ich auch noch nie gesehen?

                                          Irgendwann mal den Alias-Path im Script geändert?

                                          Du kannst jederzeit die erstellten Verzeichnisse eines NSPanel unter 0_userdata.NSPanel.X und alias.0.NSPanel.X löschen.

                                          Mit Scriptstart werden die wieder sauber erzeugt... Bis auf die paar individuellen Anpassungen...

                                          MichaelFM Offline
                                          MichaelFM Offline
                                          MichaelF
                                          schrieb am zuletzt editiert von MichaelF
                                          #7301

                                          @armilar Habe ich grade gemacht Danke!

                                          Alias-Path habe ich so wissentlich nicht geändert

                                          Aber mit dem abschalten(Display) bei Nacht hat dies doch eigentlich auch nichts zu tun, oder ?

                                          ArmilarA 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          750

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe