@easyv/react-components 0.0.13 → 0.0.15
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.
- package/dist/Color/Preview.d.ts +8 -0
- package/dist/Color/Preview.js +78 -0
- package/dist/Color/Preview.less +48 -0
- package/dist/Color/index.d.ts +2 -0
- package/dist/Color/index.js +69 -0
- package/dist/Color/interface.d.ts +5 -0
- package/dist/Color/interface.js +1 -0
- package/dist/ColorPicker/Panel.d.ts +11 -0
- package/dist/ColorPicker/Panel.js +50 -0
- package/dist/ColorPicker/Panel.less +159 -0
- package/dist/ColorPicker/index.d.ts +9 -3
- package/dist/ColorPicker/index.js +266 -44
- package/dist/ColorPicker/index.less +194 -132
- package/dist/ColorPicker/utils.d.ts +16 -6
- package/dist/ColorPicker/utils.js +86 -40
- package/dist/Input/index.js +15 -14
- package/dist/InputNumber/PointDrag.d.ts +13 -0
- package/dist/InputNumber/PointDrag.js +107 -0
- package/dist/InputNumber/index.d.ts +3 -1
- package/dist/InputNumber/index.js +183 -1
- package/dist/InputNumber/index.less +93 -0
- package/dist/InputNumber/interface.d.ts +6 -1
- package/dist/InputNumber/util.d.ts +8 -0
- package/dist/InputNumber/util.js +31 -0
- package/dist/RangeColor/Panel.d.ts +9 -0
- package/dist/RangeColor/Panel.js +187 -0
- package/dist/RangeColor/Panel.less +0 -0
- package/dist/RangeColor/Points.d.ts +2 -0
- package/dist/RangeColor/Points.js +88 -0
- package/dist/RangeColor/index.d.ts +3 -0
- package/dist/RangeColor/index.js +76 -0
- package/dist/RangeColor/index.less +49 -0
- package/dist/RangeColor/interface.d.ts +8 -0
- package/dist/RangeColor/interface.js +1 -0
- package/dist/SpaceModal/index.d.ts +5 -0
- package/dist/SpaceModal/index.js +19 -0
- package/dist/SpaceModal/index.less +5 -0
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.js +2 -0
- package/dist/hooks/useClickOutside.d.ts +1 -0
- package/dist/hooks/useClickOutside.js +16 -0
- package/dist/hooks/useEventListener.d.ts +1 -0
- package/dist/hooks/useEventListener.js +18 -0
- package/dist/index.css +4 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.js +4 -1
- package/package.json +2 -2
- package/dist/ColorPicker/ColorPreview.d.ts +0 -19
- package/dist/ColorPicker/ColorPreview.js +0 -27
- package/dist/ColorPicker/ColorPreview.less +0 -5
|
@@ -1,37 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
2
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
3
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
4
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
5
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
6
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
7
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
8
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
9
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
10
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
11
|
+
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
12
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
13
|
+
import { useState, useEffect, forwardRef, useRef } from 'react';
|
|
14
|
+
import classNames from 'classnames';
|
|
15
|
+
import { DownOutlined } from '@easyv/react-icons';
|
|
16
|
+
import InputNumber from "../InputNumber";
|
|
17
|
+
import { useLocalStorageState } from 'ahooks';
|
|
18
|
+
import SpaceModal from "../SpaceModal";
|
|
19
|
+
import Points from "./Points";
|
|
20
|
+
import { getBackgroundAccordingColor } from "./utils";
|
|
21
|
+
import ColorPickerPanel from "./Panel";
|
|
22
|
+
import { useClickOutside } from "../hooks";
|
|
6
23
|
import "./index.less";
|
|
7
|
-
import ColorPreview from "./ColorPreview";
|
|
8
24
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
9
|
-
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
10
25
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
onChange = _ref.onChange;
|
|
15
|
-
var colorObj = new Color(value);
|
|
16
|
-
var _useDebounceFn = useDebounceFn(function (_ref2) {
|
|
17
|
-
var color = _ref2.color,
|
|
18
|
-
alpha = _ref2.alpha;
|
|
19
|
-
var newColor;
|
|
20
|
-
var rgbColor;
|
|
21
|
-
if (alpha === 100) {
|
|
22
|
-
newColor = color;
|
|
23
|
-
} else {
|
|
24
|
-
rgbColor = new Color(color).RGB;
|
|
25
|
-
newColor = "RGBA(".concat(rgbColor[0], ",").concat(rgbColor[1], ",").concat(rgbColor[2], ",").concat(alpha / 100, ")");
|
|
26
|
-
}
|
|
27
|
-
onChange === null || onChange === void 0 ? void 0 : onChange(newColor);
|
|
28
|
-
}, {
|
|
29
|
-
wait: 100,
|
|
30
|
-
leading: true,
|
|
31
|
-
trailing: false
|
|
32
|
-
}),
|
|
33
|
-
run = _useDebounceFn.run;
|
|
34
|
-
var linearValue = {
|
|
26
|
+
var defaultColorValue = {
|
|
27
|
+
pure: '#000',
|
|
28
|
+
linear: {
|
|
35
29
|
stops: [{
|
|
36
30
|
offset: 0,
|
|
37
31
|
color: '#fff'
|
|
@@ -40,18 +34,246 @@ export default function ColorPicker(_ref) {
|
|
|
40
34
|
color: '#000'
|
|
41
35
|
}],
|
|
42
36
|
angle: 0,
|
|
43
|
-
opacity:
|
|
37
|
+
opacity: 1
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
function CustomColorPicker(_ref, ref) {
|
|
41
|
+
var mode = _ref.mode,
|
|
42
|
+
color = _ref.color,
|
|
43
|
+
position = _ref.position,
|
|
44
|
+
onChange = _ref.onChange,
|
|
45
|
+
onCancel = _ref.onCancel;
|
|
46
|
+
var _useLocalStorageState = useLocalStorageState('usedColors'),
|
|
47
|
+
_useLocalStorageState2 = _slicedToArray(_useLocalStorageState, 1),
|
|
48
|
+
usedPureColors = _useLocalStorageState2[0];
|
|
49
|
+
var _useLocalStorageState3 = useLocalStorageState('usedLinearColors'),
|
|
50
|
+
_useLocalStorageState4 = _slicedToArray(_useLocalStorageState3, 1),
|
|
51
|
+
usedLinearColors = _useLocalStorageState4[0];
|
|
52
|
+
var _useLocalStorageState5 = useLocalStorageState('recentCollapsed'),
|
|
53
|
+
_useLocalStorageState6 = _slicedToArray(_useLocalStorageState5, 2),
|
|
54
|
+
recentCollapsed = _useLocalStorageState6[0],
|
|
55
|
+
setRecentCollapsed = _useLocalStorageState6[1];
|
|
56
|
+
var _useState = useState(0),
|
|
57
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
58
|
+
active = _useState2[0],
|
|
59
|
+
setActive = _useState2[1];
|
|
60
|
+
var _useState3 = useState(''),
|
|
61
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
62
|
+
localColor = _useState4[0],
|
|
63
|
+
setLocalColor = _useState4[1];
|
|
64
|
+
var lastColorRef = useRef(null);
|
|
65
|
+
var currentColor = mode === 'multi' ? color.type === 'pure' ? color.pure : color[color.type].stops[active] ? color[color.type].stops[active].color : '#fff' : color;
|
|
66
|
+
useEffect(function () {
|
|
67
|
+
setLocalColor(currentColor);
|
|
68
|
+
}, [currentColor]);
|
|
69
|
+
useClickOutside(ref, onCancel);
|
|
70
|
+
useEffect(function () {
|
|
71
|
+
return function () {
|
|
72
|
+
var lastColor = lastColorRef.current;
|
|
73
|
+
console.log('lastColor', lastColor);
|
|
74
|
+
if (lastColor != null) {
|
|
75
|
+
if (typeof lastColor === 'string') {
|
|
76
|
+
var newColors = [lastColor].concat(usedPureColors || []);
|
|
77
|
+
newColors = Array.from(new Set(newColors)).slice(0, 16);
|
|
78
|
+
localStorage.setItem('usedColors', JSON.stringify(newColors));
|
|
79
|
+
} else {
|
|
80
|
+
var _newColors = [lastColor].concat(usedLinearColors || []);
|
|
81
|
+
_newColors = _newColors.slice(0, 16);
|
|
82
|
+
localStorage.setItem('usedLinearColors', JSON.stringify(_newColors));
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
}, []);
|
|
87
|
+
useEffect(function () {
|
|
88
|
+
var downHandler = function downHandler(e) {
|
|
89
|
+
e.stopPropagation();
|
|
90
|
+
if (e.key === 'Backspace') {
|
|
91
|
+
if (mode === 'multi' && color.type !== 'pure') {
|
|
92
|
+
var stops = color[color.type].stops;
|
|
93
|
+
if (stops.length > 2) {
|
|
94
|
+
stops = stops.filter(function (d, i) {
|
|
95
|
+
return i !== active;
|
|
96
|
+
});
|
|
97
|
+
setActive(active > 0 ? active - 1 : 0);
|
|
98
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, _defineProperty({}, color.type, _objectSpread(_objectSpread({}, color[color.type]), {}, {
|
|
99
|
+
stops: stops
|
|
100
|
+
}))));
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
document.body.addEventListener('keydown', downHandler);
|
|
106
|
+
return function () {
|
|
107
|
+
document.body.removeEventListener('keydown', downHandler);
|
|
108
|
+
};
|
|
109
|
+
}, [color, active]);
|
|
110
|
+
var handleTypeChange = function handleTypeChange(type) {
|
|
111
|
+
var typeValue = color[type];
|
|
112
|
+
if (typeValue) {
|
|
113
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, {
|
|
114
|
+
type: type
|
|
115
|
+
}));
|
|
116
|
+
} else {
|
|
117
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, _defineProperty({
|
|
118
|
+
type: type
|
|
119
|
+
}, type, defaultColorValue[type])));
|
|
120
|
+
}
|
|
121
|
+
setActive(0);
|
|
122
|
+
};
|
|
123
|
+
var handleColorChange = function handleColorChange(colorValue, used) {
|
|
124
|
+
if (mode === 'multi') {
|
|
125
|
+
if (color.type === 'pure') {
|
|
126
|
+
lastColorRef.current = used ? null : colorValue;
|
|
127
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, {
|
|
128
|
+
pure: colorValue
|
|
129
|
+
}));
|
|
130
|
+
} else {
|
|
131
|
+
var newColors = color[color.type].stops.map(function (d, i) {
|
|
132
|
+
return i === active ? _objectSpread(_objectSpread({}, d), {}, {
|
|
133
|
+
color: colorValue
|
|
134
|
+
}) : d;
|
|
135
|
+
});
|
|
136
|
+
lastColorRef.current = used ? null : newColors;
|
|
137
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, _defineProperty({}, color.type, _objectSpread(_objectSpread({}, color[color.type]), {}, {
|
|
138
|
+
stops: newColors
|
|
139
|
+
}))));
|
|
140
|
+
}
|
|
141
|
+
} else {
|
|
142
|
+
if (ref.current) {
|
|
143
|
+
lastColorRef.current = used ? null : colorValue;
|
|
144
|
+
}
|
|
145
|
+
onChange(colorValue);
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
|
|
149
|
+
// const handleChangeComplete = (value) => {
|
|
150
|
+
// if (value && value.hex) {
|
|
151
|
+
// const { rgb, hex } = value;
|
|
152
|
+
// const { r, g, b, a } = rgb;
|
|
153
|
+
// let newColor = rgb.a === 1 ? hex : `RGBA(${r},${g},${b},${a})`;
|
|
154
|
+
|
|
155
|
+
// handleColorChange(newColor);
|
|
156
|
+
// }
|
|
157
|
+
// };
|
|
158
|
+
|
|
159
|
+
var handleCollapseRecent = function handleCollapseRecent() {
|
|
160
|
+
setRecentCollapsed(function (prev) {
|
|
161
|
+
return !prev;
|
|
162
|
+
});
|
|
163
|
+
};
|
|
164
|
+
var handleColorsChange = function handleColorsChange(colors, used) {
|
|
165
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, _defineProperty({}, color.type, _objectSpread(_objectSpread({}, color[color.type]), {}, {
|
|
166
|
+
stops: colors
|
|
167
|
+
}))));
|
|
168
|
+
lastColorRef.current = used ? null : colors;
|
|
169
|
+
};
|
|
170
|
+
var handleAngleChange = function handleAngleChange(value) {
|
|
171
|
+
onChange(_objectSpread(_objectSpread({}, color), {}, _defineProperty({}, color.type, _objectSpread(_objectSpread({}, color[color.type]), {}, {
|
|
172
|
+
angle: value
|
|
173
|
+
}))));
|
|
44
174
|
};
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
175
|
+
|
|
176
|
+
// const handleLocalColorChange = useCallback((color) => {
|
|
177
|
+
// setLocalColor(color);
|
|
178
|
+
// }, []);
|
|
179
|
+
|
|
180
|
+
return /*#__PURE__*/_jsx(SpaceModal, {
|
|
181
|
+
children: /*#__PURE__*/_jsxs("div", {
|
|
182
|
+
className: 'arco-color-picker',
|
|
183
|
+
style: {
|
|
184
|
+
left: position.x,
|
|
185
|
+
top: position.y
|
|
186
|
+
},
|
|
187
|
+
ref: ref,
|
|
188
|
+
children: [mode === 'multi' && /*#__PURE__*/_jsxs("div", {
|
|
189
|
+
children: [/*#__PURE__*/_jsxs("div", {
|
|
190
|
+
className: 'arco-color-picker-type',
|
|
191
|
+
children: [/*#__PURE__*/_jsx("span", {
|
|
192
|
+
className: classNames('arco-color-picker-circle', 'arco-color-picker-pure', _defineProperty({}, 'arco-color-picker-active', color.type === 'pure')),
|
|
193
|
+
onClick: function onClick(e) {
|
|
194
|
+
return handleTypeChange('pure');
|
|
195
|
+
}
|
|
196
|
+
}), /*#__PURE__*/_jsx("span", {
|
|
197
|
+
className: classNames('arco-color-picker-circle', 'arco-color-picker-linear', _defineProperty({}, 'arco-color-picker-active', color.type === 'linear')),
|
|
198
|
+
onClick: function onClick(e) {
|
|
199
|
+
return handleTypeChange('linear');
|
|
200
|
+
}
|
|
201
|
+
})]
|
|
202
|
+
}), color.type === 'linear' && /*#__PURE__*/_jsxs("div", {
|
|
203
|
+
className: 'arco-color-picker-colors',
|
|
204
|
+
children: [/*#__PURE__*/_jsx(Points, {
|
|
205
|
+
dots: color.linear.stops,
|
|
206
|
+
active: active,
|
|
207
|
+
setActive: setActive,
|
|
208
|
+
onChange: handleColorsChange
|
|
209
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
210
|
+
style: {
|
|
211
|
+
flex: 1
|
|
212
|
+
},
|
|
213
|
+
children: /*#__PURE__*/_jsx(InputNumber, {
|
|
214
|
+
hideControl: true,
|
|
215
|
+
min: -360,
|
|
216
|
+
max: 360,
|
|
217
|
+
suffix: "\xB0",
|
|
218
|
+
value: color.linear.angle,
|
|
219
|
+
onChange: handleAngleChange,
|
|
220
|
+
style: {
|
|
221
|
+
width: 36
|
|
222
|
+
}
|
|
223
|
+
})
|
|
224
|
+
})]
|
|
225
|
+
})]
|
|
226
|
+
}), /*#__PURE__*/_jsxs("div", {
|
|
227
|
+
className: 'arco-color-picker-scroll-container',
|
|
228
|
+
children: [/*#__PURE__*/_jsx(ColorPickerPanel, {
|
|
229
|
+
record: lastColorRef.current,
|
|
230
|
+
color: localColor,
|
|
231
|
+
active: active,
|
|
232
|
+
onChange: handleColorChange
|
|
233
|
+
}), /*#__PURE__*/_jsxs("div", {
|
|
234
|
+
className: 'arco-color-picker-recent',
|
|
235
|
+
children: [/*#__PURE__*/_jsxs("div", {
|
|
236
|
+
className: 'arco-color-picker-title',
|
|
237
|
+
onClick: handleCollapseRecent,
|
|
238
|
+
children: [/*#__PURE__*/_jsx("div", {
|
|
239
|
+
children: "\u6700\u8FD1\u4F7F\u7528"
|
|
240
|
+
}), /*#__PURE__*/_jsx(DownOutlined, {
|
|
241
|
+
className: classNames('arco-color-picker-icon', _defineProperty({}, 'arco-color-picker-collapsed', recentCollapsed))
|
|
242
|
+
})]
|
|
243
|
+
}), !recentCollapsed && mode === 'multi' && color.type === 'linear' && usedLinearColors && usedLinearColors.length && /*#__PURE__*/_jsx("div", {
|
|
244
|
+
className: 'arco-color-picker-recent-title',
|
|
245
|
+
children: "\u6E10\u53D8"
|
|
246
|
+
}), !recentCollapsed && mode === 'multi' && color.type === 'linear' && /*#__PURE__*/_jsx("div", {
|
|
247
|
+
className: 'arco-color-picker-list',
|
|
248
|
+
children: usedLinearColors && usedLinearColors.map(function (d, i) {
|
|
249
|
+
return /*#__PURE__*/_jsx("div", {
|
|
250
|
+
className: 'arco-color-picker-item',
|
|
251
|
+
style: getBackgroundAccordingColor(d),
|
|
252
|
+
onClick: function onClick() {
|
|
253
|
+
return handleColorsChange(d, true);
|
|
254
|
+
}
|
|
255
|
+
}, i);
|
|
256
|
+
})
|
|
257
|
+
}), !recentCollapsed && mode === 'multi' && color.type === 'linear' && /*#__PURE__*/_jsx("div", {
|
|
258
|
+
className: 'arco-color-picker-recent-title',
|
|
259
|
+
children: "\u7EAF\u8272"
|
|
260
|
+
}), !recentCollapsed && /*#__PURE__*/_jsx("div", {
|
|
261
|
+
className: 'arco-color-picker-list',
|
|
262
|
+
children: usedPureColors && usedPureColors.map(function (d) {
|
|
263
|
+
return /*#__PURE__*/_jsx("div", {
|
|
264
|
+
className: 'arco-color-picker-item',
|
|
265
|
+
style: {
|
|
266
|
+
background: d
|
|
267
|
+
},
|
|
268
|
+
onClick: function onClick() {
|
|
269
|
+
return handleColorChange(d, true);
|
|
270
|
+
}
|
|
271
|
+
}, d);
|
|
272
|
+
})
|
|
273
|
+
})]
|
|
274
|
+
})]
|
|
275
|
+
})]
|
|
276
|
+
})
|
|
56
277
|
});
|
|
57
|
-
}
|
|
278
|
+
}
|
|
279
|
+
export default /*#__PURE__*/forwardRef(CustomColorPicker);
|
|
@@ -1,160 +1,222 @@
|
|
|
1
1
|
.arco-color-picker {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
position: absolute;
|
|
3
|
+
border-radius: 4px;
|
|
4
|
+
background: var(--color-bg-1);
|
|
5
|
+
border: 1px solid #393b4a;
|
|
6
|
+
box-shadow: 0 6px 6px 0 rgba(0, 0, 0, 0.3);
|
|
7
|
+
overflow-y: auto;
|
|
8
|
+
overflow-x: hidden;
|
|
9
|
+
z-index: 9999;
|
|
10
|
+
// max-height: 438px;
|
|
11
|
+
width: 242px;
|
|
12
|
+
display: flex;
|
|
13
|
+
flex-direction: column;
|
|
14
|
+
|
|
15
|
+
&::-webkit-scrollbar {
|
|
16
|
+
width: 0;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.arco-color-picker-recent {
|
|
20
|
+
padding: 6px 10px 8px;
|
|
21
|
+
border-top: 1px solid #393b4a;
|
|
22
|
+
background: var(--color-bg-1);
|
|
23
|
+
|
|
24
|
+
.arco-color-picker-title {
|
|
25
|
+
display: flex;
|
|
26
|
+
justify-content: space-between;
|
|
27
|
+
align-items: center;
|
|
28
|
+
color: #fff;
|
|
29
|
+
|
|
30
|
+
.arco-color-picker-icon {
|
|
31
|
+
cursor: pointer;
|
|
32
|
+
transition: transform linear 200ms;
|
|
33
|
+
font-size: 18px !important;
|
|
34
|
+
|
|
35
|
+
&.arco-color-picker-collapsed {
|
|
36
|
+
transform: rotate(-90deg);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
5
39
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
40
|
+
.arco-color-picker-add {
|
|
41
|
+
margin-right: 8px;
|
|
42
|
+
cursor: pointer;
|
|
9
43
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
.rc-color-picker-panel-ribbon,
|
|
15
|
-
.rc-color-picker-panel-alpha {
|
|
16
|
-
border-radius: 0;
|
|
17
|
-
box-shadow: none;
|
|
18
|
-
|
|
19
|
-
span {
|
|
20
|
-
width: 12px;
|
|
21
|
-
height: 12px;
|
|
22
|
-
border-radius: 6px;
|
|
23
|
-
border: 2px solid #fff;
|
|
24
|
-
background-color: transparent;
|
|
25
|
-
margin-left: -6px;
|
|
26
|
-
margin-top: -3px;
|
|
44
|
+
&:hover {
|
|
45
|
+
color: var(--easyv-primary-color);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
27
48
|
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
.rc-color-picker-panel-wrap {
|
|
31
|
-
margin-top: 16px;
|
|
32
|
-
}
|
|
33
49
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
#ff0099 90%,
|
|
54
|
-
#ff0000 100%
|
|
55
|
-
);
|
|
56
|
-
}
|
|
50
|
+
.arco-color-picker-list {
|
|
51
|
+
display: flex;
|
|
52
|
+
flex-wrap: wrap;
|
|
53
|
+
margin: 12px -10px 0;
|
|
54
|
+
padding: 0 0 0 10px;
|
|
55
|
+
|
|
56
|
+
.arco-color-picker-item {
|
|
57
|
+
box-sizing: border-box;
|
|
58
|
+
width: 20px;
|
|
59
|
+
height: 20px;
|
|
60
|
+
margin: 0 8px 8px 0;
|
|
61
|
+
border-radius: 50%;
|
|
62
|
+
background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAMUlEQVQ4T2NkYGAQYcAP3uCTZhw1gGGYhAGBZIA/nYDCgBDAm9BGDWAAJyRCgLaBCAAgXwixzAS0pgAAAABJRU5ErkJggg==')
|
|
63
|
+
left center;
|
|
64
|
+
overflow: hidden;
|
|
65
|
+
cursor: pointer;
|
|
66
|
+
position: relative;
|
|
67
|
+
border: 1px solid #38393f;
|
|
68
|
+
}
|
|
57
69
|
|
|
58
|
-
|
|
59
|
-
|
|
70
|
+
.arco-color-picker-color {
|
|
71
|
+
width: 100%;
|
|
72
|
+
height: 100%;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
60
75
|
}
|
|
61
76
|
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
padding: 0 6px;
|
|
77
|
+
.arco-color-picker-operate {
|
|
78
|
+
position: absolute;
|
|
79
|
+
background: var(--background-4);
|
|
80
|
+
color: var(--text-1);
|
|
81
|
+
width: 80px;
|
|
82
|
+
box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.57);
|
|
69
83
|
border-radius: 3px;
|
|
70
|
-
background-image: linear-gradient(
|
|
71
|
-
45deg,
|
|
72
|
-
#b9b8c1 25%,
|
|
73
|
-
transparent 0,
|
|
74
|
-
transparent 75%,
|
|
75
|
-
#b9b8c1 0
|
|
76
|
-
),
|
|
77
|
-
linear-gradient(
|
|
78
|
-
45deg,
|
|
79
|
-
#b9b8c1 25%,
|
|
80
|
-
transparent 0,
|
|
81
|
-
transparent 75%,
|
|
82
|
-
#b9b8c1 0
|
|
83
|
-
);
|
|
84
|
-
background-color: #e1e1ea;
|
|
85
|
-
background-size: 6px 6px;
|
|
86
|
-
background-position: 0 0, 3px 3px;
|
|
87
|
-
}
|
|
88
84
|
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
85
|
+
.arco-color-picker-item {
|
|
86
|
+
padding: 0 16px;
|
|
87
|
+
height: 28px;
|
|
88
|
+
line-height: 28px;
|
|
89
|
+
cursor: pointer;
|
|
93
90
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
91
|
+
&:hover {
|
|
92
|
+
color: #fff;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
98
95
|
}
|
|
96
|
+
}
|
|
99
97
|
|
|
100
|
-
|
|
101
|
-
|
|
98
|
+
.arco-color-picker-type {
|
|
99
|
+
display: flex;
|
|
100
|
+
height: 36px;
|
|
101
|
+
align-items: center;
|
|
102
|
+
border-bottom: 1px solid #393b4a;
|
|
103
|
+
|
|
104
|
+
.arco-color-picker-circle {
|
|
105
|
+
position: relative;
|
|
106
|
+
width: 30px;
|
|
107
|
+
height: 36px;
|
|
108
|
+
cursor: pointer;
|
|
109
|
+
|
|
110
|
+
&::before {
|
|
111
|
+
position: absolute;
|
|
112
|
+
top: 50%;
|
|
113
|
+
left: 50%;
|
|
114
|
+
transform: translate(-50%, -50%);
|
|
115
|
+
content: '';
|
|
116
|
+
width: 16px;
|
|
117
|
+
height: 16px;
|
|
118
|
+
border-radius: 50%;
|
|
119
|
+
border: 1px solid #666;
|
|
120
|
+
}
|
|
102
121
|
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
background-color: var(--color-bg-white);
|
|
108
|
-
color: #bfbfbf;
|
|
122
|
+
&.arco-color-picker-linear {
|
|
123
|
+
&::before {
|
|
124
|
+
background-image: linear-gradient(#aaa, #000);
|
|
125
|
+
}
|
|
109
126
|
|
|
110
|
-
|
|
111
|
-
|
|
127
|
+
&.arco-color-picker-active {
|
|
128
|
+
&::before {
|
|
129
|
+
background-image: linear-gradient(
|
|
130
|
+
180deg,
|
|
131
|
+
rgba(36, 145, 247, 0) 18%,
|
|
132
|
+
var(--easyv-primary-color) 100%
|
|
133
|
+
);
|
|
134
|
+
border: 1px solid var(--easyv-primary-color);
|
|
135
|
+
}
|
|
112
136
|
}
|
|
113
137
|
}
|
|
114
|
-
}
|
|
115
138
|
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
139
|
+
&.arco-color-picker-pure {
|
|
140
|
+
&::before {
|
|
141
|
+
background: #666666;
|
|
142
|
+
}
|
|
120
143
|
|
|
121
|
-
|
|
122
|
-
|
|
144
|
+
&.arco-color-picker-active {
|
|
145
|
+
&::before {
|
|
146
|
+
background: var(--easyv-primary-color);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
123
149
|
}
|
|
124
150
|
}
|
|
151
|
+
}
|
|
125
152
|
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
box-shadow: none;
|
|
133
|
-
background-color: transparent;
|
|
134
|
-
cursor: initial;
|
|
135
|
-
}
|
|
153
|
+
.arco-color-picker-colors {
|
|
154
|
+
display: flex;
|
|
155
|
+
align-items: center;
|
|
156
|
+
height: 48px;
|
|
157
|
+
padding: 0 8px 0 16px;
|
|
158
|
+
border-bottom: 1px solid #393b4a;
|
|
136
159
|
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
width:
|
|
140
|
-
height:
|
|
141
|
-
|
|
142
|
-
border-
|
|
143
|
-
|
|
144
|
-
|
|
160
|
+
.arco-color-picker-bar {
|
|
161
|
+
position: relative;
|
|
162
|
+
width: 150px;
|
|
163
|
+
height: 6px;
|
|
164
|
+
margin-right: 16px;
|
|
165
|
+
border-radius: 4px;
|
|
166
|
+
// background-image: linear-gradient(90deg, #fff, #f00);
|
|
167
|
+
&::before {
|
|
168
|
+
content: '';
|
|
169
|
+
position: relative;
|
|
170
|
+
z-index: -1;
|
|
171
|
+
display: block;
|
|
172
|
+
width: 100%;
|
|
173
|
+
height: 100%;
|
|
174
|
+
border-radius: 4px;
|
|
175
|
+
background-image: linear-gradient(
|
|
176
|
+
45deg,
|
|
177
|
+
#404040 25%,
|
|
178
|
+
transparent 0,
|
|
179
|
+
transparent 75%,
|
|
180
|
+
#404040 0
|
|
181
|
+
),
|
|
182
|
+
linear-gradient(
|
|
183
|
+
45deg,
|
|
184
|
+
#404040 25%,
|
|
185
|
+
transparent 0,
|
|
186
|
+
transparent 75%,
|
|
187
|
+
#404040 0
|
|
188
|
+
);
|
|
189
|
+
background-color: #4a4a4a;
|
|
190
|
+
background-size: 10px 10px;
|
|
191
|
+
background-position: 0 0, 5px 5px;
|
|
192
|
+
}
|
|
145
193
|
|
|
146
|
-
|
|
147
|
-
|
|
194
|
+
.arco-color-picker-item {
|
|
195
|
+
position: absolute;
|
|
196
|
+
top: -2px;
|
|
197
|
+
width: 10px;
|
|
198
|
+
height: 10px;
|
|
199
|
+
border-radius: 50%;
|
|
200
|
+
transform: translateX(-50%);
|
|
201
|
+
border: 2px solid #ffffff;
|
|
202
|
+
cursor: pointer;
|
|
203
|
+
|
|
204
|
+
&.arco-color-picker-active {
|
|
205
|
+
width: 12px;
|
|
206
|
+
height: 12px;
|
|
207
|
+
box-shadow: 0 0 0 3px rgba(36, 145, 247, 0.6);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
148
210
|
}
|
|
211
|
+
}
|
|
149
212
|
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
213
|
+
.arco-color-picker-recent-title {
|
|
214
|
+
color: #bfbfbf;
|
|
215
|
+
margin-bottom: 10px;
|
|
216
|
+
}
|
|
153
217
|
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
overflow: hidden;
|
|
159
|
-
}
|
|
218
|
+
.arco-color-picker-scroll-container {
|
|
219
|
+
flex: 1;
|
|
220
|
+
overflow-x: hidden;
|
|
221
|
+
overflow-y: auto;
|
|
160
222
|
}
|