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
- return /*#__PURE__*/_react.default.createElement(_ClickOutside.default, {
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
  }));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dtable-ui-component",
3
- "version": "5.2.15",
3
+ "version": "5.2.17-alpha1",
4
4
  "main": "./lib/index.js",
5
5
  "dependencies": {
6
6
  "@seafile/react-image-lightbox": "3.0.1",