Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Praktische Anwendungen (Showcase)
  4. Material Design Widgets: Adapter Status

NEWS

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

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

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

Material Design Widgets: Adapter Status

Geplant Angeheftet Gesperrt Verschoben Praktische Anwendungen (Showcase)
material design widgetsvisiconlistviewview adapteradapterstatusanzeige
144 Beiträge 48 Kommentatoren 33.7k Aufrufe 60 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • Q quorle

    Wollte gerade das Script ausprobieren und die VIS haben.
    Bei mir werden die Datenpunkte nicht einmal angelegt.
    Woran kann es liegen?
    Logmeldung nach Start:

    11.12.2020, 02:51:02.408	[info ]: javascript.0 (975) Stop script script.js.common.System.VISU-Anzeige.Adapterstatus
    11.12.2020, 02:51:02.541	[info ]: javascript.0 (975) Start javascript script.js.common.System.VISU-Anzeige.Adapterstatus
    11.12.2020, 02:51:02.678	[warn ]: javascript.0 (975)     at adapterStatus (script.js.common.System.VISU-Anzeige.Adapterstatus:255:13)
    11.12.2020, 02:51:02.678	[warn ]: javascript.0 (975)     at script.js.common.System.VISU-Anzeige.Adapterstatus:264:1
    11.12.2020, 02:51:02.679	[warn ]: javascript.0 (975)     at script.js.common.System.VISU-Anzeige.Adapterstatus:338:3
    11.12.2020, 02:51:02.679	[info ]: javascript.0 (975) script.js.common.System.VISU-Anzeige.Adapterstatus: registered 103 subscriptions and 1 schedule
    

    Script:

    // 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 = '0_userdata.0.vis.AdapterStatus.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
    let dpAdapterRestart = '0_userdata.0.vis.AdapterStatus.restartTrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
     
    let dpSortMode = '0_userdata.0.vis.AdapterStatus.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
    let dpFilterMode = '0_userdata.0.vis.AdapterStatus.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 = true;                                                      // 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 = 'darkgrey';                                   // 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
        try {
            let adapterList = [];
            let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
     
            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: grey; font-size: 12px; font-family: RobotoCondensed-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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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,
                    lockEnabled: true
                })
            }
     
            let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
     
            if (sortMode === 'name' || sortMode === 'mode') {
                adapterList.sort(function (a, b) {
                    return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -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].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -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;
                    });
                }
            }
     
            let result = JSON.stringify(adapterList);
            if (existsState(dpList) && getState(dpList).val !== result) {
                setState(dpList, result, true);
            } else {
                setState(dpList, result, true);
            }
     
        } catch (err) {
            console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
        }
    }
     
    // 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;
                }
            }
        }
    }
    
    
    NegaleinN Offline
    NegaleinN Offline
    Negalein
    Global Moderator
    schrieb am zuletzt editiert von Negalein
    #77

    @quorle sagte in Material Design Widgets: Adapter Status:

    Bei mir werden die Datenpunkte nicht einmal angelegt.

    Die Datenpunkte unter Skript Einstellungen musst du erstmal alle erstellen, damit es funktioniert.

    0_userdata.0.vis.AdapterStatus.jsonList
    0_userdata.0.vis.AdapterStatus.restartTrigger
    0_userdata.0.vis.AdapterStatus.sortMode
    0_userdata.0.vis.AdapterStatus.filterMode
    

    ° Node.js: 20.17.0 NPM: 10.8.2
    ° Proxmox, Ubuntu 22.04.3 LTS
    ° Fixer ---> iob fix

    Q 1 Antwort Letzte Antwort
    0
    • NegaleinN Negalein

      @quorle sagte in Material Design Widgets: Adapter Status:

      Bei mir werden die Datenpunkte nicht einmal angelegt.

      Die Datenpunkte unter Skript Einstellungen musst du erstmal alle erstellen, damit es funktioniert.

      0_userdata.0.vis.AdapterStatus.jsonList
      0_userdata.0.vis.AdapterStatus.restartTrigger
      0_userdata.0.vis.AdapterStatus.sortMode
      0_userdata.0.vis.AdapterStatus.filterMode
      
      Q Offline
      Q Offline
      quorle
      schrieb am zuletzt editiert von
      #78

      @Negalein Ach jetzt klappt es.
      Jetzt muss ich nur noch zusehen, wie ich am besten die ganzen Anzeigefarben ändere. Gibts hier eine Doku dazu?

      O 1 Antwort Letzte Antwort
      0
      • Q quorle

        @Negalein Ach jetzt klappt es.
        Jetzt muss ich nur noch zusehen, wie ich am besten die ganzen Anzeigefarben ändere. Gibts hier eine Doku dazu?

        O Online
        O Online
        Oli
        schrieb am zuletzt editiert von
        #79

        Hallo zusammen,

        ich bin gerade dabei, dass Script für den Energieverbrauch verschiedener Geräte anzupassen, was auch super funktioniert

        8f745856-9143-40f9-bc8a-dddee028db48-image.png

        Nun möchte ich, dass der kwh Wert in der Mitte rechtsbündig und daneben der € Wert ebenfalls rechtsbündig dargestellt wird

        cd85b07e-75de-4b14-b0d8-5fea2b19937f-image.png

        Wie muss ich den Subtext ändern, damit das funktioniert?

         <div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 10px; padding-right: 10px; text-align: left; align-items: center;">
                                        <div style="flex: 1;">Tag:</div> 
                                        <div style="color: #8f8f8f; font-size: 12px; font-family: Arial, Helvetica, sans-serif-LightItalic;">${tagKwh.toFixed(3)} kWh</div>                                                               
                                    </div>
        

        Gruß
        Oliver

        1 Antwort Letzte Antwort
        0
        • M Offline
          M Offline
          Maas-Meister
          schrieb am zuletzt editiert von Maas-Meister
          #80

          ERLEDIGT!
          BrowserCache löschen und neustart brachten den erhofften Erfolg

          Moin,
          ich bin noch rechts frisch mit dem Thema "Scripte einfügen".
          Meine Datenpunkte werden nicht befüllt.
          Kann mir einer sagen warum nicht?

          btw/
          wo lege ich externe Scripte ab?
          Root, Common oder Global?

          Mfg

          AdapterStatusScript.png AdapterStatusObjekte.png AdapterStatusLog.png AdapterStatusJavaScript.png AdapterStatusEditor.png

          1 Antwort Letzte Antwort
          0
          • L Offline
            L Offline
            Langer
            schrieb am zuletzt editiert von
            #81

            Hallo zusammen,

            habe den hier Beschriebenen "Adapter Status" als Vorlage genommen und an meine Belange angepasst.

            Hier das Ergebnis:
            FrageIPad.png

            Nun meine Fragen:

            1: Wie bekomme ich es hin, das wenn ich z.B: auf das Chart(?) "Kaffeemaschine" klicke ein Popup-Fenster aufgeht
            in dem ich dann denn "BSH-Zwischenstecker" über einen Schalter ein und aus schalten kann?

            Vielen Dank im voraus

            Wastl

            1 Antwort Letzte Antwort
            0
            • MeinzIsAsM Offline
              MeinzIsAsM Offline
              MeinzIsAs
              schrieb am zuletzt editiert von MeinzIsAs
              #82

              @Scrounger

              DANKE ERLEDIGT!! Hat ohne mein Zutun einfach wieder normal funktioniert.

              Funktioniert echt super. Ich habe aber ein Problem zusammen mit dem TopAppBarWidget. Die OID_Visu wird nach dem Bildaufruf wieder auf 0 zurückgesetzt.
              Könnte das irgendwie mit dem Script zusammenhängen? Die TopAppBar funktioniert mit allen anderen Bildern, nur mit dem Script und der View vom AdapterStatus nicht. Wenn ich das Script deaktiviere, tritt das Problem trotzdem auf. Hat also eher was mit der View bzw. dem verwendeten Widget zu tun.
              Vielleicht hat ja jemand eine Idee, woran das liegen könnte.

              Vielen Dank

              1 Antwort Letzte Antwort
              0
              • U Offline
                U Offline
                UV-on-fire
                schrieb am zuletzt editiert von
                #83

                @MeinzIsAs
                Also ich habe auch TopAppBar im Einsatz und keinerlei Probleme.

                @Scrounger
                Ich habe da allerdings ein Problem mit dem Restart/Stop/Start.
                Bekomme das einfach nicht zum laufen. Der Datenpunkt bleibt bei mir immer leer. Datenpunkt habe ich angelegt

                10192ab6-c9f5-4b17-91bd-22ab6794c937-grafik.png

                Im Skript habe ich den auch angepasst

                // Skript Einstellungen *************************************************************************************************************************************************
                
                 
                
                let dpList = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                
                let dpAdapterRestart = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.restartTrrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                
                 
                
                let dpSortMode = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                
                let dpFilterMode = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.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
                
                

                Im Widget selbst wird bei allen Adaptern in der Ecke ein Schloss angezeigt.

                44faaea9-3814-4344-866b-aca1c0692145-grafik.png

                Beim Bedienen des Icon verschwindet das kurz und wird nach dem Refresh wieder angezeigt.

                Habe zum Test auch mal auf neustarten=false umgestellt aber auch dann wird der Adapter nicht gestoppt/gestartet.

                In der View habe ich auch alle Verwendungstellen der Datenpunkte gesucht und abgeändert. Allerdings habe ich den Datenpunkt für den Restart in der view nicht gefunden.

                Hast du dazu einen Tipp?

                GlasfaserG reimucR 2 Antworten Letzte Antwort
                0
                • U UV-on-fire

                  @MeinzIsAs
                  Also ich habe auch TopAppBar im Einsatz und keinerlei Probleme.

                  @Scrounger
                  Ich habe da allerdings ein Problem mit dem Restart/Stop/Start.
                  Bekomme das einfach nicht zum laufen. Der Datenpunkt bleibt bei mir immer leer. Datenpunkt habe ich angelegt

                  10192ab6-c9f5-4b17-91bd-22ab6794c937-grafik.png

                  Im Skript habe ich den auch angepasst

                  // Skript Einstellungen *************************************************************************************************************************************************
                  
                   
                  
                  let dpList = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                  
                  let dpAdapterRestart = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.restartTrrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                  
                   
                  
                  let dpSortMode = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                  
                  let dpFilterMode = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.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
                  
                  

                  Im Widget selbst wird bei allen Adaptern in der Ecke ein Schloss angezeigt.

                  44faaea9-3814-4344-866b-aca1c0692145-grafik.png

                  Beim Bedienen des Icon verschwindet das kurz und wird nach dem Refresh wieder angezeigt.

                  Habe zum Test auch mal auf neustarten=false umgestellt aber auch dann wird der Adapter nicht gestoppt/gestartet.

                  In der View habe ich auch alle Verwendungstellen der Datenpunkte gesucht und abgeändert. Allerdings habe ich den Datenpunkt für den Restart in der view nicht gefunden.

                  Hast du dazu einen Tipp?

                  GlasfaserG Offline
                  GlasfaserG Offline
                  Glasfaser
                  schrieb am zuletzt editiert von Glasfaser
                  #84

                  @uv-on-fire

                  let dpAdapterRestart = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.restartTrrigger';
                  
                  Trrigger
                  

                  du hast ein r zu viel

                  Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                  U 1 Antwort Letzte Antwort
                  0
                  • GlasfaserG Glasfaser

                    @uv-on-fire

                    let dpAdapterRestart = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.restartTrrigger';
                    
                    Trrigger
                    

                    du hast ein r zu viel

                    U Offline
                    U Offline
                    UV-on-fire
                    schrieb am zuletzt editiert von UV-on-fire
                    #85

                    @Glasfaser
                    @glasfaser

                    :dizzy_face: Danke Glasfaser. Hab die Namen bestimmt zwanzigmal nach Schreibfehlern durchsucht und das doppelte r immer überlesen. Muss wohl doch mal wieder zum Optiker

                    Hat allerdings danach immer noch nicht funktioniert da im Skript noch an einer Stelle die Variable lockEnabled auf true war.

                                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,
                    
                                    lockEnabled: true
                    
                                })
                    

                    Hab das jetzt noch auf false gesetzt und jetzt geht der Restart auch. Keine Ahnung ob ich das auch überlesen habe das man das ändern muss.

                    Jetzt gehts jedenfalls :+1:

                    1 Antwort Letzte Antwort
                    0
                    • MeinzIsAsM Offline
                      MeinzIsAsM Offline
                      MeinzIsAs
                      schrieb am zuletzt editiert von
                      #86

                      @uv-on-fire Danke. Hat sich erledigt. Was auch immer da los war. Jetzt funktioniert es wieder ganz normal.

                      1 Antwort Letzte Antwort
                      0
                      • ScroungerS Scrounger

                        Skript zur Anzeige des Adapter Status mit dem Material Design IconList Widget

                        Mit diesem Skript wird ein json string erzeugt mit dem Status aller installierten Adapter. Diese Daten (Datenpunkt) kann dann im Material Design IconList Widget verwendet werden, um den Status der Adapter im VIS anzuzeigen.

                        letzte Aktualierung: 04.03.2020

                        AdapterStatus.gif

                        Voraussetzung:

                        • Material Design Widgets v0.2.62

                        Funktionen:

                        • Anzeige des Status aller Adapter (Aktiviert, Deakitivert, nicht verbunden, update verfügbar, etc.)
                        • Anzeige von Werten der Adapter (Betriebszeit, Ram, etc.)
                        • Neustarten / Starten / Stoppen von Adaptern
                        • Sortier und Filter Funktion
                        • Einstellungen, siehe im Skript Sektion Einstellungen, Funktion der Einstellungen ist dort als Kommentar beschrieben.

                        Ist auch im Online Beispiel enthalten

                        View zum importieren:

                        {
                          "settings": {
                            "style": {
                              "background_class": ""
                            },
                            "theme": "redmond",
                            "sizex": "",
                            "sizey": "",
                            "gridSize": "",
                            "snapType": null
                          },
                          "widgets": {
                            "e00001": {
                              "tpl": "tplVis-materialdesign-Icon-List",
                              "data": {
                                "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",
                                "wrapItems": true,
                                "listItemDataMethod": "jsonStringObject",
                                "countListItems": "1",
                                "vibrateOnMobilDevices": "50",
                                "listLayout": "card",
                                "itemLayout": "horizontal",
                                "listType0": "text",
                                "showValueLabel0": "true",
                                "listType1": "text",
                                "showValueLabel1": "true",
                                "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,
                                "json_string_oid": "0_userdata.0.vis.AdapterStatus.jsonList",
                                "maxItemsperRow": "6",
                                "iconItemMinWidth": "300",
                                "iconHeight": "60",
                                "buttonHeight": "100",
                                "labelFontSize": "22",
                                "subLabelFontSize": "14",
                                "subLabelFontColor": "#000000",
                                "labelFontFamily": "RobotoCondensed-Regular",
                                "subLabelFontFamily": "RobotoCondensed-Light",
                                "horizontalIconContainerWidth": "120"
                              },
                              "style": {
                                "left": "0px",
                                "top": "50px",
                                "width": "100%",
                                "height": "calc(100% - 50px)",
                                "overflow-x": "",
                                "overflow-y": "auto",
                                "z-index": "1"
                              },
                              "widgetSet": "materialdesign"
                            },
                            "e00002": {
                              "tpl": "tplHtml",
                              "data": {
                                "g_fixed": false,
                                "g_visibility": false,
                                "g_css_font_text": false,
                                "g_css_background": true,
                                "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",
                                "refreshInterval": "0",
                                "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
                              },
                              "style": {
                                "left": "0",
                                "top": "0",
                                "width": "100%",
                                "height": "50px",
                                "background-color": "#44739e"
                              },
                              "widgetSet": "basic"
                            },
                            "e00003": {
                              "tpl": "tplVis-materialdesign-Select",
                              "data": {
                                "oid": "0_userdata.0.vis.AdapterStatus.sortMode",
                                "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",
                                "inputType": "text",
                                "inputLayout": "regular",
                                "showInputMessageAlways": "true",
                                "showInputCounter": false,
                                "clearIconShow": false,
                                "listDataMethod": "jsonStringObject",
                                "countSelectItems": "1",
                                "listPosition": "bottom",
                                "showSelectedIcon": "prepend-inner",
                                "showValue": false,
                                "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,
                                "inputLabelText": "Sortieren nach",
                                "inputLabelColor": "#ffffff",
                                "inputLabelFontFamily": "RobotoCondensed-LightItalic",
                                "collapseIconColor": "#ffffff",
                                "collapseIconSize": "",
                                "jsonStringObject": "[\n\t{\n\t\t\"text\": \"Adaptername\",\n\t\t\"value\": \"name\",\n\t\t\"icon\": \"sort-alphabetical\"\n\t},\n\t{\n\t\t\"text\": \"Status\",\n\t\t\"value\": \"status\",\n\t\t\"icon\": \"information-variant\"\n\t},\t\n\t{\n\t\t\"text\": \"Modus\",\n\t\t\"value\": \"mode\",\n\t\t\"icon\": \"view-dashboard\"\n\t},\n\t{\n\t\t\"text\": \"Updates verfügbar\",\n\t\t\"value\": \"hasUpdates\",\n\t\t\"icon\": \"package-down\"\n\t},\n\t{\n\t\t\"text\": \"CPU\",\n\t\t\"value\": \"cpu\",\n\t\t\"icon\": \"cpu-64-bit\"\n\t},\n\t{\n\t\t\"text\": \"RAM total\",\n\t\t\"value\": \"memHeapTotal\",\n\t\t\"icon\": \"memory\"\n\t},\n\t{\n\t\t\"text\": \"RAM verwendet\",\n\t\t\"value\": \"memHeapUsed\",\n\t\t\"icon\": \"memory\"\n\t},\n\t{\n\t\t\"text\": \"RAM reserviert\",\n\t\t\"value\": \"memRss\",\n\t\t\"icon\": \"memory\"\n\t},\n\t{\n\t\t\"text\": \"Betriebszeit\",\n\t\t\"value\": \"uptime\",\n\t\t\"icon\": \"clock-check-outline\"\n\t}\n]",
                                "listPositionOffset": true,
                                "inputLayoutBackgroundColor": "transparent",
                                "inputLabelColorSelected": "#ffffff",
                                "inputTranslateX": "-15",
                                "clearIcon": "",
                                "inputLayoutBorderColorHover": "#ffffff",
                                "inputLayoutBorderColorSelected": "#ffffff",
                                "inputLayoutBorderColor": "#a1a1a1",
                                "listItemFontColor": "",
                                "inputTextColor": "#ffffff",
                                "inputTextFontFamily": "RobotoCondensed-LightItalic",
                                "prepandIcon": "",
                                "prepandIconColor": "",
                                "prepandIconSize": "",
                                "prepandInnerIcon": "",
                                "prepandInnerIconColor": "#ffffff",
                                "prepandInnerIconSize": "18",
                                "collapseIcon": "",
                                "inputTranslateY": "-12",
                                "listIconSelectedColor": "#44739e",
                                "listIconColor": "",
                                "appendOuterIcon": "",
                                "appendOuterIconSize": "2",
                                "listItemFont": "RobotoCondensed-Regular",
                                "listItemRippleEffectColor": "",
                                "inputLayoutBackgroundColorSelected": "",
                                "inputLayoutBackgroundColorHover": ""
                              },
                              "style": {
                                "left": "10px",
                                "top": "0px",
                                "z-index": "1",
                                "width": "calc(50% - 20px)",
                                "height": "40px"
                              },
                              "widgetSet": "materialdesign"
                            },
                            "e00004": {
                              "tpl": "tplVis-materialdesign-Select",
                              "data": {
                                "oid": "0_userdata.0.vis.AdapterStatus.filterMode",
                                "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",
                                "inputType": "text",
                                "inputLayout": "regular",
                                "showInputMessageAlways": "true",
                                "showInputCounter": false,
                                "clearIconShow": true,
                                "listDataMethod": "jsonStringObject",
                                "countSelectItems": "1",
                                "listPosition": "bottom",
                                "showSelectedIcon": "prepend-inner",
                                "showValue": false,
                                "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,
                                "inputLabelText": "Filtern nach",
                                "inputLabelColor": "#ffffff",
                                "inputLabelFontFamily": "RobotoCondensed-LightItalic",
                                "collapseIconColor": "#ffffff",
                                "collapseIconSize": "",
                                "jsonStringObject": "[\n\t{\n\t\t\"text\": \"nicht verbunden\",\n\t\t\"value\": \"notConnected\",\n\t\t\"icon\": \"network-off\"\n\t},\n\t{\n\t\t\"text\": \"deaktiviert\",\n\t\t\"value\": \"deactivated\",\n\t\t\"icon\": \"checkbox-blank-outline\"\n\t},\t\n\t{\n\t\t\"text\": \"aktiviert\",\n\t\t\"value\": \"activated\",\n\t\t\"icon\": \"checkbox-intermediate\"\n\t},\n\t{\n\t\t\"text\": \"Updates verfügbar\",\n\t\t\"value\": \"hasUpdates\",\n\t\t\"icon\": \"package-down\"\n\t}\n]",
                                "listPositionOffset": true,
                                "inputLayoutBackgroundColor": "transparent",
                                "inputLabelColorSelected": "#ffffff",
                                "inputTranslateX": "-15",
                                "clearIcon": "",
                                "inputLayoutBorderColorHover": "#ffffff",
                                "inputLayoutBorderColorSelected": "#ffffff",
                                "inputLayoutBorderColor": "#a1a1a1",
                                "listItemFontColor": "",
                                "inputTextColor": "#ffffff",
                                "inputTextFontFamily": "RobotoCondensed-LightItalic",
                                "prepandIcon": "",
                                "prepandIconColor": "",
                                "prepandIconSize": "",
                                "prepandInnerIcon": "",
                                "prepandInnerIconColor": "#ffffff",
                                "prepandInnerIconSize": "18",
                                "collapseIcon": "",
                                "inputTranslateY": "-12",
                                "listIconSelectedColor": "#44739e",
                                "listIconColor": "",
                                "appendOuterIcon": "",
                                "appendOuterIconSize": "2",
                                "listItemFont": "RobotoCondensed-Regular",
                                "listItemRippleEffectColor": "",
                                "inputLayoutBackgroundColorSelected": "",
                                "inputLayoutBackgroundColorHover": "",
                                "clearIconColor": "#ffffff"
                              },
                              "style": {
                                "left": "calc(50% + 10px)",
                                "top": "0px",
                                "z-index": "1",
                                "width": "calc(50% - 20px)",
                                "height": "40px"
                              },
                              "widgetSet": "materialdesign"
                            }
                          },
                          "name": "AdapterStatus",
                          "filterList": []
                        }
                        

                        Hier hab ich beschrieben, wie man das layout am besten einstellt:
                        https://forum.iobroker.net/topic/30661/material-design-widgets-adapter-status/5

                        Skript

                        // 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 = '0_userdata.0.vis.AdapterStatus.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                        let dpAdapterRestart = '0_userdata.0.vis.AdapterStatus.restartTrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                        
                        let dpSortMode = '0_userdata.0.vis.AdapterStatus.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                        let dpFilterMode = '0_userdata.0.vis.AdapterStatus.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 = true;                                                      // 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 = 'darkgrey';                                   // 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
                            try {
                                let adapterList = [];
                                let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
                        
                                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: grey; font-size: 12px; font-family: RobotoCondensed-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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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,
                                        lockEnabled: true
                                    })
                                }
                        
                                let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                        
                                if (sortMode === 'name' || sortMode === 'mode') {
                                    adapterList.sort(function (a, b) {
                                        return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -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].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -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;
                                        });
                                    }
                                }
                        
                                let result = JSON.stringify(adapterList);
                                if (existsState(dpList) && getState(dpList).val !== result) {
                                    setState(dpList, result, true);
                                } else {
                                    setState(dpList, result, true);
                                }
                        
                            } catch (err) {
                                console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
                            }
                        }
                        
                        // 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;
                                    }
                                }
                            }
                        }
                        

                        Benötigte libraries & Einstellungen im Javascript Adapter:
                        09332102-f89f-4189-bbd7-ba62e1752f54-grafik.png

                        Die Idee dazu kommt von @sigi234, seine Version findet ihr hier.
                        Vielen Dank für die Inspiration :+1:

                        GarganoG Offline
                        GarganoG Offline
                        Gargano
                        schrieb am zuletzt editiert von Gargano
                        #87

                        @scrounger Danke für das Script.
                        Wenn ich auf das entsprechende Feld klicke wird gleich der Adapter neu gestartet. Kann man ein Dialog einblenden für Start/Stop/Restart ?

                        Und dickes Problem :
                        Wenn ich über das Script den Adapter Influxdb neu starte sind die Passwörter vom Influxdb Adapter futsch und der Adapter startet nicht neu .

                        1 Antwort Letzte Antwort
                        0
                        • U UV-on-fire

                          @MeinzIsAs
                          Also ich habe auch TopAppBar im Einsatz und keinerlei Probleme.

                          @Scrounger
                          Ich habe da allerdings ein Problem mit dem Restart/Stop/Start.
                          Bekomme das einfach nicht zum laufen. Der Datenpunkt bleibt bei mir immer leer. Datenpunkt habe ich angelegt

                          10192ab6-c9f5-4b17-91bd-22ab6794c937-grafik.png

                          Im Skript habe ich den auch angepasst

                          // Skript Einstellungen *************************************************************************************************************************************************
                          
                           
                          
                          let dpList = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                          
                          let dpAdapterRestart = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.restartTrrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                          
                           
                          
                          let dpSortMode = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                          
                          let dpFilterMode = '0_userdata.0.Vis.MaterialDesignWidgets.AdapterStatus.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
                          
                          

                          Im Widget selbst wird bei allen Adaptern in der Ecke ein Schloss angezeigt.

                          44faaea9-3814-4344-866b-aca1c0692145-grafik.png

                          Beim Bedienen des Icon verschwindet das kurz und wird nach dem Refresh wieder angezeigt.

                          Habe zum Test auch mal auf neustarten=false umgestellt aber auch dann wird der Adapter nicht gestoppt/gestartet.

                          In der View habe ich auch alle Verwendungstellen der Datenpunkte gesucht und abgeändert. Allerdings habe ich den Datenpunkt für den Restart in der view nicht gefunden.

                          Hast du dazu einen Tipp?

                          reimucR Offline
                          reimucR Offline
                          reimuc
                          schrieb am zuletzt editiert von reimuc
                          #88

                          @uv-on-fire @Scrounger
                          Hallo
                          das mit dem Schloss im Bild in den Adapter Widgets habe ich auch. Hast du geklärt warum da ein Schloss ist?
                          Ich habe die Antwort dazu nicht gefunden.

                          c5d79434-82b8-47dd-9abf-fac4a9c3c27a-image.png
                          Danke!

                          U 1 Antwort Letzte Antwort
                          0
                          • reimucR reimuc

                            @uv-on-fire @Scrounger
                            Hallo
                            das mit dem Schloss im Bild in den Adapter Widgets habe ich auch. Hast du geklärt warum da ein Schloss ist?
                            Ich habe die Antwort dazu nicht gefunden.

                            c5d79434-82b8-47dd-9abf-fac4a9c3c27a-image.png
                            Danke!

                            U Offline
                            U Offline
                            UV-on-fire
                            schrieb am zuletzt editiert von
                            #89

                            @reimuc
                            Sorry das ich mich jetzt erst melde. War bisschen out of order. Also das mit dem Schloss liegt wie oben beschrieben daran das die Variable lockEnabled im Script auf true steht.

                            1 Antwort Letzte Antwort
                            0
                            • ScroungerS Scrounger

                              Skript zur Anzeige des Adapter Status mit dem Material Design IconList Widget

                              Mit diesem Skript wird ein json string erzeugt mit dem Status aller installierten Adapter. Diese Daten (Datenpunkt) kann dann im Material Design IconList Widget verwendet werden, um den Status der Adapter im VIS anzuzeigen.

                              letzte Aktualierung: 04.03.2020

                              AdapterStatus.gif

                              Voraussetzung:

                              • Material Design Widgets v0.2.62

                              Funktionen:

                              • Anzeige des Status aller Adapter (Aktiviert, Deakitivert, nicht verbunden, update verfügbar, etc.)
                              • Anzeige von Werten der Adapter (Betriebszeit, Ram, etc.)
                              • Neustarten / Starten / Stoppen von Adaptern
                              • Sortier und Filter Funktion
                              • Einstellungen, siehe im Skript Sektion Einstellungen, Funktion der Einstellungen ist dort als Kommentar beschrieben.

                              Ist auch im Online Beispiel enthalten

                              View zum importieren:

                              {
                                "settings": {
                                  "style": {
                                    "background_class": ""
                                  },
                                  "theme": "redmond",
                                  "sizex": "",
                                  "sizey": "",
                                  "gridSize": "",
                                  "snapType": null
                                },
                                "widgets": {
                                  "e00001": {
                                    "tpl": "tplVis-materialdesign-Icon-List",
                                    "data": {
                                      "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",
                                      "wrapItems": true,
                                      "listItemDataMethod": "jsonStringObject",
                                      "countListItems": "1",
                                      "vibrateOnMobilDevices": "50",
                                      "listLayout": "card",
                                      "itemLayout": "horizontal",
                                      "listType0": "text",
                                      "showValueLabel0": "true",
                                      "listType1": "text",
                                      "showValueLabel1": "true",
                                      "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,
                                      "json_string_oid": "0_userdata.0.vis.AdapterStatus.jsonList",
                                      "maxItemsperRow": "6",
                                      "iconItemMinWidth": "300",
                                      "iconHeight": "60",
                                      "buttonHeight": "100",
                                      "labelFontSize": "22",
                                      "subLabelFontSize": "14",
                                      "subLabelFontColor": "#000000",
                                      "labelFontFamily": "RobotoCondensed-Regular",
                                      "subLabelFontFamily": "RobotoCondensed-Light",
                                      "horizontalIconContainerWidth": "120"
                                    },
                                    "style": {
                                      "left": "0px",
                                      "top": "50px",
                                      "width": "100%",
                                      "height": "calc(100% - 50px)",
                                      "overflow-x": "",
                                      "overflow-y": "auto",
                                      "z-index": "1"
                                    },
                                    "widgetSet": "materialdesign"
                                  },
                                  "e00002": {
                                    "tpl": "tplHtml",
                                    "data": {
                                      "g_fixed": false,
                                      "g_visibility": false,
                                      "g_css_font_text": false,
                                      "g_css_background": true,
                                      "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",
                                      "refreshInterval": "0",
                                      "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
                                    },
                                    "style": {
                                      "left": "0",
                                      "top": "0",
                                      "width": "100%",
                                      "height": "50px",
                                      "background-color": "#44739e"
                                    },
                                    "widgetSet": "basic"
                                  },
                                  "e00003": {
                                    "tpl": "tplVis-materialdesign-Select",
                                    "data": {
                                      "oid": "0_userdata.0.vis.AdapterStatus.sortMode",
                                      "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",
                                      "inputType": "text",
                                      "inputLayout": "regular",
                                      "showInputMessageAlways": "true",
                                      "showInputCounter": false,
                                      "clearIconShow": false,
                                      "listDataMethod": "jsonStringObject",
                                      "countSelectItems": "1",
                                      "listPosition": "bottom",
                                      "showSelectedIcon": "prepend-inner",
                                      "showValue": false,
                                      "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,
                                      "inputLabelText": "Sortieren nach",
                                      "inputLabelColor": "#ffffff",
                                      "inputLabelFontFamily": "RobotoCondensed-LightItalic",
                                      "collapseIconColor": "#ffffff",
                                      "collapseIconSize": "",
                                      "jsonStringObject": "[\n\t{\n\t\t\"text\": \"Adaptername\",\n\t\t\"value\": \"name\",\n\t\t\"icon\": \"sort-alphabetical\"\n\t},\n\t{\n\t\t\"text\": \"Status\",\n\t\t\"value\": \"status\",\n\t\t\"icon\": \"information-variant\"\n\t},\t\n\t{\n\t\t\"text\": \"Modus\",\n\t\t\"value\": \"mode\",\n\t\t\"icon\": \"view-dashboard\"\n\t},\n\t{\n\t\t\"text\": \"Updates verfügbar\",\n\t\t\"value\": \"hasUpdates\",\n\t\t\"icon\": \"package-down\"\n\t},\n\t{\n\t\t\"text\": \"CPU\",\n\t\t\"value\": \"cpu\",\n\t\t\"icon\": \"cpu-64-bit\"\n\t},\n\t{\n\t\t\"text\": \"RAM total\",\n\t\t\"value\": \"memHeapTotal\",\n\t\t\"icon\": \"memory\"\n\t},\n\t{\n\t\t\"text\": \"RAM verwendet\",\n\t\t\"value\": \"memHeapUsed\",\n\t\t\"icon\": \"memory\"\n\t},\n\t{\n\t\t\"text\": \"RAM reserviert\",\n\t\t\"value\": \"memRss\",\n\t\t\"icon\": \"memory\"\n\t},\n\t{\n\t\t\"text\": \"Betriebszeit\",\n\t\t\"value\": \"uptime\",\n\t\t\"icon\": \"clock-check-outline\"\n\t}\n]",
                                      "listPositionOffset": true,
                                      "inputLayoutBackgroundColor": "transparent",
                                      "inputLabelColorSelected": "#ffffff",
                                      "inputTranslateX": "-15",
                                      "clearIcon": "",
                                      "inputLayoutBorderColorHover": "#ffffff",
                                      "inputLayoutBorderColorSelected": "#ffffff",
                                      "inputLayoutBorderColor": "#a1a1a1",
                                      "listItemFontColor": "",
                                      "inputTextColor": "#ffffff",
                                      "inputTextFontFamily": "RobotoCondensed-LightItalic",
                                      "prepandIcon": "",
                                      "prepandIconColor": "",
                                      "prepandIconSize": "",
                                      "prepandInnerIcon": "",
                                      "prepandInnerIconColor": "#ffffff",
                                      "prepandInnerIconSize": "18",
                                      "collapseIcon": "",
                                      "inputTranslateY": "-12",
                                      "listIconSelectedColor": "#44739e",
                                      "listIconColor": "",
                                      "appendOuterIcon": "",
                                      "appendOuterIconSize": "2",
                                      "listItemFont": "RobotoCondensed-Regular",
                                      "listItemRippleEffectColor": "",
                                      "inputLayoutBackgroundColorSelected": "",
                                      "inputLayoutBackgroundColorHover": ""
                                    },
                                    "style": {
                                      "left": "10px",
                                      "top": "0px",
                                      "z-index": "1",
                                      "width": "calc(50% - 20px)",
                                      "height": "40px"
                                    },
                                    "widgetSet": "materialdesign"
                                  },
                                  "e00004": {
                                    "tpl": "tplVis-materialdesign-Select",
                                    "data": {
                                      "oid": "0_userdata.0.vis.AdapterStatus.filterMode",
                                      "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",
                                      "inputType": "text",
                                      "inputLayout": "regular",
                                      "showInputMessageAlways": "true",
                                      "showInputCounter": false,
                                      "clearIconShow": true,
                                      "listDataMethod": "jsonStringObject",
                                      "countSelectItems": "1",
                                      "listPosition": "bottom",
                                      "showSelectedIcon": "prepend-inner",
                                      "showValue": false,
                                      "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,
                                      "inputLabelText": "Filtern nach",
                                      "inputLabelColor": "#ffffff",
                                      "inputLabelFontFamily": "RobotoCondensed-LightItalic",
                                      "collapseIconColor": "#ffffff",
                                      "collapseIconSize": "",
                                      "jsonStringObject": "[\n\t{\n\t\t\"text\": \"nicht verbunden\",\n\t\t\"value\": \"notConnected\",\n\t\t\"icon\": \"network-off\"\n\t},\n\t{\n\t\t\"text\": \"deaktiviert\",\n\t\t\"value\": \"deactivated\",\n\t\t\"icon\": \"checkbox-blank-outline\"\n\t},\t\n\t{\n\t\t\"text\": \"aktiviert\",\n\t\t\"value\": \"activated\",\n\t\t\"icon\": \"checkbox-intermediate\"\n\t},\n\t{\n\t\t\"text\": \"Updates verfügbar\",\n\t\t\"value\": \"hasUpdates\",\n\t\t\"icon\": \"package-down\"\n\t}\n]",
                                      "listPositionOffset": true,
                                      "inputLayoutBackgroundColor": "transparent",
                                      "inputLabelColorSelected": "#ffffff",
                                      "inputTranslateX": "-15",
                                      "clearIcon": "",
                                      "inputLayoutBorderColorHover": "#ffffff",
                                      "inputLayoutBorderColorSelected": "#ffffff",
                                      "inputLayoutBorderColor": "#a1a1a1",
                                      "listItemFontColor": "",
                                      "inputTextColor": "#ffffff",
                                      "inputTextFontFamily": "RobotoCondensed-LightItalic",
                                      "prepandIcon": "",
                                      "prepandIconColor": "",
                                      "prepandIconSize": "",
                                      "prepandInnerIcon": "",
                                      "prepandInnerIconColor": "#ffffff",
                                      "prepandInnerIconSize": "18",
                                      "collapseIcon": "",
                                      "inputTranslateY": "-12",
                                      "listIconSelectedColor": "#44739e",
                                      "listIconColor": "",
                                      "appendOuterIcon": "",
                                      "appendOuterIconSize": "2",
                                      "listItemFont": "RobotoCondensed-Regular",
                                      "listItemRippleEffectColor": "",
                                      "inputLayoutBackgroundColorSelected": "",
                                      "inputLayoutBackgroundColorHover": "",
                                      "clearIconColor": "#ffffff"
                                    },
                                    "style": {
                                      "left": "calc(50% + 10px)",
                                      "top": "0px",
                                      "z-index": "1",
                                      "width": "calc(50% - 20px)",
                                      "height": "40px"
                                    },
                                    "widgetSet": "materialdesign"
                                  }
                                },
                                "name": "AdapterStatus",
                                "filterList": []
                              }
                              

                              Hier hab ich beschrieben, wie man das layout am besten einstellt:
                              https://forum.iobroker.net/topic/30661/material-design-widgets-adapter-status/5

                              Skript

                              // 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 = '0_userdata.0.vis.AdapterStatus.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                              let dpAdapterRestart = '0_userdata.0.vis.AdapterStatus.restartTrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                              
                              let dpSortMode = '0_userdata.0.vis.AdapterStatus.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                              let dpFilterMode = '0_userdata.0.vis.AdapterStatus.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 = true;                                                      // 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 = 'darkgrey';                                   // 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
                                  try {
                                      let adapterList = [];
                                      let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
                              
                                      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: grey; font-size: 12px; font-family: RobotoCondensed-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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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: grey; font-size: 14px; font-family: RobotoCondensed-LightItalic; text-align: right;">${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,
                                              lockEnabled: true
                                          })
                                      }
                              
                                      let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                              
                                      if (sortMode === 'name' || sortMode === 'mode') {
                                          adapterList.sort(function (a, b) {
                                              return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -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].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -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;
                                              });
                                          }
                                      }
                              
                                      let result = JSON.stringify(adapterList);
                                      if (existsState(dpList) && getState(dpList).val !== result) {
                                          setState(dpList, result, true);
                                      } else {
                                          setState(dpList, result, true);
                                      }
                              
                                  } catch (err) {
                                      console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
                                  }
                              }
                              
                              // 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;
                                          }
                                      }
                                  }
                              }
                              

                              Benötigte libraries & Einstellungen im Javascript Adapter:
                              09332102-f89f-4189-bbd7-ba62e1752f54-grafik.png

                              Die Idee dazu kommt von @sigi234, seine Version findet ihr hier.
                              Vielen Dank für die Inspiration :+1:

                              WszeneW Offline
                              WszeneW Offline
                              Wszene
                              schrieb am zuletzt editiert von
                              #90

                              @scrounger
                              Guten Tag
                              Ich wollte nun auch dein Script nutzen aber leider bekomme ich es nicht zum laufen

                              Ich habe folgendes gemacht

                              1. im Javascript Adapter Module eingefügt

                              Bildschirmfoto 2022-01-28 um 06.11.41.png

                              1. Dein Script importiert und die Datenpunkte angepasst
                              // Skript Einstellungen *************************************************************************************************************************************************
                               
                              let dpList = '0_userdata.0.002_nurVIS.18_Status.Adapter.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                              let dpAdapterRestart = '0_userdata.0.002_nurVIS.18_Status.Adapter.restartTrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                               
                              let dpSortMode = '0_userdata.0.002_nurVIS.18_Status.Adapter.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                              let dpFilterMode = '0_userdata.0.002_nurVIS.18_Status.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 = true;                                                      // 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 = 'darkgrey';                                   // 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)
                               
                              // **********************************************************************************************************************************************************************
                              
                              1. Script gestartet

                              Dann bekomme ich folgende Fehler im Log und es werden auch keine Datenpunkte angelegt

                              
                              javascript.0
                              2022-01-28 06:09:11.533	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at script.js.001-VIS.Status.Adapterstatus:267:1 at script.js.001-VIS.Status.Adapterstatus:341:3 at Script.runInContext (vm.js:144:12) at Script.runInNewContext (vm.js:149:17) at execute (/opt/iobroker/node_modules/iobroker.javascript/main.js:1526:27) at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1736:38) at /opt/iobroker/node_modules/iobroker.javascript/main.js:1836:17 at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/main.js:1311:17) at processImmediate (internal/timers.js:466:21)
                              
                              javascript.0
                              2022-01-28 06:09:11.436	error	at Script.runInContext (vm.js:144:12)
                              
                              javascript.0
                              2022-01-28 06:09:11.436	error	at script.js.001-VIS.Status.Adapterstatus:340:3
                              
                              javascript.0
                              2022-01-28 06:09:11.436	error	at script.js.001-VIS.Status.Adapterstatus:5:35
                              
                              javascript.0
                              2022-01-28 06:09:11.436	error	at require (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:412:32)
                              
                              javascript.0
                              2022-01-28 06:09:11.436	error	at require (internal/modules/cjs/helpers.js:93:18)
                              
                              javascript.0
                              2022-01-28 06:09:11.436	error	at Module.require (internal/modules/cjs/loader.js:974:19)
                              
                              javascript.0
                              2022-01-28 06:09:11.435	error	script.js.001-VIS.Status.Adapterstatus: Error: Cannot find module 'moment-duration-format'
                              

                              Leider kenne ich mit Javascript nicht aus

                              Kannst du mir sagen wo der Fehler liegt?

                              Danke im Voraus
                              Gruß
                              Marcel

                              Meine Hard- & Software:

                              • MSI Cubi 5 10M-049DE mit Proxmox
                              • CC2652P Zigbee Stick
                              • Steckdosen mit Tasmota und Zigbee
                              • Lichtschalter mit Tasmota
                              • IKEA TRÅDFRI Glühbirnen
                              • Aqara Sensoren
                              GlasfaserG 1 Antwort Letzte Antwort
                              0
                              • WszeneW Wszene

                                @scrounger
                                Guten Tag
                                Ich wollte nun auch dein Script nutzen aber leider bekomme ich es nicht zum laufen

                                Ich habe folgendes gemacht

                                1. im Javascript Adapter Module eingefügt

                                Bildschirmfoto 2022-01-28 um 06.11.41.png

                                1. Dein Script importiert und die Datenpunkte angepasst
                                // Skript Einstellungen *************************************************************************************************************************************************
                                 
                                let dpList = '0_userdata.0.002_nurVIS.18_Status.Adapter.jsonList';                     // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
                                let dpAdapterRestart = '0_userdata.0.002_nurVIS.18_Status.Adapter.restartTrigger';     // Datenpunkt für Adapter restart (Typ: Zeichenkette (String))
                                 
                                let dpSortMode = '0_userdata.0.002_nurVIS.18_Status.Adapter.sortMode';                 // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
                                let dpFilterMode = '0_userdata.0.002_nurVIS.18_Status.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 = true;                                                      // 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 = 'darkgrey';                                   // 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)
                                 
                                // **********************************************************************************************************************************************************************
                                
                                1. Script gestartet

                                Dann bekomme ich folgende Fehler im Log und es werden auch keine Datenpunkte angelegt

                                
                                javascript.0
                                2022-01-28 06:09:11.533	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at script.js.001-VIS.Status.Adapterstatus:267:1 at script.js.001-VIS.Status.Adapterstatus:341:3 at Script.runInContext (vm.js:144:12) at Script.runInNewContext (vm.js:149:17) at execute (/opt/iobroker/node_modules/iobroker.javascript/main.js:1526:27) at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1736:38) at /opt/iobroker/node_modules/iobroker.javascript/main.js:1836:17 at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/main.js:1311:17) at processImmediate (internal/timers.js:466:21)
                                
                                javascript.0
                                2022-01-28 06:09:11.436	error	at Script.runInContext (vm.js:144:12)
                                
                                javascript.0
                                2022-01-28 06:09:11.436	error	at script.js.001-VIS.Status.Adapterstatus:340:3
                                
                                javascript.0
                                2022-01-28 06:09:11.436	error	at script.js.001-VIS.Status.Adapterstatus:5:35
                                
                                javascript.0
                                2022-01-28 06:09:11.436	error	at require (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:412:32)
                                
                                javascript.0
                                2022-01-28 06:09:11.436	error	at require (internal/modules/cjs/helpers.js:93:18)
                                
                                javascript.0
                                2022-01-28 06:09:11.436	error	at Module.require (internal/modules/cjs/loader.js:974:19)
                                
                                javascript.0
                                2022-01-28 06:09:11.435	error	script.js.001-VIS.Status.Adapterstatus: Error: Cannot find module 'moment-duration-format'
                                

                                Leider kenne ich mit Javascript nicht aus

                                Kannst du mir sagen wo der Fehler liegt?

                                Danke im Voraus
                                Gruß
                                Marcel

                                GlasfaserG Offline
                                GlasfaserG Offline
                                Glasfaser
                                schrieb am zuletzt editiert von
                                #91

                                @wszene sagte in Material Design Widgets: Adapter Status:

                                und die Datenpunkte angepasst
                                es werden auch keine Datenpunkte angelegt

                                (Typ: Zeichenkette (String))

                                Hast du den eigenen Datenpunkt erstellt , denn er wird nicht vom Skript selber erstellt .

                                Cannot find module 'moment-duration-format'

                                Mhh ,
                                lösche die Eintragung , Adapter neu starten ,
                                wieder eintragen , Adapter starten und im Log schauen ob eine Fehlermeldung kommt .

                                Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                                WszeneW GlasfaserG 2 Antworten Letzte Antwort
                                0
                                • GlasfaserG Glasfaser

                                  @wszene sagte in Material Design Widgets: Adapter Status:

                                  und die Datenpunkte angepasst
                                  es werden auch keine Datenpunkte angelegt

                                  (Typ: Zeichenkette (String))

                                  Hast du den eigenen Datenpunkt erstellt , denn er wird nicht vom Skript selber erstellt .

                                  Cannot find module 'moment-duration-format'

                                  Mhh ,
                                  lösche die Eintragung , Adapter neu starten ,
                                  wieder eintragen , Adapter starten und im Log schauen ob eine Fehlermeldung kommt .

                                  WszeneW Offline
                                  WszeneW Offline
                                  Wszene
                                  schrieb am zuletzt editiert von
                                  #92

                                  @glasfaser sagte in Material Design Widgets: Adapter Status:

                                  @wszene sagte in Material Design Widgets: Adapter Status:

                                  und die Datenpunkte angepasst
                                  es werden auch keine Datenpunkte angelegt

                                  (Typ: Zeichenkette (String))

                                  Hast du den eigenen Datenpunkt erstellt , denn er wird nicht vom Skript selber erstellt .

                                  Cannot find module 'moment-duration-format'

                                  Mhh ,
                                  lösche die Eintragung , Adapter neu starten ,
                                  wieder eintragen , Adapter starten und im Log schauen ob eine Fehlermeldung kommt .

                                  OK das werde ich heute Abend gleich ausprobieren

                                  Meine Hard- & Software:

                                  • MSI Cubi 5 10M-049DE mit Proxmox
                                  • CC2652P Zigbee Stick
                                  • Steckdosen mit Tasmota und Zigbee
                                  • Lichtschalter mit Tasmota
                                  • IKEA TRÅDFRI Glühbirnen
                                  • Aqara Sensoren
                                  O 1 Antwort Letzte Antwort
                                  0
                                  • WszeneW Wszene

                                    @glasfaser sagte in Material Design Widgets: Adapter Status:

                                    @wszene sagte in Material Design Widgets: Adapter Status:

                                    und die Datenpunkte angepasst
                                    es werden auch keine Datenpunkte angelegt

                                    (Typ: Zeichenkette (String))

                                    Hast du den eigenen Datenpunkt erstellt , denn er wird nicht vom Skript selber erstellt .

                                    Cannot find module 'moment-duration-format'

                                    Mhh ,
                                    lösche die Eintragung , Adapter neu starten ,
                                    wieder eintragen , Adapter starten und im Log schauen ob eine Fehlermeldung kommt .

                                    OK das werde ich heute Abend gleich ausprobieren

                                    O Online
                                    O Online
                                    Oli
                                    schrieb am zuletzt editiert von Oli
                                    #93

                                    @wszene

                                    Bei mir steht über den Skripteinstellungen noch folgendens:

                                    ************************************************************************************************************************************************************************/
                                    // imports NPM Module -> müssen im Javascript Adapter unter 'Zusätzliche NPM-Module' eingetragen sein
                                    const moment = require("moment");
                                    const momentDurationFormatSetup = require("moment-duration-format");
                                    // **********************************************************************************************************************************************************************
                                     
                                    // Skript Einstellungen ************************************************************************************************************************************************* 
                                    

                                    Gruß
                                    Oliver

                                    WszeneW 1 Antwort Letzte Antwort
                                    0
                                    • O Oli

                                      @wszene

                                      Bei mir steht über den Skripteinstellungen noch folgendens:

                                      ************************************************************************************************************************************************************************/
                                      // imports NPM Module -> müssen im Javascript Adapter unter 'Zusätzliche NPM-Module' eingetragen sein
                                      const moment = require("moment");
                                      const momentDurationFormatSetup = require("moment-duration-format");
                                      // **********************************************************************************************************************************************************************
                                       
                                      // Skript Einstellungen ************************************************************************************************************************************************* 
                                      
                                      WszeneW Offline
                                      WszeneW Offline
                                      Wszene
                                      schrieb am zuletzt editiert von
                                      #94

                                      @oli
                                      Das habe ich auch noch oben drüber stehen

                                      @Glasfaser
                                      Ich habe die Datenpunkte angelegt und das Modul raus gelöscht und wieder eingefügt
                                      Aber leider ohne Erfolg

                                      
                                      javascript.0
                                      2022-01-28 20:24:30.004	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at Object.adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1316: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)
                                      
                                      javascript.0
                                      2022-01-28 20:24:15.293	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at Object.adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1082:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:530:29) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5708:41) at processImmediate (internal/timers.js:464:21)
                                      
                                      javascript.0
                                      2022-01-28 20:24:07.055	info	script.js.001-VIS.Status.Adapterstatus: registered 73 subscriptions and 1 schedule
                                      
                                      javascript.0
                                      2022-01-28 20:24:07.055	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at script.js.001-VIS.Status.Adapterstatus:267:1 at script.js.001-VIS.Status.Adapterstatus:341:3 at Script.runInContext (vm.js:144:12) at Script.runInNewContext (vm.js:149:17) at execute (/opt/iobroker/node_modules/iobroker.javascript/main.js:1526:27) at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1736:38) at /opt/iobroker/node_modules/iobroker.javascript/main.js:1836:17 at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/main.js:1311:17) at processImmediate (internal/timers.js:466:21)
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.950	error	at Script.runInContext (vm.js:144:12)
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.950	error	at script.js.001-VIS.Status.Adapterstatus:340:3
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.950	error	at script.js.001-VIS.Status.Adapterstatus:5:35
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.949	error	at require (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:412:32)
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.949	error	at require (internal/modules/cjs/helpers.js:93:18)
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.949	error	at Module.require (internal/modules/cjs/loader.js:974:19)
                                      
                                      javascript.0
                                      2022-01-28 20:24:06.949	error	script.js.001-VIS.Status.Adapterstatus: Error: Cannot find module 'moment-duration-format'
                                      

                                      Meine Hard- & Software:

                                      • MSI Cubi 5 10M-049DE mit Proxmox
                                      • CC2652P Zigbee Stick
                                      • Steckdosen mit Tasmota und Zigbee
                                      • Lichtschalter mit Tasmota
                                      • IKEA TRÅDFRI Glühbirnen
                                      • Aqara Sensoren
                                      sigi234S 1 Antwort Letzte Antwort
                                      0
                                      • WszeneW Wszene

                                        @oli
                                        Das habe ich auch noch oben drüber stehen

                                        @Glasfaser
                                        Ich habe die Datenpunkte angelegt und das Modul raus gelöscht und wieder eingefügt
                                        Aber leider ohne Erfolg

                                        
                                        javascript.0
                                        2022-01-28 20:24:30.004	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at Object.adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1316: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)
                                        
                                        javascript.0
                                        2022-01-28 20:24:15.293	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at Object.adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1082:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:530:29) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5708:41) at processImmediate (internal/timers.js:464:21)
                                        
                                        javascript.0
                                        2022-01-28 20:24:07.055	info	script.js.001-VIS.Status.Adapterstatus: registered 73 subscriptions and 1 schedule
                                        
                                        javascript.0
                                        2022-01-28 20:24:07.055	error	script.js.001-VIS.Status.Adapterstatus: [adapterStatus] error: moment.duration(...).format is not a function, stack: TypeError: moment.duration(...).format is not a function at adapterStatus (script.js.001-VIS.Status.Adapterstatus:110:115) at script.js.001-VIS.Status.Adapterstatus:267:1 at script.js.001-VIS.Status.Adapterstatus:341:3 at Script.runInContext (vm.js:144:12) at Script.runInNewContext (vm.js:149:17) at execute (/opt/iobroker/node_modules/iobroker.javascript/main.js:1526:27) at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1736:38) at /opt/iobroker/node_modules/iobroker.javascript/main.js:1836:17 at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/main.js:1311:17) at processImmediate (internal/timers.js:466:21)
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.950	error	at Script.runInContext (vm.js:144:12)
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.950	error	at script.js.001-VIS.Status.Adapterstatus:340:3
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.950	error	at script.js.001-VIS.Status.Adapterstatus:5:35
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.949	error	at require (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:412:32)
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.949	error	at require (internal/modules/cjs/helpers.js:93:18)
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.949	error	at Module.require (internal/modules/cjs/loader.js:974:19)
                                        
                                        javascript.0
                                        2022-01-28 20:24:06.949	error	script.js.001-VIS.Status.Adapterstatus: Error: Cannot find module 'moment-duration-format'
                                        
                                        sigi234S Online
                                        sigi234S Online
                                        sigi234
                                        Forum Testing Most Active
                                        schrieb am zuletzt editiert von
                                        #95

                                        @wszene

                                        Welche Version von javascript hast du?

                                        Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                        Immer Daten sichern!

                                        WszeneW 1 Antwort Letzte Antwort
                                        0
                                        • sigi234S sigi234

                                          @wszene

                                          Welche Version von javascript hast du?

                                          WszeneW Offline
                                          WszeneW Offline
                                          Wszene
                                          schrieb am zuletzt editiert von
                                          #96

                                          @sigi234 sagte in Material Design Widgets: Adapter Status:

                                          @wszene

                                          Welche Version von javascript hast du?

                                          Ich habe die Version 5.2.2.1

                                          System ist:
                                          Debian 11 LXC
                                          Node.js: v14.18.3
                                          NPM: 6.14.15

                                          Meine Hard- & Software:

                                          • MSI Cubi 5 10M-049DE mit Proxmox
                                          • CC2652P Zigbee Stick
                                          • Steckdosen mit Tasmota und Zigbee
                                          • Lichtschalter mit Tasmota
                                          • IKEA TRÅDFRI Glühbirnen
                                          • Aqara Sensoren
                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          765

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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