NEWS
[Gelöst] Sensoren überwachen + Benachrichtigung
-
@d3ltoroxp sagte: wie ich die Funktion auch noch mal auf HMIP anwende ?
Wenn in beiden Fällen der Gerätename angezeigt werden soll, dann verwende eine erweiterte Funktion deviceName(id):
id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'device') return getObject(id).common.name; id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'device') return getObject(id).common.name;
-
@paul53 Auf den ersten Blick beide Zeilen identisch. Wenn ich nun noch mehrere andere Hersteller habe, kann ich dann einfach um die Anzahl erweitern ? Bei z.b. 4 unterschiedlichen Herstellern ?
id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'device') return getObject(id).common.name; id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'device') return getObject(id).common.name; id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'device') return getObject(id).common.name; id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'device') return getObject(id).common.name;
Edit:
Ich hab wohl irgendwo noch einen Fehler ??
javascript.0 (607) script.js.VIS.Sensoren_Ueberwachung: TypeError: Offline_Sensoren.split is not a function 19:27:40.685 error javascript.0 (607) at script.js.VIS.Sensoren_Ueberwachung:40:69
Oder muss ich
deviceName(id)
noch in die JS Funktion so eintragen, anstatt "name" ? Oder gar in die Variable so eintragen ?
-
@d3ltoroxp sagte: Wenn ich nun noch mehrere andere Hersteller habe, kann ich dann einfach um die Anzahl erweitern ? Bei z.b. 4 unterschiedlichen Herstellern ?
Das hat nichts mit den Herstellern zu tun, sondern mit der unterschiedlichen Objekt-Struktur der Adapter:
- Zigbee: device.state
- HM-RPC: device.channel.state
-
@d3ltoroxp sagte: noch in die JS Funktion so eintragen, anstatt "name" ?
Nein, es geht auch Name(id). Ist nur nicht so eindeutig, was zurück geliefert wird.
@d3ltoroxp sagte in [Gelöst] Sensoren überwachen + Benachrichtigung:
Offline_Sensoren.split is not a function
Nicht Text in eine Liste wandeln, sondern eine Liste in Text.
-
@paul53 Vielen vielen Dank. Sieht super aus und scheint auch seine Arbeit zu verrichten.
Also wenn noch ein weiterer Adapter dazu kommt muss ich dann noch mal was an der Funktion ändern ?
Z.b.Sonoff dazu nehmen möchte, für mich als Noob, sehen die States bei allen drei gleich aus. Woher weiß ich ober Sonoff = device.satet oder device.channel.state oder gar noch eine andere Variante hat ?
EDIT::
Ich hab das mal auf den Batterie Status umgestellt, auf "Available" sind die Zeitstempel Uhr alt. Aber wenn ich den DP raus kopiere für das Wort, tut sich da gar nichts mehr mit den Zigbee Sensoren, obwohl welche in der Liste sein müssten.
Bestimmt falsch geschrieben...
{ "type": "state", "common": { "name": "Terrasse_FK Battery percent", "type": "number", "unit": "%", "read": true, "write": false, "role": "battery.percent", "min": 0, "max": 100, "icon": "img/battery_p.png" }, "from": "system.adapter.zigbee.0", "user": "system.user.admin", "ts": 1582998804679, "_id": "zigbee.0.00158d0002e8bbbc.battery", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" } }
-
@d3ltoroxp sagte: Batterie Status umgestellt
Links ist die ID zu sehen:
@d3ltoroxp sagte in [Gelöst] Sensoren überwachen + Benachrichtigung:
Sonoff dazu nehmen möchte, für mich als Noob, sehen die States bei allen drei gleich aus.
Ich kenne die Objekt-Struktur des Sonoff-Adapters nicht. Bitte zeigen!
-
@paul53 Noch mals tausend Dank für deine tolle Unterstützung... Heute stell ich mich aber auch an. Danke für deine Geduld.
Ich hoffe das ist das richtige ?
-
@d3ltoroxp sagte: Ich hoffe das ist das richtige ?
Ja. Du möchtest den Namen "FritzBox_Ladekabel" haben? Das ist ein Kanal, kein Gerät. Hierfür benötigt man eine Funktion channelName(id) mit folgendem Inhalt:
id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'channel') return getObject(id).common.name; id = id.substring(0, id.lastIndexOf('.')); if(existsObject(id) && getObject(id).type == 'channel') return getObject(id).common.name;
-
@paul53 Ach so sorry, der blaue Marker hat nichts zu sagen. War nur zufällig. Ich hätte wäre hier auf Uptime oder auf einen Wifi DP gegangen.
-
@d3ltoroxp sagte: auf Uptime oder auf einen Wifi DP gegangen.
Den Namen doch sicherlich vom übergeordneten Objekt, das ein "channel"-Objekt ist?
-
@paul53 Ja den Namen von oben...
Kann ich das in dem JS Code mit hinzufügen ? Soll ja alles in einem Script laufen.?
-
@d3ltoroxp sagte: Kann ich das in dem JS Code mit hinzufügen ?
Ja, erstelle eine zweite JS-Funktion channelName(id) mit dem JS Code oben.
-
@paul53 Ah ja jetzt,
ein zweites und dann einfach für Sonoff dann die andere JS Funktion nutzen... Ich probierst, vielen Dank noch mal. Das andere läuft schon super !!
-
Kann ich eigentlich in der VIS auch den Zeitstempel überprüfen ? Ich würde gerne die Temps z.b. rot färben lassen, wenn der Zeitstämpel x Zeit überschreitet, damit ich weiß, er ist nicht mehr online und der Wert nicht aktuell.
Oder muss ich hier mit einem Script extra DP's mit true / false schalten und damit dann in der VIS arbeiten ?
-
@paul53 Ich hänge hier noch etwas fest.
Ich habe das für HMIP Geräte genau so gemacht, aber da spuckt er gar nichts aus. Obwohl ein Kontakt nicht erreichbar ist.Hat sich erledigt, ka. Ich hatte mal mit einer kleineren Zeit getestet da gings, die Zeit wieder hoch gesetzt dann ging's auch.