Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Vorlage] Alias per Skript erzeugen

    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

    [Vorlage] Alias per Skript erzeugen

    This topic has been deleted. Only users with topic management privileges can see it.
    • dslraser
      dslraser Forum Testing Most Active @CruziX last edited by

      @CruziX sagte in [Vorlage] Alias per Skript erzeugen:

      @dslraser Mir ist gerade noch ein Fehler aufgefallen, welcher dafür die Ursache sein könnte.
      Hab auch den Githublink eingefügt

      geht nun. Alles da wie es soll.

      javascript.0	2020-02-17 21:36:11.478	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_JS_anlegen: Adding alias.0.Test.Steckdosen.Waschmaschine to enum.functions.Testfunktion
      javascript.0	2020-02-17 21:36:11.478	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_JS_anlegen: Adding alias.0.Test.Steckdosen.Waschmaschine to enum.rooms.Testraum
      javascript.0	2020-02-17 21:36:09.477	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_JS_anlegen: registered 0 subscriptions and 0 schedules
      
      C 2 Replies Last reply Reply Quote 1
      • C
        CruziX @dslraser last edited by

        @dslraser ich werde morgen noch ein paar Kleinigkeiten einbauen.
        Schonmal jetzt vielen Dank für deine Hilfe beim Testen 👍

        1 Reply Last reply Reply Quote 1
        • C
          CruziX @dslraser last edited by CruziX

          @dslraser
          Hab ein paar Aktualisierungen hochgeladen.
          Jetzt wird da wo es mir vergleichsweise möglich war mit callback functions gearbeitet, also sicherer bei asynchronen Funktionen wie setObject und ich habe eine Funktion hinzugefügt, welche nicht mehr vorhandene IDs aus allen Räumen und Funktionen löscht.
          Das Schöne, die Säuberungsfunktion für Räume und Funktionen kann eigenständig verwendet werden 🙂

          Mensch, ich lern hierbei noch einiges über JavaScript, vorher noch nie callbacks verwendet 😅

          Achja, zum Säubern gibts nun das neue Flag bCleanEnums

          paul53 1 Reply Last reply Reply Quote 1
          • C
            CruziX last edited by CruziX

            Gerade nochmal eine Korrektur hochgeladen, die Funktionen wurden nicht korrekt gesäubert.

            https://github.com/xCruziX/ioBroker-Creating-Alias

            dslraser 2 Replies Last reply Reply Quote 0
            • dslraser
              dslraser Forum Testing Most Active @CruziX last edited by

              @CruziX
              jetzt wollte ich gerade schreiben, das es bei mir funktioniert, bis auf eine doppelte LOG Ausgabe...
              Dann lade ich nochmal die neue Version. Das löschen der nicht mehr vorhandenen hat aber funktioniert.

              18.2.2020, 23:11:56.210	[info ]: javascript.0 (4842) Stop script script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu
              18.2.2020, 23:11:56.302	[info ]: javascript.0 (4842) Start javascript script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu
              18.2.2020, 23:11:56.306	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: registered 0 subscriptions and 0 schedules
              18.2.2020, 23:11:56.326	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-Path Test.Steckdosen.Waschmaschine
              18.2.2020, 23:11:56.328	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-Path Test.Steckdosen.Waschmaschine
              18.2.2020, 23:11:56.529	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Cleaned enum enum.rooms.Testraum
              18.2.2020, 23:11:56.630	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Set members of enum.rooms.Testraum
              
              C 1 Reply Last reply Reply Quote 1
              • dslraser
                dslraser Forum Testing Most Active @CruziX last edited by

                @CruziX

                Version 1.1.1

                Was macht das Script in meiner Aufzählung/Funktion Bewegungsmelder ? (war da auch eine Leiche drinn ?)

                javascript.0	2020-02-18 23:17:22.813	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Set members of enum.functions.Bewegungsmelder
                javascript.0	2020-02-18 23:17:22.807	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Set members of enum.rooms.Testraum
                javascript.0	2020-02-18 23:17:22.705	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Cleaned enum enum.functions.Bewegungsmelder
                javascript.0	2020-02-18 23:17:22.704	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Cleaned enum enum.rooms.Testraum
                javascript.0	2020-02-18 23:17:22.502	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-Path Test.Steckdosen.Waschmaschine
                javascript.0	2020-02-18 23:17:22.497	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-Path Test.Steckdosen.Waschmaschine
                javascript.0	2020-02-18 23:17:22.478	info	(4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: registered 0 subscriptions and 0 schedules
                
                1 Reply Last reply Reply Quote 0
                • C
                  CruziX @dslraser last edited by

                  @dslraser Danke für die Info, die doppelte Meldung sollte nun weg sein

                  dslraser 1 Reply Last reply Reply Quote 0
                  • dslraser
                    dslraser Forum Testing Most Active @CruziX last edited by dslraser

                    @CruziX sagte in [Vorlage] Alias per Skript erzeugen:

                    @dslraser Danke für die Info, die doppelte Meldung sollte nun weg sein

                    ähm, nö..

                    C 1 Reply Last reply Reply Quote 0
                    • C
                      CruziX @dslraser last edited by

                      @dslraser sagte in [Vorlage] Alias per Skript erzeugen:

                      @CruziX sagte in [Vorlage] Alias per Skript erzeugen:

                      @dslraser Danke für die Info, die doppelte Meldung sollte nun weg sein

                      ähm, nö..

                      sicher? gerade erst hochgeladen ^^

                      dslraser 2 Replies Last reply Reply Quote 0
                      • dslraser
                        dslraser Forum Testing Most Active @CruziX last edited by

                        @CruziX

                        ah, 1.1.2...

                        Aber was macht er nun bei Bewegungsmelder, das habe ich nirgends im Script angegeben ?

                        C 1 Reply Last reply Reply Quote 0
                        • dslraser
                          dslraser Forum Testing Most Active @CruziX last edited by dslraser

                          @CruziX
                          1.1.2.

                          Logausgabe

                          18.2.2020, 23:27:51.578	[info ]: javascript.0 (4842) Stop script script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu
                          18.2.2020, 23:27:51.627	[info ]: javascript.0 (4842) Start javascript script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu
                          18.2.2020, 23:27:51.633	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-State alias.0.Test.Steckdosen.Waschmaschine
                          18.2.2020, 23:27:51.634	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: registered 0 subscriptions and 0 schedules
                          18.2.2020, 23:27:51.671	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-Path alias.0.Test.Steckdosen
                          18.2.2020, 23:27:51.673	[info ]: javascript.0 (4842) script.js.14_Eigene_DP_Vorlagen.Alias_erzeugen-neu: Created Alias-Path alias.0.Test.Steckdosen
                          

                          da ist das log zu viel gekürzt, oder ?

                          1 Reply Last reply Reply Quote 0
                          • C
                            CruziX @dslraser last edited by

                            @dslraser
                            Jep, das änder ich noch. Im Prinzip speichert er alle IDs ab die in der Aufzählung bleiben und setzt diese erneut, ich ändern das noch, dass nur die, wo wirklich Änderungen sind gespeichert werden

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

                              @CruziX sagte:

                              habe eine Funktion hinzugefügt, welche nicht mehr vorhandene IDs aus allen Räumen und Funktionen löscht.
                              Das Schöne, die Säuberungsfunktion für Räume und Funktionen kann eigenständig verwendet werden

                              Was hat diese Funktion mit "Alias erzeugen" zu tun ? Das Säubern sollte in einem extra Script erfolgen, damit die Funktion eigenständig verwendet wird.

                              C 1 Reply Last reply Reply Quote 0
                              • C
                                CruziX @paul53 last edited by

                                @paul53 Das war ein Wunsch von @dslraser .
                                Die Funktion kann auch eigenständig verwendet werden, und das Flag ist standardmäßig auf false

                                dslraser 1 Reply Last reply Reply Quote 0
                                • dslraser
                                  dslraser Forum Testing Most Active @CruziX last edited by dslraser

                                  @CruziX sagte in [Vorlage] Alias per Skript erzeugen:

                                  @paul53 Das war ein Wunsch von @dslraser .

                                  Na ja, nicht ganz, das war nur eine Feststellung von mir...

                                  Screenshot_20200218-235436_Chrome.jpg

                                  Grundsätzlich hat @paul53 schon recht, das könnte ja tatsächlich ein extra Script sein/werden. Aber ich bin bloß ein Anwender, müsst Ihr entscheiden.

                                  C 1 Reply Last reply Reply Quote 0
                                  • C
                                    CruziX @dslraser last edited by CruziX

                                    @dslraser also das kann man durchaus machen, ich habe da nichts gegen, als eigenes Skript.

                                    Leider hab ich es heute Abend nicht geschafft die Funktion so umzubauen, dass nur die geänderten geschrieben werden, sicherlich hab ich zu kompliziert gedacht und in meiner lokalen Version werden nun nicht mehr alle korrekt gelöscht 😅

                                    Aber an sich, bin ich schon ganz zufrieden mit dem, was bisher schon klappt 🙂

                                    Edit:
                                    Hab auch nichts dagegen, wenn sich jemand anderes dem Säuberungsskript annimmt. Muss mal schauen ob ich das als Anfänger ganz hin bekomme 😛

                                    dslraser 1 Reply Last reply Reply Quote 0
                                    • dslraser
                                      dslraser Forum Testing Most Active @CruziX last edited by

                                      @CruziX sagte in [Vorlage] Alias per Skript erzeugen:

                                      also das kann man durchaus machen, ich habe da nichts gegen, als eigenes Skript.

                                      Ich denk auch das ist besser und einfacher

                                      Leider hab ich es heute Abend nicht
                                      Aber an sich, bin ich schon ganz zufrieden mit dem, was bisher schon klappt

                                      Ja, kein Ding. Für mich ist heute auch Schluß.

                                      1 Reply Last reply Reply Quote 1
                                      • C
                                        CruziX last edited by

                                        Hab die Funktion für die Säuberung nun entfernt, kann man dann getrennt erstellen. 🙂

                                        1 Reply Last reply Reply Quote 0
                                        • C
                                          CruziX last edited by

                                          Zur Vollständigkeit, ein Skript für die Säuberung von Aufzählungen ist nun vorhanden.
                                          https://forum.iobroker.net/topic/30551/aufzählungen-säubern

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

                                            Danke für deine Skripts @paul53.

                                            Habe eine Frage: Wie bekomme ich die unit auf ""? Wenn ich unit = "" oder unit = null mache, nimmt er immer die Einheit von dem Quellobjekt.

                                            Einige Geräte haben kein DP BatteryLow, deshalb habe ich etwas mit dem DP BatteryLevel gebastelt.

                                            Gruß Nico

                                            function createAliasBatLow(idDst, naAlia, idSrc, idRd) {
                                              var typeAlias = 'boolean';
                                              var states = {false: 'Off', true: 'On'};
                                              var read = "val < 10 ? true : false";
                                              var unit = ""
                                            
                                              if(existsState(idDst)) log(idDst + ' schon vorhanden !', 'warn');
                                              else {
                                                var obj = {};
                                                obj.type = 'state';
                                                obj.common = getObject(idSrc).common;
                                                obj.common.alias = {};
                                                if(idRd) {
                                                    obj.common.alias.id = {};
                                                    obj.common.alias.id.read = idRd;
                                                    obj.common.alias.id.write = idSrc;
                                                    obj.common.read = true;
                                                } else obj.common.alias.id = idSrc;
                                                if(typeAlias) obj.common.type = typeAlias;
                                                if(obj.common.read !== false && read) obj.common.alias.read = read;
                                                if(obj.common.write !== false && write) obj.common.alias.write = write;
                                                if(naAlia) obj.common.name = naAlia;
                                                if(role) obj.common.role = role;
                                                if(desc) obj.common.desc = desc;
                                                if(min !== undefined) obj.common.min = min;
                                                if(max !== undefined) obj.common.max = max;
                                                if(unit) obj.common.unit = unit;
                                                if(states) obj.common.states = states;
                                                if(custom && obj.common.custom) obj.common.custom = custom;
                                                obj.native = {};
                                                setObject(idDst, obj);
                                                if(raum && getObject('enum.rooms.' + raum)) {
                                                   let obj = getObject('enum.rooms.' + raum)
                                                   obj.common.members.push(idDst);
                                                   setObject('enum.rooms.' + raum, obj);
                                                }
                                                if(gewerk && getObject('enum.functions.' + gewerk)) {
                                                   let obj = getObject('enum.functions.' + gewerk)
                                                   obj.common.members.push(idDst);
                                                   setObject('enum.functions.' + gewerk, obj);
                                                }
                                              }
                                            }
                                            
                                            unit = "";
                                            

                                            ODER

                                            unit = null;
                                            

                                            anstelle von

                                            if(unit) obj.common.unit = unit;
                                            

                                            habe ich auch probiert.

                                            unit = "_";
                                            

                                            funktioniert

                                            DANKE

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            934
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            38
                                            314
                                            48733
                                            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