Skip to content
  • 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
  1. ioBroker Community Home
  2. Deutsch
  3. Entwicklung
  4. Adapter Entwicklung: Custom datapoint-specific (custom_m.html) - Abfrage beim speichern

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.2k

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

Geplant Angeheftet Gesperrt Verschoben Entwicklung
16 Beiträge 3 Kommentatoren 1.1k Aufrufe 3 Watching
  • Ä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
    #5

    iobroker.admin 3.6.2 unterstützt handler customPostOnSave.

    Usage:

    if (typeof customPostOnSave !== 'undefined') {
         customPostOnSave.mydevices = function ($div, instance) {
              if (!$div.find('input[data-field="id"]').val()) {
                      return _('Please enter ID');
              }
         };
    }
    1 Antwort Letzte Antwort
    0
    • ScroungerS Offline
      ScroungerS Offline
      Scrounger
      Developer
      schrieb am zuletzt editiert von
      #6

      @Bluefox
      Perfekt, vielen Dank! Damit komm ich jetzt sicher weiter.

      Eine Frage hab ich noch, wie kann ich log Ausgaben für den custom erzeugen und wo werden diese dann abgelegt?

      <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

      <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

      BluefoxB 1 Antwort Letzte Antwort
      0
      • ScroungerS Scrounger

        @Bluefox
        Perfekt, vielen Dank! Damit komm ich jetzt sicher weiter.

        Eine Frage hab ich noch, wie kann ich log Ausgaben für den custom erzeugen und wo werden diese dann abgelegt?

        BluefoxB Offline
        BluefoxB Offline
        Bluefox
        schrieb am zuletzt editiert von
        #7

        Участник @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 Antwort Letzte Antwort
        0
        • ScroungerS Offline
          ScroungerS Offline
          Scrounger
          Developer
          schrieb am zuletzt editiert von
          #8

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

          <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

          <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

          BluefoxB 1 Antwort Letzte Antwort
          0
          • ScroungerS Scrounger

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

            BluefoxB Offline
            BluefoxB Offline
            Bluefox
            schrieb am zuletzt editiert von
            #9

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

            ScroungerS 1 Antwort Letzte Antwort
            0
            • BluefoxB Bluefox

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

              ScroungerS Offline
              ScroungerS Offline
              Scrounger
              Developer
              schrieb am zuletzt editiert von Scrounger
              #10

              @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

              <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

              <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

              1 Antwort Letzte Antwort
              0
              • ScroungerS Offline
                ScroungerS Offline
                Scrounger
                Developer
                schrieb am zuletzt editiert von Scrounger
                #11

                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()];
                

                <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                s.bormannS 1 Antwort Letzte Antwort
                1
                • ScroungerS 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.bormannS Offline
                  s.bormannS Offline
                  s.bormann
                  Most Active
                  schrieb am zuletzt editiert von
                  #12

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

                  ScroungerS 1 Antwort Letzte Antwort
                  0
                  • s.bormannS s.bormann

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

                    ScroungerS Offline
                    ScroungerS Offline
                    Scrounger
                    Developer
                    schrieb am zuletzt editiert von Scrounger
                    #13

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

                    <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                    <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                    s.bormannS 1 Antwort Letzte Antwort
                    0
                    • ScroungerS 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.bormannS Offline
                      s.bormannS Offline
                      s.bormann
                      Most Active
                      schrieb am zuletzt editiert von
                      #14

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

                      ScroungerS 1 Antwort Letzte Antwort
                      0
                      • s.bormannS s.bormann

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

                        ScroungerS Offline
                        ScroungerS Offline
                        Scrounger
                        Developer
                        schrieb am zuletzt editiert von
                        #15

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

                        <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                        <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                        s.bormannS 1 Antwort Letzte Antwort
                        0
                        • ScroungerS Scrounger

                          @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.bormannS Offline
                          s.bormannS Offline
                          s.bormann
                          Most Active
                          schrieb am zuletzt editiert von
                          #16

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

                          757

                          Online

                          32.4k

                          Benutzer

                          81.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
                          • Aktuell
                          • Tags
                          • Ungelesen 0
                          • Kategorien
                          • Unreplied
                          • Beliebt
                          • GitHub
                          • Docu
                          • Hilfe