platypush/platypush/backend/http/webapp/dist/static/js/3798.fcfdd0e0.js.map

1 line
38 KiB
Plaintext

{"version":3,"file":"static/js/3798.fcfdd0e0.js","mappings":"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","sources":["webpack://platypush/./src/components/panels/Light/color.js","webpack://platypush/./src/components/elements/Slider.vue","webpack://platypush/./src/components/elements/Slider.vue?787f","webpack://platypush/./src/components/elements/ToggleSwitch.vue","webpack://platypush/./src/components/elements/ToggleSwitch.vue?94aa","webpack://platypush/./src/components/panels/Entities/Light.vue","webpack://platypush/./src/components/panels/Entities/Light.vue?345c"],"sourcesContent":["export class ColorConverter {\n constructor(ranges) {\n this.ranges = {\n hue: [0, 360],\n sat: [0, 100],\n bri: [0, 100],\n ct: [154, 500],\n }\n\n if (ranges)\n for (const attr of Object.keys(this.ranges))\n if (ranges[attr])\n this.ranges[attr] = ranges[attr]\n }\n\n normalize(x, xRange, yRange) {\n return yRange[0] + (((x-xRange[0]) * (yRange[1]-yRange[0])) / (xRange[1]-xRange[0]))\n }\n\n hslToRgb(h, s, l) {\n [h, s, l] = [\n this.normalize(h, this.ranges.hue, [0, 360]),\n this.normalize(s, this.ranges.sat, [0, 100]),\n this.normalize(l, this.ranges.bri, [0, 100]),\n ]\n\n l /= 100\n const a = s * Math.min(l, 1 - l) / 100\n const f = n => {\n const k = (n + h / 30) % 12\n const color = l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1)\n return Math.round(255 * color)\n }\n\n return [f(0), f(8), f(4)]\n }\n\n rgbToHsl(r, g, b){\n r /= 255\n g /= 255\n b /= 255;\n const max = Math.max(r, g, b), min = Math.min(r, g, b);\n let h, s, l = (max + min) / 2;\n\n if(max === min){\n h = s = 0; // achromatic\n } else {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch(max){\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n\n return [\n parseInt(this.normalize(h, [0, 1], this.ranges.hue)),\n parseInt(this.normalize(s, [0, 1], this.ranges.sat)),\n parseInt(this.normalize(l, [0, 1], this.ranges.bri)),\n ]\n }\n\n xyToRgb(x, y, brightness) {\n // Set to maximum brightness if no custom value was given (Not the slick ECMAScript 6 way for compatibility reasons)\n if (brightness == null)\n brightness = this.ranges.bri[1];\n\n const z = 1.0 - x - y;\n const Y = (brightness / (this.ranges.bri[1]-1)).toFixed(2);\n const X = (Y / y) * x;\n const Z = (Y / y) * z;\n\n //Convert to RGB using Wide RGB D65 conversion\n let red \t= X * 1.656492 - Y * 0.354851 - Z * 0.255038;\n let green = -X * 0.707196 + Y * 1.655397 + Z * 0.036152;\n let blue \t= X * 0.051713 - Y * 0.121364 + Z * 1.011530;\n\n //If red, green or blue is larger than 1.0 set it back to the maximum of 1.0\n if (red > blue && red > green && red > 1.0) {\n green = green / red;\n blue = blue / red;\n red = 1.0;\n } else if (green > blue && green > red && green > 1.0) {\n red = red / green;\n blue = blue / green;\n green = 1.0;\n } else if (blue > red && blue > green && blue > 1.0) {\n red = red / blue;\n green = green / blue;\n blue = 1.0;\n }\n\n //Reverse gamma correction\n red \t= red <= 0.0031308 ? 12.92 * red : (1.0 + 0.055) * Math.pow(red, (1.0 / 2.4)) - 0.055;\n green \t= green <= 0.0031308 ? 12.92 * green : (1.0 + 0.055) * Math.pow(green, (1.0 / 2.4)) - 0.055;\n blue \t= blue <= 0.0031308 ? 12.92 * blue : (1.0 + 0.055) * Math.pow(blue, (1.0 / 2.4)) - 0.055;\n\n //Convert normalized decimal to decimal\n red \t= Math.round(red * 255);\n green \t= Math.round(green * 255);\n blue \t= Math.round(blue * 255);\n\n if (isNaN(red))\n red = 0;\n if (isNaN(green))\n green = 0;\n if (isNaN(blue))\n blue = 0;\n\n return [red, green, blue].map(\n (c) => Math.min(Math.max(0, c), 255)) // lgtm [js/automatic-semicolon-insertion]\n }\n\n rgbToXY(red, green, blue) {\n if (red > 1) { red /= 255; }\n if (green > 1) { green /= 255; }\n if (blue > 1) { blue /= 255; }\n\n //Apply a gamma correction to the RGB values, which makes the color more vivid and more the like the color displayed on the screen of your device\n red \t= (red > 0.04045) ? Math.pow((red + 0.055) / (1.0 + 0.055), 2.4) : (red / 12.92);\n green \t= (green > 0.04045) ? Math.pow((green + 0.055) / (1.0 + 0.055), 2.4) : (green / 12.92);\n blue \t= (blue > 0.04045) ? Math.pow((blue + 0.055) / (1.0 + 0.055), 2.4) : (blue / 12.92);\n\n //RGB values to XYZ using the Wide RGB D65 conversion formula\n const X \t\t= red * 0.664511 + green * 0.154324 + blue * 0.162028;\n const Y \t\t= red * 0.283881 + green * 0.668433 + blue * 0.047685;\n const Z \t\t= red * 0.000088 + green * 0.072310 + blue * 0.986039;\n\n //Calculate the xy values from the XYZ values\n let x \t\t= parseFloat((X / (X + Y + Z)).toFixed(4));\n let y \t\t= parseFloat((Y / (X + Y + Z)).toFixed(4));\n\n if (isNaN(x))\n x = 0;\n if (isNaN(y))\n y = 0;\n\n return [x, y];\n }\n\n rgbToBri(red, green, blue) {\n return Math.min(2 * this.rgbToHsl(red, green, blue)[2], this.ranges.bri[1])\n }\n\n getRGB(color) {\n if (color.red != null && color.green != null && color.blue != null)\n return [color.red, color.green, color.blue]\n if (color.r != null && color.g != null && color.b != null)\n return [color.r, color.g, color.b]\n if (color.rgb)\n return color.rgb\n }\n\n getXY(color) {\n if (color.x != null && color.y != null)\n return [color.x, color.y]\n if (color.xy)\n return color.xy\n }\n\n toRGB(color) {\n const rgb = this.getRGB(color)\n if (rgb)\n return rgb\n\n const xy = this.getXY(color)\n if (xy && color.bri)\n return this.xyToRgb(...xy, color.bri)\n if (color.hue && color.sat && color.bri)\n return this.hslToRgb(color.hue, color.sat, color.bri)\n\n console.debug('Could not determine color space')\n console.debug(color)\n }\n\n toXY(color) {\n const xy = this.getXY(color)\n if (xy && color.bri)\n return [xy[0], xy[1], color.bri]\n\n const rgb = this.getRGB(color)\n if (rgb)\n return this.rgbToXY(...rgb)\n\n if (color.hue && color.sat && color.bri) {\n const rgb = this.hslToRgb(color.hue, color.sat, color.bri)\n return this.rgbToXY(...rgb)\n }\n\n console.debug('Could not determine color space')\n console.debug(color)\n }\n\n toHSL(color) {\n if (color.hue && color.sat && color.bri)\n return [color.hue, color.sat, color.bri]\n\n const rgb = this.getRGB(color)\n if (rgb)\n return this.rgbToHsl(...rgb)\n\n const xy = this.getXY(color)\n if (xy && color.bri) {\n const rgb = this.xyToRgb(...xy, color.bri)\n return this.rgbToHsl(...rgb)\n }\n\n console.debug('Could not determine color space')\n console.debug(color)\n }\n\n hexToRgb(hex) {\n return [\n hex.slice(1, 3),\n hex.slice(3, 5),\n hex.slice(5, 7),\n ].map(_ => parseInt(_, 16))\n }\n\n rgbToHex(rgb) {\n return '#' + rgb.map((x) => {\n let hex = x.toString(16)\n if (hex.length < 2)\n hex = '0' + hex\n return hex\n }).join('')\n }\n}\n","<template>\n <label class=\"slider-wrapper\">\n <span class=\"range-labels\" :class=\"{'with-label': withLabel}\" v-if=\"withRange\">\n <span class=\"label left\" v-if=\"withRange\" v-text=\"range[0]\" />\n <span class=\"label right\" v-if=\"withRange\" v-text=\"range[1]\" />\n </span>\n\n <span class=\"slider-container\">\n <input class=\"slider\"\n type=\"range\"\n :class=\"{'with-label': withLabel}\"\n :min=\"range[0]\"\n :max=\"range[1]\"\n :step=\"step\"\n :disabled=\"disabled\"\n :value=\"value\"\n ref=\"range\"\n @input.stop=\"onUpdate\"\n @change.stop=\"onUpdate\">\n\n <div class=\"track\" :class=\"{'with-label': withLabel}\">\n <div class=\"track-inner\" ref=\"track\"></div>\n </div>\n <div class=\"thumb\" ref=\"thumb\"></div>\n <span class=\"label\" v-if=\"withLabel\" v-text=\"value\" ref=\"label\"></span>\n </span>\n </label>\n</template>\n\n<script>\nexport default {\n name: \"Slider\",\n emits: ['input', 'change', 'mouseup', 'mousedown', 'touchstart', 'touchend', 'keyup', 'keydown'],\n props: {\n value: {\n type: Number,\n },\n\n disabled: {\n type: Boolean,\n default: false,\n },\n\n range: {\n type: Array,\n default: () => [0, 100],\n },\n\n step: {\n type: Number,\n default: 1,\n },\n\n withLabel: {\n type: Boolean,\n default: false,\n },\n\n withRange: {\n type: Boolean,\n default: false,\n }\n },\n\n methods: {\n onUpdate(event) {\n this.update(event.target.value)\n this.$emit(event.type, {\n ...event,\n target: {\n ...event.target,\n value: this.$refs.range.value,\n }\n })\n },\n\n update(value) {\n const sliderWidth = this.$refs.range.clientWidth\n const percent = (value - this.range[0]) / (this.range[1] - this.range[0])\n const innerWidth = percent * sliderWidth\n const thumb = this.$refs.thumb\n\n thumb.style.left = `${innerWidth - thumb.clientWidth / 2}px`\n this.$refs.thumb.style.transform = `translate(-${percent}%, -50%)`\n this.$refs.track.style.width = `${innerWidth}px`\n },\n },\n\n mounted() {\n if (this.value != null)\n this.update(this.value)\n this.$watch(() => this.value, (newValue) => this.update(newValue))\n },\n}\n</script>\n\n<style lang=\"scss\" scoped>\n$label-width: 3em;\n\n.slider-wrapper {\n width: 100%;\n display: flex;\n position: relative;\n flex-direction: column;\n\n .slider-container {\n width: 100%;\n display: flex;\n position: relative;\n }\n\n .slider {\n width: 100%;\n cursor: pointer;\n opacity: 0;\n\n &::-ms-tooltip {\n display: none;\n }\n }\n\n .range-labels {\n width: 100%;\n display: flex;\n\n &.with-label {\n width: calc(100% - $label-width);\n }\n\n .left {\n text-align: left;\n }\n\n .right {\n @extend .pull-right;\n flex-grow: 1;\n }\n }\n\n .track {\n width: 100%;\n height: 0.75em;\n background: $slider-bg;\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n border-radius: 0.5em;\n box-shadow: inset 1px 0px 3px 0 $slider-track-shadow;\n pointer-events: none;\n\n .track-inner {\n width: 0;\n height: 100%;\n background: $slider-progress-bg;\n border-radius: 0.5em 0 0 0.5em;\n }\n\n &.with-label {\n width: calc(100% - $label-width);\n }\n }\n\n .thumb {\n width: 1.25em;\n height: 1.25em;\n background: $slider-thumb-bg;\n position: absolute;\n top: 50%;\n left: 0;\n transform: translate(0%, -50%);\n border-radius: 50%;\n box-shadow: 1px 0px 2px 0 $slider-thumb-shadow;\n pointer-events: none;\n }\n\n .label {\n width: $label-width;\n position: relative;\n font-weight: normal;\n text-align: center;\n }\n}\n</style>\n","import { render } from \"./Slider.vue?vue&type=template&id=4b38623f&scoped=true\"\nimport script from \"./Slider.vue?vue&type=script&lang=js\"\nexport * from \"./Slider.vue?vue&type=script&lang=js\"\n\nimport \"./Slider.vue?vue&type=style&index=0&id=4b38623f&lang=scss&scoped=true\"\n\nimport exportComponent from \"../../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-4b38623f\"]])\n\nexport default __exports__","<template>\n <div class=\"power-switch\" :class=\"{disabled: disabled}\" @click.stop=\"onInput\">\n <!--suppress HtmlFormInputWithoutLabel -->\n <input type=\"checkbox\" :checked=\"value\">\n <label>\n <!--suppress HtmlUnknownTag -->\n <div class=\"switch\">\n <div class=\"dot\" />\n </div>\n <span class=\"label\">\n <slot />\n </span>\n </label>\n </div>\n</template>\n\n<script>\nexport default {\n name: \"ToggleSwitch\",\n emits: ['input'],\n props: {\n value: {\n type: Boolean,\n default: false,\n },\n\n disabled: {\n type: Boolean,\n default: false,\n },\n },\n\n methods: {\n onInput(event) {\n if (this.disabled)\n return false\n\n this.$emit('input', event)\n },\n },\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.power-switch {\n position: relative;\n transition: transform .3s;\n transform: scale(var(--scale, 1)) translateZ(0);\n\n &:active {\n --scale: .96;\n }\n\n &.disabled {\n opacity: 0.6;\n }\n\n input {\n display: none;\n & + label {\n border-radius: 1em;\n display: inline-flex;\n cursor: pointer;\n position: relative;\n transition: box-shadow .4s;\n\n &:before {\n content: '';\n position: absolute;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n border-radius: inherit;\n background: none;\n opacity: var(--gradient, 0);\n transition: opacity .4s;\n }\n\n .switch {\n position: relative;\n display: inline-block;\n vertical-align: top;\n height: 1.4em;\n width: 2.5em;\n border-radius: 1em;\n background: $slider-bg;\n box-shadow: inset 1px 0px 3px 0 $slider-track-shadow;\n\n &:before {\n content: '';\n position: absolute;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n border-radius: inherit;\n background: $slider-progress-bg;\n opacity: var(--gradient, 0);\n transition: opacity .4s;\n }\n\n .dot {\n background: $toggle-dot-bg;\n position: absolute;\n width: 1.5em;\n height: 1.5em;\n border-radius: 50%;\n box-shadow: 1px 0px 3.5px 0 $slider-thumb-shadow;\n left: -0.25em;\n top: -0.05em;\n transform: translateX(var(--offset, 0));\n transition: transform .4s, box-shadow .4s;\n\n &:before {\n content: '';\n position: absolute;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n border-radius: inherit;\n background: $toggle-selected-dot-bg;\n opacity: var(--gradient, 0);\n transition: opacity .4s;\n }\n }\n }\n\n span {\n line-height: 2em;\n font-size: 1.2em;\n color: var(--text, #646B8C);\n font-weight: 500;\n display: inline-block;\n vertical-align: top;\n position: relative;\n margin-left: 0.5em;\n transition: color .4s;\n }\n\n & + span {\n text-align: center;\n display: block;\n position: absolute;\n left: 0;\n right: 0;\n top: 100%;\n opacity: 0;\n font-size: 1em;\n font-weight: 500;\n color: $slider-bg;\n transform: translateY(0.2em);\n transition: opacity .4s, transform .4s;\n }\n }\n\n &:not(:checked) {\n & + label {\n pointer-events: none;\n & + span {\n opacity: 1;\n transform: translateY(0.6em);\n }\n }\n }\n\n &:checked {\n & + label {\n --offset: 1.5em;\n --text: $slider-progress-bg;\n --gradient: 1;\n --shadow: rgba(0, 39, 6, .1);\n }\n }\n }\n}\n</style>\n","import { render } from \"./ToggleSwitch.vue?vue&type=template&id=a6396ae8&scoped=true\"\nimport script from \"./ToggleSwitch.vue?vue&type=script&lang=js\"\nexport * from \"./ToggleSwitch.vue?vue&type=script&lang=js\"\n\nimport \"./ToggleSwitch.vue?vue&type=style&index=0&id=a6396ae8&lang=scss&scoped=true\"\n\nimport exportComponent from \"../../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-a6396ae8\"]])\n\nexport default __exports__","<template>\n <div class=\"entity light-container\">\n <div class=\"head\" :class=\"{collapsed: collapsed}\">\n <div class=\"icon\">\n <EntityIcon\n :entity=\"value\"\n :icon=\"icon\"\n :hasColorFill=\"true\"\n :loading=\"loading\"\n :error=\"error\" />\n </div>\n\n <div class=\"label\">\n <div class=\"name\" v-text=\"value.name\" />\n </div>\n\n <div class=\"value-container\">\n <ToggleSwitch :value=\"value.on\" @input=\"toggle\"\n @click.stop :disabled=\"loading || value.is_read_only\" />\n\n <button @click.stop=\"collapsed = !collapsed\">\n <i class=\"fas\"\n :class=\"{'fa-angle-up': !collapsed, 'fa-angle-down': collapsed}\" />\n </button>\n </div>\n </div>\n\n <div class=\"body\" v-if=\"!collapsed\" @click.stop=\"prevent\">\n <div class=\"row\" v-if=\"cssColor\">\n <div class=\"icon\">\n <i class=\"fas fa-palette\" />\n </div>\n <div class=\"input\">\n <input type=\"color\" :value=\"cssColor\" @change=\"setLight({color: $event.target.value})\" />\n </div>\n </div>\n\n <div class=\"row\" v-if=\"value.brightness\">\n <div class=\"icon\">\n <i class=\"fas fa-sun\" />\n </div>\n <div class=\"input\">\n <Slider :range=\"[value.brightness_min, value.brightness_max]\"\n :value=\"value.brightness\" @input=\"setLight({brightness: $event.target.value})\" />\n </div>\n </div>\n\n <div class=\"row\" v-if=\"value.saturation\">\n <div class=\"icon\">\n <i class=\"fas fa-droplet\" />\n </div>\n <div class=\"input\">\n <Slider :range=\"[value.saturation_min, value.saturation_max]\"\n :value=\"value.saturation\" @input=\"setLight({saturation: $event.target.value})\" />\n </div>\n </div>\n\n <div class=\"row\" v-if=\"value.temperature\">\n <div class=\"icon\">\n <i class=\"fas fa-temperature-half\" />\n </div>\n <div class=\"input\">\n <Slider :range=\"[value.temperature_min, value.temperature_max]\"\n :value=\"value.temperature\" @input=\"setLight({temperature: $event.target.value})\"/>\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport Slider from \"@/components/elements/Slider\"\nimport ToggleSwitch from \"@/components/elements/ToggleSwitch\"\nimport EntityMixin from \"./EntityMixin\"\nimport EntityIcon from \"./EntityIcon\"\nimport {ColorConverter} from \"@/components/panels/Light/color\";\n\nexport default {\n name: 'Light',\n components: {ToggleSwitch, Slider, EntityIcon},\n mixins: [EntityMixin],\n\n data() {\n return {\n colorConverter: null,\n }\n },\n\n computed: {\n rgbColor() {\n if (this.value.meta?.icon?.color)\n return this.value.meta.icon.color\n\n if (this.value.red && this.value.green && this.value.blue)\n return ['red', 'green', 'blue'].map((c) => this.value[c])\n\n if (!this.colorConverter)\n return\n\n if (\n this.value.hue == null &&\n (this.value.x == null || this.value.y == null)\n )\n return\n\n if (this.value.x && this.value.y)\n return this.colorConverter.xyToRgb(\n this.value.x,\n this.value.y,\n this.value.brightness\n )\n\n return this.colorConverter.hslToRgb(\n this.value.hue,\n this.value.saturation,\n this.value.brightness\n )\n },\n\n cssColor() {\n const rgb = this.rgbColor\n if (rgb)\n return this.colorConverter.rgbToHex(rgb)\n return null\n },\n\n icon() {\n const icon = {...(this.value.meta?.icon || {})}\n if (!icon.color && this.cssColor)\n icon.color = this.cssColor\n return icon\n },\n },\n\n methods: {\n prevent(event) {\n event.stopPropagation()\n return false\n },\n\n async toggle(event) {\n event.stopPropagation()\n this.$emit('loading', true)\n\n try {\n await this.request('entities.execute', {\n id: this.value.id,\n action: 'toggle',\n })\n } finally {\n this.$emit('loading', false)\n }\n },\n\n async setLight(attrs) {\n if (attrs.color) {\n const rgb = this.colorConverter.hexToRgb(attrs.color)\n if (this.value.x != null && this.value.y != null) {\n attrs.xy = this.colorConverter.rgbToXY(...rgb)\n } else if (this.value.hue != null) {\n [attrs.hue, attrs.saturation, attrs.brightness] = this.colorConverter.rgbToHsl(...rgb)\n } else if (\n this.value.red != null && this.value.green != null && this.value.blue != null\n ) {\n [attrs.red, attrs.green, attrs.blue] = [rgb.red, rgb.green, rgb.blue]\n } else {\n console.warn('Unrecognized color format')\n console.warn(attrs.color)\n }\n\n delete attrs.color\n }\n\n this.execute({\n type: 'request',\n action: this.value.plugin + '.set_lights',\n args: {\n lights: [this.value.external_id],\n ...attrs,\n }\n })\n },\n },\n\n mounted() {\n const ranges = {}\n if (this.value.hue)\n ranges.hue = [this.value.hue_min, this.value.hue_max]\n if (this.value.saturation)\n ranges.sat = [this.value.saturation_min, this.value.saturation_max]\n if (this.value.brightness)\n ranges.bri = [this.value.brightness_min, this.value.brightness_max]\n if (this.value.temperature)\n ranges.ct = [this.value.temperature_min, this.value.temperature_max]\n\n this.colorConverter = new ColorConverter(ranges)\n },\n\n unmounted() {\n if (this.colorConverter)\n delete this.colorConverter\n },\n}\n</script>\n\n<style lang=\"scss\" scoped>\n@import \"common\";\n\n.light-container {\n .head {\n .value-container {\n button {\n margin-right: 0.5em;\n }\n }\n }\n\n .body {\n .row {\n display: flex;\n align-items: center;\n padding: 0.5em;\n\n .icon {\n width: 2em;\n margin-left: -0.5em;\n text-align: center;\n }\n\n .input {\n width: calc(100% - 2em);\n\n [type=color] {\n width: 100%;\n }\n\n :deep(.slider) {\n margin-top: 0.5em;\n }\n }\n }\n }\n}\n</style>\n","import { render } from \"./Light.vue?vue&type=template&id=3bfa13d8&scoped=true\"\nimport script from \"./Light.vue?vue&type=script&lang=js\"\nexport * from \"./Light.vue?vue&type=script&lang=js\"\n\nimport \"./Light.vue?vue&type=style&index=0&id=3bfa13d8&lang=scss&scoped=true\"\n\nimport exportComponent from \"../../../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-3bfa13d8\"]])\n\nexport default __exports__"],"names":["ColorConverter","constructor","ranges","this","hue","sat","bri","ct","attr","Object","keys","normalize","x","xRange","yRange","hslToRgb","h","s","l","a","Math","min","f","n","k","color","max","round","rgbToHsl","r","g","b","d","parseInt","xyToRgb","y","brightness","z","Y","toFixed","X","Z","red","green","blue","pow","isNaN","map","c","rgbToXY","parseFloat","rgbToBri","getRGB","rgb","getXY","xy","toRGB","console","debug","toXY","toHSL","hexToRgb","hex","slice","_","rgbToHex","toString","length","join","class","ref","_createElementBlock","_hoisted_1","$props","withRange","_normalizeClass","withLabel","_toDisplayString","range","_createElementVNode","_hoisted_4","type","step","disabled","value","onInput","_cache","_withModifiers","args","$options","onUpdate","onChange","_hoisted_6","_hoisted_7","name","emits","props","Number","Boolean","default","Array","methods","event","update","target","$emit","$refs","sliderWidth","clientWidth","percent","innerWidth","thumb","style","left","transform","track","width","mounted","$watch","newValue","__exports__","render","onClick","checked","_hoisted_2","_hoisted_3","_renderSlot","_ctx","$slots","undefined","collapsed","_createVNode","_component_EntityIcon","entity","icon","hasColorFill","loading","error","_hoisted_5","_component_ToggleSwitch","on","toggle","is_read_only","$event","prevent","cssColor","_hoisted_8","setLight","_hoisted_10","_hoisted_11","_hoisted_12","_component_Slider","brightness_min","brightness_max","saturation","_hoisted_13","_hoisted_14","_hoisted_15","saturation_min","saturation_max","temperature","_hoisted_16","_hoisted_17","_hoisted_18","temperature_min","temperature_max","components","ToggleSwitch","Slider","EntityIcon","mixins","EntityMixin","data","colorConverter","computed","rgbColor","meta","stopPropagation","request","id","action","attrs","warn","execute","plugin","lights","external_id","hue_min","hue_max","unmounted"],"sourceRoot":""}