vxe-pc-ui 4.6.39 → 4.6.40

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/es/color-picker/src/color-picker.js +175 -110
  2. package/es/color-picker/style.css +80 -20
  3. package/es/color-picker/style.min.css +1 -1
  4. package/es/icon/style.css +1 -1
  5. package/es/style.css +1 -1
  6. package/es/style.min.css +1 -1
  7. package/es/ui/index.js +5 -3
  8. package/es/ui/src/log.js +1 -1
  9. package/es/vxe-color-picker/style.css +80 -20
  10. package/es/vxe-color-picker/style.min.css +1 -1
  11. package/lib/color-picker/src/color-picker.js +84 -19
  12. package/lib/color-picker/src/color-picker.min.js +1 -1
  13. package/lib/color-picker/style/style.css +80 -20
  14. package/lib/color-picker/style/style.min.css +1 -1
  15. package/lib/icon/style/style.css +1 -1
  16. package/lib/icon/style/style.min.css +1 -1
  17. package/lib/index.umd.js +90 -23
  18. package/lib/index.umd.min.js +1 -1
  19. package/lib/style.css +1 -1
  20. package/lib/style.min.css +1 -1
  21. package/lib/ui/index.js +5 -3
  22. package/lib/ui/index.min.js +1 -1
  23. package/lib/ui/src/log.js +1 -1
  24. package/lib/ui/src/log.min.js +1 -1
  25. package/lib/vxe-color-picker/style/style.css +80 -20
  26. package/lib/vxe-color-picker/style/style.min.css +1 -1
  27. package/package.json +1 -1
  28. package/packages/color-picker/src/color-picker.ts +182 -111
  29. package/packages/ui/index.ts +4 -2
  30. package/styles/components/color-picker.scss +73 -21
  31. package/types/components/color-picker.d.ts +2 -0
  32. package/types/ui/global-icon.d.ts +4 -2
  33. /package/es/icon/{iconfont.1751277334874.ttf → iconfont.1751332695680.ttf} +0 -0
  34. /package/es/icon/{iconfont.1751277334874.woff → iconfont.1751332695680.woff} +0 -0
  35. /package/es/icon/{iconfont.1751277334874.woff2 → iconfont.1751332695680.woff2} +0 -0
  36. /package/es/{iconfont.1751277334874.ttf → iconfont.1751332695680.ttf} +0 -0
  37. /package/es/{iconfont.1751277334874.woff → iconfont.1751332695680.woff} +0 -0
  38. /package/es/{iconfont.1751277334874.woff2 → iconfont.1751332695680.woff2} +0 -0
  39. /package/lib/icon/style/{iconfont.1751277334874.ttf → iconfont.1751332695680.ttf} +0 -0
  40. /package/lib/icon/style/{iconfont.1751277334874.woff → iconfont.1751332695680.woff} +0 -0
  41. /package/lib/icon/style/{iconfont.1751277334874.woff2 → iconfont.1751332695680.woff2} +0 -0
  42. /package/lib/{iconfont.1751277334874.ttf → iconfont.1751332695680.ttf} +0 -0
  43. /package/lib/{iconfont.1751277334874.woff → iconfont.1751332695680.woff} +0 -0
  44. /package/lib/{iconfont.1751277334874.woff2 → iconfont.1751332695680.woff2} +0 -0
