@zykj2024/much-library 1.1.7-beta.2 → 1.1.7-beta.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.
Files changed (167) hide show
  1. package/dist/esm/McCascader/city.js +909 -0
  2. package/dist/esm/McCascader/index.d.ts +19 -0
  3. package/dist/esm/McCascader/index.js +221 -0
  4. package/dist/esm/McCascader/index.less +72 -0
  5. package/dist/esm/McContainer/index.d.ts +192 -0
  6. package/dist/esm/McContainer/index.js +522 -0
  7. package/dist/esm/McContainer/index.less +132 -0
  8. package/dist/esm/McDateRange/index.d.ts +28 -0
  9. package/dist/esm/McDateRange/index.js +167 -0
  10. package/dist/esm/McDateRange/index.less +33 -0
  11. package/dist/esm/McEllipsis/index.d.ts +40 -0
  12. package/dist/esm/McEllipsis/index.js +115 -0
  13. package/dist/esm/McEllipsis/index.less +9 -0
  14. package/dist/esm/McEllipsisMiddle/index.d.ts +13 -0
  15. package/dist/esm/McEllipsisMiddle/index.js +42 -0
  16. package/dist/esm/McEllipsisMiddle/index.less +9 -0
  17. package/dist/esm/McFonts/index.d.ts +8 -0
  18. package/dist/esm/McFonts/index.js +7 -0
  19. package/dist/esm/McGroupPanel/comps/SelectedItem/index.d.ts +4 -0
  20. package/dist/esm/McGroupPanel/comps/SelectedItem/index.js +75 -0
  21. package/dist/esm/McGroupPanel/index.d.ts +30 -0
  22. package/dist/esm/McGroupPanel/index.js +426 -0
  23. package/dist/esm/McGroupPanel/index.less +161 -0
  24. package/dist/esm/McIconFont/iconfont.js +1 -0
  25. package/dist/esm/McIconFont/index.d.ts +5 -0
  26. package/dist/esm/McIconFont/index.js +8 -0
  27. package/dist/esm/McIcons/business.json +137 -0
  28. package/dist/esm/McIcons/index.less +22 -0
  29. package/dist/esm/McInput/Input.d.ts +19 -0
  30. package/dist/esm/McInput/Input.js +48 -0
  31. package/dist/esm/McInput/Search.d.ts +39 -0
  32. package/dist/esm/McInput/Search.js +81 -0
  33. package/dist/esm/McInput/TextArea.d.ts +11 -0
  34. package/dist/esm/McInput/TextArea.js +37 -0
  35. package/dist/esm/McInput/demo/Input/addonBefore.d.ts +3 -0
  36. package/dist/esm/McInput/demo/Input/addonBefore.js +67 -0
  37. package/dist/esm/McInput/demo/Input/base.d.ts +2 -0
  38. package/dist/esm/McInput/demo/Input/base.js +31 -0
  39. package/dist/esm/McInput/demo/Input/isTrim.d.ts +2 -0
  40. package/dist/esm/McInput/demo/Input/isTrim.js +22 -0
  41. package/dist/esm/McInput/demo/Input/label.d.ts +2 -0
  42. package/dist/esm/McInput/demo/Input/label.js +26 -0
  43. package/dist/esm/McInput/demo/Input/ref.d.ts +3 -0
  44. package/dist/esm/McInput/demo/Input/ref.js +53 -0
  45. package/dist/esm/McInput/demo/Input/status.d.ts +2 -0
  46. package/dist/esm/McInput/demo/Input/status.js +23 -0
  47. package/dist/esm/McInput/demo/Search/search-base.d.ts +2 -0
  48. package/dist/esm/McInput/demo/Search/search-base.js +38 -0
  49. package/dist/esm/McInput/demo/TextArea/text-area-base.d.ts +2 -0
  50. package/dist/esm/McInput/demo/TextArea/text-area-base.js +38 -0
  51. package/dist/esm/McInput/index.d.ts +13 -0
  52. package/dist/esm/McInput/index.js +7 -0
  53. package/dist/esm/McInput/index.less +62 -0
  54. package/dist/esm/McInputNumber/index.d.ts +16 -0
  55. package/dist/esm/McInputNumber/index.js +50 -0
  56. package/dist/esm/McInputNumber/index.less +18 -0
  57. package/dist/esm/McLazyLoader/index.d.ts +39 -0
  58. package/dist/esm/McLazyLoader/index.js +88 -0
  59. package/dist/esm/McListSelect/comps/ListSelect.d.ts +67 -0
  60. package/dist/esm/McListSelect/comps/ListSelect.js +289 -0
  61. package/dist/esm/McListSelect/comps/ListSelectPanel.d.ts +138 -0
  62. package/dist/esm/McListSelect/comps/ListSelectPanel.js +451 -0
  63. package/dist/esm/McListSelect/comps/SelectedItem.d.ts +17 -0
  64. package/dist/esm/McListSelect/comps/SelectedItem.js +76 -0
  65. package/dist/esm/McListSelect/index.d.ts +10 -0
  66. package/dist/esm/McListSelect/index.js +5 -0
  67. package/dist/esm/McListSelect/index.less +257 -0
  68. package/dist/esm/McModalProvider/index.d.ts +174 -0
  69. package/dist/esm/McModalProvider/index.js +498 -0
  70. package/dist/esm/McPeriodSelect/index.d.ts +13 -0
  71. package/dist/esm/McPeriodSelect/index.js +305 -0
  72. package/dist/esm/McPeriodSelect/index.less +187 -0
  73. package/dist/esm/McPopoverButton/index.d.ts +14 -0
  74. package/dist/esm/McPopoverButton/index.js +52 -0
  75. package/dist/esm/McPopoverForm/index.d.ts +14 -0
  76. package/dist/esm/McPopoverForm/index.js +95 -0
  77. package/dist/esm/McProSelect/index.d.ts +35 -0
  78. package/dist/esm/McProSelect/index.js +152 -0
  79. package/dist/esm/McResult/default.d.ts +1 -0
  80. package/dist/esm/McResult/default.js +98 -0
  81. package/dist/esm/McResult/icon.d.ts +25 -0
  82. package/dist/esm/McResult/icon.js +1014 -0
  83. package/dist/esm/McResult/index.d.ts +31 -0
  84. package/dist/esm/McResult/index.js +119 -0
  85. package/dist/esm/McResult/index.less +18 -0
  86. package/dist/esm/McResult/public/403.svg +164 -0
  87. package/dist/esm/McResult/public/404.svg +123 -0
  88. package/dist/esm/McResult/public/500.svg +129 -0
  89. package/dist/esm/McResult/public/building.svg +127 -0
  90. package/dist/esm/McResult/public/code403.svg +7 -0
  91. package/dist/esm/McResult/public/code404.svg +5 -0
  92. package/dist/esm/McResult/public/code500.svg +5 -0
  93. package/dist/esm/McResult/public/detailEmpty.svg +1 -0
  94. package/dist/esm/McResult/public/empty.svg +1 -0
  95. package/dist/esm/McResult/public/noFunction.svg +1 -0
  96. package/dist/esm/McResult/public/noUser.svg +90 -0
  97. package/dist/esm/McSelect/components/PanelSearchInput/index.d.ts +12 -0
  98. package/dist/esm/McSelect/components/PanelSearchInput/index.js +45 -0
  99. package/dist/esm/McSelect/components/PanelSearchInput/index.less +7 -0
  100. package/dist/esm/McSelect/index.d.ts +47 -0
  101. package/dist/esm/McSelect/index.js +436 -0
  102. package/dist/esm/McSelect/index.less +72 -0
  103. package/dist/esm/McTag/index.d.ts +22 -0
  104. package/dist/esm/McTag/index.js +59 -0
  105. package/dist/esm/McThemeConfig/customToken.json +39 -0
  106. package/dist/esm/McThemeConfig/globalStyle.d.ts +2 -0
  107. package/dist/esm/McThemeConfig/globalStyle.js +198 -0
  108. package/dist/esm/McThemeConfig/index.d.ts +9 -0
  109. package/dist/esm/McThemeConfig/index.js +16 -0
  110. package/dist/esm/McThemeConfig/layoutStyle.d.ts +2 -0
  111. package/dist/esm/McThemeConfig/layoutStyle.js +1 -0
  112. package/dist/esm/McThemeConfig/provider.d.ts +8 -0
  113. package/dist/esm/McThemeConfig/provider.js +20 -0
  114. package/dist/esm/McThemeConfig/themeToken.json +152 -0
  115. package/dist/esm/McTreePanel/SelectedItem.d.ts +4 -0
  116. package/dist/esm/McTreePanel/SelectedItem.js +75 -0
  117. package/dist/esm/McTreePanel/index.d.ts +27 -0
  118. package/dist/esm/McTreePanel/index.js +315 -0
  119. package/dist/esm/McTreePanel/index.less +106 -0
  120. package/dist/esm/McTreeSelect/index.d.ts +13 -0
  121. package/dist/esm/McTreeSelect/index.js +182 -0
  122. package/dist/esm/McTreeSelect/index.less +72 -0
  123. package/dist/esm/McUpload/comps/McFormUpload/comps/UploadForVal/index.d.ts +38 -0
  124. package/dist/esm/McUpload/comps/McFormUpload/comps/UploadForVal/index.js +209 -0
  125. package/dist/esm/McUpload/comps/McFormUpload/comps/UploadForVal/index.less +6 -0
  126. package/dist/esm/McUpload/comps/McFormUpload/index.d.ts +7 -0
  127. package/dist/esm/McUpload/comps/McFormUpload/index.js +29 -0
  128. package/dist/esm/McUpload/comps/McUploadCmp/index.d.ts +49 -0
  129. package/dist/esm/McUpload/comps/McUploadCmp/index.js +396 -0
  130. package/dist/esm/McUpload/comps/McUploadCmp/index.less +68 -0
  131. package/dist/esm/McUpload/comps/McUploadDragger/index.d.ts +49 -0
  132. package/dist/esm/McUpload/comps/McUploadDragger/index.js +264 -0
  133. package/dist/esm/McUpload/comps/McUploadTrigger/index.d.ts +39 -0
  134. package/dist/esm/McUpload/comps/McUploadTrigger/index.js +318 -0
  135. package/dist/esm/McUpload/comps/McUploadTrigger/index.less +204 -0
  136. package/dist/esm/McUpload/index.d.ts +14 -0
  137. package/dist/esm/McUpload/index.js +9 -0
  138. package/dist/esm/McUpload/tools/calculateMD5/index.d.ts +3 -0
  139. package/dist/esm/McUpload/tools/calculateMD5/index.js +94 -0
  140. package/dist/esm/McUpload/tools/calculateMD5/md5Worker.js +44 -0
  141. package/dist/esm/McUpload/tools/getUid.d.ts +1 -0
  142. package/dist/esm/McUpload/tools/getUid.js +6 -0
  143. package/dist/esm/McUpload/tools/materialVerification.d.ts +50 -0
  144. package/dist/esm/McUpload/tools/materialVerification.js +257 -0
  145. package/dist/esm/McUpload/tools/uploadTools.d.ts +5 -0
  146. package/dist/esm/McUpload/tools/uploadTools.js +56 -0
  147. package/dist/esm/Utils/index.d.ts +8 -0
  148. package/dist/esm/Utils/index.js +9 -0
  149. package/dist/esm/Utils/lib/Queue/PriorityQueue.d.ts +21 -0
  150. package/dist/esm/Utils/lib/Queue/PriorityQueue.js +197 -0
  151. package/dist/esm/Utils/lib/Queue/TaskQueue.d.ts +17 -0
  152. package/dist/esm/Utils/lib/Queue/TaskQueue.js +199 -0
  153. package/dist/esm/Utils/lib/Queue/tools/BinaryHeap.d.ts +25 -0
  154. package/dist/esm/Utils/lib/Queue/tools/BinaryHeap.js +184 -0
  155. package/dist/esm/Utils/lib/Queue/tools/publicDependencyMethod.d.ts +6 -0
  156. package/dist/esm/Utils/lib/Queue/tools/publicDependencyMethod.js +26 -0
  157. package/dist/esm/Utils/lib/Queue/types/baseTaskQueue.d.ts +23 -0
  158. package/dist/esm/Utils/lib/Queue/types/baseTaskQueue.js +10 -0
  159. package/dist/esm/Utils/lib/copyToClipboard.d.ts +8 -0
  160. package/dist/esm/Utils/lib/copyToClipboard.js +54 -0
  161. package/dist/esm/index.d.ts +34 -0
  162. package/dist/esm/index.js +33 -0
  163. package/dist/esm/styles/index.less +2 -0
  164. package/dist/esm/styles/mixins.less +52 -0
  165. package/dist/esm/styles/utilities.less +51 -0
  166. package/dist/esm/typings.d.ts +20 -0
  167. package/package.json +13 -9
