Infrastruction modification
[smartthings-infrastructure.git] / SwitchLevel / SwitchLevels.groovy
index 35c4ad9669d21dbeab9a5b4e8b5b2de7c7836c7f..8e06b66bb2be89592ca51aa3a93f66adae179034 100644 (file)
 //Create a class for switch level
 package SwitchLevel
-import Timer.SimulatedTimer
+import SmartThing.SmartThings
 
-public class SwitchLevels {
-       int deviceNumbers       
-       List switchLevels
-       def timers
-       def sendEvent
+public class SwitchLevels extends SmartThings {
+       List switchLevels = new ArrayList()
 
-       //If we have only one device
-       private String id = "switchLevelID0"
-       private String label = "switchLevel0"
-       private String displayName = "switchLevel0"
-       private int level = 50
-       private int rate = 50
-       private String switchState = "off"
-       private String currentSwitch = "off"
-       private String switchLatestValue = "off"
+       SwitchLevels(Closure sendEvent, boolean init) {
+               // Only initialize one time since we only have one device for each capability
+               switchLevels = smartThings
 
-       SwitchLevels(Closure sendEvent, int deviceNumbers) {
-               this.sendEvent = sendEvent
-               this.timers = new SimulatedTimer()
-               this.deviceNumbers = deviceNumbers
-               this.switchLevels = []
+               // Initialization
+               StringBuilder id = new StringBuilder("switchLevelID0")
+               StringBuilder label = new StringBuilder("switchLevel")
+               StringBuilder displayName = new StringBuilder("switchLevel0")
+               MutableInteger level = new MutableInteger()
 
-               switchLevels.add(new SwitchLevel(sendEvent, id, label, displayName, this.level, this.switchState, this.switchLatestValue))
-       }
-
-       //Methods for closures
-       def count(Closure Input) {
-               switchLevels.count(Input)
-       }
-       def size() {
-               switchLevels.size()
-       }
-       def each(Closure Input) {
-               switchLevels.each(Input)
-       }
-       def find(Closure Input) {
-               switchLevels.find(Input)
-       }
-       def collect(Closure Input) {
-               switchLevels.collect(Input)
-       }
-
-       //By Apps
-       def setLevel(int level) {
-               if (this.level != level) {
-                       switchLevels[0].setLevel(level)
-                       this.level = level
-                       this.rate = level
-               }
-       }
-
-       def on() {
-               switchLevels[0].on()
-               switchLatestValue = switchState
-               switchState = "on"
-               currentSwitch = "on"
-       }
+               if (init)
+                       level.setValue(50)
+               else
+                       level.setValue(60)
 
-       def on(LinkedHashMap metaData) {
-               def task = timers.runAfter(metaData["delay"]) {
-                       switchLevels[0].on()
-                       switchLatestValue = switchState
-                       switchState = "on"
-                       currentSwitch = "on"
-               }
+               switchLevels.add(new SwitchLevel(sendEvent, id, label, displayName, level))
        }
 
-       def off() {
-               switchLevels[0].off()
-               switchLatestValue = switchState
-               switchState = "off"
-               currentSwitch = "off"
+       // Methods to set values
+       def setLevel(String newValue) {
+               setLevel(newValue.toInteger())
        }
 
-       def off(LinkedHashMap metaData) {
-               def task = timers.runAfter(metaData["delay"]) {
-                       switchLevels[0].off()
-                       switchLatestValue = switchState
-                       switchState = "off"
-                       currentSwitch = "off"
-               }
+       def setLevel(long newValue) {
+               setLevel((int) newValue)
        }
 
-       //By Model Checker
-       def setValue(LinkedHashMap eventDataMap) {
-               if (eventDataMap["value"] != switchLevels[0].level) {
-                       switchLevels[0].setValue(eventDataMap["value"])
-                       this.level = switchLevels[0].level
-                       this.rate = switchLevels[0].level
-                       sendEvent(eventDataMap)
-               }
+       def setLevel(int newValue) {
+               switchLevels[0].setLevel(newValue)
        }
 
-       def getAt(int ix) {
-               switchLevels[ix]
+       // Methods to return values
+       def getCurrentLevel() {
+               List tmpValues = new ArrayList()
+               tmpValues.add(switchLevels[0].getCurrentLevel())
+               return tmpValues
        }
 }