Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Entwicklung
    4. Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern

    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

    Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern

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

      Участник @Scrounger написал в Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern:

      custom

      Was meinst du mit für "custom" ??
      Wo in browser bei der Konfiguration oder in back-end?

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

        @Bluefox
        Ja im Browser bei der Konfiguration, also Front-end.
        Ich möchte code den ich in der custom_m.html eingebe loggen.

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

          @Scrounger Vielleicht verstehe ich was nicht, aber console.log??? Ne?

          Scrounger 1 Reply Last reply Reply Quote 0
          • Scrounger
            Scrounger Developer @Bluefox last edited by Scrounger

            @Bluefox sagte in Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern:

            @Scrounger Vielleicht verstehe ich was nicht, aber console.log??? Ne?

            Ne mit console.log schreibt er nix in die "iobroker.2019-05-07.log".

            Eine weitere Frage. Wenn das Object custom settings enabled = true gesetzt ist, dann kann man in der folgenden Funktion nicht mehr auf 'obj' zugreifen - in dem Bsp. will ich die Unit des 'obj' auslesen:

            	if (typeof defaults !== 'undefined') {
            		console.log("Hallo");
            
            		defaults.linkeddevices = function (obj, instanceObj) {
            			return {
            				enabled: false,
            				unit: obj.common.unit
            			};
            		}
            	}
            

            deaktiviert:
            custom_deactivated_2.png
            custom_deactivated.png

            aktiviert:
            custom_activated_2.png
            custom_activated.png

            Ist das ein Bug?

            source findest du jetzt hier: https://github.com/Scrounger/ioBroker.linkeddevices

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

              So nachdem ich jetzt bissle den Source code durchstöbert habe, ist es möglich das Objekt für das der custom dialog geöffnet wurde wie folgt zu bekommen:

              	// Objekt holen für das der custom Dialog geöffnet wurde 
              	var currentObj = gMain.objects[gMain.navigateGetParams()];
              
              s.bormann 1 Reply Last reply Reply Quote 1
              • s.bormann
                s.bormann Most Active @Scrounger last edited by

                @Scrounger sagte in Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern:

                So nachdem ich jetzt bissle den Source code durchstöbert habe, ist es möglich das Objekt für das der custom dialog geöffnet wurde wie folgt zu bekommen:

                	// Objekt holen für das der custom Dialog geöffnet wurde 
                	var currentObj = gMain.objects[gMain.navigateGetParams()];
                

                Hi, stehe vor folgendem Problem:
                Wenn ich dieses Objekt ändere, wird es scheinbar nicht gespeichert. Wie kann man dafür sorgen, dass Änderungen an de Objekt auch gespeichert werden?

                Hintergrund:
                Ich möchte ein Objekt vom Typ {key: "value", key2: "value2"} bearbeiten. Wenn ich den normalen Weg über die <input data-field="meinobjekt" type="text"> gehe, wird das Input-Feld escaped, d.h. aus den ganzen Anführungszeichen im Objekt werden /" gemacht. Deshalb wollte ich das Objekt direkt selbst abspeichern.

                Ideen?

                Scrounger 1 Reply Last reply Reply Quote 0
                • Scrounger
                  Scrounger Developer @s.bormann last edited by Scrounger

                  @s-bormann
                  Im custom dialog musst du entsprechend ein input feld definieren mit dem attribut 'data-field' und dem entsprechenden key, z.B.:

                  <input type="text" data-field="key">
                  

                  Die darin enthaltenen Daten werden dann beim click auf speichern im array custom[adapter.Instance].key im objekt automatisch gespeichert.

                  Müsste aber am besten mal deinen Code sehen, um dir ggf. weiterhelfen zu können. Bin mir nicht sicher ob du da irgendein spezial ding machen willst.

                  s.bormann 1 Reply Last reply Reply Quote 0
                  • s.bormann
                    s.bormann Most Active @Scrounger last edited by

                    @Scrounger Hi, danke für die Antwort! Das mit dem input-Feld klappt leider nicht, da ich darin kein Objekt speichern kann, weil ioBroker das ganze escaped. Aber das mit dem custom[adapter.instance].key hilft vielleicht, ggf. kann ich da ja direkt einen Wert abspeichern.
                    Zwischenzeitlich habe ich einen Workaround gefunden - den ich selbst allerdings ein wenig als gebastelt empfinde. Wenn es mit dem custom[adapter.instance].key klappt, werde ich das umstellen. Zu Doku-Zwecken aber hier schon mal meine Lösung:

                        //Init
                        if (typeof customPostInits !== 'undefined') {
                           customPostInits.iqontrol = function ($div, values, instanceObj, type, role) {
                    			var adapter =  $div.data('adapter');
                    			$('#dialog-customs .btn-save').on('click', function(){ 
                    				if($('#tab-customs-settings li[data-adapter="' + adapter + '"] input[data-field="enabled"]').is(":checked")){
                    					(function(){ //Closure--> (everything declared inside keeps its value as ist is at the time the function is created)
                    						var _currentId = gMain.navigateGetParams();
                    						var _currentObj = gMain.objects[_currentId];
                    						var _adapter = adapter;
                    						var _states = states[_adapter]; //<-- Das ist das Object, welches gespeichert werden soll
                    						setTimeout(function(){
                    							if (typeof _currentObj.common.custom == 'undefined') _currentObj.common.custom = {};
                    							if (typeof _currentObj.common.custom[_adapter] == 'undefined') _currentObj.common.custom[_adapter] = {};
                    							_currentObj.common.custom[_adapter].states = _states; //<-- Hier wird das Objekt in den temporären ioBroker-Objekt-Speicher übertragen
                    							gMain.socket.emit('setObject', _currentId, _currentObj, function(err){ //<-- Und hier wird es dann in die Datenbank dauerhaft übertragen
                    								if(err) alert("Errir saving Object");
                    							});
                    						}, 100);	
                    					})(); //<--End Closure
                    				}
                    			}); 
                            }
                        }
                    
                    

                    Das ganze funktioniert. Wenn ich eine gefühlt bessere Lösung habe, werde ich nachberichten.

                    LG und Danke für die Hilfe!

                    Scrounger 1 Reply Last reply Reply Quote 0
                    • Scrounger
                      Scrounger Developer @s.bormann last edited by

                      @s-bormann
                      Achso du willst ein komplettes Objekt in einem Input Feld speichern?
                      Könntest das Objekt auch als String in den custom Eigenschaften speichern. Dann würde das mit dem input Feld funktionieren.

                      s.bormann 1 Reply Last reply Reply Quote 0
                      • s.bormann
                        s.bormann Most Active @Scrounger last edited by

                        @Scrounger sagte in Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern:

                        @s-bormann
                        Achso du willst ein komplettes Objekt in einem Input Feld speichern?
                        Könntest das Objekt auch als String in den custom Eigenschaften speichern. Dann würde das mit dem input Feld funktionieren.

                        Hi, leider hat genau das nicht geklappt, weil es "escaped" wurde, d.h. aus:
                        '{"key1":"value1", "key2":"value2", ...}' wurde beim Speichern so was ähnliches wie:
                        '{\"key1\":\"value1\", \"key2\":\"value2\", ...}'

                        LG

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        635
                        Online

                        31.7k
                        Users

                        79.9k
                        Topics

                        1.3m
                        Posts

                        3
                        16
                        990
                        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