Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Wunsch: Erzeugen von js-Objekten im Reiter "Objekte"

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

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

    This topic has been deleted. Only users with topic management privileges can see it.
    • Bluefox
      Bluefox last edited by

      @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 Reply Last reply Reply Quote 0
      • paul53
        paul53 last edited by

        @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 ??

        1 Reply Last reply Reply Quote 0
        • Bluefox
          Bluefox last edited by

          @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 Reply Last reply Reply Quote 0
          • paul53
            paul53 last edited by

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

            1 Reply Last reply Reply Quote 0
            • paul53
              paul53 last edited by

              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.

              1 Reply Last reply Reply Quote 0
              • paul53
                paul53 last edited by

                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"

                1 Reply Last reply Reply Quote 0
                • Bluefox
                  Bluefox last edited by

                  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 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 last edited by

                    @Bluefox:

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

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

                    1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 last edited by

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

                      1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 last edited by

                        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';
                                                    }
                        
                        
                        1 Reply Last reply Reply Quote 0
                        • V
                          versteckt last edited by

                          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

                          1 Reply Last reply Reply Quote 0
                          • First post
                            Last post

                          Support us

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

                          942
                          Online

                          31.9k
                          Users

                          80.2k
                          Topics

                          1.3m
                          Posts

                          3
                          15
                          3472
                          Loading More Posts
                          • Oldest to Newest
                          • Newest to Oldest
                          • Most Votes
                          Reply
                          • Reply as topic
                          Log in to reply
                          Community
                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                          The ioBroker Community 2014-2023
                          logo