Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Entwicklung
    4. Admin3 Migration von Konfigurationsdateien

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    Admin3 Migration von Konfigurationsdateien

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

      @foxthefox:

      Hab keine Idee mehr, was hier die Anzeige in materialize verhindert. `
      Hast du den Eintrag in die io-package.json hinzugefügt? Adapter-Upload durchgeführt? Klasse auf dem Container-Div angepasst?

      1 Reply Last reply Reply Quote 0
      • F
        foxthefox Developer last edited by

        @AlCalzone:

        @foxthefox:

        Hab keine Idee mehr, was hier die Anzeige in materialize verhindert. Hast du den Eintrag in die io-package.json hinzugefügt? Adapter-Upload durchgeführt? Klasse auf dem Container-Div angepasst?

        Yepp.

        Habe materialize true in io-Package.json, nach jeder html Änderungen hab ich Upload gemacht, und div heißt "m adapter-container".

        Hab auch nochmals den Adapter installiert.

        GELÖST 😄

        =>

        hab id nicht in class umbenannt

        1 Reply Last reply Reply Quote 0
        • blauholsten
          blauholsten Developer last edited by

          Hi,

          so habe meine problemchen soweit beseitigt.

          @Darnat….Danke nochmal für den Tip mit dem enOcean Adapter

          Eine Laien Frage hätte ich aber noch. Wenn ich die selects dynamisch befüllen lasse, wird die translate class irgendwie nicht bearbeitet.

          Ich möchte jedoch die Optionen wie im Template-Adapter übersetzen lassen.

          (Auszug template)

          
                      <select class="value" id="mySelect"><option value="auto" class="translate">Auto</option>
                          <option value="manual" class="translate">Manual</option></select> 
                      <label for="mySelect" class="translate">My select</label>
          
          

          Kann mir jemand erklären wann auf diese Klasse reagiert wird? Sorry für die vielleicht einfache Frage.

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

            @blauholsten:

            Hi,

            so habe meine problemchen soweit beseitigt.

            @Darnat….Danke nochmal für den Tip mit dem enOcean Adapter

            Eine Laien Frage hätte ich aber noch. Wenn ich die selects dynamisch befüllen lasse, wird die translate class irgendwie nicht bearbeitet.

            Ich möchte jedoch die Optionen wie im Template-Adapter übersetzen lassen.

            (Auszug template)

            
                    
                        <select class="value" id="mySelect"><option value="auto" class="translate">Auto</option>
                            <option value="manual" class="translate">Manual</option></select> 
                        <label for="mySelect" class="translate">My select</label>
                        
                    
                
            

            Kann mir jemand erklären wann auf diese Klasse reagiert wird? Sorry für die vielleicht einfache Frage. `
            Die Texte musst du schon übersetzt einfügen.

            var options = '<option value="auto">' + _('Auto') + '</option>' + 
                         '<option value="manual">' + _('Manual') + '</option>';
            
            $('#mySelect')
            	.html(options) // add translated options
            	.select();        // reinit materialize select
            
            
            1 Reply Last reply Reply Quote 0
            • blauholsten
              blauholsten Developer last edited by

              @Bluefox:

              Die Texte musst du schon übersetzt einfügen. `
              Verstehe ich das richtig, das mit der translate class funktioniert nicht? Ich brauche also die Übersetzungen alle in der index_m?

              @Bluefox:

              var options = '<option value="auto">' + _('Auto') + '</option>' + 
                           '<option value="manual">' + _('Manual') + '</option>';
                     
              
              ```` `  
              

              Ist zwar etwas offtopic, aber kann mir jemand````
              _('xxx')

              
              Was passiert in diesem Bsp. genau? :oops: :oops: :oops:
              1 Reply Last reply Reply Quote 0
              • carsten04
                carsten04 Developer last edited by

                @blauholsten:

                @Bluefox:

                Die Texte musst du schon übersetzt einfügen. `
                Verstehe ich das richtig, das mit der translate class funktioniert nicht? Ich brauche also die Übersetzungen alle in der index_m?

                @Bluefox:

                var options = '<option value="auto">' + _('Auto') + '</option>' + 
                             '<option value="manual">' + _('Manual') + '</option>';
                       
                
                ```` `  
                

                Ist zwar etwas offtopic, aber kann mir jemand````
                _('xxx')

                
                Was passiert in diesem Bsp. genau? :oops: :oops: :oops: `  
                

                Das ist eine einfache javascript-Fkt. aus translate.js und übersetzt je nach Spracheinstellung aus dem Dictionary.

                1 Reply Last reply Reply Quote 0
                • blauholsten
                  blauholsten Developer last edited by

                  @carsten04:

                  Das ist eine einfache javascript-Fkt. aus translate.js und übersetzt je nach Spracheinstellung aus dem Dictionary. `
                  Danke, das erklärt einiges. 😐

                  Mir war nicht klar was die Funktion tut.

                  Werde morgen probieren…

                  EDIT....

                  Danke @all, das mit der Funktion geht es wunderbar

                  1 Reply Last reply Reply Quote 0
                  • P
                    PrinzEisenherz1 last edited by

                    EDIT: Hat sich erledigt. Hab den Fehler gefunden

                    Hi zusammen!

                    Hab n Problem wo ich jetzt schon mehrere Stunden dransitze und den Fehler nicht finde!

                    Und zwar möchte ich vom OPi-Adapter noch die index_m.html für Admin3 erstellen und da klappt das mit den checkboxen nicht.
                    1058_screenshot_20180126_232545.png
                    Wenn ich die betätigen möchte dann passiert da gar nichts. Also ich kann da hinklicken und da verändert sich nicht. Wenn ich aber unter Admin 2.0.9 die Einstellungen ändere dann sind sie auch im Admin 3 geändert.

                    hier mal der Ausschnitt aus meine index_m.html

                    
                              ![](opi.png)
                    
                    ##### OPI-Monitor Adapter settings
                    
                            CPU
                    
                              ###### Memory 
                    
                              Network
                    
                              eMMC
                    
                              Swap
                    
                              Temperature
                    
                              Uptime
                    
                              WLAN
                    
                    

                    Wäre super wenn mir da jemand helfen könnte.

                    Gruß

                    Johnny

                    1 Reply Last reply Reply Quote 0
                    • blauholsten
                      blauholsten Developer last edited by

                      @PrinzEisenherz1:

                      Wäre super wenn mir da jemand helfen könnte.

                      Gruß

                      Johnny `
                      Kann nur vermuten, ist nicht wirklich wissen….

                      Aber probier mal alle Checkboxen in ein form div zu packen. Des Weiteren solltest du Labels nutzen

                      http://materializecss.com/forms.html

                      EDIT…was sagt die console

                      1 Reply Last reply Reply Quote 0
                      • P
                        PrinzEisenherz1 last edited by

                        Das hatte ich schon probiert, aber hat leider auch nicht geklappt

                        EDIT:

                        Hat sich erledigt. Hab den Fehler gefunden. Lag nicht an der div-Aufteilung sondern einem Fehler im vorherigen Code.

                        Johnny

                        1 Reply Last reply Reply Quote 0
                        • P
                          Pman last edited by

                          Wenn die Adapter-Einstellungen keine Tabs haben kommt es zu einem CSS-Fehler, da dann jede "row" 100% hoch ist.

                          Was ist hier die richtige Lösung? Immer einen Dummy-Tab erstellen oder kann man das css auf diese Situation anpassen?

                          @bluefox bitte mal beim mqtt-client checken, da tritt das Problem auf.

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

                            @Pman:

                            Wenn die Adapter-Einstellungen keine Tabs haben kommt es zu einem CSS-Fehler, da dann jede "row" 100% hoch ist.

                            Was ist hier die richtige Lösung? Immer einen Dummy-Tab erstellen oder kann man das css auf diese Situation anpassen?

                            @bluefox bitte mal beim mqtt-client checken, da tritt das Problem auf. `

                             `![](mqtt-client.png)
                            
                                                note
                            
                            ###### Server settings
                            
                                                <label for="host" class="translate">host</label>
                            
                                                <label for="port" class="translate">port</label>
                            
                                                <label for="clientId">Client ID must be unique</label>
                            
                                                ssl
                            
                                                <label for="username" class="translate">username</label>
                            
                                                <label for="password" class="translate">password</label>
                            
                                                <label for="onConnectTopic" class="translate">on connect topic</label>
                            
                                                <label for="onConnectMessage" class="translate">on connect message</label>
                            
                                                <label for="lastWillTopic" class="translate">last will topic</label>
                            
                                                <label for="lastWillMessage" class="translate">last will message</label>
                            
                                                <label for="subscriptions" class="translate">additional subscriptions</label>
                            
                                                <label for="outbox" class="translate">prefix for publishing topics</label>
                            
                                                <label for="inbox" class="translate">prefix for subscribing topics</label>` 
                            Noch ein  drüber "wrapen".[/i][/i][/i]
                            
                            1 Reply Last reply Reply Quote 0
                            • F
                              foxthefox Developer last edited by

                              Ich versuche mich schon seit längerem an dem Update für adminv3 und hab die Tabelle ähnlich der in diesem thread aufgebauten Struktur erzeugt.

                              Das von adminv2 bekannte table2values erzeugt auch sauber die zu speichernden Einträge.

                              Ich habe lediglich noch ein Problem die Funktion onChange() aufzurufen, sobald ich diese in einer eigenen Funktion zu verwenden, bekomme ich ein Referenzierungsfehler. Die Funktion onChange() sheint irgendwie nur in der function load bekannt zu sein.

                              Was kann ich machen, damit ich onChange() auch woanders aufrufen kann?

                              Nachtrag:

                              wenn ich ähnlich dem Code:

                              $('#' + obj.native.id + '_deviceOP').change({id : obj.native.id}, onSelect);

                              mir eine Funktion onSelect erstelle und darin das onChange() verwende, dann gibt es den Fehler.

                              Gruß

                              Klaus

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

                                Bluefox,

                                kannst du bitte materialize.js /.css auf eine gültige Version (momentan ist 0.100.2 die letzte unterstütze vom Herbst) updaten?

                                Du verwendest eine sehr-sehr alte Version und einige Dinge von der Webseite und Doku funktionieren nicht.

                                Ich baue an einem Tab und hab mich gewundert warum das nicht hinhaut wenn ich deine includes verwende.

                                Dein include zeigt die Version gar nicht an, ist also älter als 0.80 was eigentlich uralt ist und nicht unterstütz oder supported wird.

                                Eine andere Frage: Wie kann ich einem tab ein Icon zuweisen? Mit dem Original-Eintrag funktioniert das in admin3 nicht mehr!

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

                                  Leider hab ich mit Admin 3 auch andere Probleme!

                                  Mein neuer Adapter hat (ausschließlich) einen Tab, einigen Code hab ich von der vorletzten Version vom Javascript-Adapter übernommen, aber den Tab komplett ohne jQuery-UI ausschließlich mit jquery und materialize geschrieben. Der code ist dort auf Git: https://github.com/frankjoke/ioBroker.statemachine

                                  Momentan ist die Logik im Adapter nicht fertig, d.h. man kann konfigurieren aber es wird noch nichts ausgeführt. Ein Grund ist dass ich verbissen nach Fehlern gesucht habe um die Kommunikation zwischen Tab und adapter hinzukriegen bis ich draufgekommen bin dass der Grund der neue adapter 3.1+ oder auch 3.2 ist warum all das was vorher schon funktioniert hat jetzt nicht mehr geht!

                                  Da ich die Zustände meines Adapters in der Konfig live anzeigen muss hab ich auch Objekte und states abonniert (so wie es im Javascript vorkommt…

                                  main.socket.on('objectChange', function (id, obj) {
                                                          setTimeout(main.objectChange, 0, id, obj);
                                                      });
                                  main.socket.on('onUpdate', function (id, obj) {
                                                          setTimeout(main.stateChange, 0, id, obj);
                                                      });
                                  main.socket.on('stateChange', function (id, obj) {
                                                          setTimeout(main.stateChange, 0, id, obj);
                                                      });
                                  
                                  

                                  Das hat auch funktioniert - unter Admin2.0.9 und 3.0 Beta, ich hatte vorher beide drauf und (glaubte) damit beide testen zu können, was auch funktioniert hat bis ich die 3.1.7 oder so offiziell installiert habe.

                                  Ich bekomme bei 2.0.9 alle State- (und Objekt-) änderungen durch und kann sie anzeigen.

                                  Ich verwende auch

                                  main.socket.emit('setObject', main.adapterConfigId, cconf, function (err) {
                                                          if (err) {
                                                              showError(err);
                                                              //                        that.init(true);
                                                          }
                                                      });
                                  

                                  um die Konfiguration zu speichern, hat auch wunderbar funktioniert!

                                  Jetzt das eigenartige: Sobald ich einen Admin>3.1.x verwende bekomme ich außer system.host.* keine sates mehr auf onState/onUpdate!

                                  Noch eigenartiger, solange ich NICHT am Tab war bekomme ich alle system.* state updates (system.adapter, system.host, …), sobald ich den tab öffne bekomme ich nurmehr system.host.*!

                                  Außerdem wird der Adapter zwar restarted wenn ich mit setObject die Konfig speichere aber der Tab wird gelöscht und nicht neu geladen, im admin-tab wird nichts eingeladen (und nicht der Verweis auf den tab-Link)!! Ich muss dann auf einen anderen Tab cklicken und dann zurück, damit meiner wieder geladen wird.

                                  Eigenartigerweise wird beim Click auf einen anderen Tab meiner auch im Hintergrund meiner neu geladen (was ich angand des Debuggers sehe wo ich einige console.log eingebaut habe um das Verhalten zu debuggen). Übrigens, das passiert nur beim ersten click auf einen anderen Adapter, nicht wenn ich weitere tabs ancklicke, aber die frame wird immer neu geladen wenn ich zum Tab komme oder vom tab weggehe.

                                  All das ist nicht der Fall unter Admin 2.0.9 und der Adapter Tab funktioniert dort OK.

                                  Leider funktionieren andere Dinge nicht mehr gut wenn man auch 2.0.9 zurück steigt da sich anscheinend Versionen von libraries mischen.

                                  p.s.: Hab auch noch Probleme mit woff2-Fondateien in meiner Lib. Diese werden nicht als binary sondern ahtml interpretiert was dann einen Fehler im browser erzeit der das font-binary entpacken will!. beim upload werden sie als application/font-woff2 hochgeladen aber der Browser scheint das nicht zu verstehen.

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

                                    @fsjoke:

                                    Leider hab ich mit Admin 3 auch andere Probleme!

                                    Mein neuer Adapter hat (ausschließlich) einen Tab, einigen Code hab ich von der vorletzten Version vom Javascript-Adapter übernommen, aber den Tab komplett ohne jQuery-UI ausschließlich mit jquery und materialize geschrieben. Der code ist dort auf Git: https://github.com/frankjoke/ioBroker.statemachine

                                    Momentan ist die Logik im Adapter nicht fertig, d.h. man kann konfigurieren aber es wird noch nichts ausgeführt. Ein Grund ist dass ich verbissen nach Fehlern gesucht habe um die Kommunikation zwischen Tab und adapter hinzukriegen bis ich draufgekommen bin dass der Grund der neue adapter 3.1+ oder auch 3.2 ist warum all das was vorher schon funktioniert hat jetzt nicht mehr geht!

                                    Da ich die Zustände meines Adapters in der Konfig live anzeigen muss hab ich auch Objekte und states abonniert (so wie es im Javascript vorkommt…

                                    main.socket.on('objectChange', function (id, obj) {
                                                            setTimeout(main.objectChange, 0, id, obj);
                                                        });
                                    main.socket.on('onUpdate', function (id, obj) {
                                                            setTimeout(main.stateChange, 0, id, obj);
                                                        });
                                    main.socket.on('stateChange', function (id, obj) {
                                                            setTimeout(main.stateChange, 0, id, obj);
                                                        });
                                                     
                                    

                                    Das hat auch funktioniert - unter Admin2.0.9 und 3.0 Beta, ich hatte vorher beide drauf und (glaubte) damit beide testen zu können, was auch funktioniert hat bis ich die 3.1.7 oder so offiziell installiert habe.

                                    Ich bekomme bei 2.0.9 alle State- (und Objekt-) änderungen durch und kann sie anzeigen.

                                    Ich verwende auch

                                    main.socket.emit('setObject', main.adapterConfigId, cconf, function (err) {
                                                            if (err) {
                                                                showError(err);
                                                                //                        that.init(true);
                                                            }
                                                        });
                                    

                                    um die Konfiguration zu speichern, hat auch wunderbar funktioniert!

                                    Jetzt das eigenartige: Sobald ich einen Admin>3.1.x verwende bekomme ich außer system.host.* keine sates mehr auf onState/onUpdate!

                                    Noch eigenartiger, solange ich NICHT am Tab war bekomme ich alle system.* state updates (system.adapter, system.host, …), sobald ich den tab öffne bekomme ich nurmehr system.host.*!

                                    Außerdem wird der Adapter zwar restarted wenn ich mit setObject die Konfig speichere aber der Tab wird gelöscht und nicht neu geladen, im admin-tab wird nichts eingeladen (und nicht der Verweis auf den tab-Link)!! Ich muss dann auf einen anderen Tab cklicken und dann zurück, damit meiner wieder geladen wird.

                                    Eigenartigerweise wird beim Click auf einen anderen Tab meiner auch im Hintergrund meiner neu geladen (was ich angand des Debuggers sehe wo ich einige console.log eingebaut habe um das Verhalten zu debuggen). Übrigens, das passiert nur beim ersten click auf einen anderen Adapter, nicht wenn ich weitere tabs ancklicke, aber die frame wird immer neu geladen wenn ich zum Tab komme oder vom tab weggehe.

                                    All das ist nicht der Fall unter Admin 2.0.9 und der Adapter Tab funktioniert dort OK.

                                    Leider funktionieren andere Dinge nicht mehr gut wenn man auch 2.0.9 zurück steigt da sich anscheinend Versionen von libraries mischen.

                                    p.s.: Hab auch noch Probleme mit woff2-Fondateien in meiner Lib. Diese werden nicht als binary sondern ahtml interpretiert was dann einen Fehler im browser erzeit der das font-binary entpacken will!. beim upload werden sie als application/font-woff2 hochgeladen aber der Browser scheint das nicht zu verstehen. `
                                    Man muss jetzt auf die Zustände sich subscriben. Schreib socket.emit("subscribe", "myname." + instanz);

                                    Applicatuon/font-woff2 ist falsch. Richtig:

                                    font/woff2

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

                                      Das Problem mit dem Tab-reload muss ich noch anschauen.

                                      1 Reply Last reply Reply Quote 0
                                      • arteck
                                        arteck Developer Most Active last edited by

                                        ich werde noch bekloppt..

                                        habe gerade den hs100 umgestellt… auf meinem dev system bekomme ich immer nur die alte Seite angezeigt

                                        io-package : gemacht

                                        index_m : gemacht

                                        container anpassung : gemacht

                                        nix neue admin .....

                                        verdammt

                                        sollte jemanden langweilig sein.. https://github.com/arteck/ioBroker.hs100/tree/newApi

                                        will das teil nicht dirket ins master mergen.. da ich nicht weiss obs geht..

                                        1 Reply Last reply Reply Quote 0
                                        • Homoran
                                          Homoran Global Moderator Administrators last edited by

                                          upload und STRG-F5 auch schon probiert?

                                          Gruß

                                          Rainer

                                          1 Reply Last reply Reply Quote 0
                                          • blauholsten
                                            blauholsten Developer last edited by

                                            @arteck:

                                            ich werde noch bekloppt..

                                            habe gerade den hs100 umgestellt… auf meinem dev system bekomme ich immer nur die alte Seite angezeigt

                                            io-package : gemacht

                                            index_m : gemacht

                                            container anpassung : gemacht

                                            nix neue admin .....

                                            verdammt

                                            sollte jemanden langweilig sein.. https://github.com/arteck/ioBroker.hs100/tree/newApi

                                            will das teil nicht dirket ins master mergen.. da ich nicht weiss obs geht.. `

                                            Auf die schnelle vom Handy,

                                            Nim Mal aus der Zeile 119 oder 120 das div weg. Das scheint zuviel zu sein

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            972
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            17
                                            50
                                            11110
                                            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