Fixing bug in Mobile Presence class
[smartthings-infrastructure.git] / ColorControl / ColorControl.groovy
index 4878c48b9f82c55e43a105068269d29e1b6f02dc..4380f24408c0c5534d994ae06440b5625101a79c 100644 (file)
@@ -1,69 +1,34 @@
 //Create a class for color control
 package ColorControl
-import Timer.SimulatedTimer
+import SmartThing.SmartThing
 
+public class ColorControl extends SmartThing {
+       // id, label, and display name of the device
+       String id
+       String label
+       String displayName
+       // Maps from features to values
+       HashMap<String, String> deviceValuesMap = new HashMap<String, String>()
+       HashMap<String, Integer> deviceIntValuesMap = new HashMap<String, Integer>()
 
-public class ColorControl {
-       def sendEvent
-       private String id
-       private String label
-       private String displayName
-       private String color
-       private String currentColor
-       private String currentSwitch
-       private int level
-       private int currentLevel
-       private int hue
-       private int currentHue
-       private int saturation
-       private int currentSaturation
-       private int colorTemperature
-       
-       ColorControl(Closure sendEvent, String id, String label, String displayName, String color, int hue, int saturation, int level, String currentSwitch, int colorTemperature) {
+       ColorControl(Closure sendEvent, String id, String label, String displayName, String currentColor, Integer currentHue, Integer currentSaturation) {
+               deviceValueSmartThing = deviceValuesMap
+               deviceIntValueSmartThing = deviceIntValuesMap
+               idSmartThing = id
+               labelSmartThing = label
+               displayNameSmartThing = displayName
+               sendEventSmartThings = sendEvent
+
+               // Initialization
                this.id = id
                this.label = label
                this.displayName = displayName
-               this.color = color
-               this.currentColor = color
-               this.hue = hue
-               this.currentHue = hue
-               this.saturation = saturation
-               this.currentSaturation = saturation
-               this.level = level
-               this.currentLevel = level
-               this.currentSwitch = currentSwitch
-               this.colorTemperature = colorTemperature
-               this.sendEvent = sendEvent
-       }
-       
-       //By model checker
-       def setValue(String value, String name) {
-               if ((name == "color") && (value != this.color)) {
-                       this.color = value
-                       this.currentColor = value
-                       println("the color of the light is changed to $value!")
-               } else if ((name == "hue") && (value != this.hue)) {
-                       this.hue = value.toInteger()
-                       this.currentHue = value.toInteger()
-                       println("The hue level of the light is changed to $value!")
-               } else if ((name == "saturation") && (value != this.saturation)) {
-                       this.saturation = value.toInteger()
-                       this.currentSaturation = value.toInteger()
-                       println("The saturation level of the light is changed to $value!")
-               } else if ((name == "level") && (value != this.level)) {
-                       this.currentLevel = value.toInteger()
-                       this.level = value.toInteger()
-                       println("The level of the light is changed to $value!")
-               } else if ((name == "currentSwitch") && (value != this.currentSwitch)) {
-                       this.currentSwitch = value
-                       println("The light is changed to $value!")
-               } else if ((name == "colorTemperature") && (value != this.colorTemperature)) {
-                       this.colorTemperature = value.toInteger()
-                       println("The color temperature level of the light is changed to $value!")
-               }
+
+               deviceValuesMap.put("color", currentColor)
+               deviceIntValuesMap.put("hue", currentHue)
+               deviceIntValuesMap.put("saturation", currentSaturation)
        }
 
-       //methods
        def setColor(LinkedHashMap metaData) {
                def hexColor = metaData.hex
                def newColor
@@ -93,111 +58,27 @@ public class ColorControl {
                                newColor = "Blue"
                                break;
                }
-               if (newColor != this.color) {
-                       this.currentColor = newColor
-                       this.color = newColor
-                       println("The color of the light is changed to $newColor!")
-                       sendEvent([name: "color", value: "$newColor", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
-       }
-
-       def setColor(String color) {
-               if (color != this.color) {
-                       this.currentColor = color
-                       this.color = color
-                       println("The color of the light is changed to $color!")
-                       sendEvent([name: "color", value: "$color", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
-       }
-
-       def setHue(int hue) {
-               if (hue != this.hue) {
-                       this.hue = hue
-                       this.currentHue = hue
-                       println("The hue level of the light is changed to $hue!")
-                       sendEvent([name: "hue", value: "$hue", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
-       }
-
-       def setSaturation(int saturation) {
-               if (saturation != this.saturation) {
-                       this.currentSaturation = saturation
-                       this.saturation = saturation
-                       println("The saturation level of the light is changed to $saturation!")
-                       sendEvent([name: "saturation", value: "$saturation", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
+               setColor(newColor)
        }
 
-       def setLevel(int level) {
-               if (level != this.level) {
-                       this.currentLevel = level
-                       this.level = level
-                       println("The level of the light is changed to $level!")
-                       sendEvent([name: "level", value: "$level", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
+       // Methods to set values
+       def setColor(String newValue) {
+               action(newValue, "color")
        }
 
-       def setColorTemperature(int colorTemperature) {
-               if (colorTemperature != this.colorTemperature) {
-                       this.colorTemperature = colorTemperature
-                       println("The color temperature level of the light is changed to $colorTemperature!")
-                       sendEvent([name: "colorTemperature", value: "$colorTemperature", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
-       }
-
-       def on() {
-               if (this.currentSwitch != "on") {
-                       this.currentSwitch = currentSwitch
-                       println("The light is changed to on!")
-                       sendEvent([name: "switch", value: "on", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
+       def setHue(int newValue) {
+               action(newValue, "hue")
        }
-
-       def off() {
-               if (this.currentSwitch != "off") {
-                       this.currentSwitch = currentSwitch
-                       println("The light is changed to off!")
-                       sendEvent([name: "switch", value: "off", deviceId: this.id, descriptionText: "",
-                                  displayed: true, linkText: "", isStateChange: false, unit: "", data: '{"info": "info"}'])
-               }
+       
+       def setHue(double newValue) {
+               setHue((int) newValue)
        }
 
-       def currentValue(String deviceFeature) {
-               if (deviceFeature == "color") {
-                       return color
-               } else if (deviceFeature == "saturation") {
-                       return saturation
-               } else if (deviceFeature == "hue") {
-                       return hue
-               } else if (deviceFeature == "level") {
-                       return level
-               } else if (deviceFeature == "colorTemperature") {
-                       return colorTemperature
-               } else if (deviceFeature == "switch") {
-                       return currentSwitch
-               }
+       def setSaturation(int newValue) {
+               action(newValue, "saturation")
        }
-
-       def latestValue(String deviceFeature) {
-               if (deviceFeature == "color") {
-                       return color
-               } else if (deviceFeature == "saturation") {
-                       return saturation
-               } else if (deviceFeature == "hue") {
-                       return hue
-               } else if (deviceFeature == "level") {
-                       return level
-               } else if (deviceFeature == "colorTemperature") {
-                       return colorTemperature
-               } else if (deviceFeature == "switch") {
-                       return currentSwitch
-               }
+       
+       def setSaturation(double newValue) {
+               setSaturation((int) newValue)
        }
 }