@aloudata/aloudata-design 1.6.3 → 1.7.0

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,8 @@
1
+ interface ICell {
2
+ value: TValue;
3
+ style?: React.CSSProperties;
4
+ }
5
+ import React from 'react';
6
+ import { TValue } from '../../interface';
7
+ export default function Cell(props: ICell): JSX.Element;
8
+ export {};
@@ -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("div", {
44
+ return /*#__PURE__*/React.createElement(Cell, {
44
45
  key: columnIndex,
45
46
  style: style,
46
- className: "ald-data-preview-body-cell"
47
- }, cell);
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<HTMLDivElement>>>;
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, useEffect, useMemo, useRef } from 'react';
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
- function DataPreviewTable(props, ref) {
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
- useEffect(function () {
40
- if (ref) {
41
- if (typeof ref === 'function') {
42
- ref(wrapRef.current);
38
+ useImperativeHandle(ref, function () {
39
+ return {
40
+ scrollToColumnInView: function scrollToColumnInView(columnId) {
41
+ var _wrapRef$current;
42
+
43
+ // 实现scrollTo方法
44
+ var columnPos = columnLayout[columnId];
45
+ if (!columnPos) return; // 根据容器的宽度,容器的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
- }, [ref]);
71
+ };
72
+ });
46
73
  var skeletonRows = useMemo(function () {
47
- var _wrapRef$current;
74
+ var _wrapRef$current4;
48
75
 
49
- var rows = Math.ceil((((_wrapRef$current = wrapRef.current) === null || _wrapRef$current === void 0 ? void 0 : _wrapRef$current.clientHeight) || 0 - HEADER_HEIGHT) / CELL_HEIGHT);
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$current2 = wrapRef.current) === null || _wrapRef$current2 === void 0 ? void 0 : _wrapRef$current2.clientWidth) || 0,
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;
@@ -8,6 +8,7 @@ interface IMemberSelectionProps {
8
8
  selectedUsers: IUser[];
9
9
  onSearchValueChange?: (value: string) => void;
10
10
  loading: boolean;
11
+ width: number;
11
12
  }
12
13
  export default function MemberSelection(props: IMemberSelectionProps): JSX.Element;
13
14
  export {};
@@ -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
- }, userList.length === 0 ? /*#__PURE__*/React.createElement(Empty, {
53
- title: "\u65E0\u6570\u636E",
54
- size: "small",
55
- image: Empty.PRESENTED_IMAGE_SEARCH
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-memberSelection',
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-memberSelection',
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,
@@ -4,6 +4,7 @@ interface ISelectedMemberTagsProps {
4
4
  className?: string;
5
5
  selectedUsers: IUser[];
6
6
  onRemove?: (user: IUser) => void;
7
+ width: number;
7
8
  }
8
9
  export default function SelectedMemberTags(props: ISelectedMemberTagsProps): JSX.Element;
9
10
  export {};
@@ -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("div", {
15
- className: 'ald-member-picker-tags'
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 _useState7 = useState(!!open),
71
- _useState8 = _slicedToArray(_useState7, 2),
72
- dropdownOpen = _useState8[0],
73
- setDropdownOpen = _useState8[1];
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中配置queryByKeywords方法'
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中配置queryByIds方法'
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: grid;
18
- grid-template-columns: repeat(2, 1fr);
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
- .ald-member-picker-search-input {
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
  }
@@ -0,0 +1,3 @@
1
+ import { Tag, TagProps, TagType } from 'antd';
2
+ export type { TagProps, TagType };
3
+ export default Tag;
@@ -0,0 +1,2 @@
1
+ import { Tag } from 'antd';
2
+ export default Tag;
@@ -0,0 +1,2 @@
1
+ import '../../style';
2
+ import './index.less';
@@ -0,0 +1,2 @@
1
+ import "../../style";
2
+ import "./index.less";
@@ -0,0 +1 @@
1
+ @import '../../style/index.less';
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';
@@ -81,6 +82,8 @@ export { default as Table } from './Table';
81
82
  export type { IColumn, ISort, ITableProps, TSortOrder, } from './Table/interface';
82
83
  export { default as Tabs } from './Tabs';
83
84
  export type { ITabsProps as TabsProps, TabsSize } from './Tabs';
85
+ export { default as Tag } from './Tag';
86
+ export type { TagProps, TagType } from './Tag';
84
87
  export { default as Tooltip } from './Tooltip';
85
88
  export type { ActionType as TooltipActionType, ITooltipProps as TooltipProps, } from './Tooltip';
86
89
  export { default as Tree } from './Tree';
package/dist/index.js CHANGED
@@ -46,6 +46,7 @@ export { default as Steps } from "./Steps";
46
46
  export { default as Switch } from "./Switch";
47
47
  export { default as Table } from "./Table";
48
48
  export { default as Tabs } from "./Tabs";
49
+ export { default as Tag } from "./Tag";
49
50
  export { default as Tooltip } from "./Tooltip";
50
51
  export { default as Tree } from "./Tree";
51
52
  export { default as Typography } from "./Typography";
@@ -15,3 +15,12 @@
15
15
  * :focus {
16
16
  outline: none;
17
17
  }
18
+
19
+ * {
20
+ box-sizing: border-box;
21
+ }
22
+
23
+ *::before,
24
+ *::after {
25
+ box-sizing: border-box;
26
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aloudata/aloudata-design",
3
- "version": "1.6.3",
3
+ "version": "1.7.0",
4
4
  "description": "",
5
5
  "license": "MIT",
6
6
  "module": "dist/index.js",