Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Script fürTabelle der Batterie Zustände

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Script fürTabelle der Batterie Zustände

    This topic has been deleted. Only users with topic management privileges can see it.
    • O
      Oli @liv-in-sky last edited by

      @liv-in-sky

      kennst du das Adapterscript von @Scrounger ?

      // Imports -> müssen im Javascript Adapter unter 'Zusätzliche NPM-Module' eingetragen sein
      const moment = require("moment");
      const momentDurationFormatSetup = require("moment-duration-format");
       
       
      // Skript Einstellungen *************************************************************************************************************************************************
       
      let dpList = 'javascript.0.Adapter.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
      let dpAdapterRestart = 'javascript.0.Adapter.restartTrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
       
      let dpSortMode = 'javascript.0.Adapter.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
      let dpFilterMode = 'javascript.0.Adapter.filterMode';             // Datenpunkt für Filter (Typ: Zeichenkette (String))
       
      let adminUpdatesList = 'admin.0.info.updatesList';                          // Datenpunkt Admin Adapter für verfübare Updates der Adapter
       
      const checkInterval = 30;                                                   // Interval wie oft Status der Adapter aktualisiert werden soll (in Sekunden)
       
      let sprache = 'de';                                                         // Sprache für formatierung Dauer 
      let formatierungDauer = "dd[T] hh[h] mm[m]";                                // Formatierung der Dauer -> siehe momentjs library
       
      let neustarten = false;                                                      // true: Adapter wird neugestartet, false: Adapter wird gestoppt oder gestartet
       
      let farbeAdapterAktiv = 'green';                                            // Status Bar Farbe wenn Adapter aktiv ist
      let farbeAdapterNichtAktiv = 'FireBrick';                                   // Status Bar Farbe wenn Adapter nicht aktiv ist oder Fehler vorliegt
      let farbeAdapterDeaktiviert = 'grey';                                   // Status Bar Farbe wenn Adapter deaktiviert ist
      let farbeAdapterNichtVerbunden = 'yellow';                                  // Status Bar Farbe wenn Adapter nicht verbunden ist
      let farbeAdapterZeitgesteuert = 'lightgreen';                               // Status Bar Farbe wenn Adapter zeitgesteuert ist
      let farbeAdapterErweiterung = '#44739e';                                    // Status Bar Farbe wenn Adapter Erweiterung ist
      let farbeAdapterSystem = '#44739e';                                         // Status Bar Farbe wenn Adapter mit System gestartet wird
       
      let sortResetAfter = 120;                                                   // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
      let sortReset = 'memHeapUsed'                                               // Sortierung auf die zurückgesetzt werden soll
       
      let filterResetAfter = 120;                                                 // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
       
      // **********************************************************************************************************************************************************************
       
       
      // Fomate für moment Lib
      moment.locale(sprache);
       
      // auf .alive Änderungen hören
      let aliveSelector = `[id=system.adapter.*.alive]`;
      let adapterAliveList = $(aliveSelector);
      if (adapterAliveList.length === 0) {
          // Fehlermeldung ausgeben, wenn selector kein result liefert
          console.error(`no result for selector '${aliveSelector}'`)
      } else {
          // listener nur für Änderung bei alive
          adapterAliveList.on(adapterStatus);
      }
       
      // auf .connection Änderungen hören
      let connectionSelector = `[id=*.info.connection]`;
      let adapterConnectionList = $(connectionSelector);
      if (adapterConnectionList.length === 0) {
          // Fehlermeldung ausgeben, wenn selector kein result liefert
          console.error(`no result for selector '${connectionSelector}'`)
      } else {
          // listener nur für Änderung bei alive
          adapterConnectionList.on(adapterStatus);
      }
       
      // auf .connected Änderungen hören
      let connectedSelector = `[id=system.adapter.*.connected]`;
      let adapterConnectedList = $(connectedSelector);
      if (adapterConnectedList.length === 0) {
          // Fehlermeldung ausgeben, wenn selector kein result liefert
          console.error(`no result for selector '${connectedSelector}'`)
      } else {
          // listener nur für Änderung bei alive
          adapterConnectedList.on(adapterStatus);
      }
       
      // auf Änderungen der Sortieung hören
      on({ id: dpSortMode, change: 'any' }, adapterStatus);
      on({ id: dpSortMode, change: 'any' }, resetSort);
       
      // auf Änderungen der Filter hören
      on({ id: dpFilterMode, change: 'any' }, adapterStatus);
      on({ id: dpFilterMode, change: 'any' }, resetFilter);
       
      // Funktion adapterStatus alle x Sekunden ausführen
      schedule('*/' + checkInterval + ' * * * * *', adapterStatus);
       
      function adapterStatus() {
          // Funktion um Status der Adapter abzurufen und als JSON String für das Material Design Widget IconList aufbereiten
          let adapterList = [];
          let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
       
          try {
              for (var i = 0; i <= adapterAliveList.length - 1; i++) {
                  let id = adapterAliveList[i].replace('.alive', '');
                  let obj = getObject(adapterAliveList[i].replace('.alive', ''));
       
                  let nameArray = id.replace('system.adapter.', '').split(".");
       
                  let name = nameArray[0];
                  name = name.charAt(0).toUpperCase() + name.slice(1);
       
                  let nameWithInstance = name;
                  let adapterInstance = nameArray[1];
                  if (parseInt(adapterInstance) > 0) {
                      nameWithInstance = name + '.' + adapterInstance;
                  }
       
                  let uptime = (existsState(id + '.uptime')) ? moment.duration(getState(id + '.uptime').val, 'seconds').format(formatierungDauer, 0) : '-';
                  let image = (myHelper().checkCommonPropertyExist(obj, 'icon')) ? `/${nameArray[0]}.admin/${obj.common.icon}` : 'image-off-outline';
       
                  let hasUpdates = updateList && updateList.includes(nameArray[0]);
                  let newVersion = (hasUpdates) ? '<span class="mdi mdi-update" style="color: #ec0909;"></span>' : '';
       
                  let text = `<div style="display: flex; flex-direction: row; line-height: 1.5; padding-right: 8px; align-items: center;">
                                  <div style="flex: 1">${newVersion} ${nameWithInstance}</div>
                                  <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${myHelper().getCommonPropertyIfExist(obj, 'version', '-', 'v', '')}</div>
                              </div>`
       
                  let subText = `<div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">CPU</div>
                                      <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${myHelper().getStateValueIfExist(id + '.cpu', '-', '', ' %')}</div>
                                  </div>
                                  <div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">RAM total</div>
                                      <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${myHelper().getStateValueIfExist(id + '.memHeapTotal', '-', '', ' MB')}</div>
                                  </div>
                                  <div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">RAM verwendet</div>
                                      <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${myHelper().getStateValueIfExist(id + '.memHeapUsed', '-', '', ' MB')}</div>
                                  </div>
                                  <div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">RAM reserviert</div>
                                      <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${myHelper().getStateValueIfExist(id + '.memRss', '-', '', ' MB')}</div>
                                  </div>
                                  <div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">Betriebszeit</div>
                                      <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${uptime}</div>
                                  </div>
                                  <div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">Modus</div>
                                      <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${myHelper().getCommonPropertyIfExist(obj, 'mode', '-')}</div>
                                  </div>`
       
                  let statusBarColor = farbeAdapterNichtAktiv;
                  let status = 3;
       
                  if (myHelper().getStateValueIfExist(adapterAliveList[i]) === 'true') {
                      statusBarColor = farbeAdapterAktiv;
                      status = 0;
       
                      if (existsState(id.replace('system.adapter.', '') + '.info.connection')) {
                          if (!getState(id.replace('system.adapter.', '') + '.info.connection').val) {
                              statusBarColor = farbeAdapterNichtVerbunden;
                              status = 4;
                          }
                      } else {
                          if (myHelper().getStateValueIfExist(adapterAliveList[i].replace('.alive', '.connected')) === 'false') {
                              statusBarColor = farbeAdapterNichtVerbunden;
                              status = 4;
                          }
                      }
                  }
       
                  if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'schedule') {
                      // Adapter ist zeitgesteuert
                      statusBarColor = farbeAdapterZeitgesteuert;
                      status = 1;
                  }
       
                  if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'extension') {
                      // Adapter ist Extension
                      statusBarColor = farbeAdapterErweiterung;
                      status = 1;
                  }
       
                  if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'once') {
                      // Adapter wird mit System gestartet
                      statusBarColor = farbeAdapterSystem;
                      status = 1;
                  }
       
                  if (myHelper().getCommonPropertyIfExist(obj, 'enabled', false).toString() === 'false') {
                      // Adapter ist deaktiviert
                      statusBarColor = farbeAdapterDeaktiviert;
                      status = 2;
                  }
       
                  adapterList.push({
                      text: text,
                      subText: subText,
                      image: image,
                      listType: "buttonState",
                      objectId: dpAdapterRestart,
                      buttonStateValue: id,
                      statusBarColor: statusBarColor,
                      showValueLabel: false,
                      name: name,
                      mode: myHelper().getCommonPropertyIfExist(obj, 'mode'),
                      hasUpdates: hasUpdates,
                      cpu: parseFloat(myHelper().getStateValueIfExist(id + '.cpu', '0')),
                      memHeapTotal: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapTotal', '0')),
                      memHeapUsed: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapUsed', '0')),
                      memRss: parseFloat(myHelper().getStateValueIfExist(id + '.memRss', '0')),
                      uptime: parseFloat(myHelper().getStateValueIfExist(id + '.uptime', 0)),
                      status: status
                  })
              }
       
          } catch (err) {
              console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
          }
       
          let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
       
          if (sortMode === 'name' || sortMode === 'mode') {
              adapterList.sort(function (a, b) {
                  return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
              });
          } else if (sortMode === 'hasUpdates' || sortMode === 'cpu' || sortMode === 'memHeapTotal' || sortMode === 'memHeapUsed' || sortMode === 'memRss' || sortMode === 'uptime' || sortMode === 'status') {
              adapterList.sort(function (a, b) {
                  return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
              });
          } else {
              // default: nach name sortieren
              sortMode = 'name'
              adapterList.sort(function (a, b) {
                  return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
              });
          }
       
          // Filter: not connected, updates, deaktiviert, aktiviert
       
          let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
       
          if (filterMode && filterMode !== null && filterMode !== '') {
              if (filterMode === 'hasUpdates') {
                  adapterList = adapterList.filter(function (item) {
                      return item.hasUpdates === true;
                  });
              } else if (filterMode === 'notConnected') {
                  adapterList = adapterList.filter(function (item) {
                      return item.status === 4;
                  });
              } else if (filterMode === 'deactivated') {
                  adapterList = adapterList.filter(function (item) {
                      return item.status === 2;
                  });
              } else if (filterMode === 'activated') {
                  adapterList = adapterList.filter(function (item) {
                      return item.status <= 1;
                  });
              }
          }
       
          // adapterList = adapterList.filter(function(item){
          //     return item.status === 4;
          // })
       
          let result = JSON.stringify(adapterList);
          if (getState(dpList) !== result) {
              setState(dpList, result, true);
          }
       
       
      }
       
      // Beim Staren des Skriptes Adapter Status abrufen
      adapterStatus();
       
      // Funktion um Adapter zu starten / neu starten
      on({ id: dpAdapterRestart }, function (obj) {
          var adapter = getObject(obj.state.val.toString());
       
          if (neustarten) {
              if (adapter.common && adapter.common.enabled === false) {
                  // Adapter deaktiviert -> starten
                  adapter.common.enabled = true;
              }
          } else {
              if (adapter.common && adapter.common.enabled) {
                  adapter.common.enabled = !adapter.common.enabled;
              } else {
                  adapter.common.enabled = true;
              }
          }
       
          setObject(obj.state.val, adapter);
          console.log(`${obj.state.val.replace('system.adapter.', '')} neugestartet`);
      });
       
       
      function resetSort() {
          let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
       
          if (sortResetAfter > 0) {
              setTimeout(function () {
                  if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                      setState(dpSortMode, sortReset);
                  }
              }, sortResetAfter * 1000);
          }
      }
       
      function resetFilter() {
          let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
       
          if (filterResetAfter > 0) {
              setTimeout(function () {
                  if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                      setState(dpFilterMode, '');
                  }
              }, filterResetAfter * 1000);
          }
      }
       
      function myHelper() {
          return {
              getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                  if (existsState(id)) {
                      return prepand + getState(id).val + append;
                  } else {
                      return nullValue;
                  }
              },
              getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                  if (myHelper().checkCommonPropertyExist(object, prop)) {
                      return prepand + object.common[prop] + append;
                  } else {
                      return nullValue;
                  }
              },
              checkCommonPropertyExist: function (object, prop) {
                  if (object && object.common && object.common[prop]) {
                      return true;
                  } else {
                      return false;
                  }
              }
          }
      }
      

      Vielleicht kann dir das weiterhelfen.

      1 Reply Last reply Reply Quote 0
      • sigi234
        sigi234 Forum Testing Most Active @liv-in-sky last edited by

        @liv-in-sky

        Wie muss ich die json importieren und welches Widget genau hast du genommen?

        liv-in-sky 1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @sigi234 last edited by

          @sigi234

          import - alles drin

          [{"tpl":"tplVis-materialdesign-Table","data":{"oid":"","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","countCols":"3","tableLayout":"standard","showHeader":"true","headerTextSize":"headline6","showColumn0":"true","colType0":"text","textAlign0":"left","showColumn1":"true","colType1":"text","textAlign1":"center","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"showColumn2":"true","colType2":"text","textAlign2":"center","showColumn3":"true","colType3":"image","textAlign3":"center","dataJson":"[{\"Device\": \"magnet\",\"Wert\": \"60.6 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"magnet\",\"Wert\": \"62.4 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"magnet\",\"Wert\": \"64.2 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"magnet\",\"Wert\": \"60.6 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"motion 2\",\"Wert\": \"66.1 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"motion 1\",\"Wert\": \"69.7 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"sensor_motion.aq2\",\"Wert\": \"60.6 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"switch\",\"Wert\": \"69.2 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"switch\",\"Wert\": \"71 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"vibration\",\"Wert\": \"64.2 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"vibration\",\"Wert\": \"64.2 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/xiaomki.png\" },{\"Device\": \"Fenster Küche\",\"Wert\": \"64.2 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/deconzk.png\" },{\"Device\": \"Wasser Küche\",\"Wert\": \"33 %\",\"Status\": \"✅\",\"Hersteller\":\"/vis.0/armin/img/marken/deconzk.png\" }]","colTextSize0":"headline4","label1":"Wert","label0":"Name","label2":"Status","sortKey0":"name","fontFamily0":"Jura-DemiBold","padding_left0":"10","colTextColor0":"#beb7b7","colorBackground":"#ffffff","colorHeaderRowBackground":"#000000","colorHeaderRowText":"#17ee36","borderColor":"#000000","fontFamily1":"Jura-DemiBold","colTextColor1":"#beb7b7","rowHeight":"19","label3":"Hersteller","imageSize3":"20","padding_right3":"-5"},"style":{"left":"11px","top":"472px","z-index":"900","width":"499px","height":"525px","overflow-y":"hidden"},"widgetSet":"materialdesign"}]
          

          1 Reply Last reply Reply Quote 0
          • ?
            A Former User @liv-in-sky last edited by

            @liv-in-sky sagte in Script fürTabelle der Batterie Zustände:

            @Elirion

            probiere mal das script im ersten post - deconz sollte funktionieren

            Image 2.png

            @liv-in-sky Leider immer noch doppelte Einträge:

            c4918d31-864c-4dc3-aa64-d81245d1c21c-image.png

            liv-in-sky 1 Reply Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @Guest last edited by

              @Elirion kann es sein, dass du noch eine alte instanz mit diesen werten hast - ich denke- etwas in deinem system ist doppelt

              ? 1 Reply Last reply Reply Quote 0
              • ?
                A Former User @liv-in-sky last edited by

                @liv-in-sky nein ist gelöscht und neue datenpunkte 😉

                liv-in-sky 1 Reply Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @Guest last edited by

                  @Elirion verstehe ich nicht - ich habe ja deine werte eingespielt und bei mir funktioniert es

                  es gibt also keinen deconz.1 oder deconz.2

                  das script hat eigentlich keinen grund 2 mal über das selbe zu laufen - es ist ja eine kopie - dann müßten alle namen unter allen kategorien doppelt sein - ist aber nicht der fall

                  1 Reply Last reply Reply Quote 0
                  • ?
                    A Former User last edited by A Former User

                    @liv-in-sky Nein es gibt nur deconz.0 dort aber für ein Gerät 2 IDs (wegen Luftfeuchte, Temperatur und Luftdruck)

                    liv-in-sky 2 Replies Last reply Reply Quote 0
                    • liv-in-sky
                      liv-in-sky @Guest last edited by

                      @Elirion aber diese id's haben keinen datenpunkt mit ...battery

                      deconz.0.Sensors.10.battery - ist ein sensor - der wird gefunden - wenn der nicht da ist, wird qauch nix gefunden und angezeigt - unter
                      deconz.0.Sensors.10.

                      gibt es nur ein battery

                      ds ist ein gerät

                      hast du mal iobroker neugestartet, nicht das der javascript cache ärger macht

                      ? 1 Reply Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky @Guest last edited by

                        @Elirion oder zumindest die javascript instanz beendet und wieder gestartet

                        1 Reply Last reply Reply Quote 0
                        • ?
                          A Former User @liv-in-sky last edited by

                          @liv-in-sky sagte in Script fürTabelle der Batterie Zustände:

                          @Elirion aber diese id's haben keinen datenpunkt mit ...battery

                          deconz.0.Sensors.10.battery - ist ein sensor - der wird gefunden - wenn der nicht da ist, wird qauch nix gefunden und angezeigt - unter
                          deconz.0.Sensors.10.

                          gibt es nur ein battery

                          ds ist ein gerät

                          hast du mal iobroker neugestartet, nicht das der javascript cache ärger macht

                          Hierbei geht es allerdings nicht um ID10 sondern um 3,4,5
                          Und diese werden angelegt und haben auch einen battery-Status der dann mit null quittiert ist:
                          b406e4cf-fc11-4754-b3f6-588d0c97fc38-image.png

                          Und ja Cache ist geleert und iobroker neugestartet. Macht aber ja wegen dem Bild oben kein Unterschied.

                          liv-in-sky 2 Replies Last reply Reply Quote 0
                          • D
                            darkiop Most Active @liv-in-sky last edited by

                            @liv-in-sky sagte in Script fürTabelle der Batterie Zustände:

                            wie ich die batteriewerte farbig bekomme - kann ich das im json angeben?
                            wie wird das widget aktualisiert
                            warum kann ich keine schrifart wählen

                            Alle 3 sind doch in der Tabelle von @Scrounger Einstellbar? D.h. das json liefert nur die Daten dafür.

                            liv-in-sky 1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @Guest last edited by

                              @Elirion oh man - wieder so ein super adapter - ich habe die unteren datenpunkte gelöscht und dadurch übersehen - sonst bekomme ich zuviele datenpunkte - sorry

                              das ist ein größeres problem - doppelte werte - d.h ich muss die gefundenen datenpunkte speichern und überprüfen ob ich den schon habe - warum schreibt der adapter einen datenpunkt, den er nicht besetzt - da sollte man mal bein adapterhersteller nachfragen - wenn da nix drinsteht, vielleicht kann er ihn dann garnicht schreiben - hast du mal lust, ihn das zu fragen - du kannst ihn auch gerne hierher verweisen - vielleicht gibt es ja eine erklärung dafür, die ich nicht überschaue

                              ? 1 Reply Last reply Reply Quote 0
                              • ?
                                A Former User @liv-in-sky last edited by A Former User

                                @liv-in-sky Die Antwort kann ich dir bereits geben. Der Deconz-Adapter funktioniert etwas anders als die Zigbee-Adapter. Deconz erstellt für jede "Funktion" je eine ID. Da es bei dem Temperaturmesser 3 Funktionen sind = 3 IDs.

                                Daran bin ich nämlich auch gescheitert. Deconz an sich anlegen hat geklappt aber aus der Tabelle entfernen nicht...

                                liv-in-sky 1 Reply Last reply Reply Quote 0
                                • liv-in-sky
                                  liv-in-sky @darkiop last edited by

                                  @darkiop sagte in Script fürTabelle der Batterie Zustände:

                                  @liv-in-sky sagte in Script fürTabelle der Batterie Zustände:

                                  wie ich die batteriewerte farbig bekomme - kann ich das im json angeben?
                                  wie wird das widget aktualisiert
                                  warum kann ich keine schrifart wählen

                                  Alle 3 sind doch in der Tabelle von @Scrounger Einstellbar? D.h. das json liefert nur die Daten dafür.

                                  punkt 3 ist gelöst
                                  punkt 2 - das widget zeigt nur neue sachen an, wenn ich es im browser refreshe - nicht wenn das script etwas in den datenpunkt schreibt
                                  punkt ein - nicht die schriftfarbe soll für alle eingestellt werden sondern wenn im script ein wert bestimmte werte hat sind die rot,grün oder gelb - das muss ich übergeben - aber vielleicht finde ich das in dem adapter script -- da ändert sich ja auch einiges

                                  D 1 Reply Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky @Guest last edited by

                                    @Elirion dann musss ich wohl mein script anpassen - ich komme wieder auf dich zurück

                                    ? 1 Reply Last reply Reply Quote 0
                                    • ?
                                      A Former User @liv-in-sky last edited by

                                      @liv-in-sky gern 😉

                                      liv-in-sky 1 Reply Last reply Reply Quote 0
                                      • D
                                        darkiop Most Active @liv-in-sky last edited by

                                        @liv-in-sky sagte in Script fürTabelle der Batterie Zustände:

                                        punkt 2 - das widget zeigt nur neue sachen an, wenn ich es im browser refreshe - nicht wenn das script etwas in den datenpunkt schreibt

                                        Ich hab das gerade mal mit dem Log Skript von @Mic getestet - hier aktualisiert sich die Materialdesign-Tabelle nachdem das json aktualisiert wurde. Vielleicht kann @Mic ja helfen.

                                        f6aee214-48f9-4578-b144-74c3392fe06a-grafik.png

                                        1 Reply Last reply Reply Quote 0
                                        • liv-in-sky
                                          liv-in-sky @Guest last edited by

                                          @Elirion
                                          @Jey-Cee

                                          hallo @Jey-Cee - ich wollte im script deinen adapter einbinden und habe das problem, dass ein sensor durch 2 oder 3 ID's einen battery wert hat (den frage ich ab). es würde also 2 oder 3 mal der selbe sensor auftauchen - dies könnte ich abfangen indem ich im script kontrolliere , ob er schon existiert (common.name) - mein problem ist, dass die battery-werte nur einmal einen state haben und 2 mal keinen - z.b hier zu sehen https://forum.iobroker.net/post/389281

                                          ich generiere aber dadurch eine menge warnings, weil die datenpunkte keinen states haben - ich frage auch reachable ab und da sind alle werte geschrieben - wäre es möglich, die battery werte auch in jede id zu schreiben?

                                          1 Reply Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky last edited by

                                            wegen material design - was für ein widget wäre euch den am liebsten ? man muss ja für jedes widget ein eigenes json erzeugen - oder sehe ich das falsch

                                            ich denke, dass icon list widget ist mehr euer ding ?

                                            sigi234 O D 3 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            493
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript monitoring template
                                            67
                                            1379
                                            407384
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo