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
    209

  • 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.
  • ArmilarA Armilar

    @arteck

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

    teletapiT Offline
    teletapiT Offline
    teletapi
    wrote on last edited by 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 Reply Last reply
    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
      wrote on last edited by
      #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 Reply Last reply
      0
      • ArmilarA Armilar

        @arteck

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

        arteckA Offline
        arteckA Offline
        arteck
        Developer Most Active
        wrote on last edited by
        #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 Reply Last reply
        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 Offline
          teletapiT Offline
          teletapi
          wrote on last edited by 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 Reply Last reply
          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
            wrote on last edited by
            #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 Reply Last reply
            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
              wrote on last edited by
              #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 Reply Last reply
              0
              • T TT-Tom

                @teletapi

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

                teletapiT Offline
                teletapiT Offline
                teletapi
                wrote on last edited by 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 Reply Last reply
                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
                  wrote on last edited by
                  #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 Reply Last reply
                  0
                  • T TT-Tom

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

                    teletapiT Offline
                    teletapiT Offline
                    teletapi
                    wrote on last edited by
                    #7291

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

                    1 Reply Last reply
                    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
                      wrote on last edited by
                      #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 Reply Last reply
                      0
                      • MichaelFM MichaelF

                        @armilar Danke, das war es.

                        Grüße

                        MichaelFM Offline
                        MichaelFM Offline
                        MichaelF
                        wrote on last edited by 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 Replies Last reply
                        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
                          wrote on last edited by
                          #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 Reply Last reply
                          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
                            wrote on last edited by 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 Reply Last reply
                            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
                              wrote on last edited by
                              #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 Reply Last reply
                              0
                              • arteckA arteck

                                @michaelf da ist noch ein fehler

                                NSPanel..Dimmode
                                

                                da ist ein punkt zu viel

                                MichaelFM Offline
                                MichaelFM Offline
                                MichaelF
                                wrote on last edited by
                                #7297

                                @arteck In den Objekten nicht zu finden?

                                1 Reply Last reply
                                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
                                  wrote on last edited by 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 Reply Last reply
                                  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
                                    wrote on last edited by 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 Reply Last reply
                                    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
                                      wrote on last edited by
                                      #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 Replies Last reply
                                      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
                                        wrote on last edited by 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 Reply Last reply
                                        0
                                        • MichaelFM MichaelF

                                          @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 Offline
                                          ArmilarA Offline
                                          Armilar
                                          Most Active Forum Testing
                                          wrote on last edited by
                                          #7302

                                          @michaelf

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

                                          Nein, da bedient sich das Script seiner eigenen Datenpunkte unter 0_userdata

                                          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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          91

                                          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