@@ -0,0 +1,315 @@
1
+ import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
2
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
3
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
4
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
5
+ import { DndContext } from '@dnd-kit/core';
6
+ import { SortableContext, arrayMove, verticalListSortingStrategy } from '@dnd-kit/sortable';
7
+ import { Button, Checkbox, Empty, Tree } from 'antd';
8
+ import { useEffect, useMemo, useState } from 'react';
9
+ import SelectedItem from "./SelectedItem";
10
+ import "./index.less";
11
+ import { jsx as _jsx } from "react/jsx-runtime";
12
+ import { jsxs as _jsxs } from "react/jsx-runtime";
13
+ var McTreePanel = function McTreePanel(props) {
14
+ var style = props.style,
15
+ className = props.className,
16
+ treeData = props.treeData,
17
+ fieldNames = props.fieldNames,
18
+ disabled = props.disabled,
19
+ labelInValue = props.labelInValue,
20
+ _props$inexistent = props.inexistent,
21
+ inexistent = _props$inexistent === void 0 ? false : _props$inexistent,
22
+ sortable = props.sortable,
23
+ value = props.value,
24
+ onChange = props.onChange;
25
+ var _ref = typeof inexistent === 'boolean' ? {} : inexistent,
26
+ _ref$text = _ref.text,
27
+ text = _ref$text === void 0 ? '不存在' : _ref$text,
28
+ _ref$color = _ref.color,
29
+ color = _ref$color === void 0 ? '#ff4d4f' : _ref$color,
30
+ _ref$reserved = _ref.reserved,
31
+ reserved = _ref$reserved === void 0 ? false : _ref$reserved;
32
+ var _ref2 = fieldNames || {},
33
+ _ref2$key = _ref2.key,
34
+ key = _ref2$key === void 0 ? 'key' : _ref2$key,
35
+ _ref2$title = _ref2.title,
36
+ title = _ref2$title === void 0 ? 'title' : _ref2$title,
37
+ _ref2$children = _ref2.children,
38
+ children = _ref2$children === void 0 ? 'children' : _ref2$children;
39
+ var _useState = useState({
40
+ checked: []
41
+ }),
42
+ _useState2 = _slicedToArray(_useState, 2),
43
+ checkedKeys = _useState2[0],
44
+ setCheckedKeys = _useState2[1];
45
+ var _useState3 = useState(true),
46
+ _useState4 = _slicedToArray(_useState3, 2),
47
+ linkage = _useState4[0],
48
+ setLinkage = _useState4[1];
49
+ var _useState5 = useState([]),
50
+ _useState6 = _slicedToArray(_useState5, 2),
51
+ expandedKeys = _useState6[0],
52
+ setExpandedKeys = _useState6[1];
53
+ var _useState7 = useState({}),
54
+ _useState8 = _slicedToArray(_useState7, 2),
55
+ itemMap = _useState8[0],
56
+ setItemMap = _useState8[1];
57
+ var _allKeys = useMemo(function () {
58
+ return Object.values(itemMap).map(function (item) {
59
+ return item.key;
60
+ });
61
+ }, [itemMap]);
62
+ var _useState9 = useState({}),
63
+ _useState10 = _slicedToArray(_useState9, 2),
64
+ inexistentItemMap = _useState10[0],
65
+ setInexistentItemMap = _useState10[1];
66
+ var _treeData = useMemo(function () {
67
+ var fn = function fn(arr) {
68
+ return arr === null || arr === void 0 ? void 0 : arr.map(function (item) {
69
+ return _objectSpread(_objectSpread({}, item), {}, _defineProperty({
70
+ disableCheckbox: disabled
71
+ }, children, fn(item[children])));
72
+ });
73
+ };
74
+ return fn(treeData);
75
+ }, [treeData, disabled, children]);
76
+
77
+ /* 获取选项的映射关系,重置父子联动为true */
78
+ useEffect(function () {
79
+ var _itemMap = {};
80
+ var fn = function fn(arr, parentKeys) {
81
+ var _subKeys = [];
82
+ arr.forEach(function (item) {
83
+ var _item$children;
84
+ var subKeys = ((_item$children = item[children]) === null || _item$children === void 0 ? void 0 : _item$children.length) > 0 ? fn(item[children], [].concat(_toConsumableArray(parentKeys), [item[key]])) : [];
85
+ _subKeys.push.apply(_subKeys, [item[key]].concat(_toConsumableArray(subKeys)));
86
+ _itemMap[item[key]] = {
87
+ key: item[key],
88
+ title: item[title],
89
+ parentKeys: parentKeys,
90
+ subKeys: subKeys
91
+ };
92
+ });
93
+ return _subKeys;
94
+ };
95
+ fn(treeData || [], []);
96
+ setItemMap(_itemMap);
97
+ setLinkage(true);
98
+ }, [treeData]);
99
+
100
+ /* 回显 */
101
+ var echo = function echo(value) {
102
+ var _inexistentItemMap = {};
103
+ value === null || value === void 0 || value.forEach(function (item) {
104
+ var k = labelInValue ? item[key] : item,
105
+ t = labelInValue ? item[title] || item[key] : item;
106
+ if (!itemMap[k]) _inexistentItemMap[k] = {
107
+ key: k,
108
+ title: t
109
+ };
110
+ });
111
+ setCheckedKeys({
112
+ checked: value ? labelInValue ? value.map(function (item) {
113
+ return item[key];
114
+ }) : value : []
115
+ });
116
+ setInexistentItemMap(_inexistentItemMap);
117
+ };
118
+ useEffect(function () {
119
+ echo(value);
120
+ }, [value]);
121
+
122
+ /**
123
+ * 获取选中项的方法(返回实际的checked)
124
+ * 0.父子联动时按以下逻辑执行
125
+ * 1.父级选中或取消,联动其所有子级的选中或取消
126
+ * 2.子级选中,联动其所有父级的选中
127
+ * 3.子级取消,不联动其父级的取消
128
+ */
129
+ var getCheckedKeys = function getCheckedKeys(checked, activeKey, status) {
130
+ var _checked = _toConsumableArray(checked);
131
+ // 若为父子联动时
132
+ if (linkage) {
133
+ if (status) {
134
+ // 若当前为选中,则联动其所有父级及所有子级的选中
135
+ _checked = Array.from(new Set([].concat(_toConsumableArray(_checked), _toConsumableArray(itemMap[activeKey].parentKeys), _toConsumableArray(itemMap[activeKey].subKeys))));
136
+ } else {
137
+ // 若当前为取消,则联动其所有子级的取消
138
+ _checked = _checked.filter(function (v) {
139
+ var _itemMap$activeKey;
140
+ return !((_itemMap$activeKey = itemMap[activeKey]) !== null && _itemMap$activeKey !== void 0 && (_itemMap$activeKey = _itemMap$activeKey.subKeys) !== null && _itemMap$activeKey !== void 0 && _itemMap$activeKey.includes(v));
141
+ });
142
+ }
143
+ }
144
+ return _checked;
145
+ };
146
+
147
+ /* 更新选中项状态并触发change事件 */
148
+ var changeHandle = function changeHandle(v) {
149
+ // 若无需保留不存在值,则将不存在的项移除
150
+ var _v = reserved ? _toConsumableArray(v) : v.filter(function (i) {
151
+ return !!itemMap[i];
152
+ });
153
+ setCheckedKeys({
154
+ checked: _v
155
+ });
156
+ onChange === null || onChange === void 0 || onChange(_v.length > 0 ? labelInValue ? _v.map(function (i) {
157
+ return itemMap[i] || inexistentItemMap[i];
158
+ }) : _v : undefined);
159
+ };
160
+
161
+ /* 拖拽结束事件 */
162
+ var dragEnd = function dragEnd(dragItem) {
163
+ var active = dragItem.active,
164
+ over = dragItem.over;
165
+ if (!active || !over) return;
166
+ if (active.id !== over.id) {
167
+ var _checked = _toConsumableArray(checkedKeys.checked);
168
+ var activeIndex = _checked.findIndex(function (v) {
169
+ return v === active.id;
170
+ });
171
+ var overIndex = _checked.findIndex(function (v) {
172
+ return v === over.id;
173
+ });
174
+ changeHandle(arrayMove(_checked, activeIndex, overIndex));
175
+ }
176
+ };
177
+ return /*#__PURE__*/_jsxs("div", {
178
+ style: style,
179
+ className: "mc-tree-panel ".concat(className),
180
+ children: [/*#__PURE__*/_jsx(Checkbox, {
181
+ style: {
182
+ lineHeight: '32px',
183
+ marginBottom: 8
184
+ },
185
+ checked: linkage,
186
+ onChange: function onChange(e) {
187
+ return setLinkage(e.target.checked);
188
+ },
189
+ disabled: disabled,
190
+ children: "\u7236\u5B50\u8054\u52A8"
191
+ }), /*#__PURE__*/_jsxs("div", {
192
+ className: "mc-tree-panel__wrapper",
193
+ children: [/*#__PURE__*/_jsxs("div", {
194
+ className: "mc-tree-panel__options",
195
+ children: [/*#__PURE__*/_jsxs("div", {
196
+ className: "mc-tree-panel__card-header",
197
+ children: [/*#__PURE__*/_jsx(Checkbox, {
198
+ checked: _allKeys.length > 0 && _allKeys.every(function (v) {
199
+ return checkedKeys.checked.includes(v);
200
+ }),
201
+ indeterminate: _allKeys.length > 0 && !_allKeys.every(function (v) {
202
+ return checkedKeys.checked.includes(v);
203
+ }) && _allKeys.some(function (v) {
204
+ return checkedKeys.checked.includes(v);
205
+ }),
206
+ onChange: function onChange(e) {
207
+ return changeHandle(e.target.checked ? Array.from(new Set([].concat(_toConsumableArray(checkedKeys.checked), _toConsumableArray(_allKeys)))) : reserved ? checkedKeys.checked.filter(function (i) {
208
+ return !itemMap[i];
209
+ }) : []);
210
+ },
211
+ disabled: disabled,
212
+ children: "\u5168\u9009"
213
+ }), /*#__PURE__*/_jsx(Button, {
214
+ type: "link",
215
+ onClick: function onClick() {
216
+ return setExpandedKeys([]);
217
+ },
218
+ children: "\u6536\u8D77"
219
+ })]
220
+ }), treeData && treeData.length > 0 ? /*#__PURE__*/_jsx("div", {
221
+ className: "mc-tree-panel__card-body",
222
+ children: /*#__PURE__*/_jsx(Tree, {
223
+ checkable: true,
224
+ selectable: false,
225
+ treeData: _treeData,
226
+ fieldNames: {
227
+ title: title,
228
+ key: key,
229
+ children: children
230
+ },
231
+ expandedKeys: expandedKeys,
232
+ onExpand: setExpandedKeys,
233
+ checkStrictly: true,
234
+ checkedKeys: checkedKeys,
235
+ onCheck: function onCheck(_ref3, _ref4) {
236
+ var checked = _ref3.checked;
237
+ var status = _ref4.checked,
238
+ node = _ref4.node;
239
+ return changeHandle(getCheckedKeys(checked, node[key], status));
240
+ }
241
+ })
242
+ }) : /*#__PURE__*/_jsx("div", {
243
+ style: {
244
+ height: 'calc(100% - 40px)',
245
+ display: 'grid',
246
+ placeItems: 'center'
247
+ },
248
+ children: /*#__PURE__*/_jsx(Empty, {
249
+ image: Empty.PRESENTED_IMAGE_SIMPLE
250
+ })
251
+ })]
252
+ }), /*#__PURE__*/_jsxs("div", {
253
+ className: "mc-tree-panel__selected",
254
+ children: [/*#__PURE__*/_jsxs("div", {
255
+ className: "mc-tree-panel__card-header",
256
+ children: [/*#__PURE__*/_jsxs("div", {
257
+ className: "mc-tree-panel__card-title",
258
+ children: ["\u5DF2\u9009", checkedKeys.checked.length, "\u9879"]
259
+ }), /*#__PURE__*/_jsx(Button, {
260
+ type: "link",
261
+ onClick: function onClick() {
262
+ return changeHandle(reserved ? checkedKeys.checked.filter(function (i) {
263
+ return !itemMap[i];
264
+ }) : []);
265
+ },
266
+ disabled: disabled,
267
+ children: "\u6E05\u7A7A"
268
+ })]
269
+ }), checkedKeys.checked.length > 0 ? /*#__PURE__*/_jsx(DndContext, {
270
+ onDragEnd: dragEnd,
271
+ children: /*#__PURE__*/_jsx(SortableContext, {
272
+ items: checkedKeys.checked,
273
+ strategy: verticalListSortingStrategy,
274
+ children: /*#__PURE__*/_jsx("div", {
275
+ style: {
276
+ overflowX: 'hidden'
277
+ },
278
+ className: "mc-tree-panel__card-body",
279
+ children: checkedKeys.checked.map(function (v) {
280
+ return /*#__PURE__*/_jsx(SelectedItem, {
281
+ sortable: sortable,
282
+ itemMap: itemMap,
283
+ inexistent: inexistent,
284
+ text: text,
285
+ color: color,
286
+ reserved: reserved,
287
+ inexistentItemMap: inexistentItemMap,
288
+ value: v,
289
+ onRemove: function onRemove() {
290
+ return changeHandle(getCheckedKeys(checkedKeys.checked.filter(function (i) {
291
+ return i !== v;
292
+ }), v, false));
293
+ }
294
+ }, v);
295
+ })
296
+ })
297
+ })
298
+ }) : /*#__PURE__*/_jsx("div", {
299
+ style: {
300
+ height: 'calc(100% - 40px)',
301
+ display: 'grid',
302
+ placeItems: 'center'
303
+ },
304
+ children: /*#__PURE__*/_jsx(Empty, {
305
+ image: Empty.PRESENTED_IMAGE_SIMPLE,
306
+ description: "\u8BF7\u9009\u62E9"
307
+ })
308
+ }), disabled && /*#__PURE__*/_jsx("div", {
309
+ className: "mc-tree-panel__selected--disabled"
310
+ })]
311
+ })]
312
+ })]
313
+ });
314
+ };
315
+ export default McTreePanel;
@@ -0,0 +1,106 @@
1
+ .disabled(@background: rgba(228, 228, 228, 0.3)) {
2
+ position: absolute;
3
+ top: 0;
4
+ right: 0;
5
+ bottom: 0;
6
+ left: 0;
7
+ z-index: 9;
8
+ border-radius: 4px;
9
+ background: @background;
10
+ cursor: no-drop;
11
+ }
12
+
13
+ .mc-tree-panel {
14
+ width: 100%;
15
+ height: 382px;
16
+
17
+ &__wrapper {
18
+ height: calc(100% - 40px);
19
+ display: flex;
20
+ column-gap: 8px;
21
+ }
22
+
23
+ .card() {
24
+ border-radius: 4px;
25
+ border: 1px solid #ebebeb;
26
+ overflow: hidden;
27
+ }
28
+
29
+ &__card-header {
30
+ height: 40px;
31
+ background: #fafafa;
32
+ padding: 0 16px;
33
+ display: flex;
34
+ align-items: center;
35
+ justify-content: space-between;
36
+ }
37
+
38
+ &__card-title {
39
+ color: rgba(0, 0, 0, 84.7%);
40
+ font-weight: 600;
41
+ }
42
+
43
+ &__card-body {
44
+ height: calc(100% - 40px);
45
+ overflow: auto;
46
+ padding: 8px;
47
+ }
48
+
49
+ &__options {
50
+ .card();
51
+
52
+ flex: 1;
53
+ }
54
+
55
+ &__selected {
56
+ .card();
57
+
58
+ width: 240px;
59
+ position: relative;
60
+
61
+ &-item {
62
+ width: 208px;
63
+ height: 40px;
64
+ display: flex;
65
+ align-items: center;
66
+ padding: 0 8px;
67
+ background: #f5f5f5;
68
+ border-radius: 4px;
69
+ overflow: hidden;
70
+
71
+ &:not(:first-child) {
72
+ margin-top: 8px;
73
+ }
74
+
75
+ &__drag {
76
+ flex-shrink: 0;
77
+ color: #8c8c8c;
78
+ padding: 5px 0 3px;
79
+
80
+ &:hover {
81
+ background: rgba(38, 38, 38, 15%) !important;
82
+ cursor: move;
83
+ }
84
+ }
85
+
86
+ &__remove {
87
+ flex-shrink: 0;
88
+ color: #8c8c8c;
89
+ margin-left: 8px;
90
+
91
+ &:hover {
92
+ cursor: pointer;
93
+ color: #262626;
94
+ }
95
+ }
96
+
97
+ &--disabled {
98
+ .disabled(@background: rgba(246, 246, 246, 0.66));
99
+ }
100
+ }
101
+
102
+ &--disabled {
103
+ .disabled();
104
+ }
105
+ }
106
+ }
@@ -0,0 +1,13 @@
1
+ import { TreeSelectProps } from 'antd';
2
+ import { CSSProperties, FC } from 'react';
3
+ import './index.less';
4
+ export type McTreeSelectProps = TreeSelectProps & {
5
+ style?: CSSProperties;
6
+ className?: string;
7
+ name?: string;
8
+ label?: string;
9
+ inexistent?: boolean;
10
+ [key: string]: any;
11
+ };
12
+ declare const McTreeSelect: FC<McTreeSelectProps>;
13
+ export default McTreeSelect;
@@ -0,0 +1,182 @@
1
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
+ import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
3
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
4
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
+ var _excluded = ["style", "className", "label", "inexistent", "value", "onChange", "options", "multiple", "disabled", "fieldNames", "maxTagCount", "treeCheckable"];
6
+ import { Popover, TreeSelect } from 'antd';
7
+ import { forwardRef, useEffect, useMemo, useRef, useState } from 'react';
8
+ import "./index.less";
9
+ import { jsx as _jsx } from "react/jsx-runtime";
10
+ import { jsxs as _jsxs } from "react/jsx-runtime";
11
+ var McTreeSelect = /*#__PURE__*/forwardRef(function (props, ref) {
12
+ var style = props.style,
13
+ className = props.className,
14
+ label = props.label,
15
+ _props$inexistent = props.inexistent,
16
+ inexistent = _props$inexistent === void 0 ? true : _props$inexistent,
17
+ value = props.value,
18
+ onChange = props.onChange,
19
+ options = props.options,
20
+ multiple = props.multiple,
21
+ disabled = props.disabled,
22
+ _props$fieldNames = props.fieldNames,
23
+ fieldNames = _props$fieldNames === void 0 ? {
24
+ label: 'label',
25
+ value: 'value',
26
+ children: 'children'
27
+ } : _props$fieldNames,
28
+ maxTagCount = props.maxTagCount,
29
+ treeCheckable = props.treeCheckable,
30
+ rest = _objectWithoutProperties(props, _excluded);
31
+ var _maxTagCount = useMemo(function () {
32
+ return props.hasOwnProperty('maxTagCount') ? maxTagCount : 1;
33
+ }, [maxTagCount]);
34
+ var _multiple = useMemo(function () {
35
+ return multiple || treeCheckable;
36
+ }, [treeCheckable, multiple]);
37
+
38
+ /* 获取label宽度 */
39
+ var labelRef = useRef();
40
+ var _useState = useState(11),
41
+ _useState2 = _slicedToArray(_useState, 2),
42
+ paddingLeft = _useState2[0],
43
+ setPaddingLeft = _useState2[1];
44
+ var labelResizeObserver = new ResizeObserver(function (entries) {
45
+ setPaddingLeft(entries[0].contentRect.width + 11);
46
+ });
47
+ useEffect(function () {
48
+ if (labelRef.current) {
49
+ labelResizeObserver.observe(labelRef.current);
50
+ }
51
+ return function () {
52
+ return labelResizeObserver.disconnect();
53
+ };
54
+ }, []);
55
+
56
+ /* 判断value值是否存在于options中 */
57
+ var _useState3 = useState(),
58
+ _useState4 = _slicedToArray(_useState3, 2),
59
+ _value = _useState4[0],
60
+ set_value = _useState4[1];
61
+ // 获取所有备选项的值列表
62
+ var _values = useMemo(function () {
63
+ var v = fieldNames.value,
64
+ c = fieldNames.children;
65
+ var values = [];
66
+ var loopFn = function loopFn(children, parents) {
67
+ children === null || children === void 0 || children.forEach(function (item) {
68
+ values.push([].concat(_toConsumableArray(parents), [item[v]]).join(':'));
69
+ if (item[c]) {
70
+ loopFn(item[c], [].concat(_toConsumableArray(parents), [item[v]]));
71
+ }
72
+ });
73
+ };
74
+ loopFn(options || [], []);
75
+ return values;
76
+ }, [options, fieldNames]);
77
+
78
+ /* 将树形数据扁平化 */
79
+ var flattenDeep = function flattenDeep() {
80
+ var _options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
81
+ var children = fieldNames.children;
82
+ return _options.reduce(function (pre, item) {
83
+ var _item$children;
84
+ pre.push(item);
85
+ if ((item === null || item === void 0 || (_item$children = item[children]) === null || _item$children === void 0 ? void 0 : _item$children.length) > 0) {
86
+ return [].concat(_toConsumableArray(pre), _toConsumableArray(flattenDeep(item[children])));
87
+ } else {
88
+ return pre;
89
+ }
90
+ }, []);
91
+ };
92
+
93
+ // 监听值和值列表的变化(执行不存在值的判断逻辑)
94
+ useEffect(function () {
95
+ var _v = value;
96
+ /* 若inexistent为true,判断不存在情况并重置值 */
97
+ if (inexistent) {
98
+ var _value2 = fieldNames.value;
99
+ var _options = flattenDeep(options);
100
+ if (_multiple) {
101
+ var _v2;
102
+ _v = ((_v2 = _v) === null || _v2 === void 0 ? void 0 : _v2.map(function (i) {
103
+ return _options !== null && _options !== void 0 && _options.some(function (item) {
104
+ return item[_value2] === i;
105
+ }) ? i : i + '(不存在)';
106
+ })) || [];
107
+ } else {
108
+ _v = _v || _v === 0 || _v === false ? _options !== null && _options !== void 0 && _options.some(function (item) {
109
+ return item[_value2] === _v;
110
+ }) ? _v : _v + '(不存在)' : undefined;
111
+ }
112
+ }
113
+ set_value(_v);
114
+ }, [value, _values, inexistent, _multiple, JSON.stringify(options)]);
115
+ // 组件change事件
116
+ var change = function change(v, labelList, e) {
117
+ var _v = v;
118
+ // 若inexistent为true,当重新触发change事件时,将不存在的项移除(仅多选时需处理)
119
+ if (inexistent && _multiple) {
120
+ _v = v.filter(function (item) {
121
+ return !(('' + item).indexOf('(不存在)') !== -1);
122
+ });
123
+ }
124
+ if (!props.hasOwnProperty('value')) {
125
+ set_value(_v);
126
+ }
127
+ onChange === null || onChange === void 0 || onChange(_v, labelList, e);
128
+ };
129
+ return /*#__PURE__*/_jsxs("div", {
130
+ style: _objectSpread({
131
+ position: label ? 'relative' : 'static',
132
+ height: _multiple ? 'auto' : 32,
133
+ '--selector-pl': "".concat(paddingLeft, "px")
134
+ }, style),
135
+ className: "mc-tree-select ".concat(_multiple && _maxTagCount === 1 && 'mc-tree-select--inline', " ").concat(className),
136
+ children: [label && /*#__PURE__*/_jsx("span", {
137
+ ref: labelRef,
138
+ className: "mc-tree-select__label ".concat(disabled && 'mc-tree-select--disabled'),
139
+ children: label
140
+ }), /*#__PURE__*/_jsx(TreeSelect, _objectSpread({
141
+ ref: ref,
142
+ className: "mc-tree-select__content",
143
+ value: _value,
144
+ onChange: change,
145
+ treeData: options,
146
+ multiple: multiple,
147
+ treeCheckable: treeCheckable,
148
+ disabled: disabled,
149
+ fieldNames: fieldNames,
150
+ placeholder: "\u8BF7\u9009\u62E9",
151
+ showSearch: true,
152
+ allowClear: true,
153
+ maxTagCount: _maxTagCount,
154
+ maxTagPlaceholder: function maxTagPlaceholder(v) {
155
+ return /*#__PURE__*/_jsx(Popover, {
156
+ overlayStyle: {
157
+ maxWidth: 300
158
+ },
159
+ content: v.map(function (_ref, index) {
160
+ var _ref2;
161
+ var value = _ref.value,
162
+ label = _ref.label;
163
+ return /*#__PURE__*/_jsxs("span", {
164
+ children: [index !== 0 && /*#__PURE__*/_jsx("span", {
165
+ children: ", "
166
+ }), /*#__PURE__*/_jsx("span", {
167
+ style: {
168
+ color: ((_ref2 = '' + value) === null || _ref2 === void 0 ? void 0 : _ref2.indexOf('(不存在)')) === -1 ? 'rgba(0, 0, 0, 0.88)' : '#ff4d4f'
169
+ },
170
+ children: label
171
+ })]
172
+ }, value);
173
+ }),
174
+ children: /*#__PURE__*/_jsx("span", {
175
+ children: '+' + v.length
176
+ })
177
+ });
178
+ }
179
+ }, rest))]
180
+ });
181
+ });
182
+ export default McTreeSelect;
@@ -0,0 +1,72 @@
1
+ .mc-tree-select {
2
+ &__label {
3
+ position: absolute;
4
+ top: 1px;
5
+ left: 11px;
6
+ z-index: 2;
7
+ display: flex;
8
+ align-items: center;
9
+ height: 100%;
10
+ color: #262626;
11
+ font-size: 14px;
12
+
13
+ &::after {
14
+ margin-left: 2px;
15
+ content: '\FF1A';
16
+ }
17
+
18
+ .mc-tree-select--disabled {
19
+ color: rgba(0, 0, 0, 25%);
20
+ cursor: no-drop;
21
+ }
22
+ }
23
+
24
+ &__content {
25
+ width: 100%;
26
+ height: 100%;
27
+
28
+ &.ant-tree-select.ant-select {
29
+ .ant-select-selector {
30
+ padding-left: var(--selector-pl);
31
+
32
+ .ant-select-selection-overflow-item-rest .ant-select-selection-item {
33
+ padding-left: 4px;
34
+ color: #fff;
35
+ background: #325cf7;
36
+
37
+ .ant-select-selection-item-content {
38
+ margin-right: 0;
39
+ }
40
+ }
41
+
42
+ .ant-select-selection-item[title*='不存在'] {
43
+ color: #ff4d4f;
44
+ }
45
+ }
46
+
47
+ &.ant-select-single .ant-select-selector .ant-select-selection-search {
48
+ left: var(--selector-pl);
49
+ }
50
+
51
+ &.ant-select-multiple .ant-select-selector {
52
+ .ant-select-selection-placeholder {
53
+ left: var(--selector-pl);
54
+ }
55
+
56
+ .ant-select-selection-search {
57
+ margin-left: 0;
58
+ }
59
+ }
60
+ }
61
+ }
62
+
63
+ .mc-tree-select--inline
64
+ &.ant-select-selection-overflow-item:not(
65
+ .ant-select-selection-overflow-item-rest,
66
+ .ant-select-selection-overflow-item-suffix
67
+ ) {
68
+ flex: 1;
69
+ min-width: 0;
70
+ margin-right: 4px;
71
+ }
72
+ }