Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Praktische Anwendungen (Showcase)
    4. Material Design Widets: Netzwerk Status

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Material Design Widets: Netzwerk Status

    This topic has been deleted. Only users with topic management privileges can see it.
    • L
      Langer @micklafisch last edited by

      Ich bekomme seid 2 Tagen folgende Fehlermeldung:

      13:52:35.430	info	javascript.0 (10516) script.js.common.Netzwerk.Netzwerk_Status: registered 52 subscriptions and 1 schedule
      13:52:35.456	error	javascript.0 (10516) script.js.common.Netzwerk.Netzwerk_Status: [netzwerkStatus] error: Cannot read property 'common' of null, stack: TypeError: Cannot read property 'common' of null at Object.netzwerkStatus (script.js.common.Netzwerk.Netzwerk_Status:347:33) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1087:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:525:29) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5706:41) at processImmediate (internal/timers.js:464:21)
      13:52:35.771	error	javascript.0 (10516) script.js.common.Netzwerk.Netzwerk_Status: [netzwerkStatus] error: Cannot read property 'common' of null, stack: TypeError: Cannot read property 'common' of null at Object.netzwerkStatus (script.js.common.Netzwerk.Netzwerk_Status:347:33) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1087:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:525:29) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5706:41) at processImmediate (internal/timers.js:464:21)
      13:52:36.009	info	javascript.0 (10516) Stop script script.js.common.Netzwerk.Netzwerk_Status
      

      bis dahin lief alles ohne Probleme.

      MfG
      Wastl

      totocotonio 1 Reply Last reply Reply Quote 0
      • totocotonio
        totocotonio @Langer last edited by totocotonio

        @langer sagte in Material Design Widets: Netzwerk Status:

        Ich bekomme seid 2 Tagen folgende Fehlermeldung:

        13:52:35.430	info	javascript.0 (10516) script.js.common.Netzwerk.Netzwerk_Status: registered 52 subscriptions and 1 schedule
        13:52:35.456	error	javascript.0 (10516) script.js.common.Netzwerk.Netzwerk_Status: [netzwerkStatus] error: Cannot read property 'common' of null, stack: TypeError: Cannot read property 'common' of null at Object.netzwerkStatus (script.js.common.Netzwerk.Netzwerk_Status:347:33) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1087:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:525:29) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5706:41) at processImmediate (internal/timers.js:464:21)
        13:52:35.771	error	javascript.0 (10516) script.js.common.Netzwerk.Netzwerk_Status: [netzwerkStatus] error: Cannot read property 'common' of null, stack: TypeError: Cannot read property 'common' of null at Object.netzwerkStatus (script.js.common.Netzwerk.Netzwerk_Status:347:33) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1087:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:525:29) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5706:41) at processImmediate (internal/timers.js:464:21)
        13:52:36.009	info	javascript.0 (10516) Stop script script.js.common.Netzwerk.Netzwerk_Status
        

        bis dahin lief alles ohne Probleme.

        MfG
        Wastl

        Hi,
        bei mir der gleiche Fehler. Kann es auch nicht erklären hatte sonst immer funktioniert.

        Das kommt bei mir noch:

        javascript.0 (3860879) script.js.common.Service.ip-geraete: [netzwerkStatus] error: Cannot read property 'common' of null, stack: TypeError: Cannot read property 'common' of null at Object.netzwerkStatus (script.js.common.Service.ip-geraete:98:33) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1313:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:168:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (internal/timers.js:557:17) at processTimers (internal/timers.js:500:7)
        
        
        R 1 Reply Last reply Reply Quote 0
        • R
          rallef @totocotonio last edited by

          Habe auch das Problem. Hat keiner eine Lösung?

          1 Reply Last reply Reply Quote 0
          • Knallochse
            Knallochse last edited by Knallochse

            Mir ist gerade aufgefallen, das leider die Zeiten des an/abgemeldet Status nicht mehr angezeigt werden. (Rest z.Bsp. OnlineStatus funktioniert)
            2662CAAD-B7A2-4205-B7BC-E827E12D1809.jpeg
            Hat noch jemand dieses Widget mit dem dazugehörigen Script im Einsatz und könnte das mal überprüfen?

            sigi234 1 Reply Last reply Reply Quote 0
            • sigi234
              sigi234 Forum Testing Most Active @Knallochse last edited by

              @knallochse sagte in Material Design Widets: Netzwerk Status:

              Hat noch jemand dieses Widget mit dem dazugehörigen Script im Einsatz und könnte das mal überprüfen?

              https://forum.iobroker.net/topic/54865/invalide-date/2?_=1652443601033

              1 Reply Last reply Reply Quote 1
              • H
                Hausbaer last edited by

                Ich habe zwei Instanzen des TR-064 Adapters.

                Instanz 1 wertet mir die Sensoren / Steckdosen etc (Shelly, TP-Link....) aus, die per WLan verbunden sind.
                Instanz 2 liefert die Geräte, die im Netz als "User" angemeldet sind (Mobiltelefone, Tabs, Rechner usw).

                Für die Instanz 1 läuft das Scrip ohne Probleme.

                /* Versionshistorie:
                * 
                * 1.0.2:
                * - neu: Anzeige der letzten An- und Abmeldung
                * - neu: Verwendung eigener Bilder möglich
                * 
                * 1.0.1:
                * - neu: In dem Mapping der IP-Adressen kann jetzt eine URL vergeben werden ('http' oder direkt eine spezifische URL)
                * - geändert: Styling der Details
                * - entfernt: MAC-Adresse
                * 
                * 1.0.0:
                * - Initial Release
                */
                
                const moment = require("moment");
                
                
                
                // Datenpunkte anlegen falls nicht vorhanden ********************************
                
                if ( !existsState("0_userdata.0.vis.SensorStatus.jsonList")){createState("0_userdata.0.vis.SensorStatus.jsonList", false, {type: 'string'})}; 
                if ( !existsState("0_userdata.0.vis.SensorStatus.sortMode")){createState("0_userdata.0.vis.SensorStatus.sortMode", false, {type: 'string'})}; 
                if ( !existsState("0_userdata.0.vis.SensorStatus.filterMode")){createState("0_userdata.0.vis.SensorStatus.filterMode", false, {type: 'string'})};
                
                
                // Skript Einstellungen *************************************************************************************************************************************************
                
                let dpList = '0_userdata.0.vis.SensorStatus.jsonList';          // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                
                let dpSortMode = '0_userdata.0.vis.SensorStatus.sortMode';      // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                let dpFilterMode = '0_userdata.0.vis.SensorStatus.filterMode"';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
                
                const checkInterval = 30;                                         // Interval wie oft Status der Skripte aktualisiert werden soll (in Sekunden)
                
                let sprache = 'de';                                               // Sprache für formatierung letzte Änderung
                let formatierungLastChange = "ddd DD.MM - HH:mm";                 // Formatierung letzte Änderung -> siehe momentjs library
                
                let imagePath = '/vis.0/bilder/geraete/'                          // Pfad zu den verwendeten Bildern (bitte über den VIS Dateimanager hochladen)
                                                                                 // nach Variable imagePath suchen und die entsprechenden Zeilen aus- bzw. einkommentieren
                                                                                 // Das Bild (Dateiformat png) in der Mapping-Liste hinterlegen
                //let defaultImage = 'ip-network-outline';                          // Standardbild, falls kein Bild angegeben wurde (Material Design Icons)
                let defaultImage = `${imagePath}default.png`;                   // Standardbild, falls kein Bild angegeben wurde (eigenes Bild)
                
                let farbeGeraetOnline = '0_userdata.0.einstellung_farben_schriftarten.farbe-4';                                  // Status Bar Farbe wenn Geräte online ist
                let farbeGeraetOffline = '0_userdata.0.einstellung_farben_schriftarten.farbe-5';                             // Status Bar Farbe wenn Geräte offline ist
                
                let sortResetAfter = 120;                                         // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
                let sortReset = 'name'                                            // Sortierung auf die zurückgesetzt werden soll
                
                let filterResetAfter = 120;                                       // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
                
                const deviceNames = 
                [{ ip: "192.168.8.110", alias: "Steckdose Drucker",                 image: "tp-link_hs110",              link: "http" },
                { ip: "192.168.8.111", alias: "Flur EG und Keller Licht",          image: "shelly-2-5",                 link: "http://192.168.8.111" },
                { ip: "192.168.8.112", alias: "Flur EG FBH",                       image: "shelly-1",                   link: "http://192.168.8.112" },
                { ip: "192.168.8.113", alias: "Bad FBH",                           image: "shelly-1",                   link: "http://192.168.8.113" },
                { ip: "192.168.8.114", alias: "Küche FBH",                         image: "shelly-1",                   link: "http://192.168.8.114" },
                { ip: "192.168.8.115", alias: "Esszimmer FBH",                     image: "shelly-1",                   link: "http://192.168.8.115" },
                { ip: "192.168.8.116", alias: "Fenster FBH",                       image: "shelly-1",                   link: "http://192.168.8.116" },
                { ip: "192.168.8.117", alias: "Wohnzimmer FBH",                    image: "shelly-1",                   link: "http://192.168.8.117" },
                { ip: "192.168.8.118", alias: "Pumpe FBH",                         image: "shelly-1",                   link: "http://192.168.8.118" },
                { ip: "192.168.8.119", alias: "Flur DG Licht",                     image: "shelly-2-5",                 link: "http://192.168.8.119" },
                { ip: "192.168.8.120", alias: "Volumio",                           image: "shelly-1",                   link: "http://192.168.8.120" },
                { ip: "192.168.8.130", alias: "Melkkammer Licht und Heizspirale",  image: "shelly-2-5",                 link: "http://192.168.8.130" },
                { ip: "192.168.8.131", alias: "Heizraum Licht",                    image: "shelly-1",                   link: "http://192.168.8.131" },
                { ip: "192.168.8.132", alias: "Stall Licht",                       image: "shelly-1",                   link: "http://192.168.8.132" },
                { ip: "192.168.8.133", alias: "Stodl Licht",                       image: "shelly-1",                   link: "http://192.168.8.133" },
                { ip: "192.168.8.134", alias: "Solaranlage",                       image: "shelly-plug-s",              link: "http://192.168.8.134" },
                { ip: "192.168.8.140", alias: "Garage neu Licht außen",            image: "shelly-1",                   link: "http://192.168.8.140" },
                { ip: "192.168.8.141", alias: "Garage neu und Troidlager Licht",   image: "shelly-2-5",                 link: "http://192.168.8.141" },
                { ip: "192.168.8.142", alias: "Garage neu Tor 1",              image: "shelly-1",                   link: "http://192.168.8.142" },
                { ip: "192.168.8.143", alias: "Garage neu Tor 2",               image: "shelly-1",                   link: "http://192.168.8.143" },
                { ip: "192.168.8.146", alias: "Garage neu Tor 2 geschlossen",   image: "shelly-door-2",              link: "http://192.168.8.146" },
                { ip: "192.168.8.147", alias: "Garage neu Tor 1 geschlossen",  image: "shelly-door-2",              link: "http://192.168.8.147" },
                { ip: "192.168.8.150", alias: "Garage alt Licht außen und RH",     image: "shelly-2-5",                 link: "http://192.168.8.150" },
                { ip: "192.168.8.151", alias: "Garage alt Tor 3",                 image: "shelly-1-plus",              link: "http://192.168.8.151" },
                { ip: "192.168.8.152", alias: "Garage alt Tor 4",                image: "shelly-1-plus",              link: "http://192.168.8.152" },
                { ip: "192.168.8.153", alias: "Garage alt Tor 3 geschlossen",     image: "shelly-door-2",              link: "http://192.168.8.153" },
                { ip: "192.168.8.154", alias: "Garage alt Tor 4 geschlossen",    image: "shelly-door-2",              link: "http://192.168.8.154" },
                { ip: "192.168.8.155", alias: "Garage alt Licht",              image: "shelly-1",                   link: "http://192.168.8.155" },
                ];
                
                // **********************************************************************************************************************************************************************
                
                // Fomate für moment Lib
                moment.locale(sprache);
                
                // auf Änderungen aktiver Skripts hören
                let activeSelector = `[id=tr-064.0.devices.*.active]`;
                let deviceActiveList = $(activeSelector);
                if (deviceActiveList.length === 0) {
                   // Fehlermeldung ausgeben, wenn selector kein result liefert
                   console.error(`no result for selector '${activeSelector}'`)
                } else {
                   // listener nur für Änderung bei alive
                   deviceActiveList.on(netzwerkStatus);
                } 
                
                // auf Änderungen der Sortieung hören
                on({ id: dpSortMode, change: 'any' }, netzwerkStatus);
                on({ id: dpSortMode, change: 'any' }, resetSort);
                
                // // auf Änderungen der Filter hören
                on({ id: dpFilterMode, change: 'any' }, netzwerkStatus);
                on({ id: dpFilterMode, change: 'any' }, resetFilter);
                
                
                // Funktion adapterStatus alle x Sekunden ausführen
                schedule('*/' + checkInterval + ' * * * * *', netzwerkStatus);
                
                function netzwerkStatus() {
                   try {
                       let deviceList = [];
                
                       for (var i = 0; i <= deviceActiveList.length - 1; i++) {
                           let id = deviceActiveList[i].replace('.active', '');
                           let obj = getObject(id);
                
                           let pattern = /(?:\d{1,3}\.){3}\d{1,3}/i;
                
                           let ipAddress = obj.common.name.match(pattern)[0];
                           let image = defaultImage;
                           let deviceName = obj.common.name.replace(/ \((?:\d{1,3}\.){3}\d{1,3}\)/g, '');
                           let device = deviceNames.find(element => element.ip == ipAddress);
                           let listType = 'text';
                           let buttonLink = '';
                
                           if(device) {
                               deviceName = device.alias;
                               //image = device.image;
                               image = `${imagePath}${device.image}.png`;
                
                               if(device.link) {
                                   listType = 'buttonLink';
                
                                   if(device.link == 'http') {
                                       buttonLink = `http://${ipAddress}`;
                                   } else {
                                       buttonLink = device.link;
                                   }
                               }
                           }
                
                           let macAddress = obj.native.mac;
                           let imageColor = '{0_userdata.0.einstellung_farben_schriftarten.farbe-8}';
                           let statusBarColor = farbeGeraetOffline;
                           let status = 2;
                
                           if (getState(deviceActiveList[i]).val) {
                               statusBarColor = farbeGeraetOnline;
                               status = 1;
                           }
                
                           if(listType === 'buttonLink') {
                               deviceName = `<span style="text-decoration: underline">${deviceName}</span>`                
                           }
                
                           let lastSignIn = 'noch nicht angemeldet';
                           let lastSignOff = 'noch nicht abgemeldet';
                
                           // Letzte Anmeldung auslesen
                           if(existsState(id + '.lastActive')) {
                               lastSignIn = 'angemeldet seit: ' + moment((getState(id + '.lastActive').val)).format("DD.MM.YY HH:mm:ss");
                           }        
                
                           // Letzte Abmeldung auslesen
                           if(existsState(id + '.lastInactive')) {
                               lastSignOff = 'abgemeldet seit: ' + moment((getState(id + '.lastInactive').val)).format("DD.MM.YY HH:mm:ss");
                           }
                
                           let subText = `<div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-3}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-3}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-5}">${ipAddress}</div>
                                          <div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-2}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-4}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-6}">${lastSignIn}</div>
                                          <div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-2}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-4}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-6}">${lastSignOff}</div>`
                
                
                           deviceList.push({
                               text: deviceName,
                               subText: subText,
                               statusBarColor: statusBarColor,
                               image: image,
                               imageColor: imageColor,
                               listType: listType,
                               buttonLink: buttonLink,
                               showValueLabel: false,
                               name: deviceName,
                               ipAddress: ipAddress,
                               status: status
                           });
                       }
                
                       let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                
                       if (sortMode === 'name' || sortMode === 'ipAddress') {
                           deviceList.sort(function (a, b) {
                               return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                           });
                       } else if (sortMode === 'status') {
                           deviceList.sort(function (a, b) {
                               return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                           });
                       } else {
                           // default: nach name sortieren
                           sortMode = 'name'
                           deviceList.sort(function (a, b) {
                               return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                           });
                       }
                
                
                       let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                
                       if (filterMode && filterMode !== null && filterMode !== '') {
                           if (filterMode === 'offline') {
                               deviceList = deviceList.filter(function (item) {
                                   return item.status === 2;
                               });
                           } else if (filterMode === 'online') {
                               deviceList = deviceList.filter(function (item) {
                                   return item.status === 1;
                               });
                           }
                       }
                
                
                       let result = JSON.stringify(deviceList);
                       if (getState(dpList) !== result) {
                           setState(dpList, result, true);
                       }
                
                   } catch (err) {
                       console.error(`[netzwerkStatus] error: ${err.message}, stack: ${err.stack}`);
                   }
                }
                
                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);
                   }
                }
                
                // Beim Staren des Skriptes Adapter Status abrufen
                netzwerkStatus();
                
                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;
                           }
                       }
                   }
                }
                

                Für die Instanz 2 erhalte ich aber folgende Fehlermeldungen:

                script.js.Neue-Skripte.it-adapter.it-geraete_221209: [GeraeteStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.GeraeteStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:131:59) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1214:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:596:29) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5909:56) at processImmediate (node:internal/timers:466:21)
                
                
                script.js.Neue-Skripte.it-adapter.it-geraete_221209: [GeraeteStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.GeraeteStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:131:59) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1565:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
                

                Dazu hier das Script:

                /* Versionshistorie:
                * 
                * 1.0.2:
                * - neu: Anzeige der letzten An- und Abmeldung
                * - neu: Verwendung eigener Bilder möglich
                * 
                * 1.0.1:
                * - neu: In dem Mapping der IP-Adressen kann jetzt eine URL vergeben werden ('http' oder direkt eine spezifische URL)
                * - geändert: Styling der Details
                * - entfernt: MAC-Adresse
                * 
                * 1.0.0:
                * - Initial Release
                */
                
                const moment = require("moment");
                
                
                // Datenpunkte anlegen falls nicht vorhanden ********************************
                
                if ( !existsState("0_userdata.0.vis.GeraeteStatus.jsonList")){createState("0_userdata.0.vis.GeraeteStatus.jsonList", false, {type: 'string'})}; 
                if ( !existsState("0_userdata.0.vis.GeraeteStatus.sortMode")){createState("0_userdata.0.vis.GeraeteStatus.sortMode", false, {type: 'string'})}; 
                if ( !existsState("0_userdata.0.vis.GeraeteStatus.filterMode")){createState("0_userdata.0.vis.GeraeteStatus.filterMode", false, {type: 'string'})};
                
                
                
                // Skript Einstellungen *************************************************************************************************************************************************
                
                let dpList = '0_userdata.0.vis.GeraeteStatus.jsonList';          // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                
                let dpSortMode = '0_userdata.0.vis.GeraeteStatussortMode';      // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                let dpFilterMode = '0_userdata.0.vis.GeraeteStatus.filterMode';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
                
                const checkInterval = 30;                                         // Interval wie oft Status der Skripte aktualisiert werden soll (in Sekunden)
                
                let sprache = 'de';                                               // Sprache für formatierung letzte Änderung
                let formatierungLastChange = "ddd DD.MM - HH:mm";                 // Formatierung letzte Änderung -> siehe momentjs library
                
                let imagePath =  '/vis.0/bilder/geraete/' 		                  // Pfad zu den verwendeten Bildern (bitte über den VIS Dateimanager hochladen)
                                                                                 // nach Variable imagePath suchen und die entsprechenden Zeilen aus- bzw. einkommentieren
                                                                                 // Das Bild (Dateiformat png) in der Mapping-Liste hinterlegen
                let defaultImage = 'ip-network-outline';                          // Standardbild, falls kein Bild angegeben wurde (Material Design Icons)
                //let defaultImage = `${imagePath}default.png`;                   // Standardbild, falls kein Bild angegeben wurde (eigenes Bild)
                
                let farbeGeraetOnline = 'green';                                  // Status Bar Farbe wenn Geräte online ist
                let farbeGeraetOffline = 'FireBrick';                             // Status Bar Farbe wenn Geräte offline ist
                
                let sortResetAfter = 120;                                         // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
                let sortReset = 'name'                                            // Sortierung auf die zurückgesetzt werden soll
                
                let filterResetAfter = 120;                                       // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
                
                const deviceNames = 
                [{ ip: "192.168.8.201", alias: "Laptop Büro WLan",                  image: "notebook",                   link: "http" },
                { ip: "192.168.8.202", alias: "Laptop Büro Lan",                   image: "notebook",                   link: "http" },
                { ip: "192.168.8.203", alias: "Iobroker",                          image: "raspi1",                     link: "http://192.168.8.203:8081" },
                { ip: "192.168.8.204", alias: "Laptop 2",                      image: "notebook",                   link: "http" },
                { ip: "192.168.8.205", alias: "Laptop 3",                       image: "notebook",                   link: "http" },
                { ip: "192.168.8.206", alias: "FireTV Stick Wohnzimmer",           image: "firetvstick",                link: "http" },
                { ip: "192.168.8.207", alias: "Homematic CCU3",                    image: "ccu3",                       link: "http://192.168.8.207" },
                { ip: "192.168.8.208", alias: "Drucker",                           image: "canon",                      link: "http" },
                { ip: "192.168.8.209", alias: "Metatmo Wetter",                    image: "netatmo",                    link: "http" },
                { ip: "192.168.8.210", alias: "Handy 1",                        image: "redmi8t",                    link: "http" },
                { ip: "192.168.8.211", alias: "Handy 2",                        image: "s3neo",                      link: "http" },
                { ip: "192.168.8.212", alias: "Handy 3",                      image: "mi11",                       link: "http" },
                { ip: "192.168.8.213", alias: "Handy 4",                       image: "honor20",                    link: "http" },
                { ip: "192.168.8.214", alias: "Volumio",                           image: "radio2",                     link: "http://192.168.8.214/browse" },
                { ip: "192.168.8.215", alias: "Anzeige Küche",                     image: "anzeige",                    link: "http" },
                { ip: "192.168.8.216", alias: "Arbeit",                     image: "notebook",                   link: "http" },
                { ip: "192.168.8.217", alias: "Feuerwehr",                  image: "notebook",                   link: "http" },
                { ip: "192.168.8.218", alias: "Raspi Testsystem",                  image: "kodi",                       link: "http://192.168.8.218:8081" },
                { ip: "192.168.8.219", alias: "Egon",                              image: "wr153e",                     link: "http" },
                { ip: "192.168.8.220", alias: "Heizkessel",                        image: "froling_dual",               link: "http" },
                { ip: "192.168.8.221", alias: "Raspi Strom",                       image: "iobroker",                   link: "http" },
                { ip: "192.168.8.222", alias: "NAS",                               image: "iobroker",                   link: "http://192.168.8.222" },
                { ip: "192.168.8.223", alias: "Desktop1",                     image: "desktop",                    link: "http" },
                { ip: "192.168.8.224", alias: "Raspi Heizung",                     image: "iobroker",                   link: "http" },
                { ip: "192.168.8.225", alias: "Uhr",                         image: "fenix7",                     link: "http" },
                { ip: "192.168.8.233", alias: "WD MyCloud",                        image: "mycloud",                    link: "http://192.168.8.233" },
                ];
                 
                // **********************************************************************************************************************************************************************
                
                // Fomate für moment Lib
                moment.locale(sprache);
                
                // auf Änderungen aktiver Skripts hören
                let activeSelector = `[id=tr-064.1.devices.*.active]`;
                let deviceActiveList = $(activeSelector);
                if (deviceActiveList.length === 0) {
                   // Fehlermeldung ausgeben, wenn selector kein result liefert
                   console.error(`no result for selector '${activeSelector}'`)
                } else {
                   // listener nur für Änderung bei alive
                   deviceActiveList.on(GeraeteStatus);
                } 
                
                // auf Änderungen der Sortieung hören
                on({ id: dpSortMode, change: 'any' }, GeraeteStatus);
                on({ id: dpSortMode, change: 'any' }, resetSort);
                
                // // auf Änderungen der Filter hören
                on({ id: dpFilterMode, change: 'any' }, GeraeteStatus);
                on({ id: dpFilterMode, change: 'any' }, resetFilter);
                
                
                // Funktion GeraeteStatus alle x Sekunden ausführen
                schedule('*/' + checkInterval + ' * * * * *', GeraeteStatus);
                
                function GeraeteStatus() {
                   try {
                       let deviceList = [];
                
                       for (var i = 0; i <= deviceActiveList.length - 1; i++) {
                           let id = deviceActiveList[i].replace('.active', '');
                           let obj = getObject(id);
                
                           let pattern = /(?:\d{1,3}\.){3}\d{1,3}/i;
                
                           let ipAddress = obj.common.name.match(pattern)[0];
                           let image = defaultImage;
                           let deviceName = obj.common.name.replace(/ \((?:\d{1,3}\.){3}\d{1,3}\)/g, '');
                           let device = deviceNames.find(element => element.ip == ipAddress);
                           let listType = 'text';
                           let buttonLink = '';
                
                           if(device) {
                               deviceName = device.alias;
                               image = device.image;
                               //image = `${imagePath}${device.image}.png`;
                
                               if(device.link) {
                                   listType = 'buttonLink';
                
                                   if(device.link == 'http') {
                                       buttonLink = `http://${ipAddress}`;
                                   } else {
                                       buttonLink = device.link;
                                   }
                               }
                           }
                
                           let macAddress = obj.native.mac;
                           let imageColor = 'black';
                           let statusBarColor = farbeGeraetOffline;
                           let status = 2;
                
                           if (getState(deviceActiveList[i]).val) {
                               statusBarColor = farbeGeraetOnline;
                               status = 1;
                           }
                
                           if(listType === 'buttonLink') {
                               deviceName = `<span style="text-decoration: underline">${deviceName}</span>`                
                           }
                
                           let lastSignIn = 'noch nicht angemeldet';
                           let lastSignOff = 'noch nicht abgemeldet';
                
                           // Letzte Anmeldung auslesen
                           if(existsState(id + '.lastActive')) {
                               lastSignIn = 'angemeldet seit: ' + moment((getState(id + '.lastActive').val)).format("DD.MM.YY HH:mm:ss");
                           }        
                
                           // Letzte Abmeldung auslesen
                           if(existsState(id + '.lastInactive')) {
                               lastSignOff = 'abgemeldet seit: ' + moment((getState(id + '.lastInactive').val)).format("DD.MM.YY HH:mm:ss");
                           }
                
                           let subText = `<div style="color: black; font-family: RobotoCondensed-BoldItalic">${ipAddress}</div>
                                          <div style="color: grey; font-family: RobotoCondensed-Regular">${lastSignIn}</div>
                                          <div style="color: grey; font-family: RobotoCondensed-Regular">${lastSignOff}</div>`
                
                           deviceList.push({
                               text: deviceName,
                               subText: subText,
                               statusBarColor: statusBarColor,
                               image: image,
                               imageColor: imageColor,
                               listType: listType,
                               buttonLink: buttonLink,
                               showValueLabel: false,
                               name: deviceName,
                               ipAddress: ipAddress,
                               status: status
                           });
                       }
                
                       let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                
                       if (sortMode === 'name' || sortMode === 'ipAddress') {
                           deviceList.sort(function (a, b) {
                               return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                           });
                       } else if (sortMode === 'status') {
                           deviceList.sort(function (a, b) {
                               return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                           });
                       } else {
                           // default: nach name sortieren
                           sortMode = 'name'
                           deviceList.sort(function (a, b) {
                               return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                           });
                       }
                
                
                       let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                
                       if (filterMode && filterMode !== null && filterMode !== '') {
                           if (filterMode === 'offline') {
                               deviceList = deviceList.filter(function (item) {
                                   return item.status === 2;
                               });
                           } else if (filterMode === 'online') {
                               deviceList = deviceList.filter(function (item) {
                                   return item.status === 1;
                               });
                           }
                       }
                
                
                       let result = JSON.stringify(deviceList);
                       if (getState(dpList) !== result) {
                           setState(dpList, result, true);
                       }
                
                   } catch (err) {
                       console.error(`[GeraeteStatus] error: ${err.message}, stack: ${err.stack}`);
                   }
                }
                
                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);
                   }
                }
                
                // Beim Staren des Skriptes GeraeteStatus abrufen
                GeraeteStatus();
                
                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;
                           }
                       }
                   }
                }
                

                Wo liegt hier der Fehler?

                S 1 Reply Last reply Reply Quote 0
                • H
                  Hausbaer last edited by

                  Keiner ne Idee?

                  1 Reply Last reply Reply Quote 0
                  • S
                    stephan61 @Hausbaer last edited by

                    @hausbaer in Zeile 31 fehlt ein Punkt

                    Gruß Stephan

                    DJMarc75 H 2 Replies Last reply Reply Quote 0
                    • DJMarc75
                      DJMarc75 @stephan61 last edited by DJMarc75

                      @stephan61 da fehlt kein Punkt sondern ist ein " zuviel drin. 😀

                      EDIT: ja, im zweiten Skript fehlt der Punkt - sorry @stephan61

                      1 Reply Last reply Reply Quote 0
                      • H
                        Hausbaer @stephan61 last edited by

                        @stephan61 sagte in Material Design Widets: Netzwerk Status:

                        @hausbaer in Zeile 31 fehlt ein Punkt

                        Gruß Stephan

                        Sorry, ich seh es grad nicht. 🤔
                        Wo fehlt hier ein Punkt?

                        
                        let dpFilterMode = '0_userdata.0.vis.GeraeteStatus.filterMode';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
                        
                        DJMarc75 1 Reply Last reply Reply Quote 0
                        • DJMarc75
                          DJMarc75 @Hausbaer last edited by

                          @hausbaer Zeile 31:

                          let dpSortMode = '0_userdata.0.vis.GeraeteStatussortMode';
                          
                          let dpSortMode = '0_userdata.0.vis.GeraeteStatus.sortMode';
                          
                          H 1 Reply Last reply Reply Quote 0
                          • H
                            Hausbaer @DJMarc75 last edited by

                            @djmarc75
                            Ah jetzt. 😬

                            Das ändert aber nichts an der Fehlermeldung:

                            script.js.Neue-Skripte.it-adapter.it-geraete_221209: [netzwerkStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.netzwerkStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:130:59) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1214:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:596:29) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5909:56) at processImmediate (node:internal/timers:466:21)
                            
                            1 Reply Last reply Reply Quote 0
                            • H
                              Hausbaer @Rosi8818 last edited by

                              @rosi8818 sagte in Material Design Widets: Netzwerk Status:

                              @gargano 👍 👍 👍
                              jepp, ich freu mich so, eine Menge gelernt dank deiner Geduld 🙂
                              Danke

                              Kannst du das Script mal hier posten? Ich hab eine ähnliche Situation - und das will einfach nicht.....

                              1 Reply Last reply Reply Quote 0
                              • B
                                Bongo last edited by

                                Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                                javascript.0
                                	2023-02-16 09:44:30.158	error	script.js.common.Vis.NetzwerkStatus: [netzwerkStatus] error: Cannot read properties of null (reading 'common'), stack: TypeError: Cannot read properties of null (reading 'common') at Object.netzwerkStatus (script.js.common.Vis.NetzwerkStatus:166:33) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1595:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
                                javascript.0
                                	2023-02-16 09:44:30.156	warn	script.js.common.Vis.NetzwerkStatus: Object "tr-064.0.devices.Saturn" does not exist
                                

                                Das Objekt tr-064.0.devices.Saturn aus der Warnung gibt es wirklich nicht. Ich habe es aber auch nirgends definiert.
                                In der Fritzbox steht Saturn unter "Ungenutze Verbindungen". Das war ein alter PC.

                                Der Error scheint in Zeile 166 zu sein. Da sieht es so aus:
                                hc_1645.png

                                Zur Sicherheit habe ich das Script aus dem ersten Thread nochmal runter geladen. Aber das selbe Problem.

                                Gibt es dazu eine Lösung? Ich habe nichts gefunden.
                                Achso, bis vor ein paar Tagen ist es ohne Probleme gelaufen.

                                B 1 Reply Last reply Reply Quote 0
                                • B
                                  Bongo @Bongo last edited by

                                  @bongo sagte in Material Design Widets: Netzwerk Status:

                                  Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                                  Für die Nachwelt wie ich es gelöst habe:

                                  • Script NetzwerkStatus gestoppt
                                  • tr-064 Adapter gestoppt und gelöscht.
                                  • Objektbaum von tr-064 gelöscht.
                                  • Javascript Adapter neu gestartet.
                                  • tr-064 Adapter installiert und Geräte über "Geräte suchen" hinzugefügt.
                                  • Script NetzwerkStatus neu gestartet.

                                  Läuft ohne Fehlermeldung!

                                  Vielleicht hätte es den einen oder anderen Schritt nicht gebraucht.
                                  Jedenfalls hat das script ein Device gefunden, das im Objektbaum und im Json Datenpunkt nicht vorhanden war. Zumindest nicht sichtbar. Ich denke der TR-064 Adapter war das Problem, der ein nicht aktives Device versteckt hat.

                                  B 2 Replies Last reply Reply Quote 0
                                  • B
                                    Bongo @Bongo last edited by

                                    @bongo sagte in Material Design Widets: Netzwerk Status:

                                    @bongo sagte in Material Design Widets: Netzwerk Status:

                                    Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                                    Für die Nachwelt wie ich es gelöst habe:

                                    Nachdem über Nacht für die Datensicherung der Container gestopt und wieder gestartet war, kam die Fehlermeldung wieder.
                                    Dann habe ich das Script neu gestartet, dann war die Fehlermeldung wieder weg. Verrückt!

                                    1 Reply Last reply Reply Quote 0
                                    • B
                                      Bongo @Bongo last edited by

                                      @bongo sagte in Material Design Widets: Netzwerk Status:

                                      @bongo sagte in Material Design Widets: Netzwerk Status:

                                      Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                                      Für die Nachwelt wie ich es gelöst habe:

                                      Jetzt kommt diese Fehlermeldung:

                                      error: javascript.0 (188) script.js.common.Vis.NetzwerkStatus: [netzwerkStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0')
                                          at Object.netzwerkStatus (script.js.common.Vis.NetzwerkStatus:172:59)
                                          at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1595:34)
                                          at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15)
                                          at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28
                                          at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7)
                                          at listOnTimeout (node:internal/timers:559:17)
                                          at processTimers (node:internal/timers:502:7)
                                      

                                      Ich glaube mit diesem Script gebe ich auf. 😞

                                      1 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      954
                                      Online

                                      31.9k
                                      Users

                                      80.1k
                                      Topics

                                      1.3m
                                      Posts

                                      50
                                      280
                                      40379
                                      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