@aloudata/aloudata-design 1.6.3 → 1.6.4
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/DataPreviewTable/components/Body/Cell.d.ts +8 -0
- package/dist/DataPreviewTable/components/Body/Cell.js +43 -0
- package/dist/DataPreviewTable/components/Body/index.js +4 -3
- package/dist/DataPreviewTable/index.d.ts +2 -2
- package/dist/DataPreviewTable/index.js +42 -16
- package/dist/DataPreviewTable/interface.d.ts +3 -0
- package/dist/MemberPicker/components/MemberSelection.d.ts +1 -0
- package/dist/MemberPicker/components/MemberSelection.js +25 -8
- package/dist/MemberPicker/components/NickLabel.js +2 -1
- package/dist/MemberPicker/components/Panel.js +5 -2
- package/dist/MemberPicker/components/SelectedMemberTags.d.ts +1 -0
- package/dist/MemberPicker/components/SelectedMemberTags.js +14 -4
- package/dist/MemberPicker/index.js +42 -9
- package/dist/MemberPicker/style/index.less +37 -8
- package/dist/Select/components/MultipleOption.js +6 -1
- package/dist/Select/components/SingleOption.js +6 -1
- package/dist/index.d.ts +1 -0
- package/dist/style/mixins/index.less +9 -0
- package/package.json +1 -1
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
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; }
|
|
2
|
+
|
|
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
|
+
|
|
5
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
6
|
+
|
|
7
|
+
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); }
|
|
8
|
+
|
|
9
|
+
import classNames from 'classnames';
|
|
10
|
+
import React from 'react';
|
|
11
|
+
export default function Cell(props) {
|
|
12
|
+
var style = props.style,
|
|
13
|
+
value = props.value;
|
|
14
|
+
|
|
15
|
+
if (typeof value === 'string') {
|
|
16
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
17
|
+
style: style,
|
|
18
|
+
className: "ald-data-preview-body-cell"
|
|
19
|
+
}, value);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
if (typeof value === 'number' || typeof value === 'boolean') {
|
|
23
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
24
|
+
style: style,
|
|
25
|
+
className: "ald-data-preview-body-cell"
|
|
26
|
+
}, JSON.stringify(value));
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (_typeof(value) === 'object' && value === null) {
|
|
30
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
31
|
+
style: _objectSpread({
|
|
32
|
+
fontStyle: 'italic',
|
|
33
|
+
color: '#858585'
|
|
34
|
+
}, style),
|
|
35
|
+
className: classNames('ald-data-preview-body-cell', 'ald-data-preview-body-cell-null')
|
|
36
|
+
}, "null");
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
40
|
+
style: style,
|
|
41
|
+
className: "ald-data-preview-body-cell"
|
|
42
|
+
}, value);
|
|
43
|
+
}
|
|
@@ -12,6 +12,7 @@ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
|
12
12
|
|
|
13
13
|
import React, { memo } from 'react';
|
|
14
14
|
import { CELL_HEIGHT, HEADER_HEIGHT } from "../../constant";
|
|
15
|
+
import Cell from "./Cell";
|
|
15
16
|
|
|
16
17
|
function Body(props) {
|
|
17
18
|
var columns = props.columns,
|
|
@@ -40,11 +41,11 @@ function Body(props) {
|
|
|
40
41
|
position: 'absolute',
|
|
41
42
|
textAlign: columns[columnIndex].align || 'left'
|
|
42
43
|
};
|
|
43
|
-
return /*#__PURE__*/React.createElement(
|
|
44
|
+
return /*#__PURE__*/React.createElement(Cell, {
|
|
44
45
|
key: columnIndex,
|
|
45
46
|
style: style,
|
|
46
|
-
|
|
47
|
-
}
|
|
47
|
+
value: cell
|
|
48
|
+
});
|
|
48
49
|
}));
|
|
49
50
|
}));
|
|
50
51
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { ITableProps } from './interface';
|
|
3
|
-
declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<ITableProps & React.RefAttributes<
|
|
2
|
+
import { DataPreviewTableRef, ITableProps } from './interface';
|
|
3
|
+
declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<ITableProps & React.RefAttributes<DataPreviewTableRef>>>;
|
|
4
4
|
export default _default;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import classNames from 'classnames';
|
|
2
|
-
import React, { forwardRef, memo,
|
|
2
|
+
import React, { forwardRef, memo, useImperativeHandle, useMemo, useRef } from 'react';
|
|
3
3
|
import Progress from "../Progress";
|
|
4
4
|
import ScrollArea from "../ScrollArea";
|
|
5
5
|
import Body from "./components/Body";
|
|
@@ -8,9 +8,8 @@ import SkeletonBody from "./components/Body/SkeletonBody";
|
|
|
8
8
|
import Header from "./components/Header";
|
|
9
9
|
import { CELL_HEIGHT, HEADER_HEIGHT } from "./constant";
|
|
10
10
|
import useDirection from "./hooks/useDirection";
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
var _wrapRef$current2;
|
|
11
|
+
var DataPreviewTable = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
12
|
+
var _wrapRef$current5;
|
|
14
13
|
|
|
15
14
|
var _props$columns = props.columns,
|
|
16
15
|
columns = _props$columns === void 0 ? [] : _props$columns,
|
|
@@ -36,17 +35,45 @@ function DataPreviewTable(props, ref) {
|
|
|
36
35
|
contentWidth = _useDirection.contentWidth,
|
|
37
36
|
tableColumns = _useDirection.tableColumns;
|
|
38
37
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
38
|
+
useImperativeHandle(ref, function () {
|
|
39
|
+
return {
|
|
40
|
+
scrollToColumnInView: function scrollToColumnInView(columnId) {
|
|
41
|
+
var _wrapRef$current;
|
|
42
|
+
|
|
43
|
+
// 实现scrollTo方法
|
|
44
|
+
console.log(wrapRef.current, columnLayout);
|
|
45
|
+
var columnPos = columnLayout[columnId]; // 根据容器的宽度,容器的scrollLeft,columnPos,判断当前列是否在可视区域内
|
|
46
|
+
|
|
47
|
+
var _ref = wrapRef.current,
|
|
48
|
+
scrollLeft = _ref.scrollLeft;
|
|
49
|
+
var left = columnPos.left,
|
|
50
|
+
width = columnPos.width;
|
|
51
|
+
var containerWidth = ((_wrapRef$current = wrapRef.current) === null || _wrapRef$current === void 0 ? void 0 : _wrapRef$current.clientWidth) || 0;
|
|
52
|
+
|
|
53
|
+
if (left < scrollLeft) {
|
|
54
|
+
var _wrapRef$current2;
|
|
55
|
+
|
|
56
|
+
// 左边不可见
|
|
57
|
+
(_wrapRef$current2 = wrapRef.current) === null || _wrapRef$current2 === void 0 ? void 0 : _wrapRef$current2.scrollTo({
|
|
58
|
+
left: left,
|
|
59
|
+
behavior: 'smooth'
|
|
60
|
+
});
|
|
61
|
+
} else if (left + width > scrollLeft + containerWidth) {
|
|
62
|
+
var _wrapRef$current3;
|
|
63
|
+
|
|
64
|
+
// 右边不可见
|
|
65
|
+
(_wrapRef$current3 = wrapRef.current) === null || _wrapRef$current3 === void 0 ? void 0 : _wrapRef$current3.scrollTo({
|
|
66
|
+
left: left + width - containerWidth,
|
|
67
|
+
behavior: 'smooth'
|
|
68
|
+
});
|
|
69
|
+
}
|
|
43
70
|
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
71
|
+
};
|
|
72
|
+
});
|
|
46
73
|
var skeletonRows = useMemo(function () {
|
|
47
|
-
var _wrapRef$
|
|
74
|
+
var _wrapRef$current4;
|
|
48
75
|
|
|
49
|
-
var rows = Math.ceil((((_wrapRef$
|
|
76
|
+
var rows = Math.ceil((((_wrapRef$current4 = wrapRef.current) === null || _wrapRef$current4 === void 0 ? void 0 : _wrapRef$current4.clientHeight) || 0 - HEADER_HEIGHT) / CELL_HEIGHT);
|
|
50
77
|
return rows - 1 < 0 ? 0 : rows - 1; // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
51
78
|
}, [wrapRef.current]);
|
|
52
79
|
return /*#__PURE__*/React.createElement(ScrollArea, {
|
|
@@ -91,9 +118,8 @@ function DataPreviewTable(props, ref) {
|
|
|
91
118
|
rowRange: rowRange
|
|
92
119
|
}), dataStatus === 'error' && /*#__PURE__*/React.createElement(Error, {
|
|
93
120
|
errorMsg: errorMsg,
|
|
94
|
-
wrapWidth: ((_wrapRef$
|
|
121
|
+
wrapWidth: ((_wrapRef$current5 = wrapRef.current) === null || _wrapRef$current5 === void 0 ? void 0 : _wrapRef$current5.clientWidth) || 0,
|
|
95
122
|
contentWidth: contentWidth
|
|
96
123
|
})));
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
export default /*#__PURE__*/memo( /*#__PURE__*/forwardRef(DataPreviewTable));
|
|
124
|
+
});
|
|
125
|
+
export default /*#__PURE__*/memo(DataPreviewTable);
|
|
@@ -9,6 +9,9 @@ export interface ITableProps {
|
|
|
9
9
|
errorMsg?: string;
|
|
10
10
|
className?: string;
|
|
11
11
|
}
|
|
12
|
+
export interface DataPreviewTableRef {
|
|
13
|
+
scrollToColumnInView: (columnId: string) => void;
|
|
14
|
+
}
|
|
12
15
|
export declare type Align = 'left' | 'center' | 'right';
|
|
13
16
|
export interface PreviewColumn {
|
|
14
17
|
icon?: React.ReactNode;
|
|
@@ -26,7 +26,8 @@ export default function MemberSelection(props) {
|
|
|
26
26
|
onChange = props.onChange,
|
|
27
27
|
selectedUsers = props.selectedUsers,
|
|
28
28
|
onSearchValueChange = props.onSearchValueChange,
|
|
29
|
-
loading = props.loading
|
|
29
|
+
loading = props.loading,
|
|
30
|
+
width = props.width;
|
|
30
31
|
|
|
31
32
|
var _useState = useState(''),
|
|
32
33
|
_useState2 = _slicedToArray(_useState, 2),
|
|
@@ -34,28 +35,44 @@ export default function MemberSelection(props) {
|
|
|
34
35
|
setSearchValue = _useState2[1];
|
|
35
36
|
|
|
36
37
|
var deferredSearchValue = useDeferredValue(searchValue);
|
|
38
|
+
var inputRef = React.useRef(null);
|
|
37
39
|
useEffect(function () {
|
|
38
40
|
onSearchValueChange === null || onSearchValueChange === void 0 ? void 0 : onSearchValueChange(deferredSearchValue);
|
|
39
41
|
}, [deferredSearchValue, onSearchValueChange]);
|
|
42
|
+
useEffect(function () {
|
|
43
|
+
if (inputRef.current) {
|
|
44
|
+
inputRef.current.focus();
|
|
45
|
+
}
|
|
46
|
+
}, []);
|
|
40
47
|
return /*#__PURE__*/React.createElement("div", {
|
|
41
48
|
className: classNames(className, 'ald-member-picker-member-list-wrap')
|
|
42
49
|
}, /*#__PURE__*/React.createElement(Input, {
|
|
43
50
|
prefix: /*#__PURE__*/React.createElement(SearchLine, null),
|
|
51
|
+
ref: inputRef,
|
|
44
52
|
className: 'ald-member-picker-search-input',
|
|
45
53
|
onChange: function onChange(e) {
|
|
46
54
|
setSearchValue(e.target.value);
|
|
47
55
|
}
|
|
56
|
+
}), userList.length === 0 && !loading && /*#__PURE__*/React.createElement(Empty, {
|
|
57
|
+
title: "\u65E0\u6570\u636E",
|
|
58
|
+
size: "small",
|
|
59
|
+
image: Empty.PRESENTED_IMAGE_SEARCH,
|
|
60
|
+
className: "ald-member-picker-member-list-empty"
|
|
48
61
|
}), /*#__PURE__*/React.createElement(Spin, {
|
|
49
62
|
tip: "Loading",
|
|
50
63
|
spinning: loading,
|
|
51
64
|
size: "small"
|
|
52
|
-
},
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
}) : /*#__PURE__*/React.createElement(ScrollArea, {
|
|
57
|
-
className: 'ald-member-picker-member-list',
|
|
65
|
+
}, /*#__PURE__*/React.createElement(ScrollArea, {
|
|
66
|
+
className: classNames('ald-member-picker-member-list', {
|
|
67
|
+
'ald-member-picker-member-list-null': userList.length === 0 && !loading
|
|
68
|
+
}),
|
|
58
69
|
innerClassName: "ald-member-picker-member-scroll"
|
|
70
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
71
|
+
className: "ald-member-picker-member-list-inner",
|
|
72
|
+
style: {
|
|
73
|
+
width: width,
|
|
74
|
+
overflow: 'hidden'
|
|
75
|
+
}
|
|
59
76
|
}, userList.map(function (user) {
|
|
60
77
|
var isSelected = selectedUsers.some(function (selectedUser) {
|
|
61
78
|
return selectedUser.userId === user.userId;
|
|
@@ -71,5 +88,5 @@ export default function MemberSelection(props) {
|
|
|
71
88
|
selected: isSelected,
|
|
72
89
|
onChange: onChange
|
|
73
90
|
});
|
|
74
|
-
}))));
|
|
91
|
+
})))));
|
|
75
92
|
}
|
|
@@ -13,7 +13,8 @@ var NickLabel = function NickLabel(_ref) {
|
|
|
13
13
|
src: src,
|
|
14
14
|
size: 20
|
|
15
15
|
}, innerName), /*#__PURE__*/React.createElement("div", {
|
|
16
|
-
className: "ald-member-picker-nick-label-name"
|
|
16
|
+
className: "ald-member-picker-nick-label-name",
|
|
17
|
+
title: innerName
|
|
17
18
|
}, innerName));
|
|
18
19
|
};
|
|
19
20
|
|
|
@@ -91,8 +91,9 @@ export default function Panel(props) {
|
|
|
91
91
|
width: panelWidth
|
|
92
92
|
}
|
|
93
93
|
}, multiple ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(MemberSelection, {
|
|
94
|
-
className: 'ald-member-picker-
|
|
94
|
+
className: 'ald-member-picker-member-selection-multiple',
|
|
95
95
|
userList: userList,
|
|
96
|
+
width: (panelWidth - 3) / 2,
|
|
96
97
|
selectedUsers: selectedUsers,
|
|
97
98
|
onChange: onSelectionChange,
|
|
98
99
|
onSearchValueChange: onSearchValueChange,
|
|
@@ -101,14 +102,16 @@ export default function Panel(props) {
|
|
|
101
102
|
}), /*#__PURE__*/React.createElement(SelectedMemberTags, {
|
|
102
103
|
className: 'ald-member-picker-selected-member-tags',
|
|
103
104
|
selectedUsers: selectedUsers,
|
|
105
|
+
width: (panelWidth - 3) / 2,
|
|
104
106
|
onRemove: onRemove
|
|
105
107
|
}), /*#__PURE__*/React.createElement(SelectorFooter, {
|
|
106
108
|
className: 'ald-member-picker-selector-footer',
|
|
107
109
|
onCancel: props.onCancel,
|
|
108
110
|
onOk: onOk
|
|
109
111
|
})) : /*#__PURE__*/React.createElement(MemberSelection, {
|
|
110
|
-
className: 'ald-member-picker-
|
|
112
|
+
className: 'ald-member-picker-member-selection-single',
|
|
111
113
|
userList: userList,
|
|
114
|
+
width: panelWidth - 2,
|
|
112
115
|
onChange: onSelectionChange,
|
|
113
116
|
selectedUsers: selectedUsers,
|
|
114
117
|
onSearchValueChange: onSearchValueChange,
|
|
@@ -3,16 +3,26 @@ function _extends() { _extends = Object.assign ? Object.assign.bind() : function
|
|
|
3
3
|
import { CloseMLine } from '@aloudata/icons-react';
|
|
4
4
|
import classNames from 'classnames';
|
|
5
5
|
import React from 'react';
|
|
6
|
+
import ScrollArea from "../../ScrollArea";
|
|
6
7
|
import NickLabel from "./NickLabel";
|
|
7
8
|
export default function SelectedMemberTags(props) {
|
|
8
9
|
var className = props.className,
|
|
9
|
-
selectedUsers = props.selectedUsers
|
|
10
|
+
selectedUsers = props.selectedUsers,
|
|
11
|
+
width = props.width;
|
|
10
12
|
return /*#__PURE__*/React.createElement("div", {
|
|
11
13
|
className: classNames(className, 'ald-member-picker-selected-member-tags-wrap')
|
|
12
14
|
}, /*#__PURE__*/React.createElement("div", {
|
|
13
15
|
className: 'ald-member-picker-has-selected'
|
|
14
|
-
}, "\u5DF2\u9009 ", selectedUsers.length), /*#__PURE__*/React.createElement(
|
|
15
|
-
|
|
16
|
+
}, "\u5DF2\u9009 ", selectedUsers.length), /*#__PURE__*/React.createElement(ScrollArea, {
|
|
17
|
+
style: {
|
|
18
|
+
maxHeight: 'calc(100% - 20px)',
|
|
19
|
+
overflow: 'hidden'
|
|
20
|
+
}
|
|
21
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
22
|
+
className: 'ald-member-picker-tags',
|
|
23
|
+
style: {
|
|
24
|
+
width: width - 17
|
|
25
|
+
}
|
|
16
26
|
}, selectedUsers.map(function (user) {
|
|
17
27
|
return /*#__PURE__*/React.createElement("div", {
|
|
18
28
|
className: 'ald-member-picker-selected-member-tag',
|
|
@@ -29,5 +39,5 @@ export default function SelectedMemberTags(props) {
|
|
|
29
39
|
(_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, user);
|
|
30
40
|
}
|
|
31
41
|
}));
|
|
32
|
-
})));
|
|
42
|
+
}))));
|
|
33
43
|
}
|
|
@@ -8,6 +8,8 @@ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symb
|
|
|
8
8
|
|
|
9
9
|
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
10
10
|
|
|
11
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
12
|
+
|
|
11
13
|
function _objectDestructuringEmpty(obj) { if (obj == null) throw new TypeError("Cannot destructure undefined"); }
|
|
12
14
|
|
|
13
15
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
@@ -26,7 +28,7 @@ import { FoldDownFill } from '@aloudata/icons-react';
|
|
|
26
28
|
import { useRequest } from 'ahooks';
|
|
27
29
|
import classNames from 'classnames';
|
|
28
30
|
import _ from 'lodash';
|
|
29
|
-
import React, { useCallback, useEffect, useMemo, useState } from 'react';
|
|
31
|
+
import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';
|
|
30
32
|
import ConfigProvider from "../ConfigProvider";
|
|
31
33
|
import Dropdown from "../Dropdown";
|
|
32
34
|
import message from "../message";
|
|
@@ -63,14 +65,20 @@ var MemberSelector = function MemberSelector(_ref) {
|
|
|
63
65
|
searchString = _useState6[0],
|
|
64
66
|
setSearchString = _useState6[1];
|
|
65
67
|
|
|
68
|
+
var _useState7 = useState(dropdownWidth),
|
|
69
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
70
|
+
dropdownContentWidth = _useState8[0],
|
|
71
|
+
setDropdownContentWidth = _useState8[1];
|
|
72
|
+
|
|
73
|
+
var triggerRef = useRef(null);
|
|
66
74
|
var onSearchValueChange = useCallback(function (v) {
|
|
67
75
|
setSearchString(v);
|
|
68
76
|
}, []);
|
|
69
77
|
|
|
70
|
-
var
|
|
71
|
-
|
|
72
|
-
dropdownOpen =
|
|
73
|
-
setDropdownOpen =
|
|
78
|
+
var _useState9 = useState(!!open),
|
|
79
|
+
_useState10 = _slicedToArray(_useState9, 2),
|
|
80
|
+
dropdownOpen = _useState10[0],
|
|
81
|
+
setDropdownOpen = _useState10[1];
|
|
74
82
|
|
|
75
83
|
var queryByKeywords = useMemo(function () {
|
|
76
84
|
if (getUsersByKeywords) {
|
|
@@ -81,7 +89,7 @@ var MemberSelector = function MemberSelector(_ref) {
|
|
|
81
89
|
_objectDestructuringEmpty(_ref2);
|
|
82
90
|
|
|
83
91
|
return Promise.reject({
|
|
84
|
-
message: '请在ConfigProvider中配置
|
|
92
|
+
message: '请在ConfigProvider中配置getUsersByKeywords方法'
|
|
85
93
|
});
|
|
86
94
|
};
|
|
87
95
|
}, [getUsersByKeywords]);
|
|
@@ -94,7 +102,7 @@ var MemberSelector = function MemberSelector(_ref) {
|
|
|
94
102
|
_objectDestructuringEmpty(_ref3);
|
|
95
103
|
|
|
96
104
|
return Promise.reject({
|
|
97
|
-
message: '请在ConfigProvider中配置
|
|
105
|
+
message: '请在ConfigProvider中配置getUsersByIds方法'
|
|
98
106
|
});
|
|
99
107
|
};
|
|
100
108
|
}, [getUsersByIds]);
|
|
@@ -160,6 +168,30 @@ var MemberSelector = function MemberSelector(_ref) {
|
|
|
160
168
|
setDropdownOpen(open);
|
|
161
169
|
}
|
|
162
170
|
}, [open]);
|
|
171
|
+
useEffect(function () {
|
|
172
|
+
var resizeEle = triggerRef.current;
|
|
173
|
+
if (!resizeEle) return;
|
|
174
|
+
var resizeObserver = new ResizeObserver(function (entries) {
|
|
175
|
+
var _iterator = _createForOfIteratorHelper(entries),
|
|
176
|
+
_step;
|
|
177
|
+
|
|
178
|
+
try {
|
|
179
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
180
|
+
var entry = _step.value;
|
|
181
|
+
var width = entry.contentRect.width;
|
|
182
|
+
setDropdownContentWidth(width);
|
|
183
|
+
}
|
|
184
|
+
} catch (err) {
|
|
185
|
+
_iterator.e(err);
|
|
186
|
+
} finally {
|
|
187
|
+
_iterator.f();
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
resizeObserver.observe(resizeEle);
|
|
191
|
+
return function () {
|
|
192
|
+
resizeObserver.unobserve(resizeEle);
|
|
193
|
+
};
|
|
194
|
+
}, [triggerRef]);
|
|
163
195
|
var onDropdownOpenChange = useCallback(function (open) {
|
|
164
196
|
setDropdownOpen(open);
|
|
165
197
|
onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(open);
|
|
@@ -175,7 +207,7 @@ var MemberSelector = function MemberSelector(_ref) {
|
|
|
175
207
|
userList: totalUserList,
|
|
176
208
|
multiple: multiple,
|
|
177
209
|
loading: loading,
|
|
178
|
-
dropdownWidth: dropdownWidth,
|
|
210
|
+
dropdownWidth: dropdownWidth || dropdownContentWidth,
|
|
179
211
|
onSearchValueChange: onSearchValueChange,
|
|
180
212
|
onChange: onSelectedChange,
|
|
181
213
|
onCancel: setDropdownOpen.bind(null, false)
|
|
@@ -184,7 +216,8 @@ var MemberSelector = function MemberSelector(_ref) {
|
|
|
184
216
|
}, /*#__PURE__*/React.createElement("div", {
|
|
185
217
|
className: classNames(className, 'ald-member-picker-trigger', {
|
|
186
218
|
'ald-member-picker-trigger-open': dropdownOpen
|
|
187
|
-
})
|
|
219
|
+
}),
|
|
220
|
+
ref: triggerRef
|
|
188
221
|
}, children || /*#__PURE__*/React.createElement("div", {
|
|
189
222
|
className: classNames('ald-member-picker-content-wrap', {
|
|
190
223
|
'ald-member-picker-content-wrap-open': dropdownOpen
|
|
@@ -8,15 +8,15 @@
|
|
|
8
8
|
@import '../../Spin/style/index.less';
|
|
9
9
|
|
|
10
10
|
.ald-member-picker-wrapper {
|
|
11
|
+
box-sizing: border-box;
|
|
11
12
|
border: 1px solid var(--colors-gray-400, #dbdbdb);
|
|
12
13
|
background: var(--colors-neutral-white, #fff);
|
|
13
14
|
box-shadow: 0 20px 24px -4px rgb(16 24 40 / 0.08),
|
|
14
15
|
0 8px 8px -4px rgb(16 24 40 / 0.03);
|
|
15
16
|
|
|
16
17
|
&.ald-member-picker-multiple {
|
|
17
|
-
display:
|
|
18
|
-
|
|
19
|
-
grid-template-rows: 320px 56px;
|
|
18
|
+
display: flex;
|
|
19
|
+
flex-wrap: wrap;
|
|
20
20
|
border-radius: 4px;
|
|
21
21
|
// .memberSelection {
|
|
22
22
|
// }
|
|
@@ -31,15 +31,36 @@
|
|
|
31
31
|
}
|
|
32
32
|
|
|
33
33
|
.ald-member-picker-member-list-wrap {
|
|
34
|
-
|
|
34
|
+
&.ald-member-picker-member-selection-multiple {
|
|
35
|
+
width: 50%;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
&.ald-member-picker-member-selection-single {
|
|
39
|
+
width: 100%;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.ald-member-picker-search-input.ald-member-picker-search-input {
|
|
35
43
|
border: none;
|
|
36
44
|
border-bottom: 1px solid var(--colors-gray-300, #e8e8e8);
|
|
45
|
+
border-radius: 0;
|
|
46
|
+
|
|
47
|
+
&.ant-input-affix-wrapper-focused {
|
|
48
|
+
border-color: #dbdbdb;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.ald-member-picker-member-list-empty {
|
|
53
|
+
min-height: 180px;
|
|
37
54
|
}
|
|
38
55
|
|
|
39
56
|
.ald-member-picker-member-list {
|
|
40
57
|
height: calc(100% - 32px);
|
|
41
58
|
min-height: 180px;
|
|
42
59
|
|
|
60
|
+
&.ald-member-picker-member-list-null {
|
|
61
|
+
display: none;
|
|
62
|
+
}
|
|
63
|
+
|
|
43
64
|
.ald-member-picker-member-scroll {
|
|
44
65
|
max-height: 288px;
|
|
45
66
|
}
|
|
@@ -47,12 +68,9 @@
|
|
|
47
68
|
}
|
|
48
69
|
|
|
49
70
|
.ald-member-picker-selected-member-tags-wrap {
|
|
71
|
+
width: 50%;
|
|
50
72
|
max-height: 320px;
|
|
51
73
|
padding: 8px;
|
|
52
|
-
display: grid;
|
|
53
|
-
grid-template-columns: auto;
|
|
54
|
-
grid-template-rows: 20px auto;
|
|
55
|
-
gap: 8px;
|
|
56
74
|
|
|
57
75
|
.ald-member-picker-has-selected {
|
|
58
76
|
color: var(--colors-gray-900, #171717);
|
|
@@ -60,6 +78,7 @@
|
|
|
60
78
|
font-style: normal;
|
|
61
79
|
font-weight: 400;
|
|
62
80
|
line-height: 20px;
|
|
81
|
+
margin-bottom: 8px;
|
|
63
82
|
}
|
|
64
83
|
|
|
65
84
|
.ald-member-picker-tags {
|
|
@@ -80,6 +99,7 @@
|
|
|
80
99
|
font-weight: 400;
|
|
81
100
|
line-height: 20px;
|
|
82
101
|
height: 24px;
|
|
102
|
+
max-width: 100%;
|
|
83
103
|
|
|
84
104
|
.ald-member-picker-close {
|
|
85
105
|
cursor: pointer;
|
|
@@ -89,6 +109,7 @@
|
|
|
89
109
|
}
|
|
90
110
|
|
|
91
111
|
.ald-member-picker-footer {
|
|
112
|
+
width: 100%;
|
|
92
113
|
display: flex;
|
|
93
114
|
padding: var(--global-number-spacing-spacing-sm, 12px)
|
|
94
115
|
var(--global-number-spacing-spacing-lg, 24px);
|
|
@@ -183,6 +204,12 @@
|
|
|
183
204
|
gap: 4px;
|
|
184
205
|
flex-wrap: nowrap;
|
|
185
206
|
align-items: center;
|
|
207
|
+
max-width: fit-content;
|
|
208
|
+
overflow: hidden;
|
|
209
|
+
|
|
210
|
+
.ald-avatar {
|
|
211
|
+
flex-shrink: 0;
|
|
212
|
+
}
|
|
186
213
|
|
|
187
214
|
.ald-member-picker-nick-label-name {
|
|
188
215
|
color: var(--colors-gray-900, #171717);
|
|
@@ -191,5 +218,7 @@
|
|
|
191
218
|
font-weight: 400;
|
|
192
219
|
line-height: 20px;
|
|
193
220
|
white-space: nowrap;
|
|
221
|
+
text-overflow: ellipsis;
|
|
222
|
+
overflow: hidden;
|
|
194
223
|
}
|
|
195
224
|
}
|
|
@@ -1,7 +1,11 @@
|
|
|
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
|
+
|
|
1
3
|
import classnames from 'classnames';
|
|
2
4
|
import React from 'react';
|
|
3
5
|
import Checkbox from "../../Checkbox";
|
|
4
6
|
export default function MultipleList(params) {
|
|
7
|
+
var _option$label;
|
|
8
|
+
|
|
5
9
|
var disabled = params.disabled,
|
|
6
10
|
option = params.option,
|
|
7
11
|
selected = params.selected,
|
|
@@ -22,6 +26,7 @@ export default function MultipleList(params) {
|
|
|
22
26
|
checked: selected,
|
|
23
27
|
disabled: disabled
|
|
24
28
|
}), /*#__PURE__*/React.createElement("span", {
|
|
25
|
-
className: "ald-multiple-option-label"
|
|
29
|
+
className: "ald-multiple-option-label",
|
|
30
|
+
title: _typeof(option.label) !== 'object' ? (_option$label = option.label) === null || _option$label === void 0 ? void 0 : _option$label.toString() : ''
|
|
26
31
|
}, option.label));
|
|
27
32
|
}
|
|
@@ -1,6 +1,10 @@
|
|
|
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
|
+
|
|
1
3
|
import classnames from 'classnames';
|
|
2
4
|
import React from 'react';
|
|
3
5
|
export default function SingleOption(params) {
|
|
6
|
+
var _option$label;
|
|
7
|
+
|
|
4
8
|
var disabled = params.disabled,
|
|
5
9
|
selected = params.selected,
|
|
6
10
|
option = params.option,
|
|
@@ -20,6 +24,7 @@ export default function SingleOption(params) {
|
|
|
20
24
|
}),
|
|
21
25
|
onClick: onClick
|
|
22
26
|
}, /*#__PURE__*/React.createElement("span", {
|
|
23
|
-
className: "ald-single-option-text"
|
|
27
|
+
className: "ald-single-option-text",
|
|
28
|
+
title: _typeof(option.label) !== 'object' ? (_option$label = option.label) === null || _option$label === void 0 ? void 0 : _option$label.toString() : ''
|
|
24
29
|
}, option.label));
|
|
25
30
|
}
|
package/dist/index.d.ts
CHANGED
|
@@ -23,6 +23,7 @@ export { default as ColorPicker } from './ColorPicker';
|
|
|
23
23
|
export type { IColorPickerProps } from './ColorPicker';
|
|
24
24
|
export { default as ConfigProvider } from './ConfigProvider';
|
|
25
25
|
export { default as DataPreviewTable } from './DataPreviewTable';
|
|
26
|
+
export type { DataPreviewTableRef, ITableProps as DataPreviewTableProps, PreviewColumn, } from './DataPreviewTable/interface';
|
|
26
27
|
export { default as DatePicker } from './DatePicker';
|
|
27
28
|
export type { DatePickerProps } from './DatePicker';
|
|
28
29
|
export { default as Divider } from './Divider';
|