Compare commits

..

1 Commits

Author SHA1 Message Date
ipl
b4108d359b MSA-1688: Ijini Helper Test Programe 2017-01-03 20:55:39 -08:00
2 changed files with 51 additions and 71 deletions

View File

@@ -1,71 +0,0 @@
/**
* Chime When Open
*
*/
definition(
name: "Chime When Open",
namespace: "ehrhardt",
author: "John Ehrhardt",
description: "Play a tone when some sensors being open",
category: "Convenience",
iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png",
iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png"
)
preferences {
section("When any of these are open...") {
input "doorSensor", "capability.contactSensor", title: "Door Sensor", required: true, multiple: true
}
section("Play a tone on this device:") {
input "toneDevice", "capability.audioNotification", title: "Audio Playback Device", required: true
input "toneTrack", "number", title: "Tone Track (1-100)"
}
section("Play Tones During this timeframe")
{
input "starting", "time", title: "Start time", required: true
input "ending", "time", title: "End time", required: true
}
}
def installed() {
log.debug "Installed with settings: ${settings}"
initialize()
}
def updated() {
log.debug "Updated with settings: ${settings}"
unsubscribe()
initialize()
}
def initialize() {
subscribe(doorSensor, "contact", contactHandler)
}
def contactHandler(evt) {
log.trace "contactHandler: $evt ${evt.value}"
def openSensor = doorSensor.find{it.currentValue("contact") == "open"}
if (openSensor != null) {
def result = true
if (starting && ending) {
def currTime = now()
def start = timeToday(starting).time
def stop = timeToday(ending).time
result = start < stop ? currTime >= start && currTime <= stop : currTime <= stop || currTime >= start
}
log.trace "timeOk = $result"
if ( result ) {
log.debug "At least one sensor (${openSensor.label}) is open, play track $toneTrack"
toneDevice.playTrack(toneTrack)
log.debug( "OnHandler: timeOK and dimSetting: $dimSetting" )
} else {
log.debug( "OnHandler: !timeOK" )
}
} else {
log.debug "No sensors are open."
}
}

View File

@@ -0,0 +1,51 @@
/**
* ijinihelper2
*
* Copyright 2017 ipl
*
* 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: "ijinihelper2",
namespace: "global.ipl.ijinihelper2",
author: "ipl",
description: "ijinihelper2",
category: "SmartThings Labs",
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",
oauth: true)
preferences {
section("Title") {
// TODO: put inputs here
}
}
def installed() {
log.debug "Installed with settings: ${settings}"
initialize()
}
def updated() {
log.debug "Updated with settings: ${settings}"
unsubscribe()
initialize()
}
def initialize() {
// TODO: subscribe to attributes, devices, locations, etc.
}
// TODO: implement event handlers