-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathgenericComponentTimeStampSensor.groovy
89 lines (80 loc) · 2.87 KB
/
genericComponentTimeStampSensor.groovy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*
Copyright 2023
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-------------------------------------------
Change history:
0.1.51 - Yves Mercier - initial version
0.1.52 - Yves Mercier - added button and health capability
0.1.59 - Yves Mercier - Change healthStatus handling
*/
metadata
{
definition(name: "Generic Component TimeStamp Sensor", namespace: "community", author: "community", importUrl: "https://raw.githubusercontent.com/ymerj/HE-HA-control/main/genericComponentTimeStampSensor.groovy")
{
capability "Refresh"
capability "PushableButton"
capability "Health Check"
}
preferences
{
input name: "txtEnable", type: "bool", title: "Enable descriptionText logging", defaultValue: true
input name: "pushRequired", type: "bool", title: "Enable pushed button event at the time reported", defaultValue: true
}
attribute "timestamp", "string"
attribute "date", "string"
attribute "healthStatus", "enum", ["offline", "online"]
}
void updated() {
log.info "Updated..."
log.warn "description logging is ${txtEnable == true}, button event is ${pushRequired == true}"
sendEvent(name: "numberOfButtons", value: 1, displayed: false)
}
void installed() {
log.info "Installed..."
device.updateSetting("txtEnable",[type:"bool",value:true])
device.updateSetting("pushRequired",[type:"bool",value:true])
updated()
refresh()
}
void parse(String description) { log.warn "parse(String description) not implemented" }
void parse(List<Map> description) {
description.each {
if (it.name in ["timestamp"]) {
if (txtEnable) log.info it.descriptionText
sendEvent(it)
if (pushRequired) scheduleFutureBtnPush(it.value)
}
if (it.name in ["healthStatus"]) {
if (txtEnable) log.info it.descriptionText
sendEvent(it)
}
}
}
def push(bn = 1) {
sendEvent(name: "pushed", value: bn, descriptionText: "${device.label} timestamp reached", isStateChange: true)
}
def scheduleFutureBtnPush(future) {
try {
def activation = toDateTime(future)
sendEvent(name: "date", value: activation)
runOnce(activation, push, [overwrite: true])
}
catch(e) {
log.error("Error: ${e}")
sendEvent(name: "date", value: "invalid")
}
}
void refresh() {
parent?.componentRefresh(this.device)
}
def ping() {
refresh()
}