'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var vue = require('vue'); var colorPickerPanel = require('../color-picker-panel.js'); var color = require('../utils/color.js'); var pluginVue_exportHelper = require('../../../../_virtual/plugin-vue_export-helper.js'); var index = require('../../../../hooks/use-namespace/index.js'); const _sfc_main = vue.defineComponent({ props: { colors: { type: Array, required: true }, color: { type: Object, required: true }, enableAlpha: { type: Boolean, required: true }, disabled: Boolean }, setup(props) { const ns = index.useNamespace("color-predefine"); const { currentColor } = vue.inject(colorPickerPanel.colorPickerPanelContextKey); const rgbaColors = vue.ref(parseColors(props.colors, props.color)); vue.watch(() => currentColor.value, (val) => { const color$1 = new color["default"]({ value: val }); rgbaColors.value.forEach((item) => { item.selected = color$1.compare(item); }); }); vue.watchEffect(() => { rgbaColors.value = parseColors(props.colors, props.color); }); function handleSelect(index) { if (props.disabled) return; props.color.fromString(props.colors[index]); } function parseColors(colors, color$1) { return colors.map((value) => { const c = new color["default"]({ value }); c.selected = c.compare(color$1); return c; }); } return { rgbaColors, handleSelect, ns }; } }); function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", { class: vue.normalizeClass(_ctx.ns.b()) }, [ vue.createElementVNode("div", { class: vue.normalizeClass(_ctx.ns.e("colors")) }, [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(_ctx.rgbaColors, (item, index) => { return vue.openBlock(), vue.createElementBlock("div", { key: _ctx.colors[index], class: vue.normalizeClass([ _ctx.ns.e("color-selector"), _ctx.ns.is("alpha", item.get("alpha") < 100), { selected: item.selected } ]), onClick: ($event) => _ctx.handleSelect(index) }, [ vue.createElementVNode("div", { style: vue.normalizeStyle({ backgroundColor: item.value }) }, null, 4) ], 10, ["onClick"]); }), 128)) ], 2) ], 2); } var Predefine = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["render", _sfc_render], ["__file", "predefine.vue"]]); exports["default"] = Predefine; //# sourceMappingURL=predefine.js.map