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. View Adapter Status

NEWS

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

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

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

View Adapter Status

Geplant Angeheftet Gesperrt Verschoben Praktische Anwendungen (Showcase)
view adapterview
212 Beiträge 31 Kommentatoren 37.4k Aufrufe 52 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.
  • S saeft_2003

    Das neue skript läuft bei mir auch super und ist optisch nochmal besser :blush: :+1:

    sigi234S Online
    sigi234S Online
    sigi234
    Forum Testing Most Active
    schrieb am zuletzt editiert von
    #132

    @saeft_2003 sagte in View Adapter Status:

    Das neue skript läuft bei mir auch super und ist optisch nochmal besser :blush: :+1:

    Ja, sehr gut geworden.

    Screenshot (1803).png

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

    1 Antwort Letzte Antwort
    0
    • S Offline
      S Offline
      saeft_2003
      Most Active
      schrieb am zuletzt editiert von
      #133

      ada.jpg

      Wie schon mal erwähnt wäre eine Sortierung nach läuft und gestoppt nicht schlecht.

      sigi234S ScroungerS 2 Antworten Letzte Antwort
      0
      • S saeft_2003

        ada.jpg

        Wie schon mal erwähnt wäre eine Sortierung nach läuft und gestoppt nicht schlecht.

        sigi234S Online
        sigi234S Online
        sigi234
        Forum Testing Most Active
        schrieb am zuletzt editiert von sigi234
        #134

        @saeft_2003 sagte in View Adapter Status:

        Wie schon mal erwähnt wäre eine Sortierung nach läuft und gestoppt nicht schlecht.

        Jupp, könnte man ja nach Farbe sortieren?

        Überlege mir gerade wie man auch nach Ramverbrauch oder CPU sortieren könnte?

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

        1 Antwort Letzte Antwort
        0
        • S saeft_2003

          ada.jpg

          Wie schon mal erwähnt wäre eine Sortierung nach läuft und gestoppt nicht schlecht.

          ScroungerS Offline
          ScroungerS Offline
          Scrounger
          Developer
          schrieb am zuletzt editiert von
          #135

          @saeft_2003 sagte in View Adapter Status:

          Wie schon mal erwähnt wäre eine Sortierung nach läuft und gestoppt nicht schlecht.

          @sigi234 sagte in View Adapter Status:

          Jupp, könnte man ja nach Farbe sortieren?

          Überlege mir gerade wie man auch nach Ramverbrauch oder CPU sortieren könnte?

          Kann man z.B. mit dem Select Widget realisieren. Dazu muss ein weiterer Datenpunkt angelegt werden, ein listener für diesen Datenpunkt im Skript erzeugt werden und je nachdem welchen state der Datenpunkt hat, muss eine entsprechende Sortierung angestoßen werden (siehe Zeile 156).

          <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

          <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

          S 1 Antwort Letzte Antwort
          0
          • ScroungerS Scrounger

            @saeft_2003 sagte in View Adapter Status:

            Wie schon mal erwähnt wäre eine Sortierung nach läuft und gestoppt nicht schlecht.

            @sigi234 sagte in View Adapter Status:

            Jupp, könnte man ja nach Farbe sortieren?

            Überlege mir gerade wie man auch nach Ramverbrauch oder CPU sortieren könnte?

            Kann man z.B. mit dem Select Widget realisieren. Dazu muss ein weiterer Datenpunkt angelegt werden, ein listener für diesen Datenpunkt im Skript erzeugt werden und je nachdem welchen state der Datenpunkt hat, muss eine entsprechende Sortierung angestoßen werden (siehe Zeile 156).

            S Offline
            S Offline
            saeft_2003
            Most Active
            schrieb am zuletzt editiert von
            #136

            @Scrounger

            ok danke für die Info.

            @sigi234

            Bekommst du das hin? Ich habs zwar noch nicht probiert, aber ich habe da doch meine selbstzweifel...

            sigi234S 1 Antwort Letzte Antwort
            0
            • Stephan SchleichS Offline
              Stephan SchleichS Offline
              Stephan Schleich
              schrieb am zuletzt editiert von Stephan Schleich
              #137

              Wenn man die View etwas verkleinert aber die Listenelementr pro Zeile gleich lässt kommt bei mir ein Anzeige Fehler (ändert man die Listenelemente (weniger) ist der Fehler weg) - Nur zur Info.

              a7784782-c094-44bf-a227-ee6737755987-image.png

              1 Antwort Letzte Antwort
              0
              • S saeft_2003

                @Scrounger

                ok danke für die Info.

                @sigi234

                Bekommst du das hin? Ich habs zwar noch nicht probiert, aber ich habe da doch meine selbstzweifel...

                sigi234S Online
                sigi234S Online
                sigi234
                Forum Testing Most Active
                schrieb am zuletzt editiert von
                #138

                @saeft_2003 sagte in View Adapter Status:

                Bekommst du das hin? Ich habs zwar noch nicht probiert, aber ich habe da doch meine selbstzweifel...

                Nö, das würde ich eher @Scrounger überlassen. :grinning:

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

                1 Antwort Letzte Antwort
                0
                • K Offline
                  K Offline
                  Kuddel
                  schrieb am zuletzt editiert von
                  #139

                  Wo genau finde ich die aktuelle Version vom Skript ?

                  sigi234S 1 Antwort Letzte Antwort
                  0
                  • K Kuddel

                    Wo genau finde ich die aktuelle Version vom Skript ?

                    sigi234S Online
                    sigi234S Online
                    sigi234
                    Forum Testing Most Active
                    schrieb am zuletzt editiert von sigi234
                    #140

                    @Kuddel sagte in View Adapter Status:

                    Wo genau finde ich die aktuelle Version vom Skript ?

                    post 383428
                    https://forum.iobroker.net/topic/26533/view-adapter-status/109

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

                    1 Antwort Letzte Antwort
                    0
                    • ScroungerS Offline
                      ScroungerS Offline
                      Scrounger
                      Developer
                      schrieb am zuletzt editiert von Scrounger
                      #141

                      Sodele nochmal eine neue Version des Skriptes

                      Voraussetzung Material Design Widgets v0.2.62 (demnächst im latest) !!!

                      • mehr Farbeinstellung
                      • Sortier Funktion
                      • Filter Funktion - wäre sicher als nächster Wunsch gekommen, deshalb hab ich es schon mal eingebaut ;-)
                        (Benötigt ihr weitere schaut ins skript und passt es auf eure Bedürfnisse an)
                      • Adapter Modus wird angezeigt
                      • Fehler behoben

                      AdapterStatus.gif

                      Ist auch im Online Beispiel enthalten

                      View:

                      {
                        "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": []
                      }
                      

                      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
                          let adapterList = [];
                          let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
                      
                          try {
                              for (var i = 0; i <= adapterAliveList.length - 1; i++) {
                                  let id = adapterAliveList[i].replace('.alive', '');
                                  let obj = getObject(adapterAliveList[i].replace('.alive', ''));
                      
                                  let nameArray = id.replace('system.adapter.', '').split(".");
                      
                                  let name = nameArray[0];
                                  name = name.charAt(0).toUpperCase() + name.slice(1);
                      
                                  let nameWithInstance = name;
                                  let adapterInstance = nameArray[1];
                                  if (parseInt(adapterInstance) > 0) {
                                      nameWithInstance = name + '.' + adapterInstance;
                                  }
                      
                                  let uptime = (existsState(id + '.uptime')) ? moment.duration(getState(id + '.uptime').val, 'seconds').format(formatierungDauer, 0) : '-';
                                  let image = (myHelper().checkCommonPropertyExist(obj, 'icon')) ? `/${nameArray[0]}.admin/${obj.common.icon}` : 'image-off-outline';
                      
                                  let hasUpdates = updateList && updateList.includes(nameArray[0]);
                                  let newVersion = (hasUpdates) ? '<span class="mdi mdi-update" style="color: #ec0909;"></span>' : '';
                      
                                  let text = `<div style="display: flex; flex-direction: row; line-height: 1.5; padding-right: 8px; align-items: center;">
                                                  <div style="flex: 1">${newVersion} ${nameWithInstance}</div>
                                                  <div style="color: 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;">${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;">${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;">${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;">${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;">${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;">${myHelper().getCommonPropertyIfExist(obj, 'mode', '-')}</div>
                                                  </div>`
                      
                                  let statusBarColor = farbeAdapterNichtAktiv;
                                  let status = 3;
                      
                                  if (myHelper().getStateValueIfExist(adapterAliveList[i]) === 'true') {
                                      statusBarColor = farbeAdapterAktiv;
                                      status = 0;
                      
                                      if (existsState(id.replace('system.adapter.', '') + '.info.connection')) {
                                          if (!getState(id.replace('system.adapter.', '') + '.info.connection').val) {
                                              statusBarColor = farbeAdapterNichtVerbunden;
                                              status = 4;
                                          }
                                      } else {
                                          if (myHelper().getStateValueIfExist(adapterAliveList[i].replace('.alive', '.connected')) === 'false') {
                                              statusBarColor = farbeAdapterNichtVerbunden;
                                              status = 4;
                                          }
                                      }
                                  }
                      
                                  if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'schedule') {
                                      // Adapter ist zeitgesteuert
                                      statusBarColor = farbeAdapterZeitgesteuert;
                                      status = 1;
                                  }
                      
                                  if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'extension') {
                                      // Adapter ist Extension
                                      statusBarColor = farbeAdapterErweiterung;
                                      status = 1;
                                  }
                      
                                  if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'once') {
                                      // Adapter wird mit System gestartet
                                      statusBarColor = farbeAdapterSystem;
                                      status = 1;
                                  }
                      
                                  if (myHelper().getCommonPropertyIfExist(obj, 'enabled', false).toString() === 'false') {
                                      // Adapter ist deaktiviert
                                      statusBarColor = farbeAdapterDeaktiviert;
                                      status = 2;
                                  }
                      
                                  adapterList.push({
                                      text: text,
                                      subText: subText,
                                      image: image,
                                      listType: "buttonState",
                                      objectId: dpAdapterRestart,
                                      buttonStateValue: id,
                                      statusBarColor: statusBarColor,
                                      showValueLabel: false,
                                      name: name,
                                      mode: myHelper().getCommonPropertyIfExist(obj, 'mode'),
                                      hasUpdates: hasUpdates,
                                      cpu: parseFloat(myHelper().getStateValueIfExist(id + '.cpu', '0')),
                                      memHeapTotal: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapTotal', '0')),
                                      memHeapUsed: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapUsed', '0')),
                                      memRss: parseFloat(myHelper().getStateValueIfExist(id + '.memRss', '0')),
                                      uptime: parseFloat(myHelper().getStateValueIfExist(id + '.uptime', 0)),
                                      status: status
                                  })
                              }
                      
                          } catch (err) {
                              console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
                          }
                      
                          let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                      
                          if (sortMode === 'name' || sortMode === 'mode') {
                              adapterList.sort(function (a, b) {
                                  return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
                              });
                          } else if (sortMode === 'hasUpdates' || sortMode === 'cpu' || sortMode === 'memHeapTotal' || sortMode === 'memHeapUsed' || sortMode === 'memRss' || sortMode === 'uptime' || sortMode === 'status') {
                              adapterList.sort(function (a, b) {
                                  return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                              });
                          } else {
                              // default: nach name sortieren
                              sortMode = 'name'
                              adapterList.sort(function (a, b) {
                                  return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
                              });
                          }
                      
                          // Filter: not connected, updates, deaktiviert, aktiviert
                      
                          let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                      
                          if (filterMode && filterMode !== null && filterMode !== '') {
                              if (filterMode === 'hasUpdates') {
                                  adapterList = adapterList.filter(function (item) {
                                      return item.hasUpdates === true;
                                  });
                              } else if (filterMode === 'notConnected') {
                                  adapterList = adapterList.filter(function (item) {
                                      return item.status === 4;
                                  });
                              } else if (filterMode === 'deactivated') {
                                  adapterList = adapterList.filter(function (item) {
                                      return item.status === 2;
                                  });
                              } else if (filterMode === 'activated') {
                                  adapterList = adapterList.filter(function (item) {
                                      return item.status <= 1;
                                  });
                              }
                          }
                      
                          // adapterList = adapterList.filter(function(item){
                          //     return item.status === 4;
                          // })
                      
                          let result = JSON.stringify(adapterList);
                          if (getState(dpList) !== result) {
                              setState(dpList, result, true);
                          }
                      
                      
                      }
                      
                      // Beim Staren des Skriptes Adapter Status abrufen
                      adapterStatus();
                      
                      // Funktion um Adapter zu starten / neu starten
                      on({ id: dpAdapterRestart }, function (obj) {
                          var adapter = getObject(obj.state.val.toString());
                      
                          if (neustarten) {
                              if (adapter.common && adapter.common.enabled === false) {
                                  // Adapter deaktiviert -> starten
                                  adapter.common.enabled = true;
                              }
                          } else {
                              if (adapter.common && adapter.common.enabled) {
                                  adapter.common.enabled = !adapter.common.enabled;
                              } else {
                                  adapter.common.enabled = true;
                              }
                          }
                      
                          setObject(obj.state.val, adapter);
                          console.log(`${obj.state.val.replace('system.adapter.', '')} neugestartet`);
                      });
                      
                      
                      function resetSort() {
                          let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
                      
                          if (sortResetAfter > 0) {
                              setTimeout(function () {
                                  if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                                      setState(dpSortMode, sortReset);
                                  }
                              }, sortResetAfter * 1000);
                          }
                      }
                      
                      function resetFilter() {
                          let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                      
                          if (filterResetAfter > 0) {
                              setTimeout(function () {
                                  if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                                      setState(dpFilterMode, '');
                                  }
                              }, filterResetAfter * 1000);
                          }
                      }
                      
                      function myHelper() {
                          return {
                              getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                                  if (existsState(id)) {
                                      return prepand + getState(id).val + append;
                                  } else {
                                      return nullValue;
                                  }
                              },
                              getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                                  if (myHelper().checkCommonPropertyExist(object, prop)) {
                                      return prepand + object.common[prop] + append;
                                  } else {
                                      return nullValue;
                                  }
                              },
                              checkCommonPropertyExist: function (object, prop) {
                                  if (object && object.common && object.common[prop]) {
                                      return true;
                                  } else {
                                      return false;
                                  }
                              }
                          }
                      }
                      

                      <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                      <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                      sigi234S ub.privatU S 4 Antworten Letzte Antwort
                      6
                      • ScroungerS Scrounger

                        Sodele nochmal eine neue Version des Skriptes

                        Voraussetzung Material Design Widgets v0.2.62 (demnächst im latest) !!!

                        • mehr Farbeinstellung
                        • Sortier Funktion
                        • Filter Funktion - wäre sicher als nächster Wunsch gekommen, deshalb hab ich es schon mal eingebaut ;-)
                          (Benötigt ihr weitere schaut ins skript und passt es auf eure Bedürfnisse an)
                        • Adapter Modus wird angezeigt
                        • Fehler behoben

                        AdapterStatus.gif

                        Ist auch im Online Beispiel enthalten

                        View:

                        {
                          "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": []
                        }
                        

                        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
                            let adapterList = [];
                            let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
                        
                            try {
                                for (var i = 0; i <= adapterAliveList.length - 1; i++) {
                                    let id = adapterAliveList[i].replace('.alive', '');
                                    let obj = getObject(adapterAliveList[i].replace('.alive', ''));
                        
                                    let nameArray = id.replace('system.adapter.', '').split(".");
                        
                                    let name = nameArray[0];
                                    name = name.charAt(0).toUpperCase() + name.slice(1);
                        
                                    let nameWithInstance = name;
                                    let adapterInstance = nameArray[1];
                                    if (parseInt(adapterInstance) > 0) {
                                        nameWithInstance = name + '.' + adapterInstance;
                                    }
                        
                                    let uptime = (existsState(id + '.uptime')) ? moment.duration(getState(id + '.uptime').val, 'seconds').format(formatierungDauer, 0) : '-';
                                    let image = (myHelper().checkCommonPropertyExist(obj, 'icon')) ? `/${nameArray[0]}.admin/${obj.common.icon}` : 'image-off-outline';
                        
                                    let hasUpdates = updateList && updateList.includes(nameArray[0]);
                                    let newVersion = (hasUpdates) ? '<span class="mdi mdi-update" style="color: #ec0909;"></span>' : '';
                        
                                    let text = `<div style="display: flex; flex-direction: row; line-height: 1.5; padding-right: 8px; align-items: center;">
                                                    <div style="flex: 1">${newVersion} ${nameWithInstance}</div>
                                                    <div style="color: 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;">${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;">${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;">${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;">${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;">${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;">${myHelper().getCommonPropertyIfExist(obj, 'mode', '-')}</div>
                                                    </div>`
                        
                                    let statusBarColor = farbeAdapterNichtAktiv;
                                    let status = 3;
                        
                                    if (myHelper().getStateValueIfExist(adapterAliveList[i]) === 'true') {
                                        statusBarColor = farbeAdapterAktiv;
                                        status = 0;
                        
                                        if (existsState(id.replace('system.adapter.', '') + '.info.connection')) {
                                            if (!getState(id.replace('system.adapter.', '') + '.info.connection').val) {
                                                statusBarColor = farbeAdapterNichtVerbunden;
                                                status = 4;
                                            }
                                        } else {
                                            if (myHelper().getStateValueIfExist(adapterAliveList[i].replace('.alive', '.connected')) === 'false') {
                                                statusBarColor = farbeAdapterNichtVerbunden;
                                                status = 4;
                                            }
                                        }
                                    }
                        
                                    if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'schedule') {
                                        // Adapter ist zeitgesteuert
                                        statusBarColor = farbeAdapterZeitgesteuert;
                                        status = 1;
                                    }
                        
                                    if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'extension') {
                                        // Adapter ist Extension
                                        statusBarColor = farbeAdapterErweiterung;
                                        status = 1;
                                    }
                        
                                    if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'once') {
                                        // Adapter wird mit System gestartet
                                        statusBarColor = farbeAdapterSystem;
                                        status = 1;
                                    }
                        
                                    if (myHelper().getCommonPropertyIfExist(obj, 'enabled', false).toString() === 'false') {
                                        // Adapter ist deaktiviert
                                        statusBarColor = farbeAdapterDeaktiviert;
                                        status = 2;
                                    }
                        
                                    adapterList.push({
                                        text: text,
                                        subText: subText,
                                        image: image,
                                        listType: "buttonState",
                                        objectId: dpAdapterRestart,
                                        buttonStateValue: id,
                                        statusBarColor: statusBarColor,
                                        showValueLabel: false,
                                        name: name,
                                        mode: myHelper().getCommonPropertyIfExist(obj, 'mode'),
                                        hasUpdates: hasUpdates,
                                        cpu: parseFloat(myHelper().getStateValueIfExist(id + '.cpu', '0')),
                                        memHeapTotal: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapTotal', '0')),
                                        memHeapUsed: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapUsed', '0')),
                                        memRss: parseFloat(myHelper().getStateValueIfExist(id + '.memRss', '0')),
                                        uptime: parseFloat(myHelper().getStateValueIfExist(id + '.uptime', 0)),
                                        status: status
                                    })
                                }
                        
                            } catch (err) {
                                console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
                            }
                        
                            let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                        
                            if (sortMode === 'name' || sortMode === 'mode') {
                                adapterList.sort(function (a, b) {
                                    return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
                                });
                            } else if (sortMode === 'hasUpdates' || sortMode === 'cpu' || sortMode === 'memHeapTotal' || sortMode === 'memHeapUsed' || sortMode === 'memRss' || sortMode === 'uptime' || sortMode === 'status') {
                                adapterList.sort(function (a, b) {
                                    return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                                });
                            } else {
                                // default: nach name sortieren
                                sortMode = 'name'
                                adapterList.sort(function (a, b) {
                                    return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
                                });
                            }
                        
                            // Filter: not connected, updates, deaktiviert, aktiviert
                        
                            let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                        
                            if (filterMode && filterMode !== null && filterMode !== '') {
                                if (filterMode === 'hasUpdates') {
                                    adapterList = adapterList.filter(function (item) {
                                        return item.hasUpdates === true;
                                    });
                                } else if (filterMode === 'notConnected') {
                                    adapterList = adapterList.filter(function (item) {
                                        return item.status === 4;
                                    });
                                } else if (filterMode === 'deactivated') {
                                    adapterList = adapterList.filter(function (item) {
                                        return item.status === 2;
                                    });
                                } else if (filterMode === 'activated') {
                                    adapterList = adapterList.filter(function (item) {
                                        return item.status <= 1;
                                    });
                                }
                            }
                        
                            // adapterList = adapterList.filter(function(item){
                            //     return item.status === 4;
                            // })
                        
                            let result = JSON.stringify(adapterList);
                            if (getState(dpList) !== result) {
                                setState(dpList, result, true);
                            }
                        
                        
                        }
                        
                        // Beim Staren des Skriptes Adapter Status abrufen
                        adapterStatus();
                        
                        // Funktion um Adapter zu starten / neu starten
                        on({ id: dpAdapterRestart }, function (obj) {
                            var adapter = getObject(obj.state.val.toString());
                        
                            if (neustarten) {
                                if (adapter.common && adapter.common.enabled === false) {
                                    // Adapter deaktiviert -> starten
                                    adapter.common.enabled = true;
                                }
                            } else {
                                if (adapter.common && adapter.common.enabled) {
                                    adapter.common.enabled = !adapter.common.enabled;
                                } else {
                                    adapter.common.enabled = true;
                                }
                            }
                        
                            setObject(obj.state.val, adapter);
                            console.log(`${obj.state.val.replace('system.adapter.', '')} neugestartet`);
                        });
                        
                        
                        function resetSort() {
                            let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
                        
                            if (sortResetAfter > 0) {
                                setTimeout(function () {
                                    if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                                        setState(dpSortMode, sortReset);
                                    }
                                }, sortResetAfter * 1000);
                            }
                        }
                        
                        function resetFilter() {
                            let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                        
                            if (filterResetAfter > 0) {
                                setTimeout(function () {
                                    if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                                        setState(dpFilterMode, '');
                                    }
                                }, filterResetAfter * 1000);
                            }
                        }
                        
                        function myHelper() {
                            return {
                                getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                                    if (existsState(id)) {
                                        return prepand + getState(id).val + append;
                                    } else {
                                        return nullValue;
                                    }
                                },
                                getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                                    if (myHelper().checkCommonPropertyExist(object, prop)) {
                                        return prepand + object.common[prop] + append;
                                    } else {
                                        return nullValue;
                                    }
                                },
                                checkCommonPropertyExist: function (object, prop) {
                                    if (object && object.common && object.common[prop]) {
                                        return true;
                                    } else {
                                        return false;
                                    }
                                }
                            }
                        }
                        
                        sigi234S Online
                        sigi234S Online
                        sigi234
                        Forum Testing Most Active
                        schrieb am zuletzt editiert von
                        #142

                        @Scrounger

                        Das ist MEGA Geil!:+1:

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

                        C 1 Antwort Letzte Antwort
                        0
                        • sigi234S sigi234

                          @Scrounger

                          Das ist MEGA Geil!:+1:

                          C Offline
                          C Offline
                          Conquest
                          schrieb am zuletzt editiert von
                          #143

                          @sigi234 sagte in View Adapter Status:

                          @Scrounger

                          Das ist MEGA Geil!:+1:

                          Das ist aber weit untertrieben :joy:
                          Ich fang wieder bei null an wenn ich die ganzen neuen Sachen hier sehe.

                          1 Antwort Letzte Antwort
                          0
                          • ScroungerS Scrounger

                            Sodele nochmal eine neue Version des Skriptes

                            Voraussetzung Material Design Widgets v0.2.62 (demnächst im latest) !!!

                            • mehr Farbeinstellung
                            • Sortier Funktion
                            • Filter Funktion - wäre sicher als nächster Wunsch gekommen, deshalb hab ich es schon mal eingebaut ;-)
                              (Benötigt ihr weitere schaut ins skript und passt es auf eure Bedürfnisse an)
                            • Adapter Modus wird angezeigt
                            • Fehler behoben

                            AdapterStatus.gif

                            Ist auch im Online Beispiel enthalten

                            View:

                            {
                              "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": []
                            }
                            

                            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
                                let adapterList = [];
                                let updateList = myHelper().getStateValueIfExist(adminUpdatesList);
                            
                                try {
                                    for (var i = 0; i <= adapterAliveList.length - 1; i++) {
                                        let id = adapterAliveList[i].replace('.alive', '');
                                        let obj = getObject(adapterAliveList[i].replace('.alive', ''));
                            
                                        let nameArray = id.replace('system.adapter.', '').split(".");
                            
                                        let name = nameArray[0];
                                        name = name.charAt(0).toUpperCase() + name.slice(1);
                            
                                        let nameWithInstance = name;
                                        let adapterInstance = nameArray[1];
                                        if (parseInt(adapterInstance) > 0) {
                                            nameWithInstance = name + '.' + adapterInstance;
                                        }
                            
                                        let uptime = (existsState(id + '.uptime')) ? moment.duration(getState(id + '.uptime').val, 'seconds').format(formatierungDauer, 0) : '-';
                                        let image = (myHelper().checkCommonPropertyExist(obj, 'icon')) ? `/${nameArray[0]}.admin/${obj.common.icon}` : 'image-off-outline';
                            
                                        let hasUpdates = updateList && updateList.includes(nameArray[0]);
                                        let newVersion = (hasUpdates) ? '<span class="mdi mdi-update" style="color: #ec0909;"></span>' : '';
                            
                                        let text = `<div style="display: flex; flex-direction: row; line-height: 1.5; padding-right: 8px; align-items: center;">
                                                        <div style="flex: 1">${newVersion} ${nameWithInstance}</div>
                                                        <div style="color: 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;">${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;">${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;">${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;">${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;">${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;">${myHelper().getCommonPropertyIfExist(obj, 'mode', '-')}</div>
                                                        </div>`
                            
                                        let statusBarColor = farbeAdapterNichtAktiv;
                                        let status = 3;
                            
                                        if (myHelper().getStateValueIfExist(adapterAliveList[i]) === 'true') {
                                            statusBarColor = farbeAdapterAktiv;
                                            status = 0;
                            
                                            if (existsState(id.replace('system.adapter.', '') + '.info.connection')) {
                                                if (!getState(id.replace('system.adapter.', '') + '.info.connection').val) {
                                                    statusBarColor = farbeAdapterNichtVerbunden;
                                                    status = 4;
                                                }
                                            } else {
                                                if (myHelper().getStateValueIfExist(adapterAliveList[i].replace('.alive', '.connected')) === 'false') {
                                                    statusBarColor = farbeAdapterNichtVerbunden;
                                                    status = 4;
                                                }
                                            }
                                        }
                            
                                        if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'schedule') {
                                            // Adapter ist zeitgesteuert
                                            statusBarColor = farbeAdapterZeitgesteuert;
                                            status = 1;
                                        }
                            
                                        if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'extension') {
                                            // Adapter ist Extension
                                            statusBarColor = farbeAdapterErweiterung;
                                            status = 1;
                                        }
                            
                                        if (myHelper().getCommonPropertyIfExist(obj, 'mode') === 'once') {
                                            // Adapter wird mit System gestartet
                                            statusBarColor = farbeAdapterSystem;
                                            status = 1;
                                        }
                            
                                        if (myHelper().getCommonPropertyIfExist(obj, 'enabled', false).toString() === 'false') {
                                            // Adapter ist deaktiviert
                                            statusBarColor = farbeAdapterDeaktiviert;
                                            status = 2;
                                        }
                            
                                        adapterList.push({
                                            text: text,
                                            subText: subText,
                                            image: image,
                                            listType: "buttonState",
                                            objectId: dpAdapterRestart,
                                            buttonStateValue: id,
                                            statusBarColor: statusBarColor,
                                            showValueLabel: false,
                                            name: name,
                                            mode: myHelper().getCommonPropertyIfExist(obj, 'mode'),
                                            hasUpdates: hasUpdates,
                                            cpu: parseFloat(myHelper().getStateValueIfExist(id + '.cpu', '0')),
                                            memHeapTotal: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapTotal', '0')),
                                            memHeapUsed: parseFloat(myHelper().getStateValueIfExist(id + '.memHeapUsed', '0')),
                                            memRss: parseFloat(myHelper().getStateValueIfExist(id + '.memRss', '0')),
                                            uptime: parseFloat(myHelper().getStateValueIfExist(id + '.uptime', 0)),
                                            status: status
                                        })
                                    }
                            
                                } catch (err) {
                                    console.error(`[adapterStatus] error: ${err.message}, stack: ${err.stack}`);
                                }
                            
                                let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
                            
                                if (sortMode === 'name' || sortMode === 'mode') {
                                    adapterList.sort(function (a, b) {
                                        return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
                                    });
                                } else if (sortMode === 'hasUpdates' || sortMode === 'cpu' || sortMode === 'memHeapTotal' || sortMode === 'memHeapUsed' || sortMode === 'memRss' || sortMode === 'uptime' || sortMode === 'status') {
                                    adapterList.sort(function (a, b) {
                                        return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                                    });
                                } else {
                                    // default: nach name sortieren
                                    sortMode = 'name'
                                    adapterList.sort(function (a, b) {
                                        return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] > b[sortMode]) || -1;
                                    });
                                }
                            
                                // Filter: not connected, updates, deaktiviert, aktiviert
                            
                                let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                            
                                if (filterMode && filterMode !== null && filterMode !== '') {
                                    if (filterMode === 'hasUpdates') {
                                        adapterList = adapterList.filter(function (item) {
                                            return item.hasUpdates === true;
                                        });
                                    } else if (filterMode === 'notConnected') {
                                        adapterList = adapterList.filter(function (item) {
                                            return item.status === 4;
                                        });
                                    } else if (filterMode === 'deactivated') {
                                        adapterList = adapterList.filter(function (item) {
                                            return item.status === 2;
                                        });
                                    } else if (filterMode === 'activated') {
                                        adapterList = adapterList.filter(function (item) {
                                            return item.status <= 1;
                                        });
                                    }
                                }
                            
                                // adapterList = adapterList.filter(function(item){
                                //     return item.status === 4;
                                // })
                            
                                let result = JSON.stringify(adapterList);
                                if (getState(dpList) !== result) {
                                    setState(dpList, result, true);
                                }
                            
                            
                            }
                            
                            // Beim Staren des Skriptes Adapter Status abrufen
                            adapterStatus();
                            
                            // Funktion um Adapter zu starten / neu starten
                            on({ id: dpAdapterRestart }, function (obj) {
                                var adapter = getObject(obj.state.val.toString());
                            
                                if (neustarten) {
                                    if (adapter.common && adapter.common.enabled === false) {
                                        // Adapter deaktiviert -> starten
                                        adapter.common.enabled = true;
                                    }
                                } else {
                                    if (adapter.common && adapter.common.enabled) {
                                        adapter.common.enabled = !adapter.common.enabled;
                                    } else {
                                        adapter.common.enabled = true;
                                    }
                                }
                            
                                setObject(obj.state.val, adapter);
                                console.log(`${obj.state.val.replace('system.adapter.', '')} neugestartet`);
                            });
                            
                            
                            function resetSort() {
                                let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
                            
                                if (sortResetAfter > 0) {
                                    setTimeout(function () {
                                        if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                                            setState(dpSortMode, sortReset);
                                        }
                                    }, sortResetAfter * 1000);
                                }
                            }
                            
                            function resetFilter() {
                                let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
                            
                                if (filterResetAfter > 0) {
                                    setTimeout(function () {
                                        if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                                            setState(dpFilterMode, '');
                                        }
                                    }, filterResetAfter * 1000);
                                }
                            }
                            
                            function myHelper() {
                                return {
                                    getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                                        if (existsState(id)) {
                                            return prepand + getState(id).val + append;
                                        } else {
                                            return nullValue;
                                        }
                                    },
                                    getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                                        if (myHelper().checkCommonPropertyExist(object, prop)) {
                                            return prepand + object.common[prop] + append;
                                        } else {
                                            return nullValue;
                                        }
                                    },
                                    checkCommonPropertyExist: function (object, prop) {
                                        if (object && object.common && object.common[prop]) {
                                            return true;
                                        } else {
                                            return false;
                                        }
                                    }
                                }
                            }
                            
                            sigi234S Online
                            sigi234S Online
                            sigi234
                            Forum Testing Most Active
                            schrieb am zuletzt editiert von
                            #144

                            @Scrounger

                            Screenshot (1837).png

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

                            ScroungerS 1 Antwort Letzte Antwort
                            0
                            • sigi234S sigi234

                              @Scrounger

                              Screenshot (1837).png

                              ScroungerS Offline
                              ScroungerS Offline
                              Scrounger
                              Developer
                              schrieb am zuletzt editiert von Scrounger
                              #145

                              @sigi234
                              Du brauchst Version 0.2.62!
                              Und die scheinst du nicht zu haben, da der JSON-String noch als html input im Editor ist, man aber ab der Version 0.2.62 eine Objekt Id angeben muss.

                              siehe Online Beispiel

                              <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                              <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                              1 Antwort Letzte Antwort
                              0
                              • NegaleinN Offline
                                NegaleinN Offline
                                Negalein
                                Global Moderator
                                schrieb am zuletzt editiert von
                                #146

                                @Scrounger

                                läuft :)
                                vis (34).png

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

                                GlasfaserG 1 Antwort Letzte Antwort
                                0
                                • NegaleinN Negalein

                                  @Scrounger

                                  läuft :)
                                  vis (34).png

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

                                  @Scrounger

                                  Mein View geht im Popup Widget auf ... kann aber nichts anwählen über die Select , dort geht nichts auf.

                                  1.JPG

                                  Normaler View geht :

                                  2.JPG

                                  Geht das nicht über ein Popup !?

                                  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 ..

                                  ScroungerS 1 Antwort Letzte Antwort
                                  0
                                  • GlasfaserG Glasfaser

                                    @Scrounger

                                    Mein View geht im Popup Widget auf ... kann aber nichts anwählen über die Select , dort geht nichts auf.

                                    1.JPG

                                    Normaler View geht :

                                    2.JPG

                                    Geht das nicht über ein Popup !?

                                    ScroungerS Offline
                                    ScroungerS Offline
                                    Scrounger
                                    Developer
                                    schrieb am zuletzt editiert von
                                    #148

                                    @Glasfaser sagte in View Adapter Status:

                                    Mein View geht im Popup Widget auf ... kann aber nichts anwählen über die Select , dort geht nichts auf.

                                    Was meinst du mit Popup? Welches Widget?
                                    Mach am besten mal nen export.

                                    <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                                    <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                                    GlasfaserG 1 Antwort Letzte Antwort
                                    0
                                    • ScroungerS Scrounger

                                      @Glasfaser sagte in View Adapter Status:

                                      Mein View geht im Popup Widget auf ... kann aber nichts anwählen über die Select , dort geht nichts auf.

                                      Was meinst du mit Popup? Welches Widget?
                                      Mach am besten mal nen export.

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

                                      @Scrounger

                                      Sorry habe ich vergessen .. Container Dialog

                                      [{"tpl":"tplContainerDialog","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":false,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":true,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","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,"contains_view":"AdapterStatus","dialog_width":"1400","dialog_height":"782","title":"Adapter Status","dialog_top":"0","dialog_left":"0","modal":false,"noHeader":false,"class":"","name":"Adapterstatus Popup","comment":"transparent Layout"},"style":{"left":"881px","top":"378px","background":"transparent","width":"197px","height":"90px","z-index":"20","border-color":"transparent","font-family":"Jura-DemiBold","font-size":"14px"},"widgetSet":"jqui"}]
                                      

                                      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 ..

                                      1 Antwort Letzte Antwort
                                      0
                                      • ScroungerS Offline
                                        ScroungerS Offline
                                        Scrounger
                                        Developer
                                        schrieb am zuletzt editiert von Scrounger
                                        #150

                                        Hab das skript oben nochmal geupdated
                                        https://forum.iobroker.net/topic/26533/view-adapter-status/142

                                        und folgende Funktionen hinzugefügt:

                                        • Sortierung nach x Sekunden zurücksetzen
                                        • Filter nach x Sekunden zurücksetzen

                                        Timer startet jedesmal, wenn man die Auswahl für Sortierung oder Filter ändert. Konfigurierbar / Deaktivierbar über

                                        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)
                                        

                                        @Glasfaser sagte in View Adapter Status:

                                        @Scrounger

                                        Sorry habe ich vergessen .. Container Dialog

                                        Muss ich mir in Ruhe anschauen, tippe auf einen Bug im Select Widget. Bitte erstellt dazu einen issue auf git, dann vergesse ich es nicht.

                                        <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                                        <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                                        ScroungerS NegaleinN 2 Antworten Letzte Antwort
                                        0
                                        • ScroungerS Scrounger

                                          Hab das skript oben nochmal geupdated
                                          https://forum.iobroker.net/topic/26533/view-adapter-status/142

                                          und folgende Funktionen hinzugefügt:

                                          • Sortierung nach x Sekunden zurücksetzen
                                          • Filter nach x Sekunden zurücksetzen

                                          Timer startet jedesmal, wenn man die Auswahl für Sortierung oder Filter ändert. Konfigurierbar / Deaktivierbar über

                                          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)
                                          

                                          @Glasfaser sagte in View Adapter Status:

                                          @Scrounger

                                          Sorry habe ich vergessen .. Container Dialog

                                          Muss ich mir in Ruhe anschauen, tippe auf einen Bug im Select Widget. Bitte erstellt dazu einen issue auf git, dann vergesse ich es nicht.

                                          ScroungerS Offline
                                          ScroungerS Offline
                                          Scrounger
                                          Developer
                                          schrieb am zuletzt editiert von
                                          #151

                                          @Glasfaser sagte in View Adapter Status:

                                          @Scrounger

                                          Sorry habe ich vergessen .. Container Dialog

                                          Muss ich mir in Ruhe anschauen, tippe auf einen Bug im Select Widget. Bitte erstellt dazu einen issue auf git, dann vergesse ich es nicht.

                                          Ok ist nur ein z-index problem. Musst für die beiden Select Widgets nur den z-index erhöhen, hab ihn einfach mal auf 1000 gesetzt, dann wirds angezeigt.

                                          <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                                          <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                                          GlasfaserG 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

                                          428

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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