element-plus
Version:
A Component Library for Vue 3
169 lines (164 loc) • 6.1 kB
JavaScript
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var vue = require('vue');
var index$1 = require('../../input/index.js');
var alphaSlider = require('./components/alpha-slider.js');
var hueSlider = require('./components/hue-slider.js');
var predefine = require('./components/predefine.js');
var svPanel = require('./components/sv-panel.js');
var colorPickerPanel = require('./color-picker-panel.js');
var useCommonColor = require('./composables/use-common-color.js');
var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
var index = require('../../../hooks/use-namespace/index.js');
var useFormItem = require('../../form/src/hooks/use-form-item.js');
var useFormCommonProps = require('../../form/src/hooks/use-form-common-props.js');
var event = require('../../../constants/event.js');
var error = require('../../../utils/error.js');
const _sfc_main = vue.defineComponent({
...{
name: "ElColorPickerPanel"
},
__name: "color-picker-panel",
props: colorPickerPanel.colorPickerPanelProps,
emits: colorPickerPanel.colorPickerPanelEmits,
setup(__props, { expose: __expose, emit: __emit }) {
const props = __props;
const emit = __emit;
const ns = index.useNamespace("color-picker-panel");
const { formItem } = useFormItem.useFormItem();
const disabled = useFormCommonProps.useFormDisabled();
const hueRef = vue.ref();
const svRef = vue.ref();
const alphaRef = vue.ref();
const inputRef = vue.ref();
const customInput = vue.ref("");
const { color } = vue.inject(
colorPickerPanel.ROOT_COMMON_COLOR_INJECTION_KEY,
() => useCommonColor.useCommonColor(props, emit),
true
);
function handleConfirm() {
color.fromString(customInput.value);
if (color.value !== customInput.value) {
customInput.value = color.value;
}
}
function handleFocusout() {
var _a;
if (props.validateEvent) {
(_a = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a.call(formItem, "blur").catch((err) => error.debugWarn(err));
}
}
function update() {
var _a, _b, _c;
(_a = hueRef.value) == null ? void 0 : _a.update();
(_b = svRef.value) == null ? void 0 : _b.update();
(_c = alphaRef.value) == null ? void 0 : _c.update();
}
vue.onMounted(() => {
if (props.modelValue) {
customInput.value = color.value;
}
vue.nextTick(update);
});
vue.watch(
() => props.modelValue,
(newVal) => {
if (newVal !== color.value) {
newVal ? color.fromString(newVal) : color.clear();
}
}
);
vue.watch(
() => color.value,
(val) => {
emit(event.UPDATE_MODEL_EVENT, val);
customInput.value = val;
if (props.validateEvent) {
formItem == null ? void 0 : formItem.validate("change").catch((err) => error.debugWarn(err));
}
}
);
vue.provide(colorPickerPanel.colorPickerPanelContextKey, {
currentColor: vue.computed(() => color.value)
});
__expose({
color,
inputRef,
update
});
return (_ctx, _cache) => {
return vue.openBlock(), vue.createElementBlock(
"div",
{
class: vue.normalizeClass([vue.unref(ns).b(), vue.unref(ns).is("disabled", vue.unref(disabled)), vue.unref(ns).is("border", _ctx.border)]),
onFocusout: handleFocusout
},
[
vue.createElementVNode(
"div",
{
class: vue.normalizeClass(vue.unref(ns).e("wrapper"))
},
[
vue.createVNode(hueSlider["default"], {
ref_key: "hueRef",
ref: hueRef,
class: "hue-slider",
color: vue.unref(color),
vertical: "",
disabled: vue.unref(disabled)
}, null, 8, ["color", "disabled"]),
vue.createVNode(svPanel["default"], {
ref_key: "svRef",
ref: svRef,
color: vue.unref(color),
disabled: vue.unref(disabled)
}, null, 8, ["color", "disabled"])
],
2
),
_ctx.showAlpha ? (vue.openBlock(), vue.createBlock(alphaSlider["default"], {
key: 0,
ref_key: "alphaRef",
ref: alphaRef,
color: vue.unref(color),
disabled: vue.unref(disabled)
}, null, 8, ["color", "disabled"])) : vue.createCommentVNode("v-if", true),
_ctx.predefine ? (vue.openBlock(), vue.createBlock(predefine["default"], {
key: 1,
ref: "predefine",
"enable-alpha": _ctx.showAlpha,
color: vue.unref(color),
colors: _ctx.predefine,
disabled: vue.unref(disabled)
}, null, 8, ["enable-alpha", "color", "colors", "disabled"])) : vue.createCommentVNode("v-if", true),
vue.createElementVNode(
"div",
{
class: vue.normalizeClass(vue.unref(ns).e("footer"))
},
[
vue.createVNode(vue.unref(index$1.ElInput), {
ref_key: "inputRef",
ref: inputRef,
modelValue: customInput.value,
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => customInput.value = $event),
"validate-event": false,
size: "small",
disabled: vue.unref(disabled),
onChange: handleConfirm
}, null, 8, ["modelValue", "disabled"]),
vue.renderSlot(_ctx.$slots, "footer")
],
2
)
],
34
);
};
}
});
var ColorPickerPanel = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/color-picker-panel/src/color-picker-panel.vue"]]);
exports["default"] = ColorPickerPanel;
//# sourceMappingURL=color-picker-panel2.js.map