Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. ioBroker Allgemein
  4. Javascript Adapter Object neu zusammensetzen

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    688

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.8k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

Javascript Adapter Object neu zusammensetzen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
1 Beiträge 1 Kommentatoren 167 Aufrufe 1 Beobachtet
  • Ä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.
  • L Online
    L Online
    Lucky_ESA
    Developer Most Active
    schrieb am zuletzt editiert von Lucky_ESA
    #1

    Hallo zusammen,

    der HIOB Adapter von @mor15Euro bekommt gerade eine neue Widget Struktur und später werden die alten Widgets auf die neue Struktur migriert. Da ich nicht warten wollte habe ich versucht die Migration über ein Javascript/Blockly umzusetzen, was mir tatsächlich nicht gelungen ist. Habe die Migration dann per Adapter umgesetzt.

    Hier nun der Versuch:
    Aus dem alten Object:

    [
      {
        "id": "-n7qvTNg4XoiPuQgD2zY3ibaDw-1jw==",
        "name": "Bewegungsmelder",
        "widget": {
          "type": "CustomWidgetTypeDeprecated.table",
          "name": "Bewegungsmelder",
          "header": "Bewegungsmelder",
          "sortAsc": true,
          "initialSortColumn": 1,
          "initialSortEnabled": false,
          "elementsPerPage": 10,
          "dataPoint": "0_userdata.0.Geraete_zaehlen.Bewegungsmelder.Haus.01_Anzeigen_und_Listen.11_Table_JSON",
          "columns": {
            "name": "Name",
            "zustand": "Zustand"
          }
        }
      }
    ]
    

    Soll nun das werden:

    [
    	{
    		"type": "tableNew",
    		"id": "-n7qvTNg4XoiPuQgD2zY3ibaDw-1jw==",
    		"name": "Bewegungsmelder",
    		"dataPoint": "0_userdata.0.Geraete_zaehlen.Bewegungsmelder.Haus.01_Anzeigen_und_Listen.11_Table_JSON",
    		"header": "Bewegungsmelder",
    		"sortAsc": true,
    		"initalSortColumn": 1,
    		"initialSortEnabled": false,
    		"elementsPerPage": 10,
    		"columns": {
    			"name": "Name",
    			"zustand": "Zustand"
    		},
    		"customPopupmenu": null
    	}
    ]
    

    Ohne die Attribute zu ändern habe ich einfach das Object neu zusammengesetzt mit diesem Resultat:
    Aus:

    [
                {
                    id: "-n7qvTNg4XoiPuQgD2zY3ibaDw-1jw==",
                    name: "Bewegungsmelder",
                    widget: {
                        type: "CustomWidgetTypeDeprecated.table",
                        name: "Bewegungsmelder",
                        header: "Bewegungsmelder",
                        sortAsc: true,
                        initialSortColumn: 1,
                        initialSortEnabled: false,
                        elementsPerPage: 10,
                        dataPoint: "0_userdata.0.Geraete_zaehlen.Bewegungsmelder.Haus.01_Anzeigen_und_Listen.11_Table_JSON",
                        columns: { name: "Name", zustand: "Zustand" },
                    },
                },
                {
                    id: "kekWHmqyCjw6Z1CY4el0m6jz3Q3Djw==",
                    name: "Fenster",
                    widget: {
                        type: "CustomWidgetTypeDeprecated.table",
                        name: "Fenster",
                        header: "Fenster",
                        sortAsc: true,
                        initialSortColumn: 1,
                        initialSortEnabled: false,
                        elementsPerPage: 11,
                        dataPoint: "0_userdata.0.Geraete_zaehlen.Fenster.Haus.01_Anzeigen_und_Listen.14_Table_JSON",
                        columns: { name: "Name", zustand: "Zustand" },
                    },
                },
            ]
    

    Wird:

    [
      {
        id: '-n7qvTNg4XoiPuQgD2zY3ibaDw-1jw==',
        name: 'Bewegungsmelder',
        widget: {
          type: 'CustomWidgetTypeDeprecated.table',
          name: 'Bewegungsmelder',
          header: 'Bewegungsmelder',
          sortAsc: true,
          initialSortColumn: 1,
          initialSortEnabled: false,
          elementsPerPage: 10,
          dataPoint: '0_userdata.0.Geraete_zaehlen.Bewegungsmelder.Haus.01_Anzeigen_und_Listen.11_Table_JSON',
          columns: [Object]
        }
      },
      {
        id: 'kekWHmqyCjw6Z1CY4el0m6jz3Q3Djw==',
        name: 'Fenster',
        widget: {
          type: 'CustomWidgetTypeDeprecated.table',
          name: 'Fenster',
          header: 'Fenster',
          sortAsc: true,
          initialSortColumn: 1,
          initialSortEnabled: false,
          elementsPerPage: 11,
          dataPoint: '0_userdata.0.Geraete_zaehlen.Fenster.Haus.01_Anzeigen_und_Listen.14_Table_JSON',
          columns: [Object]
        }
      }
    ]
    

    Wie zu sehen ist bekommt columns ein object....
    Bin der Meinung das wurde schon mal besprochen....finde aber den Beitrag nicht mehr...

    Hier das Blockly:
    Screenshot 2024-09-21 135608.png

    Und die Funktion:

    if (json && json.widget && json.widget.type === "CustomWidgetTypeDeprecated.table") {
        // Result object
        console.info(typeof json.widget);
        // Result object
        console.info(typeof json.widget.columns);
        //new_widget = new_widget.concat([json]);
        new_widget.push(json);
    } else {
        new_widget.push(json);
    }
    

    Gab es dazu bereits eine Lösung? Wahrscheinlich sehe ich gerade den Wald vor lauter Bäume nicht 😀

    Gruß//Lucky

    1 Antwort Letzte Antwort
    0

    Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

    Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

    Mit deinem Input könnte dieser Beitrag noch besser werden 💗

    Registrieren Anmelden
    Antworten
    • In einem neuen Thema antworten
    Anmelden zum Antworten
    • Älteste zuerst
    • Neuste zuerst
    • Meiste Stimmen


    Support us

    ioBroker
    Community Adapters
    Donate
    FAQ Cloud / IOT
    HowTo: Node.js-Update
    HowTo: Backup/Restore
    Downloads
    BLOG

    517

    Online

    32.7k

    Benutzer

    82.6k

    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