mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-03-26 05:14:11 +00:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9a3614547e |
@@ -25,6 +25,7 @@ metadata {
|
|||||||
fingerprint profileId: "0104", inClusters: "0000, 0003, 0004, 0005, 0006, 0008, 0B04, FC0F", outClusters: "0019", manufacturer: "OSRAM", model: "LIGHTIFY A19 ON/OFF/DIM", deviceJoinName: "OSRAM LIGHTIFY LED Smart Connected Light"
|
fingerprint profileId: "0104", inClusters: "0000, 0003, 0004, 0005, 0006, 0008, 0B04, FC0F", outClusters: "0019", manufacturer: "OSRAM", model: "LIGHTIFY A19 ON/OFF/DIM", deviceJoinName: "OSRAM LIGHTIFY LED Smart Connected Light"
|
||||||
fingerprint profileId: "0104", inClusters: "0000, 0003, 0004, 0005, 0006, 0008, FF00", outClusters: "0019", manufacturer: "MRVL", model: "MZ100", deviceJoinName: "Wemo Bulb"
|
fingerprint profileId: "0104", inClusters: "0000, 0003, 0004, 0005, 0006, 0008, FF00", outClusters: "0019", manufacturer: "MRVL", model: "MZ100", deviceJoinName: "Wemo Bulb"
|
||||||
fingerprint profileId: "0104", inClusters: "0000, 0003, 0004, 0005, 0006, 0008, 0B05", outClusters: "0019", manufacturer: "OSRAM SYLVANIA", model: "iQBR30", deviceJoinName: "Sylvania Ultra iQ"
|
fingerprint profileId: "0104", inClusters: "0000, 0003, 0004, 0005, 0006, 0008, 0B05", outClusters: "0019", manufacturer: "OSRAM SYLVANIA", model: "iQBR30", deviceJoinName: "Sylvania Ultra iQ"
|
||||||
|
fingerprint profileId: "0104", inClusters: "0000, 0001, 0300, 0006, 0008", outClusters: "0019", manufacturer: "OSRAM", model: "ZHA_LIGHTIFY_COLOR_A19", deviceJoinName: "OSRAM LIGHTIFY COLOR SMART A19"
|
||||||
}
|
}
|
||||||
|
|
||||||
tiles(scale: 2) {
|
tiles(scale: 2) {
|
||||||
@@ -86,4 +87,4 @@ def refresh() {
|
|||||||
def configure() {
|
def configure() {
|
||||||
log.debug "Configuring Reporting and Bindings."
|
log.debug "Configuring Reporting and Bindings."
|
||||||
zigbee.onOffConfig() + zigbee.levelConfig() + zigbee.onOffRefresh() + zigbee.levelRefresh()
|
zigbee.onOffConfig() + zigbee.levelConfig() + zigbee.onOffRefresh() + zigbee.levelRefresh()
|
||||||
}
|
}
|
||||||
@@ -1,105 +0,0 @@
|
|||||||
/**
|
|
||||||
* Light Up The Night
|
|
||||||
*
|
|
||||||
* Copyright 2015 Brian Warner
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
definition(
|
|
||||||
name: "Light Up The Night",
|
|
||||||
namespace: "brianwarner",
|
|
||||||
author: "Brian Warner",
|
|
||||||
description: "Turn on certain lights when a door opens at night, and turn them off a certain time after the last door closes. Great for garage doors and driveway lights.",
|
|
||||||
category: "Convenience",
|
|
||||||
iconUrl: "http://cdn.device-icons.smartthings.com/Lighting/light9-icn.png",
|
|
||||||
iconX2Url: "http://cdn.device-icons.smartthings.com/Lighting/light9-icn@2x.png",
|
|
||||||
iconX3Url: "http://cdn.device-icons.smartthings.com/Lighting/light9-icn@3x.png")
|
|
||||||
|
|
||||||
|
|
||||||
preferences {
|
|
||||||
|
|
||||||
section() {
|
|
||||||
input "contactsensors", "capability.contactSensor", multiple: true, title: "When these doors open:"
|
|
||||||
}
|
|
||||||
|
|
||||||
section() {
|
|
||||||
input "lights", "capability.switch", required: true, multiple: true, title: "Turn on these lights:"
|
|
||||||
}
|
|
||||||
|
|
||||||
section() {
|
|
||||||
input "timer", "number", required: true, title: "Keep them on until all doors are closed for this many minutes:", range: "0..240"
|
|
||||||
}
|
|
||||||
|
|
||||||
section() {
|
|
||||||
input "sunriseoffset", "number", required: true, title: "Start turning on the lights this many minutes before sunset:", range: "0..360"
|
|
||||||
}
|
|
||||||
|
|
||||||
section() {
|
|
||||||
input "sunsetoffset", "number", required: true, title: "Stop turning on the lights this many minutes after sunrise:", range: "0..360"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
def installed() {
|
|
||||||
log.debug "Installed with settings: ${settings}"
|
|
||||||
|
|
||||||
initialize()
|
|
||||||
}
|
|
||||||
|
|
||||||
def updated() {
|
|
||||||
log.debug "Updated with settings: ${settings}"
|
|
||||||
|
|
||||||
unsubscribe()
|
|
||||||
initialize()
|
|
||||||
}
|
|
||||||
|
|
||||||
def initialize() {
|
|
||||||
subscribe(garagedoors, "door.open", doorOpenHandler)
|
|
||||||
subscribe(garagedoors, "door.closed", doorClosedHandler)
|
|
||||||
subscribe(contactsensors, "contact.open", doorOpenHandler)
|
|
||||||
subscribe(contactsensors, "contact.closed", doorClosedHandler)
|
|
||||||
}
|
|
||||||
|
|
||||||
def doorOpenHandler(evt) {
|
|
||||||
// log.debug "Door opened."
|
|
||||||
def now = new Date()
|
|
||||||
def sunTime = getSunriseAndSunset(sunriseOffset: "00:$sunriseoffset", sunsetOffset: "-00:$sunsetoffset")
|
|
||||||
|
|
||||||
if (now > sunTime.sunset || now < sunTime.sunrise) {
|
|
||||||
// log.debug "Turning lights on."
|
|
||||||
lights.on()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
def doorClosedHandler(evt) {
|
|
||||||
// log.debug "A door closed."
|
|
||||||
runIn(60 * timer, checkClosed)
|
|
||||||
}
|
|
||||||
|
|
||||||
def checkClosed() {
|
|
||||||
// log.debug "Checking to ensure all doors are still closed."
|
|
||||||
|
|
||||||
def contactSensorState = contactsensors.currentState("contact")
|
|
||||||
def anyContactSensorsOpen = contactSensorState.value.findAll {it == "open"}
|
|
||||||
|
|
||||||
if (!anyContactSensorsOpen) {
|
|
||||||
def elapsed = now() - contactSensorState.date.time.max()
|
|
||||||
def timeout = 1000 * 60 * timer
|
|
||||||
|
|
||||||
if (elapsed >= timeout) {
|
|
||||||
// log.debug "Doors have stayed closed. Turning off the lights."
|
|
||||||
lights.off()
|
|
||||||
} else {
|
|
||||||
// log.debug "Doors were opened. Wait a little longer."
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// log.debug "It appears a door is still open."
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user