dtable-ui-component 5.2.15 → 5.2.17-alpha1
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.
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = ColorPickerPortal;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _reactDom = _interopRequireDefault(require("react-dom"));
|
|
11
|
+
var _utils = require("../../utils/utils");
|
|
12
|
+
function ColorPickerPortal(_ref) {
|
|
13
|
+
let {
|
|
14
|
+
target,
|
|
15
|
+
scrollContainerId,
|
|
16
|
+
throttleDelay,
|
|
17
|
+
children
|
|
18
|
+
} = _ref;
|
|
19
|
+
const containerRef = (0, _react.useRef)(null);
|
|
20
|
+
const [position, setPosition] = (0, _react.useState)({
|
|
21
|
+
top: 0,
|
|
22
|
+
left: 0
|
|
23
|
+
});
|
|
24
|
+
(0, _react.useEffect)(() => {
|
|
25
|
+
if (!target || !containerRef.current) return;
|
|
26
|
+
const updatePosition = () => {
|
|
27
|
+
const targetRect = target.getBoundingClientRect();
|
|
28
|
+
const {
|
|
29
|
+
top: spaceAbove,
|
|
30
|
+
left
|
|
31
|
+
} = targetRect;
|
|
32
|
+
const portalRectHeight = containerRef.current.clientHeight;
|
|
33
|
+
if (spaceAbove < portalRectHeight) {
|
|
34
|
+
setPosition({
|
|
35
|
+
top: "calc(".concat(spaceAbove, "px + 2.375rem)"),
|
|
36
|
+
left: left + 1 + 'px'
|
|
37
|
+
});
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
setPosition({
|
|
41
|
+
top: "calc(".concat(spaceAbove - portalRectHeight, "px)"),
|
|
42
|
+
left: left + 1 + 'px'
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
updatePosition();
|
|
46
|
+
const throttledUpdatePosition = (0, _utils.throttle)(updatePosition, throttleDelay);
|
|
47
|
+
const scrollContainer = scrollContainerId ? document.getElementById(scrollContainerId) : null;
|
|
48
|
+
scrollContainer && scrollContainer.addEventListener('scroll', throttledUpdatePosition);
|
|
49
|
+
window.addEventListener('resize', updatePosition);
|
|
50
|
+
return () => {
|
|
51
|
+
window.removeEventListener('resize', updatePosition);
|
|
52
|
+
scrollContainer && scrollContainer.removeEventListener('scroll', throttledUpdatePosition);
|
|
53
|
+
};
|
|
54
|
+
}, [target, containerRef, scrollContainerId, throttleDelay]);
|
|
55
|
+
return /*#__PURE__*/_reactDom.default.createPortal( /*#__PURE__*/_react.default.createElement("div", {
|
|
56
|
+
className: "dtable-color-picker-portal",
|
|
57
|
+
style: {
|
|
58
|
+
position: 'absolute',
|
|
59
|
+
zIndex: '10',
|
|
60
|
+
left: position.left,
|
|
61
|
+
top: position.top,
|
|
62
|
+
width: '240px',
|
|
63
|
+
height: '370px'
|
|
64
|
+
},
|
|
65
|
+
ref: containerRef
|
|
66
|
+
}, children), document.body);
|
|
67
|
+
}
|
|
@@ -13,6 +13,7 @@ var _dtableUtils = require("dtable-utils");
|
|
|
13
13
|
var _lang = require("../lang");
|
|
14
14
|
var _ClickOutside = _interopRequireDefault(require("../ClickOutside"));
|
|
15
15
|
var _utils = require("./utils");
|
|
16
|
+
var _ColorPickerPortal = _interopRequireDefault(require("./ColorPickerPortal"));
|
|
16
17
|
require("./index.css");
|
|
17
18
|
const DEFAULT_COLORS = ['#ffffff', '#f5f5f5', '#eef6f9', '#333333', '#ff0000', '#ffff00', '#0000ff', '#00ff00'];
|
|
18
19
|
const COLOR_PICKER_MODE = {
|
|
@@ -30,7 +31,11 @@ const DTableColorPicker = /*#__PURE__*/(0, _react.forwardRef)((props, ref) => {
|
|
|
30
31
|
onToggle,
|
|
31
32
|
popoverStyle,
|
|
32
33
|
color,
|
|
33
|
-
defaultColors
|
|
34
|
+
defaultColors,
|
|
35
|
+
useProtal,
|
|
36
|
+
target,
|
|
37
|
+
scrollContainerId,
|
|
38
|
+
throttleDelay = 20
|
|
34
39
|
} = props;
|
|
35
40
|
const initialRgbaColor = (0, _utils.hexToRgba)(color);
|
|
36
41
|
const [value, setValue] = (0, _react.useState)(initialRgbaColor);
|
|
@@ -327,13 +332,21 @@ const DTableColorPicker = /*#__PURE__*/(0, _react.forwardRef)((props, ref) => {
|
|
|
327
332
|
className: "blank-placeholder d-flex align-items-center justify-content-center"
|
|
328
333
|
}, /*#__PURE__*/_react.default.createElement("span", null, "/"))));
|
|
329
334
|
};
|
|
330
|
-
|
|
335
|
+
const colorPicker = /*#__PURE__*/_react.default.createElement(_ClickOutside.default, {
|
|
331
336
|
onClickOutside: onClosePopover
|
|
332
337
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
333
338
|
style: popoverStyle,
|
|
334
339
|
ref: colorPickerRef,
|
|
335
340
|
className: "dtable-color-picker"
|
|
336
341
|
}, renderDefaultContainer(), renderCustomContainer(), renderUsedContainer()));
|
|
342
|
+
if (useProtal && target && scrollContainerId) {
|
|
343
|
+
return /*#__PURE__*/_react.default.createElement(_ColorPickerPortal.default, {
|
|
344
|
+
target: target,
|
|
345
|
+
scrollContainerId: scrollContainerId,
|
|
346
|
+
throttleDelay: throttleDelay
|
|
347
|
+
}, colorPicker);
|
|
348
|
+
}
|
|
349
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, colorPicker);
|
|
337
350
|
});
|
|
338
351
|
DTableColorPicker.defaultProps = {
|
|
339
352
|
color: '#ffffff'
|
|
@@ -145,7 +145,8 @@ class SelectOptionGroup extends _react.Component {
|
|
|
145
145
|
changeIndex: this.changeIndex,
|
|
146
146
|
disableHover: this.state.disableHover
|
|
147
147
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
148
|
-
className: "option-label"
|
|
148
|
+
className: "option-label text-truncate",
|
|
149
|
+
title: option.label
|
|
149
150
|
}, option.label), isSelected && /*#__PURE__*/_react.default.createElement("i", {
|
|
150
151
|
className: "dtable-font dtable-icon-check-mark"
|
|
151
152
|
}));
|