mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-04-18 14:23:07 +01:00
Compare commits
8 Commits
Dianoga-we
...
MSA-1693-1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
93219abcc8 | ||
|
|
4b8e94b7ca | ||
|
|
c028515fcd | ||
|
|
751c98d123 | ||
|
|
5b874e8f3a | ||
|
|
9e10405527 | ||
|
|
32ceaff54d | ||
|
|
5b1da30a47 |
@@ -22,9 +22,10 @@ metadata {
|
|||||||
capability "Sensor"
|
capability "Sensor"
|
||||||
capability "Health Check"
|
capability "Health Check"
|
||||||
|
|
||||||
fingerprint mfr:"0063", prod:"4457", deviceJoinName: "Z-Wave Wall Dimmer"
|
fingerprint mfr:"0063", prod:"4457", deviceJoinName: "GE In-Wall Smart Dimmer "
|
||||||
fingerprint mfr:"0063", prod:"4944", deviceJoinName: "Z-Wave Wall Dimmer"
|
fingerprint mfr:"0063", prod:"4944", deviceJoinName: "GE In-Wall Smart Dimmer "
|
||||||
fingerprint mfr:"0063", prod:"5044", deviceJoinName: "Z-Wave Plug-In Dimmer"
|
fingerprint mfr:"0063", prod:"5044", deviceJoinName: "GE Plug-In Smart Dimmer "
|
||||||
|
fingerprint mfr:"0063", prod:"4944", model:"3034", deviceJoinName: "GE In-Wall Smart Fan Control"
|
||||||
}
|
}
|
||||||
|
|
||||||
simulator {
|
simulator {
|
||||||
|
|||||||
@@ -16,15 +16,12 @@
|
|||||||
*
|
*
|
||||||
* Date: 2013-04-30
|
* Date: 2013-04-30
|
||||||
*/
|
*/
|
||||||
// for the UI
|
|
||||||
metadata {
|
metadata {
|
||||||
// Automatically generated. Make future change here.
|
|
||||||
definition (name: "SmartWeather Station Tile", namespace: "smartthings", author: "SmartThings") {
|
definition (name: "SmartWeather Station Tile", namespace: "smartthings", author: "SmartThings") {
|
||||||
capability "Illuminance Measurement"
|
capability "Illuminance Measurement"
|
||||||
capability "Temperature Measurement"
|
capability "Temperature Measurement"
|
||||||
capability "Relative Humidity Measurement"
|
capability "Relative Humidity Measurement"
|
||||||
capability "Sensor"
|
capability "Sensor"
|
||||||
capability "Polling"
|
|
||||||
|
|
||||||
attribute "localSunrise", "string"
|
attribute "localSunrise", "string"
|
||||||
attribute "localSunset", "string"
|
attribute "localSunset", "string"
|
||||||
@@ -217,7 +214,7 @@ def poll() {
|
|||||||
send(name: "localSunrise", value: localSunrise, descriptionText: "Sunrise today is at $localSunrise")
|
send(name: "localSunrise", value: localSunrise, descriptionText: "Sunrise today is at $localSunrise")
|
||||||
send(name: "localSunset", value: localSunset, descriptionText: "Sunset today at is $localSunset")
|
send(name: "localSunset", value: localSunset, descriptionText: "Sunset today at is $localSunset")
|
||||||
|
|
||||||
send(name: "illuminance", value: estimateLux(obs.solarradiation, sunriseDate, sunsetDate, weatherIcon) as Integer)
|
send(name: "illuminance", value: estimateLux(sunriseDate, sunsetDate, weatherIcon))
|
||||||
|
|
||||||
// Forecast
|
// Forecast
|
||||||
def f = get("forecast")
|
def f = get("forecast")
|
||||||
@@ -308,54 +305,49 @@ private send(map) {
|
|||||||
sendEvent(map)
|
sendEvent(map)
|
||||||
}
|
}
|
||||||
|
|
||||||
private estimateLux(solarradiation, sunriseDate, sunsetDate, weatherIcon) {
|
private estimateLux(sunriseDate, sunsetDate, weatherIcon) {
|
||||||
def lux = 0
|
def lux = 0
|
||||||
|
def now = new Date().time
|
||||||
if (solarradiation != '--') {
|
if (now > sunriseDate.time && now < sunsetDate.time) {
|
||||||
lux = solarradiation.toDouble() / 0.0079
|
//day
|
||||||
} else {
|
switch(weatherIcon) {
|
||||||
def now = new Date().time
|
case 'tstorms':
|
||||||
if (now > sunriseDate.time && now < sunsetDate.time) {
|
lux = 200
|
||||||
//day
|
break
|
||||||
switch(weatherIcon) {
|
case ['cloudy', 'fog', 'rain', 'sleet', 'snow', 'flurries',
|
||||||
case 'tstorms':
|
'chanceflurries', 'chancerain', 'chancesleet',
|
||||||
lux = 200
|
'chancesnow', 'chancetstorms']:
|
||||||
break
|
lux = 1000
|
||||||
case ['cloudy', 'fog', 'rain', 'sleet', 'snow', 'flurries',
|
break
|
||||||
'chanceflurries', 'chancerain', 'chancesleet',
|
case 'mostlycloudy':
|
||||||
'chancesnow', 'chancetstorms']:
|
lux = 2500
|
||||||
lux = 1000
|
break
|
||||||
break
|
case ['partlysunny', 'partlycloudy', 'hazy']:
|
||||||
case 'mostlycloudy':
|
lux = 7500
|
||||||
lux = 2500
|
break
|
||||||
break
|
default:
|
||||||
case ['partlysunny', 'partlycloudy', 'hazy']:
|
//sunny, clear
|
||||||
lux = 7500
|
lux = 10000
|
||||||
break
|
|
||||||
default:
|
|
||||||
//sunny, clear
|
|
||||||
lux = 10000
|
|
||||||
}
|
|
||||||
|
|
||||||
//adjust for dusk/dawn
|
|
||||||
def afterSunrise = now - sunriseDate.time
|
|
||||||
def beforeSunset = sunsetDate.time - now
|
|
||||||
def oneHour = 1000 * 60 * 60
|
|
||||||
|
|
||||||
if(afterSunrise < oneHour) {
|
|
||||||
//dawn
|
|
||||||
lux = (long)(lux * (afterSunrise/oneHour))
|
|
||||||
} else if (beforeSunset < oneHour) {
|
|
||||||
//dusk
|
|
||||||
lux = (long)(lux * (beforeSunset/oneHour))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
//night - always set to 10 for now
|
//adjust for dusk/dawn
|
||||||
//could do calculations for dusk/dawn too
|
def afterSunrise = now - sunriseDate.time
|
||||||
lux = 10
|
def beforeSunset = sunsetDate.time - now
|
||||||
|
def oneHour = 1000 * 60 * 60
|
||||||
|
|
||||||
|
if(afterSunrise < oneHour) {
|
||||||
|
//dawn
|
||||||
|
lux = (long)(lux * (afterSunrise/oneHour))
|
||||||
|
} else if (beforeSunset < oneHour) {
|
||||||
|
//dusk
|
||||||
|
lux = (long)(lux * (beforeSunset/oneHour))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
//night - always set to 10 for now
|
||||||
|
//could do calculations for dusk/dawn too
|
||||||
|
lux = 10
|
||||||
|
}
|
||||||
|
|
||||||
lux
|
lux
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,6 +24,10 @@ metadata {
|
|||||||
fingerprint inClusters: "0x26", deviceJoinName: "Z-Wave Dimmer"
|
fingerprint inClusters: "0x26", deviceJoinName: "Z-Wave Dimmer"
|
||||||
fingerprint mfr:"001D", prod:"1902", deviceJoinName: "Z-Wave Dimmer"
|
fingerprint mfr:"001D", prod:"1902", deviceJoinName: "Z-Wave Dimmer"
|
||||||
fingerprint mfr:"001D", prod:"1B03", model:"0334", deviceJoinName: "Leviton Universal Dimmer"
|
fingerprint mfr:"001D", prod:"1B03", model:"0334", deviceJoinName: "Leviton Universal Dimmer"
|
||||||
|
fingerprint mfr:"011A", prod:"0102", model:"0201", deviceJoinName: "Enerwave In-Wall Dimmer"
|
||||||
|
fingerprint mfr:"001D", prod:"1001", model:"0334", deviceJoinName: "Leviton 3-Speed Fan Controller"
|
||||||
|
fingerprint mfr:"001D", prod:"0602", model:"0334", deviceJoinName: "Leviton Magnetic Low Voltage Dimmer"
|
||||||
|
fingerprint mfr:"001D", prod:"0401", model:"0334", deviceJoinName: "Leviton 600W Incandescent Dimmer"
|
||||||
}
|
}
|
||||||
|
|
||||||
simulator {
|
simulator {
|
||||||
|
|||||||
@@ -25,6 +25,9 @@ metadata {
|
|||||||
fingerprint mfr:"0063", prod:"4F50", model:"3031", deviceJoinName: "GE Plug-in Outdoor Switch"
|
fingerprint mfr:"0063", prod:"4F50", model:"3031", deviceJoinName: "GE Plug-in Outdoor Switch"
|
||||||
fingerprint mfr:"001D", prod:"1D04", model:"0334", deviceJoinName: "Leviton Outlet"
|
fingerprint mfr:"001D", prod:"1D04", model:"0334", deviceJoinName: "Leviton Outlet"
|
||||||
fingerprint mfr:"001D", prod:"1C02", model:"0334", deviceJoinName: "Leviton Switch"
|
fingerprint mfr:"001D", prod:"1C02", model:"0334", deviceJoinName: "Leviton Switch"
|
||||||
|
fingerprint mfr:"001D", prod:"0301", model:"0334", deviceJoinName: "Leviton 15A Switch"
|
||||||
|
fingerprint mfr:"011A", prod:"0101", model:"0102", deviceJoinName: "Enerwave On/Off Switch"
|
||||||
|
fingerprint mfr:"011A", prod:"0101", model:"0603", deviceJoinName: "Enerwave Duplex Receptacle"
|
||||||
}
|
}
|
||||||
|
|
||||||
// simulator metadata
|
// simulator metadata
|
||||||
|
|||||||
@@ -0,0 +1,125 @@
|
|||||||
|
//==================================================================================
|
||||||
|
/**
|
||||||
|
* Motion-Switch-Sched SmartApp
|
||||||
|
*
|
||||||
|
* Copyright 2017 PASCI Ciro Ippolito 2017
|
||||||
|
***********************************************************************************
|
||||||
|
* 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: "Motion Switch SmartTimeframe",
|
||||||
|
namespace: "PASCI",
|
||||||
|
author: "PASCI",
|
||||||
|
description: "Motion Activated switch + Override timeframe.",
|
||||||
|
category: "Convenience",
|
||||||
|
iconUrl: "http://cdn.device-icons.smartthings.com/Home/home30-icn@2x.png",
|
||||||
|
iconX2Url: "http://cdn.device-icons.smartthings.com/Home/home30-icn@2x.png",
|
||||||
|
iconX3Url: "http://cdn.device-icons.smartthings.com/Home/home30-icn@2x.png"
|
||||||
|
)
|
||||||
|
//iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png",
|
||||||
|
//iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png",
|
||||||
|
//iconX3Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png")
|
||||||
|
//==================================================================================
|
||||||
|
preferences {
|
||||||
|
section("When MOTION is detected") {
|
||||||
|
input "themotion", "capability.motionSensor", required: true, title: "WHERE"
|
||||||
|
}
|
||||||
|
section("Turn ON this SWITCH") {
|
||||||
|
input "OUTLE", "capability.switch", required: true, title: "WHICH"
|
||||||
|
}
|
||||||
|
section("ON for how long") {
|
||||||
|
input "minutes", "number", required: true, title: "MINUTES)"
|
||||||
|
}
|
||||||
|
section("ON OVERRIDE time frame (if there is no motion)") {
|
||||||
|
input "FROMTime", "time", title: "From", required: true
|
||||||
|
input "TOTime", "time", title: "To", required: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def installed() {
|
||||||
|
log.debug "Installed with settings: ${settings}"
|
||||||
|
initialize()
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def updated() {
|
||||||
|
log.debug "Updated with settings: ${settings}"
|
||||||
|
unsubscribe()
|
||||||
|
initialize()
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def initialize() {
|
||||||
|
log.debug "Installata at: " + now()
|
||||||
|
schedule(FROMTime, handlerFROMTIME)
|
||||||
|
schedule(TOTime, handlerTOTime)
|
||||||
|
subscribe(themotion, "motion.active", handler_Motion___Active)
|
||||||
|
subscribe(themotion, "motion.inactive", handler_motion_inactive)
|
||||||
|
}
|
||||||
|
// HANDLERS
|
||||||
|
//==================================================================================
|
||||||
|
def handlerFROMTIME() {
|
||||||
|
log.debug "FROM TIME at ${new Date()}"
|
||||||
|
OUTLE.on()
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def handlerTOTime() {
|
||||||
|
log.debug "TO TIME at ${new Date()}"
|
||||||
|
checkMotion();
|
||||||
|
/*
|
||||||
|
def motionState = themotion.currentState("motion")
|
||||||
|
log.debug "state of motion sensor is: " + motionState.value
|
||||||
|
log.debug "TURN OFF at ${new Date()}"
|
||||||
|
log.debug "state of motion sensor is: " + themotion.motion
|
||||||
|
if (motionState.value == "active"){
|
||||||
|
log.debug "state of motion sensor is ACTIVE"
|
||||||
|
}else{
|
||||||
|
OUTLE.off()
|
||||||
|
log.debug "state of motion sensor is INACTIVE"
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def handler_Motion___Active(evt) {
|
||||||
|
log.debug("MOT Active")
|
||||||
|
OUTLE.on()
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def handler_motion_inactive(evt) {
|
||||||
|
log.debug("MOT Inactive")
|
||||||
|
def between = timeOfDayIsBetween(FROMTime, TOTime, new Date(), location.timeZone)
|
||||||
|
if (between) {
|
||||||
|
log.debug("It dasan't mattar Christopha")
|
||||||
|
OUTLE.on()
|
||||||
|
} else {
|
||||||
|
runIn(60 * minutes, checkMotion)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
def checkMotion() {
|
||||||
|
log.debug "In checkMotion scheduled method"
|
||||||
|
// get the current state object for the motion sensor
|
||||||
|
def motionState = themotion.currentState("motion")
|
||||||
|
if (motionState.value == "inactive") {
|
||||||
|
def elapsed = now() - motionState.date.time // time elapsed between now and when the motion reported inactive
|
||||||
|
def threshold = 1000 * 60 * minutes // elapsed time is in milliseconds
|
||||||
|
if (elapsed >= threshold) {
|
||||||
|
log.debug "Motion has stayed inactive long enough since last check ($elapsed ms): turning switch off"
|
||||||
|
OUTLE.off()
|
||||||
|
} else {
|
||||||
|
log.debug "Motion has not stayed inactive long enough since last check ($elapsed ms): doing nothing"
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Motion active; just log it and do nothing
|
||||||
|
log.debug "Motion is active, do nothing and wait for inactive"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
//==================================================================================
|
||||||
Reference in New Issue
Block a user