Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Hardware
    4. SONOFF NSPanel mit Lovelace UI

    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

    SONOFF NSPanel mit Lovelace UI

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

      @tt-tom Danke werd ich heute Abend mal prüfen

      T 1 Reply Last reply Reply Quote 0
      • T
        TT-Tom @niiccooo1 last edited by

        @niiccooo1

        schau dir mal das im WIKI an.

        1 Reply Last reply Reply Quote 0
        • D
          danny_v1 @lesiflo last edited by

          @lesiflo said in SONOFF NSPanel mit Lovelace UI:

          Moin, gibt es die Möglichkeit bei Typ "cardGrid" oder "cardGrid2" das Icon eines PageItems in Abhängigkeit vom Status zu ändern? Im Moment benutze ich dafür 2 Items die ich wechselweise ein und ausschalte.

                  <PageItem>{ id: "alias.0.Auto.Phasen", icon: 'numeric-1-circle', name: "Phasen", onColor: MSGreen, offColor: Gray},
                  <PageItem>{ id: "alias.0.Auto.Phasen", icon: 'numeric-3-circle', name: "Phasen", onColor: Gray, offColor: MSGreen},
          
          

          1693987904594.jpg

          Genau die Funktion hätte ich auch gern, enbenso das zb. nur Elemente mit dem Status "on" angezeigt werden.

          T L 2 Replies Last reply Reply Quote 0
          • T
            TT-Tom @danny_v1 last edited by

            @danny_v1
            warum stürzt bei dir Accuweather ab. Läuft bei mir problemlos. Du darfst mit dem API Schlüssel nur eine Instanz laufen lassen.

            D 1 Reply Last reply Reply Quote 0
            • T
              TT-Tom @danny_v1 last edited by

              @danny_v1

              zeige mal die Datenpunkte die du anzeigen möchtest

              D 1 Reply Last reply Reply Quote 0
              • N
                niiccooo1 last edited by

                @tt-tom Danke für die Verknüpfung.

                Ich hätte erwähnen sollen, dass der WLED-Adapter den Datenpunkt Temperatur nicht direkt darstellt.
                Über den Slider werden lediglich die Farbcodierung RGB oder HEX geändert.
                Im Prinzip bräuchte eine Umrechnung von Kelvin nach RGB.

                Hat das jemand schon mal gemacht?

                T 1 Reply Last reply Reply Quote 0
                • T
                  TT-Tom @niiccooo1 last edited by

                  @niiccooo1

                  ich hatte mal dieses Script genutzt und als Typ dann Hue. Es legt dir Datenpunkte unter 0_userdata an, die musst du dann mit dem Alias verknüpfen.
                  teste mal

                  // ##############################
                  // ######### DutchmanNL #########
                  // ###### HSV Color to HEX ######
                  // ############ V1.0 ############
                  // ##############################
                  
                  // Add the state containing HEX values here :
                  const colorSourceHex = [
                         // Beispiel Zigbee 'zigbee.0.group_2.color', 
                         'wled.0.4c11ae0dce1e.seg.0.col.0_HEX', //  WLED_TV
                         'wled.0.4c11ae0dd3ac.seg.0.col.0_HEX', //  WLED_links
                         'wled.0.4c11ae0dd0a3.seg.0.col.0_HEX'  //  WLED_Mitte 
                  ];
                  
                  // #####################################
                  // ## Don't change anything from here ##
                  // #####################################
                  
                  // Prepare variables
                  const mySubscription = {}, debounceTimer = {};
                  
                  // Create Folder structure
                  extendObjectAsync(`0_userdata.0.HEXtoHSL` , {
                     "type": "folder",
                     "common": {
                     "name": 'Convert HEX to HSL color',
                         "role": "",
                         "icon": "",
                  },
                     "native": {},
                  });
                  
                  // Read all array objects, create new state in javascript instance and subscribe on changes
                  for (const device in colorSourceHex) {
                  
                     // Define folder structure in userdata directory
                     const statePrepare = colorSourceHex[device].split('.');
                     const deviceName = `0_userdata.0.HEXtoHSL.${statePrepare[0]}_${statePrepare[1]}_${statePrepare[2]}`
                  
                     // Create Device Structure
                     extendObjectAsync(deviceName , {
                         "type": "device",
                         "common": {
                         "name": statePrepare[2],
                             "role": "",
                             "icon": "",
                     },
                         "native": {},
                     });
                  
                     // States to cover Hue and Sat values
                     createState(`${deviceName}.hue` , {
                     	'name': `Hue of ${statePrepare[2]}`,
                     	'role': 'level.color.hue',
                     	'type': 'number'
                     });
                     // @ts-ignore
                     createState(`${deviceName}.sat`, {
                     	'name': `Sat of ${statePrepare[2]}`,
                     	'role': 'level.color.sat',
                     	'type': 'number'
                     });
                  
                     // Subscribe on state changes for HUE and Saturation
                     // @ts-ignore
                     mySubscription[`${deviceName}.hue`] = on(
                         [`${deviceName}.hue`, 
                         `${deviceName}.sat`
                         ], (data) => {
                  
                         // DebounceTimer
                         // Reset timer (if running) and start new one for next watchdog interval
                     	if (debounceTimer[colorSourceHex[device]]) {
                     		clearTimeout(debounceTimer[colorSourceHex[device]]);
                     		debounceTimer[colorSourceHex[device]] = null;
                     	}
                     	debounceTimer[colorSourceHex[device]] = setTimeout(() => {
                  
                             if (!data.state.ack){
                                 const h = getState(`${deviceName}.hue`).val / 360;
                                 const s = getState(`${deviceName}.sat`).val / 100;
                                 const v = 1;
                                 const colorRGB = hsvTOrgb(h,s,v)
                                 const colorHEX = rgbTOhex(colorRGB)
                                 // console.log(`HSV value : ${h}, ${s}, ${v}`);
                                 setState(`${colorSourceHex[device]}`, colorHEX);
                             }
                         
                         }, (500));
                     });
                  
                     // Subscribe on state changes for HEX surce
                     mySubscription[`${deviceName}.hue`] = on(
                         [
                         `${colorSourceHex[device]}`,
                         ], (data) => {
                         // DebounceTimer
                     	if (debounceTimer[colorSourceHex[device]]) {
                     		clearTimeout(debounceTimer[colorSourceHex[device]]);
                     		debounceTimer[colorSourceHex[device]] = null;
                     	}
                     	debounceTimer[colorSourceHex[device]] = setTimeout(() => {
                             
                                 // console.log(`Device change detected : ${JSON.stringify(data.id)} value : ${data.state.val} | ack : ${data.state.ack}`);
                                 const colorHEX = data.state.val;
                                 const colorRGB = hexTOrgb(colorHEX)
                                 const colorHSV = rgbTOhsv(colorRGB)
                                 const h = roundDigit(colorHSV[0]);
                                 console.log(colorHSV);
                                 const s = roundDigit(colorHSV[1]);
                                 setState(`${deviceName}.sat`, s, true);
                                 setState(`${deviceName}.hue`, h, true);
                             
                  
                         }, (500));
                  
                     });
                  }
                  
                  ////////////////Funktionen////////////////
                  /**
                  * Coonvert HSV to RGB
                  * @param {number} h - HUE value 
                  * @param {number} s - Saturation value 
                  * @param {number} v - Brightness value 
                  */
                  function hsvTOrgb(h, s, v) {
                             var r, g, b, i, f, p, q, t;
                             i = Math.floor(h * 6);
                             f = h * 6 - i;
                             p = v * (1 - s);
                             q = v * (1 - f * s);
                             t = v * (1 - (1 - f) * s);
                             switch (i % 6) {
                                 case 0: r = v, g = t, b = p; break;
                                 case 1: r = q, g = v, b = p; break;
                                 case 2: r = p, g = v, b = t; break;
                                 case 3: r = p, g = q, b = v; break;
                                 case 4: r = t, g = p, b = v; break;
                                 case 5: r = v, g = p, b = q; break;
                             }
                             console.log(`${r} ${g} ${b}`)
                             r=Math.round(255 * r);
                             g=Math.round(255 * g);
                             b=Math.round(255 * b);
                             return [r,g,b];
                  };
                  
                  function rgbTOhsv(rgb) {
                     let rdif;
                     let gdif;
                     let bdif;
                     let h;
                     let s;
                  
                     const r = rgb[0] / 255;
                     const g = rgb[1] / 255;
                     const b = rgb[2] / 255;
                     const v = Math.max(r, g, b);
                     const diff = v - Math.min(r, g, b);
                     const diffc = function (c) {
                     	return (v - c) / 6 / diff + 1 / 2;
                     };
                  
                     if (diff === 0) {
                     	h = 0;
                     	s = 0;
                     } else {
                     	s = diff / v;
                     	rdif = diffc(r);
                     	gdif = diffc(g);
                     	bdif = diffc(b);
                  
                     	if (r === v) {
                     		h = bdif - gdif;
                     	} else if (g === v) {
                     		h = (1 / 3) + rdif - bdif;
                     	} else if (b === v) {
                     		h = (2 / 3) + gdif - rdif;
                     	}
                  
                     	if (h < 0) {
                     		h += 1;
                     	} else if (h > 1) {
                     		h -= 1;
                     	}
                     }
                  
                     return [
                     	h * 360,
                     	s * 100,
                     	v * 100
                     ];
                  };
                  
                  function rgbTOhex (args) {
                     const integer = ((Math.round(args[0]) & 0xFF) << 16)
                     	+ ((Math.round(args[1]) & 0xFF) << 8)
                     	+ (Math.round(args[2]) & 0xFF);
                  
                     const string = integer.toString(16).toUpperCase();
                     return '000000'.substring(string.length) + string;
                  };
                  
                  //In HEX konvertieren
                  function toHex(number) {
                     if (number < 0) number = 0xFFFFFFFF + number + 1;
                     var n = number.toString(16).toUpperCase();
                     if (n.length == 1) {
                         n = '0' + n;
                     }
                     return n;
                  }
                  
                  // Function to convert HEX to RGB 
                  function hexTOrgb(args) {
                     const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);
                  
                     if (!match) {
                         return [0, 0, 0];
                     }
                  
                     let colorString = match[0];
                  
                     if (match[0].length === 3) {
                         colorString = colorString.split('').map(char => {
                             return char + char;
                         }).join('');
                     }
                  
                     const integer = parseInt(colorString, 16);
                     const r = (integer >> 16) & 0xFF;
                     const g = (integer >> 8) & 0xFF;
                     const b = integer & 0xFF;
                     return [r, g, b];
                  };
                  
                  // Function to convert RGB to HSL
                  function rgbTOhsl (rgb) {
                     const r = rgb[0] / 255;
                     const g = rgb[1] / 255;
                     const b = rgb[2] / 255;
                     const min = Math.min(r, g, b);
                     const max = Math.max(r, g, b);
                     const delta = max - min;
                     let h;
                     let s;
                  
                     if (max === min) {
                     	h = 0;
                     } else if (r === max) {
                     	h = (g - b) / delta;
                     } else if (g === max) {
                     	h = 2 + (b - r) / delta;
                     } else if (b === max) {
                     	h = 4 + (r - g) / delta;
                     }
                  
                     h = Math.min(h * 60, 360);
                  
                     if (h < 0) {
                     	h += 360;
                     }
                  
                     const l = (min + max) / 2;
                  
                     if (max === min) {
                     	s = 0;
                     } else if (l <= 0.5) {
                     	s = delta / (max + min);
                     } else {
                     	s = delta / (2 - max - min);
                     }
                  
                     return [h, s * 100, l * 100];
                  };
                  
                  // Funtion to round digits properly
                  function roundDigit(num){
                     // return Math.round((num + Number.EPSILON) * 100) / 100
                     return Math.round((num + Number.EPSILON));
                  }
                  
                  

                  N 1 Reply Last reply Reply Quote 1
                  • T
                    TT-Tom @Futty last edited by

                    @futty

                    ich glaube das Problem gefunden zu haben. Suche bitte im Script in der Funktion "function GenerateThermoPage(page: PageThermo): Payload[] {"
                    diesen Abschnitt und ändere mal 'POW' in 'POWER'

                                                    case 'POWER':
                                                        if (existsState(id + '.POWER') && getState(id + '.POWER').val != null) {
                                                            if (getState(id + '.POWER').val) {
                                                                bt[i - 1] = Icons.GetIcon('power-standby') + '~2016~1~' + 'POW' + '~';
                                                            } else {
                                                                bt[i - 1] = Icons.GetIcon('power-standby') + '~33840~1~' + 'POW' + '~';
                                                            }
                                                        } else i--;
                                                        break;
                    
                    F 1 Reply Last reply Reply Quote 0
                    • T
                      TT-Tom @Vocaris last edited by

                      @vocaris sagte in SONOFF NSPanel mit Lovelace UI:

                      PS: wenn ich über den IOT Adapter eine Alexa Gerät erstelle und auf den MQTT Punkt Power1 und Power2 verweise, dann schaltet Alexa die Befehle zwar. Aber sie setzt TRUE und FALSE anstatt ON und OFF. Und eine Änderung der Werte im MQTT Baum löst an der Hardware leider nichts aus. Auch wenn ich im MQTT manuell ON oder OFF eingebe, passiert am Panel nix.

                      hast du alles auf den aktuellen Stand gebracht ? TFT, Script, Tasmota

                      du musst diese Datenpunkte nutzen 0_userdata.0.NSPanel.1.Relay

                      1 Reply Last reply Reply Quote 0
                      • F
                        Futty @TT-Tom last edited by Futty

                        @tt-tom
                        Mit der Info "könnte am Script selbst liegen" hab ich den Script nun auch mal durchforstet und glaube das Case von dir passt und dient lediglich der Anzeige bzw. Initialisierung.

                        Wenn ich mir den Log noch einmal anschaue:

                        6.9.2023, 00:20:44.967	[info ]: javascript.0 (2440423) script.js.common.NSPanel: HandleButtonEvent übergebene Werte event - buttonPress2 - alias.0.NSPanel.1.ThermostatWohnbereich - hvac_action - POW - PageId: 1
                        6.9.2023, 00:20:44.968	[info ]: javascript.0 (2440423) script.js.common.NSPanel: HandleButtonEvent buttonAction: hvac_action
                        6.9.2023, 00:20:44.979	[info ]: javascript.0 (2440423) script.js.common.NSPanel: GetNavigationString Übergabe pageId: 1
                        6.9.2023, 00:20:44.980	[info ]: javascript.0 (2440423) script.js.common.NSPanel: thermostat - Currently
                        6.9.2023, 00:20:44.985	[info ]: javascript.0 (2440423) script.js.common.NSPanel: thermostat - State
                        6.9.2023, 00:20:44.989	[info ]: javascript.0 (2440423) script.js.common.NSPanel: GenerateThermoPage payload: [object Object],[object Object]
                        6.9.2023, 00:20:44.991	[info ]: javascript.0 (2440423) script.js.common.NSPanel: function SendToPanel payload: pageType~cardThermo
                        6.9.2023, 00:20:44.992	[info ]: javascript.0 (2440423) script.js.common.NSPanel: function SendToPanel payload: entityUpd~Thermostat~button~bPrev~~65535~~~button~bNext~~65535~~~alias.0.NSPanel.1.ThermostatWohnbereich~22.4°C~220~MANU~50~300~5~~2016~1~POW~~~~~~~~~~~~~~~~~~~~~~~~~~~~~Aktuell~Zustand~~°C~~1
                        6.9.2023, 00:20:44.992	[info ]: javascript.0 (2440423) script.js.common.NSPanel: HandleMessage -> buttonPress2 event - buttonPress2 - alias.0.NSPanel.1.ThermostatWohnbereich - hvac_action - POW
                        

                        Dürfte die Action "hvac_action" sein, welche das Bit (nach meinem Verständnis) beschreiben sollte...
                        Im Script sieht das dann so aus:

                        switch (buttonAction) {
                        .
                        .
                        .
                                case 'hvac_action':
                                        if (words[4] == 'BOOT' || words[4] == 'PART' || words[4] == 'AUTT' || words[4] == 'MANT' || words[4] == 'VACT') {
                                            switch (words[4]) {
                                                case 'BOOT':
                                                    setIfExists(words[2] + '.' + 'BOOST', !getState(words[2] + '.' + 'BOOST').val);
                                                    break;
                                                case 'PART':
                                                    setIfExists(words[2] + '.' + 'PARTY', !getState(words[2] + '.' + 'PARTY').val);
                                                    break;
                                                case 'AUTT':
                                                    setIfExists(words[2] + '.' + 'AUTOMATIC', !getState(words[2] + '.' + 'AUTOMATIC').val);
                                                    break;
                                                case 'MANT':
                                                    setIfExists(words[2] + '.' + 'MANUAL', !getState(words[2] + '.' + 'MANUAL').val);
                                                    break;
                                                case 'VACT':
                                                    setIfExists(words[2] + '.' + 'VACATION', !getState(words[2] + '.' + 'VACATION').val);
                                                    break;
                                            }
                                            let modes = ['BOOT', 'PART', 'AUTT', 'MANT', 'VACT'];
                                            let modesDP = ['BOOST', 'PARTY', 'AUTOMATIC', 'MANUAL', 'VACATION'];
                                            for (let mode=0; mode < 5; mode++) {
                                                if (words[4] != modes[mode]) {
                                                    setIfExists(words[2] + '.' + modesDP[mode], false);
                                                }
                                            }
                                            GeneratePage(activePage);
                                        } else {
                                            let HVACMode = getState(words[2] + '.MODE').val;
                        
                                            // Event ist an ein eigenes Objekt gebunden
                                            if(existsObject(words[2] + '.' + words[4])) {
                                                switch(words[4]) {
                                                    case 'SWING':
                                                        if (getState(words[2] + '.SWING').val == 0) {
                                                            setIfExists(words[2] + '.SWING', 1);
                                                        } else {
                                                            setIfExists(words[2] + '.' + 'SWING', 0);
                                                        }
                                                        break;
                                                    default: // Power und Eco koennen einfach getoggelt werden
                                                        setIfExists(words[2] + '.' + words[4], !getState(words[2] + '.' + words[4]).val);
                                                        break;
                                                }
                                            }
                        
                                            // Event ist ein Modus der Liste (Moduswechsel)
                                            let HVACModeList = getObject(words[2] + '.MODE').common.states;
                                            for(const statekey in HVACModeList) {
                                                if(HVACModeList[statekey] == words[4]) {
                                                    HVACMode = parseInt(statekey);
                                                    break;
                                                }
                                            }
                                            
                                            setIfExists(words[2] + '.' + 'MODE', HVACMode);
                                            GeneratePage(activePage);
                                        }
                                        break;
                        

                        Meine Vermutung:
                        POWER oder POW wird hier gar nicht ausgewertet...

                        Ich versuche mal deine Idee und wenn das nicht klappt versuche ich das an meiner "Fundstelle" im Script zu implementieren.
                        Danke für den Hinweis

                        F T 2 Replies Last reply Reply Quote 0
                        • D
                          danny_v1 @TT-Tom last edited by

                          @tt-tom said in SONOFF NSPanel mit Lovelace UI:

                          @danny_v1
                          warum stürzt bei dir Accuweather ab. Läuft bei mir problemlos. Du darfst mit dem API Schlüssel nur eine Instanz laufen lassen.

                          Das hab ich noch nicht herausgefunden. Ja hab nur eine Instanz laufen.

                          T 1 Reply Last reply Reply Quote 0
                          • D
                            danny_v1 @TT-Tom last edited by

                            @tt-tom said in SONOFF NSPanel mit Lovelace UI:

                            @danny_v1

                            zeige mal die Datenpunkte die du anzeigen möchtest

                            Bin gerade nicht an der Anlage. Aber z.B. nur Fenster die offen sind, oder nur Sensoren die nicht erreichbar sind, oder Batterien die unter 10% haben.

                            1 Reply Last reply Reply Quote 0
                            • F
                              Futty @Futty last edited by

                              @TT-Tom

                              case 'hvac_action':
                                              if (words[4] == 'BOOT' || words[4] == 'PART' || words[4] == 'AUTT' || words[4] == 'MANT' || words[4] == 'VACT' || words[4] == 'POW') {
                              
                                                  switch (words[4]) {
                                                      case 'BOOT':
                                                          setIfExists(words[2] + '.' + 'BOOST', !getState(words[2] + '.' + 'BOOST').val);
                                                          break;
                                                      case 'PART':
                                                          setIfExists(words[2] + '.' + 'PARTY', !getState(words[2] + '.' + 'PARTY').val);
                                                          break;
                                                      case 'AUTT':
                                                          setIfExists(words[2] + '.' + 'AUTOMATIC', !getState(words[2] + '.' + 'AUTOMATIC').val);
                                                          break;
                                                      case 'MANT':
                                                          setIfExists(words[2] + '.' + 'MANUAL', !getState(words[2] + '.' + 'MANUAL').val);
                                                          break;
                                                      case 'VACT':
                                                          setIfExists(words[2] + '.' + 'VACATION', !getState(words[2] + '.' + 'VACATION').val);
                                                          break;
                                                      case 'POW':
                                                          setIfExists(words[2] + '.' + 'POWER', !getState(words[2] + '.' + 'POWER').val);
                                                          break;
                                                  }
                              

                              hab es nun so zum laufen bekommen,
                              also die komplette case 'POW' unten ins switch (words[4]) { und oben in der IF-Abrage noch verodert das words[4] == 'POW' am Ende hinzugefügt.

                              Danke für den Tipp mit dem Script.

                              1 Reply Last reply Reply Quote 0
                              • T
                                TT-Tom @Futty last edited by

                                @futty sagte in SONOFF NSPanel mit Lovelace UI:

                                                            default: // Power und Eco koennen einfach getoggelt werden
                                                                setIfExists(words[2] + '.' + words[4], !getState(words[2] + '.' + words[4]).val);
                                                                break;
                                
                                

                                das Problem liegt eigentlich hier. words[2] ist der Alias Pfad und words[4] der DatenPunkt

                                HandleButtonEvent übergebene Werte event - buttonPress2 - alias.0.NSPanel.1.ThermostatWohnbereich - hvac_action - ç - PageId: 1
                                
                                • words[0]=event
                                • words[1]=buttonPress2
                                • words[2]=alias.0.NSPanel.1.ThermostatWohnbereich
                                • words[3]=hvac_action
                                • words[4]=POW

                                darum ergibt der Befehl übersetzt

                                setIfExists('alias.0.NSPanel.1.ThermostatWohnbereich.POW', !getState('alias.0.NSPanel.1.ThermostatWohnbereich.POW').val);
                                

                                und da es diesen DP nicht gibt, passiert auch nix.

                                Darum bitte mal meinen Vorschlag testen.

                                F 1 Reply Last reply Reply Quote 1
                                • T
                                  TT-Tom @danny_v1 last edited by

                                  @danny_v1
                                  hast du dir mal einen neuen API Schlüssel erstellt?

                                  D 1 Reply Last reply Reply Quote 0
                                  • N
                                    niiccooo1 @TT-Tom last edited by

                                    @tt-tom

                                    Vielen Dank für das Skript.
                                    Die Datenpunkte wurden angelegt und aktualisieren sich bei Änderung des Sliders.

                                    Brauche ich den Wert "sat" im Alias auch?

                                    T 1 Reply Last reply Reply Quote 0
                                    • F
                                      Futty @TT-Tom last edited by

                                      @tt-tom
                                      auch deine Lösung geht.

                                      Warum macht man dann bei den anderen Feldern den Umweg über SwitchCase und gibt nicht gleich den richtigen Datenpunktname an?
                                      Das gleiche betrifft ja dann auch
                                      AUTOMATIC -> AUTT
                                      MANUAL -> MANT
                                      PARTY -> PART
                                      VACATION -> VACT
                                      BOOST -> BOOT

                                      Könnte man das nicht auch einfach auf den richtigen Namen an der entsprechenden Stelle (wie bei `POW -> POWER) abändern?

                                      T 1 Reply Last reply Reply Quote 0
                                      • T
                                        TT-Tom @Futty last edited by

                                        @futty
                                        Werde ich mit @Armilar besprechen; in wie weit wir die Funktion anpassen.

                                        F 1 Reply Last reply Reply Quote 0
                                        • D
                                          danny_v1 @TT-Tom last edited by

                                          @tt-tom said in SONOFF NSPanel mit Lovelace UI:

                                          @danny_v1
                                          hast du dir mal einen neuen API Schlüssel erstellt?

                                          Ja hatte ich vor ca einem Monat mal gemacht da der alte abgelaufen war.

                                          1 Reply Last reply Reply Quote 0
                                          • F
                                            Futty @TT-Tom last edited by

                                            @tt-tom
                                            Ok, ist bestimmt gewachsen bzw. vielleicht hat es ja auch einen Grund, bin sicherlich nicht der Experte auf dem Gebiet...
                                            Für meine Verwendung geht erst einmal alles wie ich mir das vorstelle.

                                            Danke dir für den Austausch

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            847
                                            Online

                                            31.8k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            lovelace ui nspanel sonoff
                                            265
                                            7292
                                            5000898
                                            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