Skip to content
  • Home
  • 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
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. SONOFF NSPanel mit Lovelace UI (TypeScript Version)

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    16
    1
    340

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    4.8k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.3k

SONOFF NSPanel mit Lovelace UI (TypeScript Version)

Scheduled Pinned Locked Moved Hardware
lovelace uinspanelsonoff
8.0k Posts 277 Posters 7.2m Views 262 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.
  • Rene55R Rene55

    @armilar Gibt es für cardChart auch ein Script für die Aufbereitung der Daten? Ich wollte auch so etwas umsetzen wie 'ChartsDemo' für Gas oder 'Stromzähler L1+L2+L3'.

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

    @rene55

    https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

    etwas unterhalb ist ein abgebildetes Blockly für influxDB2

    darunter der Link zum Blockly

    yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

    Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

    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.

    theknutT 1 Reply Last reply
    1
    • Rene55R Rene55

      @armilar Gibt es für cardChart auch ein Script für die Aufbereitung der Daten? Ich wollte auch so etwas umsetzen wie 'ChartsDemo' für Gas oder 'Stromzähler L1+L2+L3'.

      T Offline
      T Offline
      TT-Tom
      wrote on last edited by
      #5254

      @rene55
      offiziell im Wiki für Influx nur als Blockly. BalkenChart oder auf meinem git als TypeScript.

      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

      Rene55R 1 Reply Last reply
      1
      • T TT-Tom

        @rene55
        offiziell im Wiki für Influx nur als Blockly. BalkenChart oder auf meinem git als TypeScript.

        Rene55R Online
        Rene55R Online
        Rene55
        wrote on last edited by
        #5255

        @tt-tom Oh, sehr gut - schau ich mir sofort an.

        Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
        ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
        Wetterstation: Froggit WH3000SE V1.6.6

        1 Reply Last reply
        0
        • ArmilarA Armilar

          @rene55

          https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

          etwas unterhalb ist ein abgebildetes Blockly für influxDB2

          darunter der Link zum Blockly

          yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

          Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

          theknutT Offline
          theknutT Offline
          theknut
          wrote on last edited by theknut
          #5256

          @armilar said in SONOFF NSPanel mit Lovelace UI:

          @rene55

          https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

          etwas unterhalb ist ein abgebildetes Blockly für influxDB2

          darunter der Link zum Blockly

          yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

          Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

          gäbe es einen Grund, dass man/ich das nicht noch so umschreiben könnte, dass es auch berechnet wird?

          ☕ @ https://ko-fi.com/theknut

          Rene55R T 2 Replies Last reply
          0
          • theknutT theknut

            @armilar said in SONOFF NSPanel mit Lovelace UI:

            @rene55

            https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

            etwas unterhalb ist ein abgebildetes Blockly für influxDB2

            darunter der Link zum Blockly

            yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

            Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

            gäbe es einen Grund, dass man/ich das nicht noch so umschreiben könnte, dass es auch berechnet wird?

            Rene55R Online
            Rene55R Online
            Rene55
            wrote on last edited by
            #5257

            @theknut Das würde ich auch gerne in Anspruch nehmen. Meine aktuell generierten Balken zeigen alle ins Minus! :face_with_head_bandage: . Vielleicht hab ich auch noch nicht gerafft, welchen Datenpunkt ich nehmen muss.

            Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
            ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
            Wetterstation: Froggit WH3000SE V1.6.6

            T 1 Reply Last reply
            0
            • Rene55R Rene55

              @theknut Das würde ich auch gerne in Anspruch nehmen. Meine aktuell generierten Balken zeigen alle ins Minus! :face_with_head_bandage: . Vielleicht hab ich auch noch nicht gerafft, welchen Datenpunkt ich nehmen muss.

              T Offline
              T Offline
              TT-Tom
              wrote on last edited by
              #5258

              @rene55
              das kann auch der Bug bei der Card sein.

              https://github.com/joBr99/nspanel-lovelace-ui/issues/934

              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

              Rene55R 1 Reply Last reply
              0
              • theknutT theknut

                @armilar said in SONOFF NSPanel mit Lovelace UI:

                @rene55

                https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

                etwas unterhalb ist ein abgebildetes Blockly für influxDB2

                darunter der Link zum Blockly

                yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

                Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

                gäbe es einen Grund, dass man/ich das nicht noch so umschreiben könnte, dass es auch berechnet wird?

                T Offline
                T Offline
                TT-Tom
                wrote on last edited by
                #5259

                @theknut

                kannst du gerne machen.

                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

                1 Reply Last reply
                0
                • T TT-Tom

                  @rene55
                  das kann auch der Bug bei der Card sein.

                  https://github.com/joBr99/nspanel-lovelace-ui/issues/934

                  Rene55R Online
                  Rene55R Online
                  Rene55
                  wrote on last edited by
                  #5260

                  @tt-tom Ich glaube, ich stell meine Balken erstmal zurück. Hab mir das Issue mal angesehen, sagt mir aber nix. Die Werte, die ich gerade zum Panel schicke sehen so aus:
                  Werte: 4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~
                  Scale: [0,2369,4738,7107,9476]

                  Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                  ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                  Wetterstation: Froggit WH3000SE V1.6.6

                  ArmilarA T 3 Replies Last reply
                  0
                  • Rene55R Rene55

                    @tt-tom Ich glaube, ich stell meine Balken erstmal zurück. Hab mir das Issue mal angesehen, sagt mir aber nix. Die Werte, die ich gerade zum Panel schicke sehen so aus:
                    Werte: 4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~
                    Scale: [0,2369,4738,7107,9476]

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

                    @rene55

                    Rechne die Werte in kW um - dann sollte es passen... Die Skala schafft da keine W

                    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.

                    Rene55R 1 Reply Last reply
                    0
                    • ArmilarA Armilar

                      @rene55

                      Rechne die Werte in kW um - dann sollte es passen... Die Skala schafft da keine W

                      Rene55R Online
                      Rene55R Online
                      Rene55
                      wrote on last edited by
                      #5262

                      @armilar Nochmals die (dumme) Frage: welche Daten muss ich da nehmen. Ziel ist, dass ich den Verbrauch vom Haus im Stundenraster sehe, damit ich erkennen kann, zu welcher Stunde die meiste Energie verbraten wird.

                      Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                      ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                      Wetterstation: Froggit WH3000SE V1.6.6

                      ArmilarA 1 Reply Last reply
                      0
                      • Rene55R Rene55

                        @armilar Nochmals die (dumme) Frage: welche Daten muss ich da nehmen. Ziel ist, dass ich den Verbrauch vom Haus im Stundenraster sehe, damit ich erkennen kann, zu welcher Stunde die meiste Energie verbraten wird.

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

                        @rene55

                        Das kommt darauf an, was du für DP's hast...

                        Beispiel String:
                        28^14:00~27~31~28~28^18:00~34~31~26~24^22:00~22~14~6~5^2:00~5~5~5~5^6:00~16~14~43~29^10:00~21~23~41

                        Da die HMI keine Fließkommazahl verträgt, ist die Umrechnung nicht "/1000", sondern "/100"

                        32f9986e-f777-4414-b947-d4c53bdefb15-image.png

                        28 bedeutet dann 2,8
                        27 bedeutet dann 2,7
                        etc...

                        Das ganze sieht dann so aus:

                        6ed91ebb-bbac-47ff-b95a-4903e8f7faf4-image.png

                        Nur im tausender Bereich kannst du keine Werte übermitteln... ist aber auch alles beschrieben...

                        let CardChartExample: PageType = 
                        {
                            'type': 'cardChart',
                            'heading': 'Stromzähler L1+L2+L3',
                            'items': [{ 
                                        id: 'alias.0.NSPanel_1.cardChart', 
                                        yAxis: 'Leistung [kW]', 
                                        yAxisTicks: [0,10,20,30],
                                        onColor: Yellow
                                     }]
                        };
                        

                        auch in der Y-Achse ist die Skalierung dann 10 = 1,0; 20 = 2,0 usw...

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

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

                        1 Reply Last reply
                        1
                        • Rene55R Rene55

                          @tt-tom Ich glaube, ich stell meine Balken erstmal zurück. Hab mir das Issue mal angesehen, sagt mir aber nix. Die Werte, die ich gerade zum Panel schicke sehen so aus:
                          Werte: 4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~
                          Scale: [0,2369,4738,7107,9476]

                          T Offline
                          T Offline
                          TT-Tom
                          wrote on last edited by TT-Tom
                          #5264

                          @rene55 okay, die sind eindeutig zu hoch.
                          wenn du im Stunden Raster nutzen möchtest, kannst du mein Script so nicht nehmen, es arbeitet auf Tagesverbrauch.

                          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

                          1 Reply Last reply
                          0
                          • Rene55R Rene55

                            @tt-tom Ich glaube, ich stell meine Balken erstmal zurück. Hab mir das Issue mal angesehen, sagt mir aber nix. Die Werte, die ich gerade zum Panel schicke sehen so aus:
                            Werte: 4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~
                            Scale: [0,2369,4738,7107,9476]

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

                            @rene55

                            4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~

                            Deine xAxisTicks sehen auch sehr merkwürdig aus...

                            Was für Werte werden denn aggregiert... Sind das sekündliche Daten? Da stimmt irgendwas grundsätzlich nicht in deinem Script...

                            Wenn die TypeScripts zu komplex für dich sind, dann verwende doch das Blockly... macht meines Erachtens genau das was du benötigst...

                            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.

                            T Rene55R 2 Replies Last reply
                            0
                            • ArmilarA Armilar

                              @rene55

                              4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~

                              Deine xAxisTicks sehen auch sehr merkwürdig aus...

                              Was für Werte werden denn aggregiert... Sind das sekündliche Daten? Da stimmt irgendwas grundsätzlich nicht in deinem Script...

                              Wenn die TypeScripts zu komplex für dich sind, dann verwende doch das Blockly... macht meines Erachtens genau das was du benötigst...

                              T Offline
                              T Offline
                              TT-Tom
                              wrote on last edited by
                              #5266

                              @armilar

                              Kommt von meinem Script, es rechnet aber mit Tagen/ Tagesverbrauch. Und die Ticks sind der Tag halt.

                              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

                              ArmilarA 1 Reply Last reply
                              1
                              • T TT-Tom

                                @armilar

                                Kommt von meinem Script, es rechnet aber mit Tagen/ Tagesverbrauch. Und die Ticks sind der Tag halt.

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

                                @tt-tom

                                schon klar, aber wir können unmöglich für jeden Anwendungsfall ein Script erstellen...

                                Da muss man ggfs. schon mal etwas im influx-Admin testen, damit die grundsätzliche Abfrage stimmt... :blush:

                                Und auch ein Blockly lässt sich in JS wandeln, wenn es dann reiner Code sein soll...

                                sieht dann wohl so aus:

                                var sourceDP, targetDP, AxisXHours, AxisXTicks, Debug, flux, AxisTickCounter, i, queryStunde, queryOutput, queryValue, AxisTicksBool, result;
                                
                                
                                // Example String
                                // 7^2:00~7~6^4:00~6~7^6:00~0~7^8:00~5~1^10:00~1~10^12:00~5~6^14:00~8
                                // Start Parameter
                                sourceDP = 'sonoff.0.DZG_DWSB20_2H.DZG_Leistung_Aktuell';
                                targetDP = '0_userdata.0.Test.cardChart.txt';
                                AxisXHours = 24;
                                AxisXTicks = 5;
                                Debug = false;
                                // Ende Parameter
                                on({id: [].concat(sourceDP), change: "ne"}, async function (obj) {
                                  var value = obj.state.val;
                                  var oldValue = obj.oldState.val;
                                  flux = ['from(bucket: "iobroker")','|> range(start: -24h, stop: now())','|> filter(fn: (r) => r["_measurement"] == "',sourceDP,'")','|> filter(fn: (r) => r["_field"] == "value")','|> aggregateWindow(every: 1h, fn: mean, createEmpty: false)','|> yield(name: "mean")'].join('');
                                  sendTo("influxdb.1", "query", flux, async function (result) {
                                      AxisTickCounter = 0;
                                    var i_inc = 1;
                                    if (1 > AxisXHours) {
                                      i_inc = -i_inc;
                                    }
                                    for (i = 1; i_inc >= 0 ? i <= AxisXHours : i >= AxisXHours; i += i_inc) {
                                      AxisTickCounter = (typeof AxisTickCounter == 'number' ? AxisTickCounter : 0) + 1;
                                      queryStunde = getDateObject(getAttr(JSON.stringify(result, null, 2), (['result.0.',i,'._time'].join('')))).getHours();
                                      queryValue = Math.round(parseFloat(parseFloat(getAttr(JSON.stringify(result, null, 2), (['result.0.',i,'._value'].join(''))))) / 100);
                                      if (i == 1) {
                                        AxisTicksBool = true;
                                      } else if (AxisTickCounter == AxisXTicks) {
                                        AxisTicksBool = true;
                                        AxisTickCounter = 1;
                                      } else {
                                        AxisTicksBool = false;
                                      }
                                      if (i == AxisXHours) {
                                        if (AxisTicksBool) {
                                          queryOutput = [queryOutput,queryValue,'^',queryStunde,':00'].join('');
                                        } else {
                                          queryOutput = String(queryOutput) + String(queryValue);
                                        }
                                      } else {
                                        if (AxisTicksBool) {
                                          queryOutput = [queryOutput,queryValue,'^',queryStunde,':00','~'].join('');
                                        } else {
                                          queryOutput = [queryOutput,queryValue,'~'].join('');
                                        }
                                      }
                                      if (i == AxisXHours) {
                                        queryStunde = (typeof queryStunde == 'number' ? queryStunde : 0) + 1;
                                      }
                                      if (Debug) {
                                        console.log(([i,' - ',queryValue,' - ',queryStunde].join('')));
                                      }
                                    }
                                    setStateDelayed(targetDP, queryOutput, false, parseInt(((0) || "").toString(), 10), false);
                                    if (Debug) {
                                      console.log(queryOutput);
                                    }
                                    queryOutput = '';
                                    });
                                });
                                

                                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.

                                Rene55R 1 Reply Last reply
                                1
                                • ArmilarA Armilar

                                  @tt-tom

                                  schon klar, aber wir können unmöglich für jeden Anwendungsfall ein Script erstellen...

                                  Da muss man ggfs. schon mal etwas im influx-Admin testen, damit die grundsätzliche Abfrage stimmt... :blush:

                                  Und auch ein Blockly lässt sich in JS wandeln, wenn es dann reiner Code sein soll...

                                  sieht dann wohl so aus:

                                  var sourceDP, targetDP, AxisXHours, AxisXTicks, Debug, flux, AxisTickCounter, i, queryStunde, queryOutput, queryValue, AxisTicksBool, result;
                                  
                                  
                                  // Example String
                                  // 7^2:00~7~6^4:00~6~7^6:00~0~7^8:00~5~1^10:00~1~10^12:00~5~6^14:00~8
                                  // Start Parameter
                                  sourceDP = 'sonoff.0.DZG_DWSB20_2H.DZG_Leistung_Aktuell';
                                  targetDP = '0_userdata.0.Test.cardChart.txt';
                                  AxisXHours = 24;
                                  AxisXTicks = 5;
                                  Debug = false;
                                  // Ende Parameter
                                  on({id: [].concat(sourceDP), change: "ne"}, async function (obj) {
                                    var value = obj.state.val;
                                    var oldValue = obj.oldState.val;
                                    flux = ['from(bucket: "iobroker")','|> range(start: -24h, stop: now())','|> filter(fn: (r) => r["_measurement"] == "',sourceDP,'")','|> filter(fn: (r) => r["_field"] == "value")','|> aggregateWindow(every: 1h, fn: mean, createEmpty: false)','|> yield(name: "mean")'].join('');
                                    sendTo("influxdb.1", "query", flux, async function (result) {
                                        AxisTickCounter = 0;
                                      var i_inc = 1;
                                      if (1 > AxisXHours) {
                                        i_inc = -i_inc;
                                      }
                                      for (i = 1; i_inc >= 0 ? i <= AxisXHours : i >= AxisXHours; i += i_inc) {
                                        AxisTickCounter = (typeof AxisTickCounter == 'number' ? AxisTickCounter : 0) + 1;
                                        queryStunde = getDateObject(getAttr(JSON.stringify(result, null, 2), (['result.0.',i,'._time'].join('')))).getHours();
                                        queryValue = Math.round(parseFloat(parseFloat(getAttr(JSON.stringify(result, null, 2), (['result.0.',i,'._value'].join(''))))) / 100);
                                        if (i == 1) {
                                          AxisTicksBool = true;
                                        } else if (AxisTickCounter == AxisXTicks) {
                                          AxisTicksBool = true;
                                          AxisTickCounter = 1;
                                        } else {
                                          AxisTicksBool = false;
                                        }
                                        if (i == AxisXHours) {
                                          if (AxisTicksBool) {
                                            queryOutput = [queryOutput,queryValue,'^',queryStunde,':00'].join('');
                                          } else {
                                            queryOutput = String(queryOutput) + String(queryValue);
                                          }
                                        } else {
                                          if (AxisTicksBool) {
                                            queryOutput = [queryOutput,queryValue,'^',queryStunde,':00','~'].join('');
                                          } else {
                                            queryOutput = [queryOutput,queryValue,'~'].join('');
                                          }
                                        }
                                        if (i == AxisXHours) {
                                          queryStunde = (typeof queryStunde == 'number' ? queryStunde : 0) + 1;
                                        }
                                        if (Debug) {
                                          console.log(([i,' - ',queryValue,' - ',queryStunde].join('')));
                                        }
                                      }
                                      setStateDelayed(targetDP, queryOutput, false, parseInt(((0) || "").toString(), 10), false);
                                      if (Debug) {
                                        console.log(queryOutput);
                                      }
                                      queryOutput = '';
                                      });
                                  });
                                  
                                  Rene55R Online
                                  Rene55R Online
                                  Rene55
                                  wrote on last edited by
                                  #5268

                                  @armilar Ich würde schon selbst versuchen, für meinen evtl. speziellen Anwendungsfall was eigenes zu machen. Dazu muss ich aber vorher verstanden haben, was was bedeutet.

                                  Beispiel String: 28^14:00~27~31~28~28
                                  Daraus entnehme ich dass um 14:00 Uhr ein Wert von 27 (also 2.7) angezeigt werden soll, um 15 Uhr 31, 16 Uhr 28 und um 17 Uhr auch 28, und dann kommt die nächste Sequenz ab 18:00 Uhr. Was bedeutet die 28 und das ^ ?

                                  Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                                  ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                                  Wetterstation: Froggit WH3000SE V1.6.6

                                  1 Reply Last reply
                                  0
                                  • ArmilarA Armilar

                                    @rene55

                                    4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~

                                    Deine xAxisTicks sehen auch sehr merkwürdig aus...

                                    Was für Werte werden denn aggregiert... Sind das sekündliche Daten? Da stimmt irgendwas grundsätzlich nicht in deinem Script...

                                    Wenn die TypeScripts zu komplex für dich sind, dann verwende doch das Blockly... macht meines Erachtens genau das was du benötigst...

                                    Rene55R Online
                                    Rene55R Online
                                    Rene55
                                    wrote on last edited by
                                    #5269

                                    @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                                    Was für Werte werden denn aggregiert...

                                    Ich habe einen Lesekopf für meinen Stromzähler, der liefert mir quasi im Sekundentakt die Messwerte, hier den kumulierten Verbrauch aller drei Phasen. Damit die DB (und das Script) keine dicken Backen bekommt, lasse ich den Wert 'nur' alle 10 Sekunden in die DB schreiben. Den Datenpunkt wollte ich nehmen um das zu realisieren (... und später so etwas mit Gas).

                                    Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                                    ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                                    Wetterstation: Froggit WH3000SE V1.6.6

                                    ArmilarA 1 Reply Last reply
                                    0
                                    • Rene55R Rene55

                                      @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                                      Was für Werte werden denn aggregiert...

                                      Ich habe einen Lesekopf für meinen Stromzähler, der liefert mir quasi im Sekundentakt die Messwerte, hier den kumulierten Verbrauch aller drei Phasen. Damit die DB (und das Script) keine dicken Backen bekommt, lasse ich den Wert 'nur' alle 10 Sekunden in die DB schreiben. Den Datenpunkt wollte ich nehmen um das zu realisieren (... und später so etwas mit Gas).

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

                                      @rene55

                                      Was für Werte werden denn aggregiert...

                                      glaubst du wirklich, dass in den Chart 8640 Balken gehen? Wie lang wär denn so ein String an das Panel?

                                      Wenn du die Spitzen pro Stunde möchtest, dann aggregiere mit max/h ansonsten mit mean/h

                                      ^Wert sind die xAxisTicks mit Wert

                                      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.

                                      Rene55R 1 Reply Last reply
                                      0
                                      • ArmilarA Armilar

                                        @rene55

                                        Was für Werte werden denn aggregiert...

                                        glaubst du wirklich, dass in den Chart 8640 Balken gehen? Wie lang wär denn so ein String an das Panel?

                                        Wenn du die Spitzen pro Stunde möchtest, dann aggregiere mit max/h ansonsten mit mean/h

                                        ^Wert sind die xAxisTicks mit Wert

                                        Rene55R Online
                                        Rene55R Online
                                        Rene55
                                        wrote on last edited by
                                        #5271

                                        @armilar Nee natürlich nicht, mir würden tatsächlich 24 Balken für einen Tag reichen. Und dann haben wir das nächste Problem: von Influx keine Ahnung!

                                        Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                                        ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                                        Wetterstation: Froggit WH3000SE V1.6.6

                                        ArmilarA 1 Reply Last reply
                                        0
                                        • Rene55R Rene55

                                          @armilar Nee natürlich nicht, mir würden tatsächlich 24 Balken für einen Tag reichen. Und dann haben wir das nächste Problem: von Influx keine Ahnung!

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

                                          @rene55

                                          ... und warum machst du es dann nicht mit der fertigen Lösung im Wiki??? ;-)

                                          Bei influxDB2 kann ich dir nicht helfen...

                                          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.

                                          Rene55R 2 Replies 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

                                          621

                                          Online

                                          32.7k

                                          Users

                                          82.5k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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