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

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

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

View Adapter Status

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

                                          NegaleinN Offline
                                          NegaleinN Offline
                                          Negalein
                                          Global Moderator
                                          schrieb am zuletzt editiert von
                                          #152

                                          @Scrounger sagte in View Adapter Status:

                                          und folgende Funktionen hinzugefügt:

                                          Muss das ganze Script ausgetauscht werden, oder reicht es die besagten Zeilen einzufügen?

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

                                          ScroungerS 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

                                          823

                                          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