tntd 2.8.10 → 2.8.12
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/es/array-input/index.js +10 -3
- package/es/array-input/index.js.map +1 -1
- package/es/form/form.js +1 -0
- package/es/form/form.js.map +1 -1
- package/es/index.js +1 -0
- package/es/index.js.map +1 -1
- package/es/locale/en_US.js +16 -0
- package/es/locale/en_US.js.map +1 -1
- package/es/locale/zh_CN.js +16 -0
- package/es/locale/zh_CN.js.map +1 -1
- package/es/prev-locale.js +32 -2
- package/es/prev-locale.js.map +1 -1
- package/es/query-list-scene/index.less +4 -0
- package/es/table/index.js +2 -2
- package/es/table/index.js.map +1 -1
- package/es/table/resizableTable/index.js +90 -0
- package/es/table/resizableTable/index.js.map +1 -0
- package/es/table/resizableTable/index.less +36 -0
- package/es/table/table-hoc.js +26 -0
- package/es/table/table-hoc.js.map +1 -0
- package/es/table/table.js +27 -25
- package/es/table/table.js.map +1 -1
- package/es/title/index.less +4 -1
- package/es/tntd-reference/AHref/index.js +39 -0
- package/es/tntd-reference/AHref/index.js.map +1 -0
- package/es/tntd-reference/ReferenceBatchCheck/index.js +153 -0
- package/es/tntd-reference/ReferenceBatchCheck/index.js.map +1 -0
- package/es/tntd-reference/ReferenceBatchCheck/index.less +21 -0
- package/es/tntd-reference/ReferenceBatchDrawer/index.js +102 -0
- package/es/tntd-reference/ReferenceBatchDrawer/index.js.map +1 -0
- package/es/tntd-reference/ReferenceBatchDrawer/index.less +0 -0
- package/es/tntd-reference/ReferenceCheck/index.js +117 -0
- package/es/tntd-reference/ReferenceCheck/index.js.map +1 -0
- package/es/tntd-reference/ReferenceCheck/index.less +10 -0
- package/es/tntd-reference/ReferenceDrawer/index.js +69 -0
- package/es/tntd-reference/ReferenceDrawer/index.js.map +1 -0
- package/es/tntd-reference/ReferenceDrawer/index.less +0 -0
- package/es/tntd-reference/ReferenceInfo/index.js +150 -0
- package/es/tntd-reference/ReferenceInfo/index.js.map +1 -0
- package/es/tntd-reference/ReferenceInfo/index.less +31 -0
- package/es/tntd-reference/index.js +13 -0
- package/es/tntd-reference/index.js.map +1 -0
- package/es/tntd-virtual-tree/index.js +14 -3
- package/es/tntd-virtual-tree/index.js.map +1 -1
- package/es/tntd-virtual-tree/index.less +2 -42
- package/es/tntd-virtual-tree-select/index.js +95 -21
- package/es/tntd-virtual-tree-select/index.js.map +1 -1
- package/es/tntd-virtual-tree-select/utils.js +20 -124
- package/es/tntd-virtual-tree-select/utils.js.map +1 -1
- package/lib/array-input/index.d.ts.map +1 -1
- package/lib/array-input/index.js +13 -4
- package/lib/array-input/index.js.map +1 -1
- package/lib/form/form.d.ts.map +1 -1
- package/lib/form/form.js +1 -0
- package/lib/form/form.js.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +7 -0
- package/lib/index.js.map +1 -1
- package/lib/locale/default.d.ts +16 -0
- package/lib/locale/default.d.ts.map +1 -1
- package/lib/locale/en_US.d.ts +16 -0
- package/lib/locale/en_US.d.ts.map +1 -1
- package/lib/locale/en_US.js +16 -0
- package/lib/locale/en_US.js.map +1 -1
- package/lib/locale/zh_CN.d.ts +16 -0
- package/lib/locale/zh_CN.d.ts.map +1 -1
- package/lib/locale/zh_CN.js +16 -0
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/prev-locale.d.ts +42 -0
- package/lib/prev-locale.d.ts.map +1 -1
- package/lib/prev-locale.js +32 -2
- package/lib/prev-locale.js.map +1 -1
- package/lib/query-list-scene/index.less +4 -0
- package/lib/segmented/index.d.ts +1 -1
- package/lib/table/index.d.ts +2 -2
- package/lib/table/index.d.ts.map +1 -1
- package/lib/table/index.js +7 -7
- package/lib/table/index.js.map +1 -1
- package/lib/table/resizableTable/index.d.ts +12 -0
- package/lib/table/resizableTable/index.d.ts.map +1 -0
- package/lib/table/resizableTable/index.js +113 -0
- package/lib/table/resizableTable/index.js.map +1 -0
- package/lib/table/resizableTable/index.less +36 -0
- package/lib/table/table-hoc.d.ts +14 -0
- package/lib/table/table-hoc.d.ts.map +1 -0
- package/lib/table/table-hoc.js +31 -0
- package/lib/table/table-hoc.js.map +1 -0
- package/lib/table/table.js +18 -15
- package/lib/table/table.js.map +1 -1
- package/lib/table/table.stories.d.ts +1 -1
- package/lib/title/index.less +4 -1
- package/lib/tntd-reference/AHref/index.d.ts +4 -0
- package/lib/tntd-reference/AHref/index.d.ts.map +1 -0
- package/lib/tntd-reference/AHref/index.js +44 -0
- package/lib/tntd-reference/AHref/index.js.map +1 -0
- package/lib/tntd-reference/ReferenceBatchCheck/index.d.ts +3 -0
- package/lib/tntd-reference/ReferenceBatchCheck/index.d.ts.map +1 -0
- package/lib/tntd-reference/ReferenceBatchCheck/index.js +165 -0
- package/lib/tntd-reference/ReferenceBatchCheck/index.js.map +1 -0
- package/lib/tntd-reference/ReferenceBatchCheck/index.less +21 -0
- package/lib/tntd-reference/ReferenceBatchDrawer/index.d.ts +4 -0
- package/lib/tntd-reference/ReferenceBatchDrawer/index.d.ts.map +1 -0
- package/lib/tntd-reference/ReferenceBatchDrawer/index.js +126 -0
- package/lib/tntd-reference/ReferenceBatchDrawer/index.js.map +1 -0
- package/lib/tntd-reference/ReferenceBatchDrawer/index.less +0 -0
- package/lib/tntd-reference/ReferenceCheck/index.d.ts +3 -0
- package/lib/tntd-reference/ReferenceCheck/index.d.ts.map +1 -0
- package/lib/tntd-reference/ReferenceCheck/index.js +126 -0
- package/lib/tntd-reference/ReferenceCheck/index.js.map +1 -0
- package/lib/tntd-reference/ReferenceCheck/index.less +10 -0
- package/lib/tntd-reference/ReferenceDrawer/index.d.ts +4 -0
- package/lib/tntd-reference/ReferenceDrawer/index.d.ts.map +1 -0
- package/lib/tntd-reference/ReferenceDrawer/index.js +93 -0
- package/lib/tntd-reference/ReferenceDrawer/index.js.map +1 -0
- package/lib/tntd-reference/ReferenceDrawer/index.less +0 -0
- package/lib/tntd-reference/ReferenceInfo/index.d.ts +4 -0
- package/lib/tntd-reference/ReferenceInfo/index.d.ts.map +1 -0
- package/lib/tntd-reference/ReferenceInfo/index.js +164 -0
- package/lib/tntd-reference/ReferenceInfo/index.js.map +1 -0
- package/lib/tntd-reference/ReferenceInfo/index.less +31 -0
- package/lib/tntd-reference/index.d.ts +15 -0
- package/lib/tntd-reference/index.d.ts.map +1 -0
- package/lib/tntd-reference/index.js +20 -0
- package/lib/tntd-reference/index.js.map +1 -0
- package/lib/tntd-virtual-tree/index.d.ts +3 -1
- package/lib/tntd-virtual-tree/index.d.ts.map +1 -1
- package/lib/tntd-virtual-tree/index.js +15 -4
- package/lib/tntd-virtual-tree/index.js.map +1 -1
- package/lib/tntd-virtual-tree/index.less +2 -42
- package/lib/tntd-virtual-tree-select/index.d.ts +12 -4
- package/lib/tntd-virtual-tree-select/index.d.ts.map +1 -1
- package/lib/tntd-virtual-tree-select/index.js +96 -17
- package/lib/tntd-virtual-tree-select/index.js.map +1 -1
- package/lib/tntd-virtual-tree-select/utils.d.ts +2 -9
- package/lib/tntd-virtual-tree-select/utils.d.ts.map +1 -1
- package/lib/tntd-virtual-tree-select/utils.js +23 -142
- package/lib/tntd-virtual-tree-select/utils.js.map +1 -1
- package/package.json +4 -2
- package/es/spin/spin.js +0 -36
- package/es/spin/spin.js.map +0 -1
- package/es/spin/spin.less +0 -9
- package/es/tntd-virtual-tree-select/VirtualTree.js +0 -125
- package/es/tntd-virtual-tree-select/VirtualTree.js.map +0 -1
- package/es/tntd-virtual-tree-select/tree.less +0 -29
- package/lib/spin/spin.d.ts +0 -9
- package/lib/spin/spin.d.ts.map +0 -1
- package/lib/spin/spin.js +0 -44
- package/lib/spin/spin.js.map +0 -1
- package/lib/spin/spin.less +0 -9
- package/lib/tntd-virtual-tree-select/VirtualTree.d.ts +0 -13
- package/lib/tntd-virtual-tree-select/VirtualTree.d.ts.map +0 -1
- package/lib/tntd-virtual-tree-select/VirtualTree.js +0 -155
- package/lib/tntd-virtual-tree-select/VirtualTree.js.map +0 -1
- package/lib/tntd-virtual-tree-select/tree.less +0 -29
|
@@ -8,10 +8,17 @@ exports["default"] = void 0;
|
|
|
8
8
|
var _react = _interopRequireWildcard(require("react"));
|
|
9
9
|
var _tntdRcSelect = _interopRequireDefault(require("../tntd-rc-select"));
|
|
10
10
|
var _tntdVirtualTree = _interopRequireDefault(require("../tntd-virtual-tree"));
|
|
11
|
+
var _utils = require("./utils.js");
|
|
11
12
|
require("./index.less");
|
|
12
13
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
13
14
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
14
15
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
16
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
17
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
18
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
19
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
20
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
21
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
15
22
|
var __rest = void 0 && (void 0).__rest || function (s, e) {
|
|
16
23
|
var t = {};
|
|
17
24
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
@@ -25,52 +32,124 @@ var __rest = void 0 && (void 0).__rest || function (s, e) {
|
|
|
25
32
|
* @Author: 郑泳健
|
|
26
33
|
* @Date: 2024-08-05 10:50:17
|
|
27
34
|
* @LastEditors: 郑泳健
|
|
28
|
-
* @LastEditTime: 2024-08-
|
|
35
|
+
* @LastEditTime: 2024-08-20 15:03:16
|
|
29
36
|
*/
|
|
30
37
|
|
|
31
38
|
var TntdVirtualTreeSelect = function TntdVirtualTreeSelect(_a) {
|
|
32
39
|
var value = _a.value,
|
|
33
40
|
onChange = _a.onChange,
|
|
34
|
-
renderItem = _a.renderItem,
|
|
35
41
|
treeData = _a.treeData,
|
|
36
42
|
showSearch = _a.showSearch,
|
|
37
|
-
treeDefaultExpandAll = _a.treeDefaultExpandAll,
|
|
38
|
-
treeExpandedKeys = _a.treeExpandedKeys,
|
|
39
43
|
fieldNames = _a.fieldNames,
|
|
40
44
|
dropdownMatchSelectWidth = _a.dropdownMatchSelectWidth,
|
|
41
45
|
dropdownStyle = _a.dropdownStyle,
|
|
46
|
+
showCheckedStrategy = _a.showCheckedStrategy,
|
|
42
47
|
treeCheckable = _a.treeCheckable,
|
|
43
|
-
|
|
48
|
+
treeCheckStrictly = _a.treeCheckStrictly,
|
|
49
|
+
treeDefaultExpandAll = _a.treeDefaultExpandAll,
|
|
50
|
+
treeExpandedKeys = _a.treeExpandedKeys,
|
|
51
|
+
onTreeCheck = _a.onTreeCheck,
|
|
52
|
+
onTreeExpand = _a.onTreeExpand,
|
|
53
|
+
treeTitleRender = _a.treeTitleRender,
|
|
54
|
+
restProps = __rest(_a, ["value", "onChange", "treeData", "showSearch", "fieldNames", "dropdownMatchSelectWidth", "dropdownStyle", "showCheckedStrategy", "treeCheckable", "treeCheckStrictly", "treeDefaultExpandAll", "treeExpandedKeys", "onTreeCheck", "onTreeExpand", "treeTitleRender"]);
|
|
55
|
+
var selectRef = (0, _react.useRef)(null);
|
|
56
|
+
var _useState = (0, _react.useState)(undefined),
|
|
57
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
58
|
+
filterKey = _useState2[0],
|
|
59
|
+
setFilterKey = _useState2[1];
|
|
44
60
|
var mergeDropdownStyle = (0, _react.useMemo)(function () {
|
|
45
61
|
return Array.isArray(treeData) && treeData.length ? dropdownStyle : {};
|
|
46
62
|
}, [dropdownStyle, treeData]);
|
|
47
63
|
var mergeDropdownMatchSelectWidth = (0, _react.useMemo)(function () {
|
|
48
64
|
return Array.isArray(treeData) && treeData.length ? dropdownMatchSelectWidth : true;
|
|
49
65
|
}, [dropdownMatchSelectWidth, treeData]);
|
|
50
|
-
var
|
|
66
|
+
var treeNodeWithParents = (0, _react.useMemo)(function () {
|
|
67
|
+
return (0, _utils.flatWithParents)(treeData, fieldNames);
|
|
68
|
+
}, [treeData, fieldNames]);
|
|
69
|
+
var selectValue = (0, _react.useMemo)(function () {
|
|
70
|
+
if (!treeCheckable) {
|
|
71
|
+
return value;
|
|
72
|
+
}
|
|
73
|
+
if (Array.isArray(value)) {
|
|
74
|
+
if (showCheckedStrategy === TntdVirtualTreeSelect.SHOW_ALL) {
|
|
75
|
+
return value;
|
|
76
|
+
}
|
|
77
|
+
// 过滤掉有子节点,
|
|
78
|
+
return value.filter(function (i) {
|
|
79
|
+
return (0, _utils.filterLastestNode)(treeNodeWithParents, i, value);
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
return undefined;
|
|
83
|
+
}, [treeCheckable, treeNodeWithParents, value, showCheckedStrategy]);
|
|
84
|
+
var mergeMode = (0, _react.useMemo)(function () {
|
|
85
|
+
if (treeCheckable) {
|
|
86
|
+
return {
|
|
87
|
+
multiple: true,
|
|
88
|
+
mode: 'tags'
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
return {};
|
|
92
|
+
}, [treeCheckable]);
|
|
93
|
+
var handleRender = function handleRender(_a) {
|
|
94
|
+
var showSearch = _a.showSearch,
|
|
95
|
+
rest = __rest(_a, ["showSearch"]);
|
|
51
96
|
return _react["default"].createElement("div", {
|
|
52
|
-
className:
|
|
97
|
+
className: "virtual-tree-options"
|
|
53
98
|
}, _react["default"].createElement(_tntdVirtualTree["default"], Object.assign({}, rest)));
|
|
54
99
|
};
|
|
55
|
-
|
|
100
|
+
var handleChange = function handleChange(val) {
|
|
101
|
+
onChange(val);
|
|
102
|
+
};
|
|
103
|
+
var handleSearch = function handleSearch(val) {
|
|
104
|
+
setFilterKey(val);
|
|
105
|
+
};
|
|
106
|
+
var handleSelect = function handleSelect(val) {
|
|
107
|
+
var _a;
|
|
108
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(val);
|
|
109
|
+
if (selectRef.current) {
|
|
110
|
+
// 主动触发下拉框消失
|
|
111
|
+
(_a = selectRef.current) === null || _a === void 0 ? void 0 : _a.blur();
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
return _react["default"].createElement(_tntdRcSelect["default"], Object.assign({
|
|
115
|
+
ref: selectRef,
|
|
116
|
+
value: selectValue,
|
|
117
|
+
onChange: handleChange,
|
|
118
|
+
showSearch: showSearch,
|
|
119
|
+
onSearch: handleSearch
|
|
120
|
+
}, mergeMode, restProps, {
|
|
56
121
|
dropdownMatchSelectWidth: mergeDropdownMatchSelectWidth,
|
|
57
122
|
dropdownStyle: Object.assign({
|
|
58
123
|
maxHeight: '100vh',
|
|
59
124
|
overflow: 'auto'
|
|
60
125
|
}, mergeDropdownStyle),
|
|
61
126
|
dropdownRender: function dropdownRender() {
|
|
62
|
-
|
|
63
|
-
value: value,
|
|
64
|
-
onChange: onChange,
|
|
65
|
-
renderItem: renderItem,
|
|
127
|
+
var obj = {
|
|
66
128
|
treeData: treeData,
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
129
|
+
filterKey: filterKey,
|
|
130
|
+
defaultExpandAll: treeDefaultExpandAll,
|
|
131
|
+
expandedKeys: treeExpandedKeys,
|
|
70
132
|
fieldNames: fieldNames,
|
|
71
|
-
|
|
72
|
-
|
|
133
|
+
onExpand: onTreeExpand,
|
|
134
|
+
titleRender: treeTitleRender,
|
|
135
|
+
onSelect: handleSelect
|
|
136
|
+
};
|
|
137
|
+
if (treeCheckable) {
|
|
138
|
+
obj = Object.assign(Object.assign({}, obj), {
|
|
139
|
+
checkedKeys: value,
|
|
140
|
+
checkStrictly: treeCheckStrictly,
|
|
141
|
+
checkable: treeCheckable,
|
|
142
|
+
onCheck: onTreeCheck
|
|
143
|
+
});
|
|
144
|
+
} else {
|
|
145
|
+
obj = Object.assign(Object.assign({}, obj), {
|
|
146
|
+
value: value
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
return handleRender(obj);
|
|
73
150
|
}
|
|
74
151
|
}));
|
|
75
152
|
};
|
|
153
|
+
TntdVirtualTreeSelect.SHOW_CHILD = 'SHOW_CHILD';
|
|
154
|
+
TntdVirtualTreeSelect.SHOW_ALL = 'SHOW_ALL';
|
|
76
155
|
var _default = exports["default"] = TntdVirtualTreeSelect;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tntd-virtual-tree-select/index.jsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;GAMG;AACH,+
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tntd-virtual-tree-select/index.jsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * @Descripttion: 用select包裹虚拟树\n * @Author: 郑泳健\n * @Date: 2024-08-05 10:50:17\n * @LastEditors: 郑泳健\n * @LastEditTime: 2024-08-20 15:03:16\n */\nimport React, { useState, useRef, useMemo } from 'react';\nimport RcSelect from '../tntd-rc-select';\nimport TntdVirtualTree from '../tntd-virtual-tree';\nimport { filterLastestNode, flatWithParents } from './utils.js'\nimport './index.less';\n\nconst TntdVirtualTreeSelect = ({\n value,\n onChange,\n treeData,\n showSearch,\n fieldNames,\n dropdownMatchSelectWidth,\n dropdownStyle,\n showCheckedStrategy,\n treeCheckable,\n treeCheckStrictly,\n treeDefaultExpandAll,\n treeExpandedKeys,\n onTreeCheck,\n onTreeExpand,\n treeTitleRender,\n ...restProps\n}) => {\n const selectRef = useRef(null);\n const [filterKey, setFilterKey] = useState(undefined);\n\n const mergeDropdownStyle = useMemo(() => {\n return Array.isArray(treeData) && treeData.length ? dropdownStyle : {};\n }, [dropdownStyle, treeData]);\n\n const mergeDropdownMatchSelectWidth = useMemo(() => {\n return Array.isArray(treeData) && treeData.length ? dropdownMatchSelectWidth : true;\n }, [dropdownMatchSelectWidth, treeData]);\n\n const treeNodeWithParents = useMemo(() => {\n return flatWithParents(treeData, fieldNames)\n }, [treeData, fieldNames])\n\n const selectValue = useMemo(() => {\n if(!treeCheckable) {\n return value\n }\n\n if(Array.isArray(value)) {\n if(showCheckedStrategy === TntdVirtualTreeSelect.SHOW_ALL) {\n return value;\n }\n // 过滤掉有子节点,\n return value.filter(i => {\n return filterLastestNode(treeNodeWithParents, i, value)\n })\n }\n return undefined\n\n }, [treeCheckable, treeNodeWithParents, value, showCheckedStrategy])\n\n const mergeMode = useMemo(() => {\n if(treeCheckable) {\n return {\n multiple: true,\n mode: 'tags'\n }\n }\n return {}\n }, [treeCheckable])\n\n const handleRender = ({ showSearch, ...rest }) => {\n return (\n <div className=\"virtual-tree-options\">\n <TntdVirtualTree {...rest} />\n </div>\n );\n };\n\n const handleChange = (val) => {\n onChange(val);\n };\n\n const handleSearch = (val) => {\n setFilterKey(val);\n };\n\n const handleSelect = (val) => {\n onChange?.(val);\n if (selectRef.current) {\n // 主动触发下拉框消失\n selectRef.current?.blur();\n }\n };\n\n return (\n <RcSelect\n ref={selectRef}\n value={selectValue}\n onChange={handleChange}\n showSearch={showSearch}\n onSearch={handleSearch}\n {...mergeMode}\n {...restProps}\n dropdownMatchSelectWidth={mergeDropdownMatchSelectWidth}\n dropdownStyle={{ maxHeight: '100vh', overflow: 'auto', ...mergeDropdownStyle }}\n dropdownRender={() => {\n let obj = {\n treeData,\n filterKey,\n defaultExpandAll: treeDefaultExpandAll,\n expandedKeys: treeExpandedKeys,\n fieldNames,\n onExpand: onTreeExpand,\n titleRender: treeTitleRender,\n onSelect: handleSelect\n };\n if (treeCheckable) {\n obj = { ...obj, checkedKeys: value, checkStrictly: treeCheckStrictly, checkable: treeCheckable, onCheck: onTreeCheck };\n } else {\n obj = { ...obj, value };\n }\n return handleRender(obj);\n }}\n />\n );\n};\n\nTntdVirtualTreeSelect.SHOW_CHILD = 'SHOW_CHILD'\nTntdVirtualTreeSelect.SHOW_ALL = 'SHOW_ALL'\n\nexport default TntdVirtualTreeSelect;\n"]}
|
|
@@ -1,10 +1,3 @@
|
|
|
1
|
-
export function
|
|
2
|
-
|
|
3
|
-
value: string;
|
|
4
|
-
children: string;
|
|
5
|
-
}): any[];
|
|
6
|
-
export function getNodeStr(node: any, key: any, result?: any[]): any[];
|
|
7
|
-
export function getNodeKeys(node: any, widthSelf?: any, result?: any): any;
|
|
8
|
-
export function flatTreeData(treeData: any, filterKey?: string, expandedKeys?: any, treeDefaultExpandAll?: any, level?: any, result?: any): any;
|
|
9
|
-
export function getFullExpandedKeys(treeDataWithKeys: any, treeExpandedKeys: any, treeDefaultExpandAll: any, result?: any): any;
|
|
1
|
+
export function flatWithParents(treeData: any, fieldNames?: any, parents?: any, result?: {}): {};
|
|
2
|
+
export function filterLastestNode(treeNodeWithParents: any, item: any, list: any): boolean;
|
|
10
3
|
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/tntd-virtual-tree-select/utils.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/tntd-virtual-tree-select/utils.js"],"names":[],"mappings":"AAOO,iGAaN;AAEM,2FAQN"}
|
|
@@ -3,165 +3,46 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.
|
|
7
|
-
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(_e) { throw _e; }, 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(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
|
6
|
+
exports.flatWithParents = exports.filterLastestNode = void 0;
|
|
8
7
|
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
9
8
|
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
10
9
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
11
10
|
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
12
11
|
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
13
12
|
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
14
|
-
var __rest = void 0 && (void 0).__rest || function (s, e) {
|
|
15
|
-
var t = {};
|
|
16
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
17
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
18
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
|
19
|
-
}
|
|
20
|
-
return t;
|
|
21
|
-
};
|
|
22
13
|
/**
|
|
23
|
-
*
|
|
24
|
-
* 用于判断后续展开/收起
|
|
14
|
+
* 给每个节点增加一个parent字段,记录其父节点用于showCheckedStrategy
|
|
25
15
|
* @param {*} treeData
|
|
16
|
+
* @param {*} fieldNames
|
|
17
|
+
* @param {*} parents
|
|
18
|
+
* @returns
|
|
26
19
|
*/
|
|
27
|
-
var
|
|
20
|
+
var flatWithParents = exports.flatWithParents = function flatWithParents(treeData) {
|
|
28
21
|
var fieldNames = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {
|
|
29
22
|
title: 'title',
|
|
30
23
|
value: 'value',
|
|
31
|
-
children: 'children'
|
|
24
|
+
children: 'children',
|
|
25
|
+
disabled: 'disabled'
|
|
32
26
|
};
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
}
|
|
43
|
-
return Object.assign(Object.assign({}, query), {
|
|
44
|
-
title: query[fieldNames['title']],
|
|
45
|
-
value: query[fieldNames['value']],
|
|
46
|
-
keys: getNodeKeys(query),
|
|
47
|
-
titleTotal: getNodeStr(query, fieldNames['title'])
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
return [];
|
|
52
|
-
};
|
|
53
|
-
var getNodeStr = exports.getNodeStr = function getNodeStr(node, key) {
|
|
54
|
-
var result = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
|
55
|
-
result.push(node[key]);
|
|
56
|
-
if (Array.isArray(node.children) && !!node.children.length) {
|
|
57
|
-
node.children.forEach(function (element) {
|
|
58
|
-
result = [].concat(_toConsumableArray(result), _toConsumableArray(getNodeStr(element, key)));
|
|
27
|
+
var parents = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
|
28
|
+
var result = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
|
|
29
|
+
if (Array.isArray(treeData)) {
|
|
30
|
+
treeData.forEach(function (i) {
|
|
31
|
+
result[i[fieldNames['value']]] = parents;
|
|
32
|
+
if (Array.isArray(i[fieldNames['children']])) {
|
|
33
|
+
var list = flatWithParents(i[fieldNames['children']], fieldNames, [].concat(_toConsumableArray(parents), [i[fieldNames['value']]]));
|
|
34
|
+
result = Object.assign(Object.assign({}, result), list);
|
|
35
|
+
} else {}
|
|
59
36
|
});
|
|
60
37
|
}
|
|
61
38
|
return result;
|
|
62
39
|
};
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
* @returns []
|
|
69
|
-
*/
|
|
70
|
-
var getNodeKeys = exports.getNodeKeys = function getNodeKeys(node) {
|
|
71
|
-
var widthSelf = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|
72
|
-
var result = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
|
73
|
-
if (widthSelf) {
|
|
74
|
-
result.push(node.value);
|
|
75
|
-
}
|
|
76
|
-
if (Array.isArray(node.children) && !!node.children.length) {
|
|
77
|
-
node.children.forEach(function (element) {
|
|
78
|
-
result = [].concat(_toConsumableArray(result), _toConsumableArray(getNodeKeys(element)));
|
|
40
|
+
var filterLastestNode = exports.filterLastestNode = function filterLastestNode(treeNodeWithParents, item, list) {
|
|
41
|
+
var parents = treeNodeWithParents[item] || {};
|
|
42
|
+
if (Array.isArray(parents) && !!parents.length && Array.isArray(list) && !!list.length) {
|
|
43
|
+
return parents.every(function (el) {
|
|
44
|
+
return !list.includes(el);
|
|
79
45
|
});
|
|
80
46
|
}
|
|
81
|
-
return
|
|
82
|
-
};
|
|
83
|
-
/**
|
|
84
|
-
* 扁平树
|
|
85
|
-
* @param {*} treeData
|
|
86
|
-
* @param {*} expandedKeys 展开的节点
|
|
87
|
-
* @param {*} treeDefaultExpandAll
|
|
88
|
-
* @param {*} level
|
|
89
|
-
* @param {*} result
|
|
90
|
-
* @returns
|
|
91
|
-
*/
|
|
92
|
-
var flatTreeData = exports.flatTreeData = function flatTreeData(treeData) {
|
|
93
|
-
var filterKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|
94
|
-
var expandedKeys = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
|
95
|
-
var treeDefaultExpandAll = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
|
96
|
-
var level = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0;
|
|
97
|
-
var result = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : [];
|
|
98
|
-
if (Array.isArray(treeData)) {
|
|
99
|
-
var _iterator = _createForOfIteratorHelper(treeData),
|
|
100
|
-
_step;
|
|
101
|
-
try {
|
|
102
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
103
|
-
var i = _step.value;
|
|
104
|
-
var value = i.value,
|
|
105
|
-
children = i.children,
|
|
106
|
-
titleTotal = i.titleTotal,
|
|
107
|
-
title = i.title,
|
|
108
|
-
rest = __rest(i, ["value", "children", "titleTotal", "title"]);
|
|
109
|
-
// 判断是否命中过滤
|
|
110
|
-
var bingo = true;
|
|
111
|
-
var transFilterKey = !['', null, undefined].includes(filterKey);
|
|
112
|
-
if (transFilterKey) {
|
|
113
|
-
bingo = Array.isArray(titleTotal) ? titleTotal.some(function (i) {
|
|
114
|
-
return i.includes(filterKey);
|
|
115
|
-
}) : false;
|
|
116
|
-
}
|
|
117
|
-
if (bingo) {
|
|
118
|
-
result.push({
|
|
119
|
-
value: value,
|
|
120
|
-
children: children,
|
|
121
|
-
title: title,
|
|
122
|
-
level: level,
|
|
123
|
-
titleTotal: titleTotal
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
var selfIn = Array.isArray(expandedKeys) ? expandedKeys.includes(value) : false;
|
|
127
|
-
if ((treeDefaultExpandAll || selfIn || transFilterKey && bingo) && Array.isArray(children) && !!children.length) {
|
|
128
|
-
result = [].concat(_toConsumableArray(result), _toConsumableArray(flatTreeData(children, filterKey, expandedKeys, treeDefaultExpandAll, level + 1)));
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
} catch (err) {
|
|
132
|
-
_iterator.e(err);
|
|
133
|
-
} finally {
|
|
134
|
-
_iterator.f();
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
return result;
|
|
138
|
-
};
|
|
139
|
-
/**
|
|
140
|
-
* 获取所有展开的节点 (组件传入最后一层,需要将其上层全部加入到expandedKeys)
|
|
141
|
-
* @param {*} treeDataWithKeys
|
|
142
|
-
* @param {*} treeExpandedKeys
|
|
143
|
-
* @param {*} result
|
|
144
|
-
* @returns
|
|
145
|
-
*/
|
|
146
|
-
var getFullExpandedKeys = exports.getFullExpandedKeys = function getFullExpandedKeys(treeDataWithKeys) {
|
|
147
|
-
var treeExpandedKeys = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
148
|
-
var treeDefaultExpandAll = arguments.length > 2 ? arguments[2] : undefined;
|
|
149
|
-
var result = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];
|
|
150
|
-
if (!treeDefaultExpandAll && (!Array.isArray(treeDataWithKeys) || !treeDataWithKeys.length || !Array.isArray(treeExpandedKeys) || !treeExpandedKeys.length)) {
|
|
151
|
-
return [];
|
|
152
|
-
}
|
|
153
|
-
treeDataWithKeys.forEach(function (i) {
|
|
154
|
-
var keys = i.keys,
|
|
155
|
-
value = i.value,
|
|
156
|
-
children = i.children;
|
|
157
|
-
if (treeDefaultExpandAll || Array.isArray(keys) && keys.some(function (el) {
|
|
158
|
-
return treeExpandedKeys.includes(el);
|
|
159
|
-
})) {
|
|
160
|
-
result.push(value);
|
|
161
|
-
if (Array.isArray(children) && !!children.length) {
|
|
162
|
-
result = [].concat(_toConsumableArray(result), _toConsumableArray(getFullExpandedKeys(children, treeExpandedKeys, treeDefaultExpandAll)));
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
});
|
|
166
|
-
return result;
|
|
47
|
+
return false;
|
|
167
48
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/tntd-virtual-tree-select/utils.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/tntd-virtual-tree-select/utils.js"],"names":[],"mappings":";;;AAAA;;;;;;GAMG;AACI,MAAM,eAAe,GAAG,CAAC,QAAQ,EAAE,UAAU,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,OAAO,GAAG,EAAE,EAAE,MAAM,GAAG,EAAE,EAAE,EAAE;IAClK,IAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;QAC1B,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACnB,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;YACzC,IAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,EAAC;gBAC1C,MAAM,IAAI,GAAG,IAAA,uBAAe,EAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAA;gBACzG,MAAM,mCAAO,MAAM,GAAK,IAAI,CAAC,CAAA;aAC9B;iBAAI;aAEJ;QACH,CAAC,CAAC,CAAA;KACH;IACD,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAbY,QAAA,eAAe,mBAa3B;AAEM,MAAM,iBAAiB,GAAG,CAAC,mBAAmB,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;IACnE,MAAM,OAAO,GAAG,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;IAE/C,IAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE;QACrF,OAAO,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAA;KAC/C;IAED,OAAO,KAAK,CAAA;AACd,CAAC,CAAA;AARY,QAAA,iBAAiB,qBAQ7B","sourcesContent":["/**\n * 给每个节点增加一个parent字段,记录其父节点用于showCheckedStrategy\n * @param {*} treeData \n * @param {*} fieldNames \n * @param {*} parents \n * @returns \n */\nexport const flatWithParents = (treeData, fieldNames = { title: 'title', value: 'value', children: 'children', disabled: 'disabled' }, parents = [], result = {}) => {\n if(Array.isArray(treeData)) {\n treeData.forEach(i => {\n result[i[fieldNames['value']]] = parents;\n if(Array.isArray(i[fieldNames['children']])){\n const list = flatWithParents(i[fieldNames['children']], fieldNames, [...parents, i[fieldNames['value']]])\n result = {...result, ...list}\n }else{\n \n }\n })\n }\n return result\n}\n\nexport const filterLastestNode = (treeNodeWithParents, item, list) => {\n const parents = treeNodeWithParents[item] || {}\n \n if(Array.isArray(parents) && !!parents.length && Array.isArray(list) && !!list.length) {\n return parents.every(el => !list.includes(el))\n }\n\n return false\n}\n\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "tntd",
|
|
3
|
-
"version": "2.8.
|
|
3
|
+
"version": "2.8.12",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"start": "heft start --storybook",
|
|
@@ -42,7 +42,9 @@
|
|
|
42
42
|
"scroll-into-view-if-needed": "^2.2.25",
|
|
43
43
|
"@tntd/icons": "^1.0.10",
|
|
44
44
|
"@ant-design/colors": "^3.1.0",
|
|
45
|
-
"rc-resize-observer": "~1.4.0"
|
|
45
|
+
"rc-resize-observer": "~1.4.0",
|
|
46
|
+
"react-resizable": "~3.0.4",
|
|
47
|
+
"@types/react-resizable": "~3.0.8"
|
|
46
48
|
},
|
|
47
49
|
"devDependencies": {
|
|
48
50
|
"@react-types/shared": "^3.10.1",
|
package/es/spin/spin.js
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* @Author: 周泽飞 zefei.zhou@tongdun.net
|
|
3
|
-
* @Date: 2024-07-19 18:49:24
|
|
4
|
-
* @LastEditors: 周泽飞 zefei.zhou@tongdun.net
|
|
5
|
-
* @LastEditTime: 2024-07-19 18:54:42
|
|
6
|
-
* @FilePath: /tntd/packages/tntd/src/spin/spin.tsx
|
|
7
|
-
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
|
|
8
|
-
*/
|
|
9
|
-
var __rest = this && this.__rest || function (s, e) {
|
|
10
|
-
var t = {};
|
|
11
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
12
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
13
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
|
14
|
-
}
|
|
15
|
-
return t;
|
|
16
|
-
};
|
|
17
|
-
import React, { forwardRef } from 'react';
|
|
18
|
-
import { ConfigConsumer } from 'antd/es/config-provider';
|
|
19
|
-
import { default as AntdSpin } from 'antd/es/spin';
|
|
20
|
-
import classNames from 'classnames';
|
|
21
|
-
import './spin.less';
|
|
22
|
-
export const Spin = forwardRef((props, ref) => {
|
|
23
|
-
const {
|
|
24
|
-
className,
|
|
25
|
-
wrapperClassName
|
|
26
|
-
} = props,
|
|
27
|
-
restProps = __rest(props, ["className", "wrapperClassName"]);
|
|
28
|
-
return React.createElement(ConfigConsumer, null, () => {
|
|
29
|
-
return React.createElement(AntdSpin, Object.assign({
|
|
30
|
-
wrapperClassName: classNames('tnt-spin-nested', className || ''),
|
|
31
|
-
className: classNames('tnt-spin', className || '')
|
|
32
|
-
}, restProps, {
|
|
33
|
-
ref: ref
|
|
34
|
-
}));
|
|
35
|
-
});
|
|
36
|
-
});
|
package/es/spin/spin.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spin.js","sourceRoot":"","sources":["../../src/spin/spin.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;;;;;;;;;;;;AAEH,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,cAAc,CAAA;AAClD,OAAO,UAAU,MAAM,YAAY,CAAA;AAEnC,OAAO,aAAa,CAAA;AAKpB,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAA0B,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;IACrE,MAAM,EAAE,SAAS,EAAE,gBAAgB,KAAmB,KAAK,EAAnB,SAAS,UAAK,KAAK,EAArD,iCAA6C,CAAQ,CAAA;IAC3D,OAAO,CACL,oBAAC,cAAc,QACZ,GAAG,EAAE;QACJ,OAAO,CACL,oBAAC,QAAQ,kBACP,gBAAgB,EAAE,UAAU,CAAC,iBAAiB,EAAE,SAAS,IAAI,EAAE,CAAC,EAChE,SAAS,EAAE,UAAU,CAAC,UAAU,EAAE,SAAS,IAAI,EAAE,CAAC,IAC9C,SAAS,IACb,GAAG,EAAE,GAAG,IACR,CACH,CAAA;IACH,CAAC,CACc,CAClB,CAAA;AACH,CAAC,CAAkB,CAAA","sourcesContent":["/*\n * @Author: 周泽飞 zefei.zhou@tongdun.net\n * @Date: 2024-07-19 18:49:24\n * @LastEditors: 周泽飞 zefei.zhou@tongdun.net\n * @LastEditTime: 2024-07-19 18:54:42\n * @FilePath: /tntd/packages/tntd/src/spin/spin.tsx\n * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE\n */\n\nimport React, { forwardRef } from 'react'\nimport type { SpinProps as AntdSpinProps } from 'antd/es/spin'\nimport { ConfigConsumer } from 'antd/es/config-provider'\nimport { default as AntdSpin } from 'antd/es/spin'\nimport classNames from 'classnames'\n\nimport './spin.less'\n\ninterface SpinComponent\n extends React.ForwardRefExoticComponent<AntdSpinProps & React.RefAttributes<AntdSpin>> {}\n\nexport const Spin = forwardRef<AntdSpin, AntdSpinProps>((props, ref) => {\n const { className, wrapperClassName, ...restProps } = props\n return (\n <ConfigConsumer>\n {() => {\n return (\n <AntdSpin\n wrapperClassName={classNames('tnt-spin-nested', className || '')}\n className={classNames('tnt-spin', className || '')}\n {...restProps}\n ref={ref}\n />\n )\n }}\n </ConfigConsumer>\n )\n}) as SpinComponent\n"]}
|
package/es/spin/spin.less
DELETED
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* @Descripttion: 最简单的tree下拉框,增加了虚拟滚动
|
|
3
|
-
* @Author: 郑泳健
|
|
4
|
-
* @Date: 2024-07-31 14:46:55
|
|
5
|
-
* @LastEditors: 郑泳健
|
|
6
|
-
* @LastEditTime: 2024-08-05 15:58:47
|
|
7
|
-
*/
|
|
8
|
-
import React, { useState, useMemo, useEffect } from 'react';
|
|
9
|
-
import List from 'rc-virtual-list';
|
|
10
|
-
import Icon from '../icon';
|
|
11
|
-
import Ellipsis from '../ellipsis';
|
|
12
|
-
import Empty from '../empty';
|
|
13
|
-
import Input from '../input';
|
|
14
|
-
import { flatTreeData, getFullExpandedKeys, addTreeNodeKeys } from './utils';
|
|
15
|
-
import './tree.less';
|
|
16
|
-
const VirtualTree = ({
|
|
17
|
-
value,
|
|
18
|
-
onChange,
|
|
19
|
-
treeDefaultExpandAll,
|
|
20
|
-
fieldNames,
|
|
21
|
-
treeExpandedKeys,
|
|
22
|
-
showSearch,
|
|
23
|
-
treeData,
|
|
24
|
-
renderItem
|
|
25
|
-
}) => {
|
|
26
|
-
const ref = React.useRef(null);
|
|
27
|
-
// 展开的节点列表
|
|
28
|
-
const [expandedKeys, setExpandedKeys] = useState([]);
|
|
29
|
-
const [choosedValue, setChoosedValue] = useState([]);
|
|
30
|
-
const [filterKey, setFilterKey] = useState(undefined);
|
|
31
|
-
useEffect(() => {
|
|
32
|
-
if (!['', null, undefined].includes(value)) {
|
|
33
|
-
setChoosedValue(value);
|
|
34
|
-
} else {
|
|
35
|
-
setChoosedValue(undefined);
|
|
36
|
-
}
|
|
37
|
-
}, [value]);
|
|
38
|
-
/** 给每个节点增加属性keys,值为其下面所有节点的集合 */
|
|
39
|
-
const treeDataWithKeys = useMemo(() => {
|
|
40
|
-
return addTreeNodeKeys(treeData, fieldNames);
|
|
41
|
-
}, [treeData, fieldNames]);
|
|
42
|
-
const mergeTreeDefaultExpandAll = useMemo(() => {
|
|
43
|
-
if (Array.isArray(treeExpandedKeys) && treeExpandedKeys.length) {
|
|
44
|
-
return false;
|
|
45
|
-
}
|
|
46
|
-
return treeDefaultExpandAll;
|
|
47
|
-
}, [treeDefaultExpandAll, treeExpandedKeys]);
|
|
48
|
-
/** 获取到所有展开的节点,因为treeDataWithKeys可能传入的是最后一级 */
|
|
49
|
-
useEffect(() => {
|
|
50
|
-
let transTreeExpandedKeys = Array.isArray(treeExpandedKeys) ? treeExpandedKeys : [];
|
|
51
|
-
if (value) {
|
|
52
|
-
transTreeExpandedKeys = [...treeExpandedKeys, value];
|
|
53
|
-
}
|
|
54
|
-
const _expandedKeys = getFullExpandedKeys(treeDataWithKeys, transTreeExpandedKeys, mergeTreeDefaultExpandAll);
|
|
55
|
-
setExpandedKeys(_expandedKeys);
|
|
56
|
-
}, [treeDataWithKeys, treeExpandedKeys, mergeTreeDefaultExpandAll, value]);
|
|
57
|
-
/** 最终渲染的数据 */
|
|
58
|
-
const renderData = useMemo(() => {
|
|
59
|
-
return flatTreeData(treeDataWithKeys, filterKey, expandedKeys);
|
|
60
|
-
}, [treeDataWithKeys, filterKey, expandedKeys]);
|
|
61
|
-
/** 切换展开/收起 */
|
|
62
|
-
const handleToggle = item => {
|
|
63
|
-
const {
|
|
64
|
-
value
|
|
65
|
-
} = item || {};
|
|
66
|
-
const bool = Array.isArray(expandedKeys) ? expandedKeys.includes(value) : false;
|
|
67
|
-
if (bool) {
|
|
68
|
-
const list = Array.isArray(expandedKeys) ? expandedKeys.filter(i => i !== value) : [];
|
|
69
|
-
setExpandedKeys(list);
|
|
70
|
-
} else {
|
|
71
|
-
setExpandedKeys([...expandedKeys, value]);
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
const defaultRenderItem = (item, expandedKeys) => {
|
|
75
|
-
return React.createElement(Ellipsis, {
|
|
76
|
-
title: item.title,
|
|
77
|
-
widthLimit: '100%'
|
|
78
|
-
});
|
|
79
|
-
};
|
|
80
|
-
const handleChange = _value => {
|
|
81
|
-
setChoosedValue(_value);
|
|
82
|
-
onChange === null || onChange === void 0 ? void 0 : onChange(_value);
|
|
83
|
-
};
|
|
84
|
-
const handleInput = e => {
|
|
85
|
-
const _filterValue = e.target.value;
|
|
86
|
-
setFilterKey(_filterValue);
|
|
87
|
-
};
|
|
88
|
-
return React.createElement("div", {
|
|
89
|
-
className: 'tntd-tree-select'
|
|
90
|
-
}, showSearch && Array.isArray(treeData) && !!treeData.length ? React.createElement(Input, {
|
|
91
|
-
onChange: handleInput,
|
|
92
|
-
allowClear: true
|
|
93
|
-
}) : '', !Array.isArray(renderData) || !renderData.length ? React.createElement(Empty, {
|
|
94
|
-
size: 'small'
|
|
95
|
-
}) : React.createElement(List, {
|
|
96
|
-
ref: ref,
|
|
97
|
-
height: 300,
|
|
98
|
-
itemHeight: 44,
|
|
99
|
-
data: renderData
|
|
100
|
-
}, item => {
|
|
101
|
-
const {
|
|
102
|
-
level,
|
|
103
|
-
children
|
|
104
|
-
} = item;
|
|
105
|
-
const bool = expandedKeys.includes(item.value);
|
|
106
|
-
return React.createElement("div", {
|
|
107
|
-
className: "tntd-tree-select-item",
|
|
108
|
-
style: {
|
|
109
|
-
paddingLeft: level * 18
|
|
110
|
-
}
|
|
111
|
-
}, React.createElement("div", {
|
|
112
|
-
style: {
|
|
113
|
-
width: 18,
|
|
114
|
-
paddingLeft: 3
|
|
115
|
-
}
|
|
116
|
-
}, Array.isArray(children) && !!children.length ? React.createElement(Icon, {
|
|
117
|
-
type: bool ? 'caret-down' : 'caret-right',
|
|
118
|
-
onClick: () => handleToggle(item)
|
|
119
|
-
}) : React.createElement(Icon, null)), React.createElement("div", {
|
|
120
|
-
className: `tntd-tree-select-item-title ${choosedValue === item.value ? 'tntd-tree-select-item-title_active' : ''}`,
|
|
121
|
-
onClick: () => handleChange(item.value)
|
|
122
|
-
}, renderItem ? renderItem(item, expandedKeys) : defaultRenderItem(item, expandedKeys)));
|
|
123
|
-
}));
|
|
124
|
-
};
|
|
125
|
-
export default VirtualTree;
|