@@ -91,7 +91,9 @@ export default defineVxeComponent({
91
91
  const refColorActiveElem = ref();
92
92
  const reactData = reactive({
93
93
  initialized: false,
94
+ selectTyle: 'hex',
94
95
  selectColor: `${props.modelValue || ''}`,
96
+ showTypePopup: false,
95
97
  panelColor: '',
96
98
  hexValue: '',
97
99
  rValue: 0,
@@ -105,6 +107,10 @@ export default defineVxeComponent({
105
107
  isAniVisible: false,
106
108
  isActivated: false
107
109
  });
110
+ const typeList = [
111
+ { label: 'HEX', value: 'hex' },
112
+ { label: 'RGB', value: 'rgb' }
113
+ ];
108
114
  const internalData = {
109
115
  // hpTimeout: undefined
110
116
  };
@@ -159,16 +165,13 @@ export default defineVxeComponent({
159
165
  }
160
166
  return [];
161
167
  });
162
- const computeValueType = computed(() => {
163
- const { type } = props;
164
- if (type === 'rgb' || type === 'rgba') {
165
- return 'rgb';
166
- }
167
- return 'hex';
168
- });
169
168
  const computeIsRgb = computed(() => {
170
- const valueType = computeValueType.value;
171
- return valueType === 'rgb';
169
+ const { selectTyle } = reactData;
170
+ return selectTyle === 'rgb';
171
+ });
172
+ const computeSelectTypeItem = computed(() => {
173
+ const { selectTyle } = reactData;
174
+ return typeList.find(item => item.value === selectTyle);
172
175
  });
173
176
  const refMaps = {
174
177
  refElem
@@ -190,6 +193,15 @@ export default defineVxeComponent({
190
193
  reactData.selectColor = XEUtils.toValueString(modelValue);
191
194
  updateModelColor();
192
195
  };
196
+ const updateType = () => {
197
+ const { type } = props;
198
+ let selectTyle = 'hex';
199
+ if (type === 'rgb' || type === 'rgba') {
200
+ selectTyle = 'rgb';
201
+ }
202
+ reactData.selectTyle = selectTyle;
203
+ updateMode();
204
+ };
193
205
  const updateModelColor = () => {
194
206
  const { selectColor, isAniVisible } = reactData;
195
207
  const isRgb = computeIsRgb.value;
@@ -337,6 +349,21 @@ export default defineVxeComponent({
337
349
  togglePanelEvent(evnt);
338
350
  dispatchEvent('click', {}, evnt);
339
351
  };
352
+ const handlePanelClickEvent = () => {
353
+ reactData.showTypePopup = false;
354
+ };
355
+ const toggleTypeVisibleEvent = (evnt) => {
356
+ evnt.stopPropagation();
357
+ reactData.showTypePopup = !reactData.showTypePopup;
358
+ };
359
+ const handleChangeType = (type) => {
360
+ const { selectTyle } = reactData;
361
+ if (type !== selectTyle) {
362
+ reactData.selectTyle = type;
363
+ updateModelColor();
364
+ }
365
+ reactData.showTypePopup = false;
366
+ };
340
367
  const handleHueColor = (offsetLeft) => {
341
368
  const hueSliderEl = refHueSliderElem.value;
342
369
  const hueSliderBtnEl = refHueSliderBtnElem.value;
@@ -598,9 +625,9 @@ export default defineVxeComponent({
598
625
  };
599
626
  const renderColorBar = () => {
600
627
  const { showAlpha, clickToCopy, showEyeDropper } = props;
601
- const { hexValue, rValue, gValue, bValue, aValue, selectColor, panelColor } = reactData;
602
- const valueType = computeValueType.value;
628
+ const { selectTyle, showTypePopup, hexValue, rValue, gValue, bValue, aValue, selectColor, panelColor } = reactData;
603
629
  const isRgb = computeIsRgb.value;
630
+ const selectTypeItem = computeSelectTypeItem.value;
604
631
  return h('div', {
605
632
  class: 'vxe-color-picker--bar-wrapper'
606
633
  }, [
@@ -616,7 +643,7 @@ export default defineVxeComponent({
616
643
  onClick: handleEyeDropperEvent
617
644
  }, [
618
645
  h('i', {
619
- class: getIcon().EYE_DROPPER
646
+ class: getIcon().COLOR_PICKER_EYE_DROPPER
620
647
  })
621
648
  ])
622
649
  ])
@@ -639,7 +666,7 @@ export default defineVxeComponent({
639
666
  onClick: handleCopyColorEvent
640
667
  }, [
641
668
  h('i', {
642
- class: getIcon().COLOR_COPY
669
+ class: getIcon().COLOR_PICKER_COLOR_COPY
643
670
  })
644
671
  ])
645
672
  ]
@@ -682,108 +709,142 @@ export default defineVxeComponent({
682
709
  ])
683
710
  ]),
684
711
  h('div', {
685
- class: `vxe-color-picker--${valueType}-wrapper`
686
- }, isRgb
687
- ? [
712
+ class: 'vxe-color-picker--custom-wrapper'
713
+ }, [
714
+ h('div', {
715
+ class: 'vxe-color-picker--type-switch'
716
+ }, [
688
717
  h('div', {
689
- class: 'vxe-color-picker--input-wrapper'
718
+ class: 'vxe-color-picker--type-label',
719
+ onClick: toggleTypeVisibleEvent
690
720
  }, [
691
- h(VxeInputComponent, {
692
- type: 'integer',
693
- size: 'mini',
694
- align: 'center',
695
- min: 0,
696
- max: 255,
697
- maxLength: 3,
698
- placeholder: '',
699
- modelValue: rValue,
700
- 'onUpdate:modelValue'(val) {
701
- reactData.rValue = val;
702
- },
703
- onChange: handleInputRgbEvent
704
- }),
705
- h(VxeInputComponent, {
706
- type: 'integer',
707
- size: 'mini',
708
- align: 'center',
709
- min: 0,
710
- max: 255,
711
- maxLength: 3,
712
- placeholder: '',
713
- modelValue: gValue,
714
- 'onUpdate:modelValue'(val) {
715
- reactData.gValue = val;
716
- },
717
- onChange: handleInputRgbEvent
718
- }),
719
- h(VxeInputComponent, {
720
- type: 'integer',
721
- size: 'mini',
722
- align: 'center',
723
- min: 0,
724
- max: 255,
725
- maxLength: 3,
726
- placeholder: '',
727
- modelValue: bValue,
728
- 'onUpdate:modelValue'(val) {
729
- reactData.bValue = val;
730
- },
731
- onChange: handleInputRgbEvent
732
- }),
733
- h(VxeInputComponent, {
734
- type: 'number',
735
- size: 'mini',
736
- align: 'center',
737
- min: 0,
738
- max: 1,
739
- step: 0.01,
740
- maxLength: 4,
741
- placeholder: '',
742
- modelValue: aValue,
743
- 'onUpdate:modelValue'(val) {
744
- reactData.aValue = val;
745
- },
746
- onChange: handleInputAlphaEvent
747
- })
721
+ h('span', `${selectTypeItem ? selectTypeItem.label : selectTyle}`),
722
+ h('span', {
723
+ class: 'vxe-color-picker--type-icon'
724
+ }, [
725
+ h('i', {
726
+ class: showTypePopup ? getIcon().COLOR_PICKER_TPTY_OPEN : getIcon().COLOR_PICKER_TPTY_CLOSE
727
+ })
728
+ ])
748
729
  ]),
749
730
  h('div', {
750
- class: 'vxe-color-picker--input-title'
751
- }, [
752
- h('span', 'R'),
753
- h('span', 'G'),
754
- h('span', 'B'),
755
- h('span', 'A')
756
- ])
757
- ]
758
- : [
759
- h('div', {
760
- class: 'vxe-color-picker--input-title'
761
- }, 'HEX'),
762
- h('div', {
763
- class: 'vxe-color-picker--input-wrapper'
764
- }, [
765
- h(VxeInputComponent, {
766
- type: 'text',
767
- size: 'mini',
768
- align: 'center',
769
- maxLength: 9,
770
- placeholder: '',
771
- modelValue: hexValue,
772
- 'onUpdate:modelValue'(val) {
773
- reactData.hexValue = val;
774
- },
775
- onChange() {
776
- const colorRest = parseColor(reactData.hexValue);
777
- if (colorRest) {
778
- if (colorRest.value) {
779
- reactData.selectColor = colorRest.value;
780
- updateModelColor();
731
+ class: ['vxe-color-picker--type-popup', {
732
+ 'is--visible': showTypePopup
733
+ }]
734
+ }, typeList.map(item => {
735
+ return h('div', {
736
+ class: 'vxe-color-picker--type-item',
737
+ onClick(evnt) {
738
+ evnt.stopPropagation();
739
+ handleChangeType(item.value);
740
+ }
741
+ }, item.label);
742
+ }))
743
+ ]),
744
+ h('div', {
745
+ class: `vxe-color-picker--${selectTyle}-wrapper`
746
+ }, isRgb
747
+ ? [
748
+ h('div', {
749
+ class: 'vxe-color-picker--input-wrapper'
750
+ }, [
751
+ h(VxeInputComponent, {
752
+ type: 'integer',
753
+ size: 'mini',
754
+ align: 'center',
755
+ min: 0,
756
+ max: 255,
757
+ maxLength: 3,
758
+ placeholder: '',
759
+ modelValue: rValue,
760
+ 'onUpdate:modelValue'(val) {
761
+ reactData.rValue = val;
762
+ },
763
+ onChange: handleInputRgbEvent
764
+ }),
765
+ h(VxeInputComponent, {
766
+ type: 'integer',
767
+ size: 'mini',
768
+ align: 'center',
769
+ min: 0,
770
+ max: 255,
771
+ maxLength: 3,
772
+ placeholder: '',
773
+ modelValue: gValue,
774
+ 'onUpdate:modelValue'(val) {
775
+ reactData.gValue = val;
776
+ },
777
+ onChange: handleInputRgbEvent
778
+ }),
779
+ h(VxeInputComponent, {
780
+ type: 'integer',
781
+ size: 'mini',
782
+ align: 'center',
783
+ min: 0,
784
+ max: 255,
785
+ maxLength: 3,
786
+ placeholder: '',
787
+ modelValue: bValue,
788
+ 'onUpdate:modelValue'(val) {
789
+ reactData.bValue = val;
790
+ },
791
+ onChange: handleInputRgbEvent
792
+ }),
793
+ h(VxeInputComponent, {
794
+ type: 'number',
795
+ size: 'mini',
796
+ align: 'center',
797
+ min: 0,
798
+ max: 1,
799
+ step: 0.01,
800
+ maxLength: 4,
801
+ placeholder: '',
802
+ modelValue: aValue,
803
+ 'onUpdate:modelValue'(val) {
804
+ reactData.aValue = val;
805
+ },
806
+ onChange: handleInputAlphaEvent
807
+ })
808
+ ]),
809
+ h('div', {
810
+ class: 'vxe-color-picker--input-title'
811
+ }, [
812
+ h('span', 'R'),
813
+ h('span', 'G'),
814
+ h('span', 'B'),
815
+ h('span', 'A')
816
+ ])
817
+ ]
818
+ : [
819
+ h('div', {
820
+ class: 'vxe-color-picker--input-wrapper'
821
+ }, [
822
+ h(VxeInputComponent, {
823
+ type: 'text',
824
+ size: 'mini',
825
+ align: 'center',
826
+ maxLength: 9,
827
+ placeholder: '',
828
+ modelValue: hexValue,
829
+ 'onUpdate:modelValue'(val) {
830
+ reactData.hexValue = val;
831
+ },
832
+ onChange() {
833
+ const colorRest = parseColor(reactData.hexValue);
834
+ if (colorRest) {
835
+ if (colorRest.value) {
836
+ reactData.selectColor = colorRest.value;
837
+ updateModelColor();
838
+ }
781
839
  }
782
840
  }
783
- }
784
- })
841
+ })
842
+ ]),
843
+ h('div', {
844
+ class: 'vxe-color-picker--input-title'
845
+ }, 'HEX')
785
846
  ])
786
- ])
847
+ ])
787
848
  ]);
788
849
  };
789
850
  const renderQuickWrapper = () => {
@@ -872,7 +933,8 @@ export default defineVxeComponent({
872
933
  }, [
873
934
  initialized && (visiblePanel || isAniVisible)
874
935
  ? h('div', {
875
- class: 'vxe-color-picker--panel-wrapper'
936
+ class: 'vxe-color-picker--panel-wrapper',
937
+ onClick: handlePanelClickEvent
876
938
  }, [
877
939
  renderColorWrapper(),
878
940
  renderColorBar(),
@@ -903,6 +965,9 @@ export default defineVxeComponent({
903
965
  watch(() => props.modelValue, () => {
904
966
  updateMode();
905
967
  });
968
+ watch(() => props.type, () => {
969
+ updateType();
970
+ });
906
971
  onMounted(() => {
907
972
  globalEvents.on($xeColorPicker, 'mousewheel', handleGlobalMousewheelEvent);
908
973
  globalEvents.on($xeColorPicker, 'mousedown', handleGlobalMousedownEvent);
@@ -915,7 +980,7 @@ export default defineVxeComponent({
915
980
  globalEvents.off($xeColorPicker, 'blur');
916
981
  globalEvents.off($xeColorPicker, 'resize');
917
982
  });
918
- updateMode();
983
+ updateType();
919
984
  provide('$xeColorPicker', $xeColorPicker);
920
985
  $xeColorPicker.renderVN = renderVN;
921
986
  return $xeColorPicker;
@@ -322,44 +322,104 @@
322
322
  height: 100%;
323
323
  }
324
324
 
325
- .vxe-color-picker--hex-wrapper,
326
- .vxe-color-picker--rgb-wrapper {
327
- text-align: center;
325
+ .vxe-color-picker--custom-wrapper {
326
+ display: flex;
327
+ flex-direction: row;
328
+ padding: 0 0.8em;
329
+ }
330
+
331
+ .vxe-color-picker--type-switch {
332
+ position: relative;
333
+ flex-shrink: 0;
328
334
  margin-top: 0.4em;
329
335
  }
330
336
 
331
- .vxe-color-picker--hex-wrapper {
332
- display: flex;
333
- flex-direction: row;
334
- padding: 0 1.8em;
337
+ .vxe-color-picker--type-icon {
338
+ padding: 0.25em;
339
+ color: var(--vxe-ui-input-placeholder-color);
335
340
  }
336
- .vxe-color-picker--hex-wrapper .vxe-color-picker--input-wrapper > .vxe-input {
337
- width: 12em;
341
+ .vxe-color-picker--type-icon i {
342
+ display: inline-block;
343
+ transition: transform 0.2s ease-in-out;
338
344
  }
339
- .vxe-color-picker--hex-wrapper .vxe-color-picker--input-title {
340
- padding: 0 0.6em;
345
+
346
+ .vxe-color-picker--type-label {
347
+ padding: 0 0.25em;
348
+ line-height: 2em;
349
+ cursor: pointer;
350
+ -webkit-user-select: none;
351
+ -moz-user-select: none;
352
+ user-select: none;
341
353
  }
342
354
 
343
- .vxe-color-picker--input-title {
344
- color: var(--vxe-ui-input-placeholder-color);
355
+ .vxe-color-picker--type-popup {
356
+ position: absolute;
357
+ display: none;
358
+ border-radius: var(--vxe-ui-base-border-radius);
359
+ border: 1px solid var(--vxe-ui-base-popup-border-color);
360
+ box-shadow: var(--vxe-ui-base-popup-box-shadow);
361
+ background-color: var(--vxe-ui-layout-background-color);
362
+ padding: 0.25em 1em;
363
+ -webkit-user-select: none;
364
+ -moz-user-select: none;
365
+ user-select: none;
366
+ }
367
+ .vxe-color-picker--type-popup.is--visible {
368
+ display: block;
345
369
  }
346
370
 
347
- .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper {
371
+ .vxe-color-picker--type-item {
372
+ line-height: 1.6em;
373
+ cursor: pointer;
374
+ }
375
+ .vxe-color-picker--type-item:hover {
376
+ color: var(--vxe-ui-font-primary-lighten-color);
377
+ }
378
+
379
+ .vxe-color-picker--hex-wrapper,
380
+ .vxe-color-picker--rgb-wrapper {
381
+ flex-grow: 1;
382
+ text-align: center;
383
+ margin-top: 0.4em;
384
+ }
385
+
386
+ .vxe-color-picker--input-wrapper {
348
387
  display: flex;
349
388
  flex-direction: row;
350
389
  align-items: center;
351
- justify-content: center;
352
- }
353
- .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper > .vxe-input {
354
- width: 5.4em;
355
- margin: 0 0.4em;
390
+ justify-content: right;
356
391
  }
357
- .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-title {
392
+
393
+ .vxe-color-picker--input-title {
358
394
  display: flex;
359
395
  flex-direction: row;
360
396
  align-items: center;
361
397
  justify-content: center;
362
398
  line-height: 1.4em;
399
+ color: var(--vxe-ui-input-placeholder-color);
400
+ }
401
+
402
+ .vxe-color-picker--hex-wrapper {
403
+ display: flex;
404
+ flex-direction: column;
405
+ }
406
+ .vxe-color-picker--hex-wrapper .vxe-color-picker--input-wrapper > .vxe-input {
407
+ width: 20.2em;
408
+ }
409
+
410
+ .vxe-color-picker--rgb-wrapper {
411
+ display: flex;
412
+ flex-direction: column;
413
+ }
414
+ .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper > .vxe-input {
415
+ width: 4.6em;
416
+ margin-left: 0.6em;
417
+ }
418
+ .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper > .vxe-input:first-child {
419
+ margin-left: 0;
420
+ }
421
+ .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper > .vxe-input .vxe-input--control-icon {
422
+ min-width: 1.6em;
363
423
  }
364
424
  .vxe-color-picker--rgb-wrapper .vxe-color-picker--input-title > span {
365
425
  display: block;
@@ -1 +1 @@
1
- .vxe-color-picker.is--selected .vxe-color-picker--inner-color{color:#fff}.vxe-color-picker.is--active{border-color:var(--vxe-ui-font-primary-color)}.vxe-color-picker,.vxe-color-picker--readonly{position:relative;display:inline-block;width:2.4em;padding:.25em;border:1px solid var(--vxe-ui-input-border-color);border-radius:var(--vxe-ui-base-border-radius);background-color:var(--vxe-ui-layout-background-color)}.vxe-color-picker--bar-alpha-slider,.vxe-color-picker--inner,.vxe-color-picker--preview-btn{background:#fff url()}.vxe-color-picker--inner,.vxe-color-picker--readonly-color{width:100%;height:100%;background-size:1em 1em;border-radius:var(--vxe-ui-base-border-radius)}.vxe-color-picker--readonly-color{border:1px solid var(--vxe-ui-input-border-color)}.vxe-color-picker--inner{cursor:pointer}.vxe-color-picker--input{position:absolute;z-index:-1;width:1px;height:1px;outline:0;border:0}.vxe-color-picker--inner-color{width:100%;height:100%;display:flex;flex-direction:row;align-items:center;justify-content:center;border:1px solid var(--vxe-ui-input-border-color);border-radius:var(--vxe-ui-base-border-radius)}.vxe-color-picker--panel-wrapper{position:relative;width:23.4em;border-radius:var(--vxe-ui-base-border-radius);border:1px solid var(--vxe-ui-base-popup-border-color);box-shadow:var(--vxe-ui-base-popup-box-shadow);background-color:var(--vxe-ui-layout-background-color)}.vxe-color-picker--panel{display:none;position:absolute;left:0;padding:4px 0;color:var(--vxe-ui-font-color);text-align:left}.vxe-color-picker--panel:not(.is--transfer){min-width:100%}.vxe-color-picker--panel.is--transfer{position:fixed}.vxe-color-picker--panel.ani--leave{display:block;opacity:0;transform:scaleY(.5);transition:transform .3s cubic-bezier(.23,1,.32,1),opacity .3s cubic-bezier(.23,1,.32,1);transform-origin:center top;backface-visibility:hidden}.vxe-color-picker--panel.ani--leave[placement=top]{transform-origin:center bottom}.vxe-color-picker--panel.ani--enter{opacity:1;transform:scaleY(1)}.vxe-color-picker--panel.ani--enter>div::after{display:none}.vxe-color-picker--panel>div::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vxe-color-picker--color-wrapper{position:relative;height:160px;overflow:hidden}.vxe-color-picker--black-bg,.vxe-color-picker--color-bg,.vxe-color-picker--white-bg{position:absolute;top:0;left:0;width:100%;height:100%}.vxe-color-picker--white-bg{background:linear-gradient(to right,#fff,rgba(255,255,255,0))}.vxe-color-picker--black-bg{background:linear-gradient(to top,#000,rgba(255,255,255,0))}.vxe-color-picker--color-active{position:absolute;left:0;top:0;width:.8em;height:.8em;border-radius:50%;border:1px solid #fff;background-color:transparent;box-shadow:0 0 4px 1px rgba(0,0,0,.3);transform:translate(-.4em,-.4em)}.vxe-color-picker--quick-wrapper{display:flex;flex-direction:row;flex-wrap:wrap;align-content:flex-start;overflow-x:hidden;overflow-y:auto;max-height:9.2em}.vxe-color-picker--quick-item{width:1.5em;height:1.5em;margin:.4em;border:1px solid var(--vxe-ui-base-popup-border-color);border-radius:var(--vxe-ui-base-border-radius);cursor:pointer;transition:transform .1s ease-in-out}.vxe-color-picker--quick-item:hover{transform:scale(1.2);border-color:var(--vxe-ui-font-primary-lighten-color)}.vxe-color-picker--quick-item:active{transform:scale(.8)}.vxe-color-picker--bar-wrapper{margin-top:.4em}.vxe-color-picker--slider-wrapper{display:flex;flex-direction:row}.vxe-color-picker--color-dropper,.vxe-color-picker--slider-preview{padding-left:.8em}.vxe-color-picker--color-dropper{display:flex;flex-direction:row;justify-content:center;align-items:center;padding-left:.8em;font-size:1.2em;cursor:pointer;transition:transform .1s ease-in-out}.vxe-color-picker--color-dropper:hover{color:var(--vxe-ui-font-primary-color)}.vxe-color-picker--color-dropper:active{transform:scale(.8)}.vxe-color-picker--slider-preview{display:flex;flex-direction:row;flex-shrink:0;align-items:center;justify-content:center}.vxe-color-picker--preview-btn,.vxe-color-picker--preview-color{width:2.2em;height:2.2em;border-radius:50%}.vxe-color-picker--preview-btn{background-size:.8em .8em}.vxe-color-picker--preview-color{position:relative;display:flex;flex-direction:row;align-items:center;justify-content:center;border:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-color-picker--preview-color:hover::before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background-color:rgba(0,0,0,.3);z-index:0}.vxe-color-picker--preview-color:hover .vxe-color-picker--preview-copy-btn{display:block;z-index:1}.vxe-color-picker--preview-color:active .vxe-color-picker--preview-copy-btn{font-size:.8em}.vxe-color-picker--preview-copy-btn{display:none;color:#fff;cursor:pointer}.vxe-color-picker--slider-handle{display:flex;flex-direction:column;justify-content:center;flex-grow:1;padding:0 .8em}.vxe-color-picker--bar-alpha-slider,.vxe-color-picker--bar-hue-slider{position:relative;height:1em;width:100%;margin:.4em 0;cursor:pointer}.vxe-color-picker--bar-alpha-bg,.vxe-color-picker--bar-alpha-slider,.vxe-color-picker--bar-hue-slider{border-radius:var(--vxe-ui-base-border-radius)}.vxe-color-picker--bar-hue-slider{background:linear-gradient(to left,red,#ff0 17%,#0f0 33%,#0ff,#00f 67%,#f0f 83%,red)}.vxe-color-picker--bar-alpha-btn,.vxe-color-picker--bar-hue-btn{position:absolute;left:0;top:-4px;width:.6em;height:calc(100% + 8px);border-radius:.2em;background-color:#fff;border:1px solid var(--vxe-ui-base-popup-border-color);transform:translateX(-.3em);cursor:grab;box-shadow:0 0 8px 0 rgba(0,0,0,.3);transition:transform .1s ease-in-out}.vxe-color-picker--bar-alpha-btn:hover,.vxe-color-picker--bar-hue-btn:hover{transform:translateX(-.3em) scale(1.1)}.vxe-color-picker--bar-alpha-btn:active,.vxe-color-picker--bar-hue-btn:active{transform:translateX(-.3em) scale(1.2);cursor:grabbing}.vxe-color-picker--bar-alpha-slider{background-size:1em 1em}.vxe-color-picker--bar-alpha-slider .vxe-color-picker--bar-alpha-bg{position:absolute;top:0;left:0;width:100%;height:100%}.vxe-color-picker--hex-wrapper,.vxe-color-picker--rgb-wrapper{text-align:center;margin-top:.4em}.vxe-color-picker--hex-wrapper{display:flex;flex-direction:row;padding:0 1.8em}.vxe-color-picker--hex-wrapper .vxe-color-picker--input-wrapper>.vxe-input{width:12em}.vxe-color-picker--hex-wrapper .vxe-color-picker--input-title{padding:0 .6em}.vxe-color-picker--input-title{color:var(--vxe-ui-input-placeholder-color)}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:center}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper>.vxe-input{width:5.4em;margin:0 .4em}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-title{display:flex;flex-direction:row;align-items:center;justify-content:center;line-height:1.4em}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-title>span{display:block;width:50px;margin:0 .4em}.vxe-color-picker--footer-wrapper{text-align:right;margin-top:.4em;padding:0 .4em .4em .4em}.vxe-color-picker,.vxe-color-picker--readonly{height:var(--vxe-ui-input-height-default);line-height:var(--vxe-ui-input-height-default)}.vxe-color-picker--readonly.size--medium,.vxe-color-picker.size--medium{height:var(--vxe-ui-input-height-medium);line-height:var(--vxe-ui-input-height-medium)}.vxe-color-picker--readonly.size--small,.vxe-color-picker.size--small{height:var(--vxe-ui-input-height-small);line-height:var(--vxe-ui-input-height-small)}.vxe-color-picker--readonly.size--mini,.vxe-color-picker.size--mini{height:var(--vxe-ui-input-height-mini);line-height:var(--vxe-ui-input-height-mini)}.vxe-color-picker,.vxe-color-picker--panel,.vxe-color-picker--readonly{font-size:var(--vxe-ui-font-size-default)}.vxe-color-picker--panel.size--medium,.vxe-color-picker--readonly.size--medium,.vxe-color-picker.size--medium{font-size:var(--vxe-ui-font-size-medium)}.vxe-color-picker--panel.size--small,.vxe-color-picker--readonly.size--small,.vxe-color-picker.size--small{font-size:var(--vxe-ui-font-size-small)}.vxe-color-picker--panel.size--mini,.vxe-color-picker--readonly.size--mini,.vxe-color-picker.size--mini{font-size:var(--vxe-ui-font-size-mini)}
1
+ .vxe-color-picker.is--selected .vxe-color-picker--inner-color{color:#fff}.vxe-color-picker.is--active{border-color:var(--vxe-ui-font-primary-color)}.vxe-color-picker,.vxe-color-picker--readonly{position:relative;display:inline-block;width:2.4em;padding:.25em;border:1px solid var(--vxe-ui-input-border-color);border-radius:var(--vxe-ui-base-border-radius);background-color:var(--vxe-ui-layout-background-color)}.vxe-color-picker--bar-alpha-slider,.vxe-color-picker--inner,.vxe-color-picker--preview-btn{background:#fff url()}.vxe-color-picker--inner,.vxe-color-picker--readonly-color{width:100%;height:100%;background-size:1em 1em;border-radius:var(--vxe-ui-base-border-radius)}.vxe-color-picker--readonly-color{border:1px solid var(--vxe-ui-input-border-color)}.vxe-color-picker--inner{cursor:pointer}.vxe-color-picker--input{position:absolute;z-index:-1;width:1px;height:1px;outline:0;border:0}.vxe-color-picker--inner-color{width:100%;height:100%;display:flex;flex-direction:row;align-items:center;justify-content:center;border:1px solid var(--vxe-ui-input-border-color);border-radius:var(--vxe-ui-base-border-radius)}.vxe-color-picker--panel-wrapper{position:relative;width:23.4em;border-radius:var(--vxe-ui-base-border-radius);border:1px solid var(--vxe-ui-base-popup-border-color);box-shadow:var(--vxe-ui-base-popup-box-shadow);background-color:var(--vxe-ui-layout-background-color)}.vxe-color-picker--panel{display:none;position:absolute;left:0;padding:4px 0;color:var(--vxe-ui-font-color);text-align:left}.vxe-color-picker--panel:not(.is--transfer){min-width:100%}.vxe-color-picker--panel.is--transfer{position:fixed}.vxe-color-picker--panel.ani--leave{display:block;opacity:0;transform:scaleY(.5);transition:transform .3s cubic-bezier(.23,1,.32,1),opacity .3s cubic-bezier(.23,1,.32,1);transform-origin:center top;backface-visibility:hidden}.vxe-color-picker--panel.ani--leave[placement=top]{transform-origin:center bottom}.vxe-color-picker--panel.ani--enter{opacity:1;transform:scaleY(1)}.vxe-color-picker--panel.ani--enter>div::after{display:none}.vxe-color-picker--panel>div::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vxe-color-picker--color-wrapper{position:relative;height:160px;overflow:hidden}.vxe-color-picker--black-bg,.vxe-color-picker--color-bg,.vxe-color-picker--white-bg{position:absolute;top:0;left:0;width:100%;height:100%}.vxe-color-picker--white-bg{background:linear-gradient(to right,#fff,rgba(255,255,255,0))}.vxe-color-picker--black-bg{background:linear-gradient(to top,#000,rgba(255,255,255,0))}.vxe-color-picker--color-active{position:absolute;left:0;top:0;width:.8em;height:.8em;border-radius:50%;border:1px solid #fff;background-color:transparent;box-shadow:0 0 4px 1px rgba(0,0,0,.3);transform:translate(-.4em,-.4em)}.vxe-color-picker--quick-wrapper{display:flex;flex-direction:row;flex-wrap:wrap;align-content:flex-start;overflow-x:hidden;overflow-y:auto;max-height:9.2em}.vxe-color-picker--quick-item{width:1.5em;height:1.5em;margin:.4em;border:1px solid var(--vxe-ui-base-popup-border-color);border-radius:var(--vxe-ui-base-border-radius);cursor:pointer;transition:transform .1s ease-in-out}.vxe-color-picker--quick-item:hover{transform:scale(1.2);border-color:var(--vxe-ui-font-primary-lighten-color)}.vxe-color-picker--quick-item:active{transform:scale(.8)}.vxe-color-picker--bar-wrapper{margin-top:.4em}.vxe-color-picker--slider-wrapper{display:flex;flex-direction:row}.vxe-color-picker--color-dropper,.vxe-color-picker--slider-preview{padding-left:.8em}.vxe-color-picker--color-dropper{display:flex;flex-direction:row;justify-content:center;align-items:center;padding-left:.8em;font-size:1.2em;cursor:pointer;transition:transform .1s ease-in-out}.vxe-color-picker--color-dropper:hover{color:var(--vxe-ui-font-primary-color)}.vxe-color-picker--color-dropper:active{transform:scale(.8)}.vxe-color-picker--slider-preview{display:flex;flex-direction:row;flex-shrink:0;align-items:center;justify-content:center}.vxe-color-picker--preview-btn,.vxe-color-picker--preview-color{width:2.2em;height:2.2em;border-radius:50%}.vxe-color-picker--preview-btn{background-size:.8em .8em}.vxe-color-picker--preview-color{position:relative;display:flex;flex-direction:row;align-items:center;justify-content:center;border:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-color-picker--preview-color:hover::before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background-color:rgba(0,0,0,.3);z-index:0}.vxe-color-picker--preview-color:hover .vxe-color-picker--preview-copy-btn{display:block;z-index:1}.vxe-color-picker--preview-color:active .vxe-color-picker--preview-copy-btn{font-size:.8em}.vxe-color-picker--preview-copy-btn{display:none;color:#fff;cursor:pointer}.vxe-color-picker--slider-handle{display:flex;flex-direction:column;justify-content:center;flex-grow:1;padding:0 .8em}.vxe-color-picker--bar-alpha-slider,.vxe-color-picker--bar-hue-slider{position:relative;height:1em;width:100%;margin:.4em 0;cursor:pointer}.vxe-color-picker--bar-alpha-bg,.vxe-color-picker--bar-alpha-slider,.vxe-color-picker--bar-hue-slider{border-radius:var(--vxe-ui-base-border-radius)}.vxe-color-picker--bar-hue-slider{background:linear-gradient(to left,red,#ff0 17%,#0f0 33%,#0ff,#00f 67%,#f0f 83%,red)}.vxe-color-picker--bar-alpha-btn,.vxe-color-picker--bar-hue-btn{position:absolute;left:0;top:-4px;width:.6em;height:calc(100% + 8px);border-radius:.2em;background-color:#fff;border:1px solid var(--vxe-ui-base-popup-border-color);transform:translateX(-.3em);cursor:grab;box-shadow:0 0 8px 0 rgba(0,0,0,.3);transition:transform .1s ease-in-out}.vxe-color-picker--bar-alpha-btn:hover,.vxe-color-picker--bar-hue-btn:hover{transform:translateX(-.3em) scale(1.1)}.vxe-color-picker--bar-alpha-btn:active,.vxe-color-picker--bar-hue-btn:active{transform:translateX(-.3em) scale(1.2);cursor:grabbing}.vxe-color-picker--bar-alpha-slider{background-size:1em 1em}.vxe-color-picker--bar-alpha-slider .vxe-color-picker--bar-alpha-bg{position:absolute;top:0;left:0;width:100%;height:100%}.vxe-color-picker--custom-wrapper{display:flex;flex-direction:row;padding:0 .8em}.vxe-color-picker--type-switch{position:relative;flex-shrink:0;margin-top:.4em}.vxe-color-picker--type-icon{padding:.25em;color:var(--vxe-ui-input-placeholder-color)}.vxe-color-picker--type-icon i{display:inline-block;transition:transform .2s ease-in-out}.vxe-color-picker--type-label{padding:0 .25em;line-height:2em;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vxe-color-picker--type-popup{position:absolute;display:none;border-radius:var(--vxe-ui-base-border-radius);border:1px solid var(--vxe-ui-base-popup-border-color);box-shadow:var(--vxe-ui-base-popup-box-shadow);background-color:var(--vxe-ui-layout-background-color);padding:.25em 1em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vxe-color-picker--type-popup.is--visible{display:block}.vxe-color-picker--type-item{line-height:1.6em;cursor:pointer}.vxe-color-picker--type-item:hover{color:var(--vxe-ui-font-primary-lighten-color)}.vxe-color-picker--hex-wrapper,.vxe-color-picker--rgb-wrapper{flex-grow:1;text-align:center;margin-top:.4em}.vxe-color-picker--input-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:right}.vxe-color-picker--input-title{display:flex;flex-direction:row;align-items:center;justify-content:center;line-height:1.4em;color:var(--vxe-ui-input-placeholder-color)}.vxe-color-picker--hex-wrapper{display:flex;flex-direction:column}.vxe-color-picker--hex-wrapper .vxe-color-picker--input-wrapper>.vxe-input{width:20.2em}.vxe-color-picker--rgb-wrapper{display:flex;flex-direction:column}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper>.vxe-input{width:4.6em;margin-left:.6em}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper>.vxe-input:first-child{margin-left:0}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-wrapper>.vxe-input .vxe-input--control-icon{min-width:1.6em}.vxe-color-picker--rgb-wrapper .vxe-color-picker--input-title>span{display:block;width:50px;margin:0 .4em}.vxe-color-picker--footer-wrapper{text-align:right;margin-top:.4em;padding:0 .4em .4em .4em}.vxe-color-picker,.vxe-color-picker--readonly{height:var(--vxe-ui-input-height-default);line-height:var(--vxe-ui-input-height-default)}.vxe-color-picker--readonly.size--medium,.vxe-color-picker.size--medium{height:var(--vxe-ui-input-height-medium);line-height:var(--vxe-ui-input-height-medium)}.vxe-color-picker--readonly.size--small,.vxe-color-picker.size--small{height:var(--vxe-ui-input-height-small);line-height:var(--vxe-ui-input-height-small)}.vxe-color-picker--readonly.size--mini,.vxe-color-picker.size--mini{height:var(--vxe-ui-input-height-mini);line-height:var(--vxe-ui-input-height-mini)}.vxe-color-picker,.vxe-color-picker--panel,.vxe-color-picker--readonly{font-size:var(--vxe-ui-font-size-default)}.vxe-color-picker--panel.size--medium,.vxe-color-picker--readonly.size--medium,.vxe-color-picker.size--medium{font-size:var(--vxe-ui-font-size-medium)}.vxe-color-picker--panel.size--small,.vxe-color-picker--readonly.size--small,.vxe-color-picker.size--small{font-size:var(--vxe-ui-font-size-small)}.vxe-color-picker--panel.size--mini,.vxe-color-picker--readonly.size--mini,.vxe-color-picker.size--mini{font-size:var(--vxe-ui-font-size-mini)}