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. ioBroker Allgemein
  4. Wunsch: Erzeugen von js-Objekten im Reiter "Objekte"

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

Wunsch: Erzeugen von js-Objekten im Reiter "Objekte"

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
15 Beiträge 3 Kommentatoren 3.7k Aufrufe
  • Ä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.
  • BluefoxB Offline
    BluefoxB Offline
    Bluefox
    schrieb am zuletzt editiert von
    #2

    Ich habe nichts dagegen. Kannst du mir einen Use-Case nennen?

    1 Antwort Letzte Antwort
    0
    • paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von
      #3

      Es wäre übersichtlicher und man würde sehen, welche Attribute möglich sind, ohne die Doku neben sich liegen zu haben. Auch die Eingabe der common-Attribute vereinfacht sich. Die Eingabemaske hast Du ja bereits vorbereitet.

      Außerdem kommt der Nutzer mit der vorgegebenen Maske nicht so leicht auf die Idee, nicht (in ioBroker) standardisierte Attribute zu erstellen, worauf man anhand der Dokumentation durchaus kommen kann: "'values' : 'stop,play,pause,next,previous,mute,unmute',"

      Das Erstellen von Objektstrukturen in createState() ist für Unerfahrene in Javascript nicht so einfach. Ich fange auch gerade erst an, mich in Javascript einzuarbeiten.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      1 Antwort Letzte Antwort
      0
      • paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #4

        Als Zwischenlösung stelle ich die folgenden 5 Funktionen in einem globalen Script zur Verfügung:

        • createCheckbox(name) - für boolsche Werte ohne Zustandstexte

        • createSwitch(name) - für boolsche Werte mit Zustandstexten (Ein/Aus, Ja/Nein, Sommer/Winter, …)

        • createMultistate(name) - für Multistate-Werte (Werteliste, z.B. Auto;Manu;Boost)

        • createLevel(name) - für Analogwerte

        • createString(name) - für Zeichenketten

        Die Attribute der so erstellten Objekte kann man dann in der Eingabemaske "allgemein" bequem editieren.

        // Datenpunkte mit Voreinstellungen erzeugen (createState)
        
        function createCheckbox(name) {
            createState(name, false, {read: true, 
                                      write: true, 
                                      desc: "Beschreibung", 
                                      type: "boolean", 
                                      def: false
            });
        }
        
        function createSwitch(name) {
            createState(name, 0, {read: true, 
                                  write: true, 
                                  desc: "Beschreibung", 
                                  type: "number", 
                                  def: 0, 
                                  states: "0:Aus; 1:Ein"
            });
        }
        
        function createMultistate(name) {
            createState(name, 0, {read: true, 
                                  write: true, 
                                  desc: "Beschreibung", 
                                  type: "number", 
                                  min: 0, 
                                  max: 2, 
                                  def: 0, 
                                  states: "0:Wert0; 1:Wert1; 2:Wert2"
            });
        }
        
        function createLevel(name) {
            createState(name, 0, {read: true,
                                  write: true, 
                                  desc: "Beschreibung", 
                                  type: "number", 
                                  min: -30, 
                                  max: 70, 
                                  def: 0,
                                  unit: "°C"
            });
        }
        
        function createString(name) {
            createState(name, "", {read: true, 
                                   write: true, 
                                   desc: "Beschreibung", 
                                   type: "string", 
                                   def: ""
            });
        }
        
        

        type des Switch-Datenpunktes sollte eigentlich "boolean" sein. Dazu müsste allerdings Bluefox die Datei "adminStates.js" in (vor) Zeile 90 um eine zusätzliche Abfrage erweitern:

        if (
             main.objects[_id] &&
             main.objects[_id].common && 
             main.objects[_id].common.type == 'boolean' &&
             main.objects[_id].common.states) {
             that.$grid.setColProp('val', {
                       editable: true,
                       edittype: 'select',
                       editoptions: {value: main.objects[_id].common.states},
                       align: 'center'
              });
        } else if (
        
        

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        1 Antwort Letzte Antwort
        0
        • BluefoxB Offline
          BluefoxB Offline
          Bluefox
          schrieb am zuletzt editiert von
          #5

          @paul53:

          type des Switch-Datenpunktes sollte eigentlich "boolean" sein. Dazu müsste allerdings Bluefox die Datei "adminStates.js" in (vor) Zeile 90 um eine zusätzliche Abfrage erweitern:

          if (
               main.objects[_id] &&
               main.objects[_id].common && 
               main.objects[_id].common.type == 'boolean' &&
               main.objects[_id].common.states) {
               that.$grid.setColProp('val', {
                         editable: true,
                         edittype: 'select',
                         editoptions: {value: main.objects[_id].common.states},
                         align: 'center'
                });
          } else if (
          
          ```` `  
          

          Danke für den Kode habe ich erstmals eingebaut. (In der nächsten Version)

          Aber, dann sollte switch so aussehen:

          function createSwitch(name) {
              createState(name, 0, {read: true, 
                                    write: true, 
                                    desc: "Beschreibung", 
                                    type: "boolean", 
                                    def: 0, 
                                    states: "true:Aus; false:Ein"
              });
          }
          

          Weil "boolean" versteht sich true/false. Mindestens andere Adapter erwarten das.

          1 Antwort Letzte Antwort
          0
          • paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #6

            @Bluefox:

            Aber, dann sollte switch so aussehen:

            … `
            Ja, wenn die neue Version verfügbar ist. Und mit

                 def: false,
                 states: "false:Aus; true:Ein"
            

            Oder ??

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            1 Antwort Letzte Antwort
            0
            • BluefoxB Offline
              BluefoxB Offline
              Bluefox
              schrieb am zuletzt editiert von
              #7

              @paul53:

              @Bluefox:

              Aber, dann sollte switch so aussehen:

              … `
              Ja, wenn die neue Version verfügbar ist. Und mit

                   def: false,
                   states: "false:Aus; true:Ein"
              

              Oder ?? `
              Ja genau. :)

              1 Antwort Letzte Antwort
              0
              • paul53P Offline
                paul53P Offline
                paul53
                schrieb am zuletzt editiert von
                #8

                @Bluefox:

                Danke für den Kode habe ich erstmals eingebaut. (In der nächsten Version) `
                Es ist Dein Code. Habe ihn nur kopiert und modifiziert.

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                1 Antwort Letzte Antwort
                0
                • paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von
                  #9

                  Die Datei "adminStates.js" habe ich mir schon mal von GitHub geladen und erfolgreich getestet.

                  Werde unter "iobroker Skripten" einen neuen Beitrag mit dem korrigierten Script erstellen.

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  1 Antwort Letzte Antwort
                  0
                  • paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von
                    #10

                    Hi Bluefox,

                    habe gesehen, daß Du den Tab "Objekte" um die Funktion "Add new object" erweitert hast.

                    Diese Art der Erzeugung von Objekten durch den Anwender halte ich nicht für sinnvoll, zumal nicht ausgewählt werden kann, zu welcher Instanz das Objekt zugefügt werden kann. Es entsteht ein übergeordnetes (globales) Objekt. Eine Zuordnung als Objekt zu einer bestehenden Instanz halte ich für notwendig.

                    Noch besser wäre das "+" (Add new object) ganz rechts bei Instanzen, bei denen eine Erzeugung neuer Objekte durch den Anwender auch Sinn macht (z.B. javascript.N).

                    EDIT zur Übersetzung:

                    "State type": "de": "Datenpunkttyp"

                    "boolean": "de": "Logikwert"

                    "string": "de": "Zeichenkette"

                    "number": "de": "Zahl"

                    "enum": "de": "Aufzählung "

                    "array": "de": "Feld"

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    1 Antwort Letzte Antwort
                    0
                    • BluefoxB Offline
                      BluefoxB Offline
                      Bluefox
                      schrieb am zuletzt editiert von
                      #11

                      Du kannst erst Objekt anklicken, dann wird es als Kind von diesem Objekt erzeugt.

                      Leider der Knopf ganz hinten ist schwer realisierbar.

                      Was ich machen kann, das ist Knopf deaktivieren, solange es kein Parent ausgewählt ist und dann Id nur begrenzt editieren lassen.

                      1 Antwort Letzte Antwort
                      0
                      • paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von
                        #12

                        @Bluefox:

                        Du kannst erst Objekt anklicken, dann wird es als Kind von diesem Objekt erzeugt. `
                        Das ist Ok. Danke :D

                        Es sollte allerdings irgendwo erwähnt werden, oder Du änderst den "+"-Text von "Add new object" in "Add new child object to selected parent".

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        1 Antwort Letzte Antwort
                        0
                        • paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von
                          #13

                          Hi Bluefox,

                          habe getestet und festgestellt, dass jetzt die Selektoren für Multistate-Werte im Tab "Zustände" nicht mehr funktionieren: Mache ich einen Doppelklick auf einen Multistate-Wert, wird nicht mehr ein Selektor, sondern ein Eingabefeld angeboten. Anschließend ist das Attribut

                          "type": "number" im Objekt verschwunden:
                          ` > {

                          "common": {

                          "name": "Bad.Lüfter",

                          "desc": "Multistate: 3-Stufen-Lüfter",

                          "def": "Aus",

                          "states": "0:Aus; 1:Stufe-1; 2:Stufe-2; 3:Stufe-3",

                          "role": "javascript",

                          "min": 0,

                          "max": 3,

                          "read": true,

                          "write": true

                          }, `
                          Bei den "boolean" Datenpunkten mit Zustandstexten funktioniert der Selektor.

                          EDIT: Das Verschwinden von common.type ist beseitigt, nachdem ich den common.type-Selektor der Tabs "common" und "native" durch eine Text-Eingabemaske ersetzt habe. Außerdem habe ich common.type "enum" durch "number" ersetzt (siehe nächster Beitrag).

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          1 Antwort Letzte Antwort
                          0
                          • paul53P Offline
                            paul53P Offline
                            paul53
                            schrieb am zuletzt editiert von
                            #14

                            Habe mir mal die Änderungen in "adminObjects.js" angesehen, und festgestellt dass als state type auch "enum" verwendet wird.

                            Mit einer Erweiterung um den boolean Datenpunkt mit Zustandstexten (switch, de: Schalter) sollte es ab Zeile 157 etwa so aussehen:

                                                        if (stype == 'boolean') {
                                                           obj.common.def = false;
                                                        } else if (stype == 'switch') {
                                                           obj.common.type = 'boolean';
                                                           obj.common.def = false;
                                                           obj.common.states = 'false:no;true:yes';
                                                        } else if (stype == 'string') {
                                                            obj.common.def = '';
                                                        } else if (stype == 'number') {
                                                            obj.common.min = 0;
                                                            obj.common.max = 100;
                                                            obj.common.def = 0;
                                                            obj.common.unit = '%';
                                                        } else if (stype == 'multistate') {
                                                            obj.common.type = 'number';
                                                            obj.common.min = 0;
                                                            obj.common.max = 5;
                                                            obj.common.def = 0;
                                                            obj.common.states = '0:zero;1:one;2:two;3:three;4:four;5:five';
                                                        }
                            
                            

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            1 Antwort Letzte Antwort
                            0
                            • V Offline
                              V Offline
                              versteckt
                              schrieb am zuletzt editiert von
                              #15

                              Ich kann doch auch gleich eine Baumstruktur anlegen, indem ich den Namen mit Punkten trenne, z.B. zwave.0.NODE1.MeinParent.MeinState

                              Gesendet von meinem iPhone mit Tapatalk

                              Raspi 1, Raspi 2, iobroker, Mac Mini: alles mit aktueller ioBroker Version

                              homegear für Homematic und MAX!

                              occ, zWave, rpi, hmm und homekit Entwickler

                              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
                              FAQ Cloud / IOT
                              HowTo: Node.js-Update
                              HowTo: Backup/Restore
                              Downloads
                              BLOG

                              642

                              Online

                              32.7k

                              Benutzer

                              82.4k

                              Themen

                              1.3m

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

                              • Du hast noch kein Konto? Registrieren

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