090660aef4c1961a19a6dcc770fe55b57187b9aacf3dc3a584d5fd68a443a5ede702778d4239b25510a6804f908695442869b7004daedc7cd64bcda5cfe493 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. import { defineComponent, ref, inject, onMounted, nextTick, watch, provide, computed, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, createVNode, createBlock, createCommentVNode, renderSlot } from 'vue';
  2. import { ElInput } from '../../input/index.mjs';
  3. import AlphaSlider from './components/alpha-slider.mjs';
  4. import HueSlider from './components/hue-slider.mjs';
  5. import Predefine from './components/predefine.mjs';
  6. import SvPanel from './components/sv-panel.mjs';
  7. import { colorPickerPanelProps, colorPickerPanelEmits, ROOT_COMMON_COLOR_INJECTION_KEY, colorPickerPanelContextKey } from './color-picker-panel.mjs';
  8. import { useCommonColor } from './composables/use-common-color.mjs';
  9. import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
  10. import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
  11. import { useFormDisabled } from '../../form/src/hooks/use-form-common-props.mjs';
  12. import { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
  13. const __default__ = defineComponent({
  14. name: "ElColorPickerPanel"
  15. });
  16. const _sfc_main = /* @__PURE__ */ defineComponent({
  17. ...__default__,
  18. props: colorPickerPanelProps,
  19. emits: colorPickerPanelEmits,
  20. setup(__props, { expose, emit }) {
  21. const props = __props;
  22. const ns = useNamespace("color-picker-panel");
  23. const disabled = useFormDisabled();
  24. const hue = ref();
  25. const sv = ref();
  26. const alpha = ref();
  27. const inputRef = ref();
  28. const customInput = ref("");
  29. const { color } = inject(ROOT_COMMON_COLOR_INJECTION_KEY, () => useCommonColor(props, emit), true);
  30. function handleConfirm() {
  31. color.fromString(customInput.value);
  32. if (color.value !== customInput.value) {
  33. customInput.value = color.value;
  34. }
  35. }
  36. onMounted(() => {
  37. if (props.modelValue) {
  38. customInput.value = color.value;
  39. }
  40. nextTick(() => {
  41. var _a, _b, _c;
  42. (_a = hue.value) == null ? void 0 : _a.update();
  43. (_b = sv.value) == null ? void 0 : _b.update();
  44. (_c = alpha.value) == null ? void 0 : _c.update();
  45. });
  46. });
  47. watch(() => props.modelValue, (newVal) => {
  48. if (newVal && newVal !== color.value) {
  49. color.fromString(newVal);
  50. }
  51. });
  52. watch(() => color.value, (val) => {
  53. emit(UPDATE_MODEL_EVENT, val);
  54. customInput.value = val;
  55. });
  56. provide(colorPickerPanelContextKey, {
  57. currentColor: computed(() => color.value)
  58. });
  59. expose({
  60. color,
  61. inputRef
  62. });
  63. return (_ctx, _cache) => {
  64. return openBlock(), createElementBlock("div", {
  65. class: normalizeClass([unref(ns).b(), unref(ns).is("disabled", unref(disabled)), unref(ns).is("border", _ctx.border)])
  66. }, [
  67. createElementVNode("div", {
  68. class: normalizeClass(unref(ns).e("wrapper"))
  69. }, [
  70. createVNode(HueSlider, {
  71. ref_key: "hue",
  72. ref: hue,
  73. class: "hue-slider",
  74. color: unref(color),
  75. vertical: "",
  76. disabled: unref(disabled)
  77. }, null, 8, ["color", "disabled"]),
  78. createVNode(SvPanel, {
  79. ref_key: "sv",
  80. ref: sv,
  81. color: unref(color),
  82. disabled: unref(disabled)
  83. }, null, 8, ["color", "disabled"])
  84. ], 2),
  85. _ctx.showAlpha ? (openBlock(), createBlock(AlphaSlider, {
  86. key: 0,
  87. ref_key: "alpha",
  88. ref: alpha,
  89. color: unref(color),
  90. disabled: unref(disabled)
  91. }, null, 8, ["color", "disabled"])) : createCommentVNode("v-if", true),
  92. _ctx.predefine ? (openBlock(), createBlock(Predefine, {
  93. key: 1,
  94. ref: "predefine",
  95. "enable-alpha": _ctx.showAlpha,
  96. color: unref(color),
  97. colors: _ctx.predefine,
  98. disabled: unref(disabled)
  99. }, null, 8, ["enable-alpha", "color", "colors", "disabled"])) : createCommentVNode("v-if", true),
  100. createElementVNode("div", {
  101. class: normalizeClass(unref(ns).e("footer"))
  102. }, [
  103. createVNode(unref(ElInput), {
  104. ref_key: "inputRef",
  105. ref: inputRef,
  106. modelValue: customInput.value,
  107. "onUpdate:modelValue": ($event) => customInput.value = $event,
  108. "validate-event": false,
  109. size: "small",
  110. disabled: unref(disabled),
  111. onChange: handleConfirm
  112. }, null, 8, ["modelValue", "onUpdate:modelValue", "disabled"]),
  113. renderSlot(_ctx.$slots, "footer")
  114. ], 2)
  115. ], 2);
  116. };
  117. }
  118. });
  119. var ColorPickerPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "color-picker-panel.vue"]]);
  120. export { ColorPickerPanel as default };
  121. //# sourceMappingURL=color-picker-panel2.mjs.map