NEWS
SONOFF NSPanel mit Lovelace UI
-
Das hatte ich verbrochen und sollte nicht nochmal passieren und es war optional
EDIT: changelog fehlt dann
-
@ticaki Passt so, danke
-
@ticaki sagte in SONOFF NSPanel mit Lovelace UI:
Das hatte ich verbrochen und
sollte nicht nochmal passierenund es war optionalDie Aussage ziehe ich zu 50% wieder zurück, beim kommenden Update werden PageItems gezählt und zuviele oder zuwenige werden angemeckert.
Wir ändern nix, aber wenn ihr euch nicht an die
überschaubare
Wiki gehalten habt, müsst ihr was ändern. -
@ticaki Gut, dass ich noch nicht so viele Funktionen nutze bis jetzt
https://forum.iobroker.net/topic/58170/sonoff-nspanel-mit-lovelace-ui/4828?_=1705424364978
Nochmal bezogen auf dieses Thema (weswegen ich das Update gemacht habe). Würde gerne manche Buttons entkoppeln die für andere Funktionen genutzt werden. Ich steuere über den Schalter ein Blockly Skript. Brauche also einen Datenpunkt oder sonst irgendetwas was sich verändert.
Muss hier dann wirklich ein Gerät anlegen, oder kann ich einfach einen Datenpunkt anlegen, bspw. so:button1: { // DE: Mögliche Werte wenn Rule2 definiert: 'page', 'toggle', 'set' - Wenn nicht definiert --> mode: null // EN: Possible values if Rule2 defined: 'page', 'toggle', 'set' - If not defined --> mode: null mode: 'toggle', // DE: Zielpage - Verwendet wenn mode = page // EN: Target page - Used if mode = page page: null, // DE: Zielentity - Verwendet wenn mode = set oder toggle // EN: Target entity - Used if mode = set or toggle entity: AliasPath + 'Rollo', // DE: Zielwert - Verwendet wenn mode = set // EN: Target value - Used if mode = set setValue: null },
-
button1: { // DE: Mögliche Werte wenn Rule2 definiert: 'page', 'toggle', 'set' - Wenn nicht definiert --> mode: null // EN: Possible values if Rule2 defined: 'page', 'toggle', 'set' - If not defined --> mode: null mode: 'toggle', // DE: Zielpage - Verwendet wenn mode = page // EN: Target page - Used if mode = page page: null, // DE: Zielentity - Verwendet wenn mode = set oder toggle // EN: Target entity - Used if mode = set or toggle entity: 'shelly.0.shellyplus1pm#84cca87727dc#1.Relay0.Switch', // DE: Zielwert - Verwendet wenn mode = set // EN: Target value - Used if mode = set setValue: null },
so siehts bei mir im Flur aus.
-
@ticaki
Ja geht nicht so ganz. Ist ja ein Rollo. Hier gibt es open, close, stop.
Würde hier dann denke ich einfach einen weiteren DP erstellen für den Trigger, korrekt? AliasPath liegt doch dann unter 0_userdata.0.XXX.Panelname ?Habs für mich so gelöst. Hoch geht es ja leider nur wenn ich bspw. noch den Doppelklick nutze.
EDIT: Sollte mir vielleicht auch mal anschauen was ihr da programmiert habt. NSPanel_Path tut es
-
Du brauchst einen Datenpunkt den du veränderst fürs Panel, Dann ein Skript das bei jeder Veränderung an diesem Datenpunkt durch auf, stop, zu, stop , auf, stop, zu,.. schaltet.
-
@ticaki Ja das ist ne Idee. Dann kann ich aber nicht mit toggle arbeiten. Mache ich dann einfach SET und mit nem kleinen Blockly, welches hochzählt bei Zustandänderung?
-
Ich kopiere, analog der Ankündigungen in den Updates, ebenfalls nur den unteren Teil + den Header des NSPanelTs.ts in das Script. Update je Panel würde ich mal auf 1 Minute schätzen.
Es müssen faktisch nicht alle Updates gemacht werden. Nur wenn sie für euch einen Mehrwert bringen oder ein paar elementare Bugs behoben werden, die euch stören.
Wir arbeiten aber an einer Lösung, die ein manuelles Update künftig nicht mehr erforderlich macht. Bitte etwas geduld
-
@armilar Wow. Das hört sich richtig gut an!
-
-
@armilar Ich bin echt gespannt. Das Projekt hat auf jeden Fall noch richtig viel Potential!
-
Oh ja - da kommt noch einiges in das NSPanel...
-
Ich mach das Update immer mit Beyond Compare, ist relativ easy. Gibt auch kostenlose Tools bspw. https://editor.mergely.com/. Links das neue Skript, rechts deins. Dann haust du mit dem kleinen Pfeil einfach die Sachen von dir in das linke Skript, dann
Strg + A
&Strg + C
. Dann in deinem Skript im ioBrokerStrg + A
&Strg + V
. Klatsch klatsch, das geht ruckzuck -
mach noch einen State der hoch zählt und den Wert auch für Neustarts usw. speichert und dann
counter = counter + 1
counter = counter % 4Du brauchst 4 Wert für auf, stop ,zu ,stop und mit dem modulo (%) machst du eine 4 zu einer 0
Keine Ahnung wie das im Blockly hießt, wohl irgendwas mit Rest weil
5 % 4 = 1
5 geteilt durch 4 hat den Rest 1 -
@armilar Ich bin jetzt kein Pro was Hardware angeht, aber was haltet ihr denn davon, eine Stempeluhr zu implementieren? Ich weiß nicht ob der ESP noch entsprechende Pins frei hat für einen NFC oder RFID Leser, aber das wäre eine echt schicke Lösung.
-
@ticaki Danke probiere ich gerne mal aus.
-
@armilar Ich bin jetzt kein Pro was Hardware angeht, aber was haltet ihr denn davon, eine Stempeluhr zu implementieren? Ich weiß nicht ob der ESP noch entsprechende Pins frei hat für einen NFC oder RFID Leser, aber das wäre eine echt schicke Lösung.
GPIO20 ist neben 5V und GND ungenutzt, da könntest du direkt etwas aufstecken. Welcher RFID Reader schwebt dir denn vor? In der Regel benötigen die Tasmota-fähigen RFID-Reader 5 GPIO's auf dem ESP32. Und die sind zumindest nicht offensichtlich verfügbar.
Ich könnte mir also im Moment vorstellen, dass das Vorhaben aufgrund verfügbarer GPIO's scheitern wird
EDIT: Wenn du allerdings absoluter und schmerzfreier Lötprofi bist (ich würde mir das nicht zutrauen ) , dann kannst du noch ne Menge mehr GPIO'S freischaufeln...
-
@armilar Also eine Präferenz für einen RFID-Reader habe ich jetzt nicht. Im Endeffekt geht es ja nur darum, den Mitarbeiter einfach zu identifizieren. Da finde ich RFID/NFC am einfachsten. Über das Panel den Mitarbeiter auszuwählen finde ich unpraktikabel.
Ne du das traue ich mir nicht zu. Würde zwar sagen ich kann ganz gut löten, aber das ist mir dann doch etwas zu klein -
Das einzige was mir derzeit einfallen würde wäre ein RDM-6300 (5V, GND, RX). Aber ob Platz für das Modul im NSPanel ist, müsstest du ausprobieren...