@bit-sun/business-component 2.3.20 → 2.3.22-beta1

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 (212) hide show
  1. package/.editorconfig +16 -16
  2. package/.fatherrc.ts +5 -5
  3. package/.gitlab-ci.yml +179 -179
  4. package/.prettierignore +7 -7
  5. package/.prettierrc +11 -11
  6. package/.umirc.ts +74 -74
  7. package/README.md +27 -27
  8. package/dist/components/Business/BsLayouts/Components/AllFunc/drawContent.d.ts +1 -1
  9. package/dist/components/Business/BsLayouts/Components/AllFunc/index.d.ts +1 -1
  10. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.d.ts +1 -1
  11. package/dist/components/Business/BsLayouts/Components/CustomerMenu/index.d.ts +1 -1
  12. package/dist/components/Business/BsLayouts/Components/RightContent/index.d.ts +2 -2
  13. package/dist/components/Business/BsLayouts/Components/SearchFunc/index.d.ts +2 -2
  14. package/dist/components/Business/BsLayouts/index.d.ts +2 -2
  15. package/dist/components/Business/BsLayouts/service.d.ts +1 -1
  16. package/dist/components/Business/BsSulaQueryTable/utils.d.ts +2 -2
  17. package/dist/components/Business/SearchSelect/index.d.ts +1 -1
  18. package/dist/components/Business/moreTreeTable/FixedScrollBar.d.ts +1 -1
  19. package/dist/components/Functional/AddSelect/helps.d.ts +13 -0
  20. package/dist/components/Functional/BsAntdSula/BsCascader/index.d.ts +1 -1
  21. package/dist/components/Functional/SearchSelect/index.d.ts +1 -1
  22. package/dist/components/Solution/RuleComponent/services.d.ts +1 -1
  23. package/dist/index.esm.js +1401 -1292
  24. package/dist/index.js +1401 -1292
  25. package/dist/utils/TableUtils.d.ts +2 -2
  26. package/dist/utils/utils.d.ts +1 -1
  27. package/docs/index.md +21 -21
  28. package/lib/assets/drag.svg +17 -17
  29. package/lib/assets/exportFail.svg +37 -37
  30. package/lib/assets/exportProcessing.svg +28 -28
  31. package/lib/assets/exportSuccess.svg +34 -34
  32. package/lib/assets/label_icon_bottom.svg +25 -25
  33. package/lib/assets/upExport.svg +22 -22
  34. package/package.json +78 -78
  35. package/src/assets/32.svg +27 -27
  36. package/src/assets/addIcon.svg +17 -17
  37. package/src/assets/allfunc.svg +27 -27
  38. package/src/assets/arrowRight.svg +24 -24
  39. package/src/assets/btn-delete.svg +29 -29
  40. package/src/assets/btn-edit.svg +19 -19
  41. package/src/assets/btn-more.svg +17 -17
  42. package/src/assets/btn-submit.svg +19 -19
  43. package/src/assets/caidan.svg +11 -11
  44. package/src/assets/close.svg +26 -26
  45. package/src/assets/drag.svg +17 -17
  46. package/src/assets/exportFail.svg +37 -37
  47. package/src/assets/exportProcessing.svg +28 -28
  48. package/src/assets/exportSuccess.svg +34 -34
  49. package/src/assets/fixed-left-active.svg +11 -11
  50. package/src/assets/fixed-left.svg +15 -15
  51. package/src/assets/fixed-right-active.svg +11 -11
  52. package/src/assets/fixed-right.svg +15 -15
  53. package/src/assets/guanbi.svg +15 -15
  54. package/src/assets/icon-quanping.svg +15 -15
  55. package/src/assets/icon-shezhi.svg +17 -17
  56. package/src/assets/label_icon_bottom.svg +25 -25
  57. package/src/assets/list-no-img.svg +21 -21
  58. package/src/assets/morentouxiang-32.svg +23 -23
  59. package/src/assets/scanning.svg +24 -24
  60. package/src/assets/upExport.svg +22 -22
  61. package/src/common/ENUM.ts +41 -41
  62. package/src/components/Business/AddSelectBusiness/index.md +162 -162
  63. package/src/components/Business/AddSelectBusiness/index.tsx +1060 -895
  64. package/src/components/Business/BsLayouts/Components/AllFunc/drawContent.tsx +111 -111
  65. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  66. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  67. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  68. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  69. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  70. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  71. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.tsx +285 -285
  72. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  73. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/drawContent.less +170 -170
  74. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  75. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  76. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +72 -72
  77. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +157 -157
  78. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  79. package/src/components/Business/BsLayouts/Components/RightContent/home.less +218 -218
  80. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +155 -155
  81. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +160 -160
  82. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  83. package/src/components/Business/BsLayouts/index.less +79 -79
  84. package/src/components/Business/BsLayouts/index.tsx +1484 -1484
  85. package/src/components/Business/BsLayouts/service.ts +10 -10
  86. package/src/components/Business/BsLayouts/utils.tsx +203 -203
  87. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +564 -564
  88. package/src/components/Business/BsSulaQueryTable/index.less +221 -221
  89. package/src/components/Business/BsSulaQueryTable/index.tsx +535 -535
  90. package/src/components/Business/BsSulaQueryTable/setting.tsx +852 -852
  91. package/src/components/Business/BsSulaQueryTable/utils.less +65 -65
  92. package/src/components/Business/BsSulaQueryTable/utils.tsx +690 -688
  93. package/src/components/Business/CommodityEntry/index.md +70 -70
  94. package/src/components/Business/CommodityEntry/index.tsx +80 -80
  95. package/src/components/Business/CommonAlert/index.tsx +23 -23
  96. package/src/components/Business/CommonGuideWrapper/index.less +111 -111
  97. package/src/components/Business/CommonGuideWrapper/index.md +39 -39
  98. package/src/components/Business/CommonGuideWrapper/index.tsx +83 -83
  99. package/src/components/Business/DetailPageWrapper/index.less +79 -79
  100. package/src/components/Business/DetailPageWrapper/index.tsx +313 -313
  101. package/src/components/Business/DetailPageWrapper/utils.tsx +100 -100
  102. package/src/components/Business/HomePageWrapper/index.less +33 -33
  103. package/src/components/Business/HomePageWrapper/index.md +45 -45
  104. package/src/components/Business/HomePageWrapper/index.tsx +162 -162
  105. package/src/components/Business/JsonQueryTable/components/FieldsModifyModal.tsx +824 -824
  106. package/src/components/Business/JsonQueryTable/components/FieldsSettingsTable.tsx +205 -205
  107. package/src/components/Business/JsonQueryTable/components/Formula.tsx +205 -205
  108. package/src/components/Business/JsonQueryTable/components/MaintainOptions.tsx +127 -127
  109. package/src/components/Business/JsonQueryTable/configButton/index.js +20 -20
  110. package/src/components/Business/JsonQueryTable/configTree/component/compactArrayView.js +25 -25
  111. package/src/components/Business/JsonQueryTable/configTree/component/compactObjectView.js +30 -30
  112. package/src/components/Business/JsonQueryTable/configTree/index.js +82 -82
  113. package/src/components/Business/JsonQueryTable/configTree/index.less +44 -44
  114. package/src/components/Business/JsonQueryTable/configTree/parser/highlight.js +57 -57
  115. package/src/components/Business/JsonQueryTable/configTree/parser/index.js +124 -124
  116. package/src/components/Business/JsonQueryTable/configTree/render/iconRender.js +29 -29
  117. package/src/components/Business/JsonQueryTable/configTree/render/nameRender.js +22 -22
  118. package/src/components/Business/JsonQueryTable/configTree/treeNode.js +116 -116
  119. package/src/components/Business/JsonQueryTable/drawer/index.tsx +12 -12
  120. package/src/components/Business/JsonQueryTable/function.ts +62 -62
  121. package/src/components/Business/JsonQueryTable/index.less +16 -16
  122. package/src/components/Business/JsonQueryTable/index.md +328 -328
  123. package/src/components/Business/JsonQueryTable/index.tsx +535 -535
  124. package/src/components/Business/JsonQueryTable/jsonEditor/index.js +346 -346
  125. package/src/components/Business/JsonQueryTable/jsonEditor/index.less +22 -22
  126. package/src/components/Business/JsonQueryTable/jsonEditor/lint/basicType.js +147 -147
  127. package/src/components/Business/JsonQueryTable/jsonEditor/lint/index.js +389 -389
  128. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/actions.js +118 -118
  129. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/dependency.js +22 -22
  130. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/index.js +21 -21
  131. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/request.js +65 -65
  132. package/src/components/Business/JsonQueryTable/static.ts +390 -390
  133. package/src/components/Business/SearchSelect/BusinessUtils.ts +1762 -1762
  134. package/src/components/Business/SearchSelect/common.ts +75 -75
  135. package/src/components/Business/SearchSelect/index.md +1329 -1329
  136. package/src/components/Business/SearchSelect/index.tsx +55 -55
  137. package/src/components/Business/SearchSelect/utils.ts +100 -100
  138. package/src/components/Business/StateFlow/index.less +130 -130
  139. package/src/components/Business/StateFlow/index.md +60 -60
  140. package/src/components/Business/StateFlow/index.tsx +29 -29
  141. package/src/components/Business/TreeSearchSelect/index.md +156 -156
  142. package/src/components/Business/TreeSearchSelect/index.tsx +33 -33
  143. package/src/components/Business/TreeSearchSelect/utils.ts +75 -75
  144. package/src/components/Business/columnSettingTable/columnSetting.tsx +764 -764
  145. package/src/components/Business/columnSettingTable/index.less +247 -247
  146. package/src/components/Business/columnSettingTable/index.md +357 -357
  147. package/src/components/Business/columnSettingTable/index.tsx +232 -232
  148. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +240 -240
  149. package/src/components/Business/columnSettingTable/utils.tsx +71 -69
  150. package/src/components/Business/moreTreeTable/FixedScrollBar.tsx +87 -87
  151. package/src/components/Business/moreTreeTable/hooks/useSticky.ts +21 -21
  152. package/src/components/Business/moreTreeTable/index.less +99 -99
  153. package/src/components/Business/moreTreeTable/index.md +448 -448
  154. package/src/components/Business/moreTreeTable/index.tsx +387 -387
  155. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  156. package/src/components/Functional/AddSelect/helps.ts +79 -14
  157. package/src/components/Functional/AddSelect/index.less +367 -367
  158. package/src/components/Functional/AddSelect/index.md +155 -155
  159. package/src/components/Functional/AddSelect/index.tsx +1170 -1282
  160. package/src/components/Functional/BillEntry/index.less +371 -371
  161. package/src/components/Functional/BillEntry/index.md +39 -39
  162. package/src/components/Functional/BillEntry/index.tsx +772 -772
  163. package/src/components/Functional/BsAntdSula/BsCascader/index.md +62 -62
  164. package/src/components/Functional/BsAntdSula/BsCascader/index.tsx +178 -178
  165. package/src/components/Functional/BsAntdSula/index.ts +2 -2
  166. package/src/components/Functional/DataImport/index.less +63 -63
  167. package/src/components/Functional/DataImport/index.md +44 -44
  168. package/src/components/Functional/DataImport/index.tsx +695 -695
  169. package/src/components/Functional/DataValidation/index.less +63 -63
  170. package/src/components/Functional/DataValidation/index.md +39 -39
  171. package/src/components/Functional/DataValidation/index.tsx +687 -687
  172. package/src/components/Functional/EllipsisTooltip/index.d.ts +5 -5
  173. package/src/components/Functional/EllipsisTooltip/index.js +36 -36
  174. package/src/components/Functional/EllipsisTooltip/index.md +30 -30
  175. package/src/components/Functional/ExportFunctions/ExportIcon/index.md +37 -37
  176. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +59 -59
  177. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  178. package/src/components/Functional/QueryMutipleInput/index.md +33 -33
  179. package/src/components/Functional/QueryMutipleInput/index.tsx +128 -128
  180. package/src/components/Functional/SearchSelect/index.less +115 -115
  181. package/src/components/Functional/SearchSelect/index.md +141 -141
  182. package/src/components/Functional/SearchSelect/index.tsx +879 -879
  183. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  184. package/src/components/Functional/TreeSearchSelect/index.md +47 -47
  185. package/src/components/Functional/TreeSearchSelect/index.tsx +199 -199
  186. package/src/components/Solution/RuleComponent/Formula.tsx +335 -335
  187. package/src/components/Solution/RuleComponent/index.d.ts +29 -29
  188. package/src/components/Solution/RuleComponent/index.js +2032 -2032
  189. package/src/components/Solution/RuleComponent/index.less +230 -230
  190. package/src/components/Solution/RuleComponent/renderSpecificAction.js +99 -99
  191. package/src/components/Solution/RuleComponent/ruleFiled.js +2107 -2107
  192. package/src/components/Solution/RuleComponent/services.ts +13 -13
  193. package/src/components/Solution/RuleComponent/util.js +139 -139
  194. package/src/index.ts +38 -38
  195. package/src/plugin/TableColumnSetting/index.less +247 -247
  196. package/src/plugin/TableColumnSetting/index.md +50 -50
  197. package/src/plugin/TableColumnSetting/index.tsx +724 -724
  198. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  199. package/src/styles/bsDefault.less +1912 -1912
  200. package/src/utils/CheckOneUser/index.md +39 -39
  201. package/src/utils/CheckOneUser/index.ts +51 -51
  202. package/src/utils/LocalstorageUtils.ts +95 -95
  203. package/src/utils/TableUtils.tsx +18 -18
  204. package/src/utils/checkUtils.ts +39 -39
  205. package/src/utils/enumConfig.ts +11 -11
  206. package/src/utils/getFormMode.js +12 -12
  207. package/src/utils/index.ts +4 -4
  208. package/src/utils/requestUtils.ts +34 -34
  209. package/src/utils/serialize.js +7 -7
  210. package/src/utils/utils.ts +212 -212
  211. package/tsconfig.json +29 -29
  212. package/typings.d.ts +4 -4
@@ -1,20 +1,20 @@
1
- import React from 'react';
2
- import { Affix, Button } from 'antd';
3
- import { SettingOutlined } from '@ant-design/icons';
4
-
5
- export default props => {
6
- const { onClick } = props;
7
-
8
- const style = { position: 'fixed', top: 360, right: 24, zIndex: 1001 };
9
-
10
- return (
11
- <Affix style={style}>
12
- <Button
13
- style={{ width: 50, height: 50, lineHeight: '57px' }}
14
- icon={<SettingOutlined style={{ fontSize: 30 }} />}
15
- type="primary"
16
- onClick={onClick}
17
- />
18
- </Affix>
19
- );
20
- };
1
+ import React from 'react';
2
+ import { Affix, Button } from 'antd';
3
+ import { SettingOutlined } from '@ant-design/icons';
4
+
5
+ export default props => {
6
+ const { onClick } = props;
7
+
8
+ const style = { position: 'fixed', top: 360, right: 24, zIndex: 1001 };
9
+
10
+ return (
11
+ <Affix style={style}>
12
+ <Button
13
+ style={{ width: 50, height: 50, lineHeight: '57px' }}
14
+ icon={<SettingOutlined style={{ fontSize: 30 }} />}
15
+ type="primary"
16
+ onClick={onClick}
17
+ />
18
+ </Affix>
19
+ );
20
+ };
@@ -1,25 +1,25 @@
1
- import React from 'react';
2
-
3
- const prefixCls = 'tree-compact';
4
-
5
- export default class CompactArrayView extends React.Component {
6
- shouldComponentUpdate(nextProps) {
7
- return nextProps.array.length !== this.props.array.length;
8
- }
9
-
10
- render() {
11
- let { array } = this.props;
12
- let count = array.length;
13
-
14
- if (count === 0) {
15
- return <span>{'[ ]'}</span>;
16
- }
17
- return (
18
- <span className={prefixCls}>
19
- <span>{'['}</span>
20
- <span>{count + ' element' + (count > 1 ? 's' : '')}</span>
21
- <span>{']'}</span>
22
- </span>
23
- );
24
- }
25
- }
1
+ import React from 'react';
2
+
3
+ const prefixCls = 'tree-compact';
4
+
5
+ export default class CompactArrayView extends React.Component {
6
+ shouldComponentUpdate(nextProps) {
7
+ return nextProps.array.length !== this.props.array.length;
8
+ }
9
+
10
+ render() {
11
+ let { array } = this.props;
12
+ let count = array.length;
13
+
14
+ if (count === 0) {
15
+ return <span>{'[ ]'}</span>;
16
+ }
17
+ return (
18
+ <span className={prefixCls}>
19
+ <span>{'['}</span>
20
+ <span>{count + ' element' + (count > 1 ? 's' : '')}</span>
21
+ <span>{']'}</span>
22
+ </span>
23
+ );
24
+ }
25
+ }
@@ -1,30 +1,30 @@
1
- import React from 'react';
2
-
3
- const prefixCls = 'tree-compact';
4
-
5
- export default class CompactObjectView extends React.Component {
6
- shouldComponentUpdate(nextProps) {
7
- const nextLength = Object.keys(nextProps.object).length;
8
- const prevLength = Object.keys(this.props.object).length;
9
- return nextLength !== prevLength;
10
- }
11
-
12
- render() {
13
- let keys = this.props.object.map(v => v.name);
14
- let count = keys.length;
15
-
16
- if (count === 0) {
17
- return <span>{'{ }'}</span>;
18
- }
19
- if (count > 2) {
20
- keys = keys.slice(0, 2).concat([`... +${count - 2}`]);
21
- }
22
- return (
23
- <span className={prefixCls}>
24
- <span>{'{'}</span>
25
- <span>{keys.join(', ')}</span>
26
- <span>{'}'}</span>
27
- </span>
28
- );
29
- }
30
- }
1
+ import React from 'react';
2
+
3
+ const prefixCls = 'tree-compact';
4
+
5
+ export default class CompactObjectView extends React.Component {
6
+ shouldComponentUpdate(nextProps) {
7
+ const nextLength = Object.keys(nextProps.object).length;
8
+ const prevLength = Object.keys(this.props.object).length;
9
+ return nextLength !== prevLength;
10
+ }
11
+
12
+ render() {
13
+ let keys = this.props.object.map(v => v.name);
14
+ let count = keys.length;
15
+
16
+ if (count === 0) {
17
+ return <span>{'{ }'}</span>;
18
+ }
19
+ if (count > 2) {
20
+ keys = keys.slice(0, 2).concat([`... +${count - 2}`]);
21
+ }
22
+ return (
23
+ <span className={prefixCls}>
24
+ <span>{'{'}</span>
25
+ <span>{keys.join(', ')}</span>
26
+ <span>{'}'}</span>
27
+ </span>
28
+ );
29
+ }
30
+ }
@@ -1,82 +1,82 @@
1
- import React, { useState, useEffect } from 'react';
2
- import castArray from 'lodash/castArray';
3
- import createTreeData, { getConfigNode } from './parser';
4
- import { createHighLightTreeData, clearActiveNode } from './parser/highlight';
5
- import TreeNode from './treeNode';
6
- import iconRender from './render/iconRender';
7
- import nameRender from './render/nameRender';
8
-
9
- import './index.less';
10
-
11
- export { iconRender, nameRender };
12
-
13
- function parseData(data) {
14
- let res;
15
- try {
16
- res = createTreeData(getConfigNode(data));
17
- } catch (e) {}
18
-
19
- return res;
20
- }
21
-
22
- export default props => {
23
- const {
24
- data,
25
- onToggle,
26
- onSelect,
27
- nameRender,
28
- iconRender,
29
- contextMenuRender,
30
- style,
31
- level = 0,
32
- currentLine,
33
- } = props;
34
- const [treeData, setTreeData] = useState(parseData(data));
35
- const [activeLine, setActiveLine] = useState(-1);
36
-
37
- useEffect(() => {
38
- setTreeData(parseData(data));
39
- }, [data]);
40
-
41
- useEffect(() => {
42
- if (!treeData || !treeData[0]) {
43
- setActiveLine(-1);
44
- } else {
45
- setActiveLine(currentLine);
46
- }
47
- }, [treeData, currentLine]);
48
-
49
- useEffect(() => {
50
- setTimeout(() => {
51
- setTreeData(createHighLightTreeData(treeData, activeLine));
52
- });
53
- }, [activeLine]);
54
-
55
- const handleSelect = (node, hasChildren) => {
56
- const noActiveData = clearActiveNode(treeData);
57
- setTreeData(noActiveData);
58
- onSelect(node, hasChildren);
59
- };
60
-
61
- return (
62
- <div className="si-tree" style={style}>
63
- {castArray(treeData).map((node, index) => {
64
- if (!node) return;
65
-
66
- return (
67
- <TreeNode
68
- data={node}
69
- onToggle={onToggle}
70
- onSelect={handleSelect}
71
- nameRender={nameRender}
72
- iconRender={iconRender}
73
- contextMenuRender={contextMenuRender}
74
- key={node.name || index}
75
- level={level}
76
- activeLine={activeLine}
77
- />
78
- );
79
- })}
80
- </div>
81
- );
82
- };
1
+ import React, { useState, useEffect } from 'react';
2
+ import castArray from 'lodash/castArray';
3
+ import createTreeData, { getConfigNode } from './parser';
4
+ import { createHighLightTreeData, clearActiveNode } from './parser/highlight';
5
+ import TreeNode from './treeNode';
6
+ import iconRender from './render/iconRender';
7
+ import nameRender from './render/nameRender';
8
+
9
+ import './index.less';
10
+
11
+ export { iconRender, nameRender };
12
+
13
+ function parseData(data) {
14
+ let res;
15
+ try {
16
+ res = createTreeData(getConfigNode(data));
17
+ } catch (e) {}
18
+
19
+ return res;
20
+ }
21
+
22
+ export default props => {
23
+ const {
24
+ data,
25
+ onToggle,
26
+ onSelect,
27
+ nameRender,
28
+ iconRender,
29
+ contextMenuRender,
30
+ style,
31
+ level = 0,
32
+ currentLine,
33
+ } = props;
34
+ const [treeData, setTreeData] = useState(parseData(data));
35
+ const [activeLine, setActiveLine] = useState(-1);
36
+
37
+ useEffect(() => {
38
+ setTreeData(parseData(data));
39
+ }, [data]);
40
+
41
+ useEffect(() => {
42
+ if (!treeData || !treeData[0]) {
43
+ setActiveLine(-1);
44
+ } else {
45
+ setActiveLine(currentLine);
46
+ }
47
+ }, [treeData, currentLine]);
48
+
49
+ useEffect(() => {
50
+ setTimeout(() => {
51
+ setTreeData(createHighLightTreeData(treeData, activeLine));
52
+ });
53
+ }, [activeLine]);
54
+
55
+ const handleSelect = (node, hasChildren) => {
56
+ const noActiveData = clearActiveNode(treeData);
57
+ setTreeData(noActiveData);
58
+ onSelect(node, hasChildren);
59
+ };
60
+
61
+ return (
62
+ <div className="si-tree" style={style}>
63
+ {castArray(treeData).map((node, index) => {
64
+ if (!node) return;
65
+
66
+ return (
67
+ <TreeNode
68
+ data={node}
69
+ onToggle={onToggle}
70
+ onSelect={handleSelect}
71
+ nameRender={nameRender}
72
+ iconRender={iconRender}
73
+ contextMenuRender={contextMenuRender}
74
+ key={node.name || index}
75
+ level={level}
76
+ activeLine={activeLine}
77
+ />
78
+ );
79
+ })}
80
+ </div>
81
+ );
82
+ };
@@ -1,44 +1,44 @@
1
- // hover background
2
- @hover-background: #1990ffab;
3
-
4
- .si-tree {
5
- font-size: 14px;
6
-
7
- &-node {
8
- &-block {
9
- display: flex;
10
- align-items: center;
11
- padding: 2px 4px;
12
- cursor: pointer;
13
- user-select: none;
14
- &:hover {
15
- background-color: @hover-background;
16
- color: #fff;
17
- }
18
-
19
- &-actived {
20
- background-color: @hover-background;
21
- color: #fff;
22
- }
23
- }
24
-
25
- &-switcher {
26
- margin-right: 2px;
27
- }
28
-
29
- &-icon {
30
- margin-right: 4px;
31
- display: flex;
32
- }
33
-
34
- &-name {
35
- }
36
- }
37
- }
38
-
39
- .tree-compact {
40
- margin-left: 4px;
41
- font-size: 13px;
42
- font-style: italic;
43
- color: #49aa19;
44
- }
1
+ // hover background
2
+ @hover-background: #1990ffab;
3
+
4
+ .si-tree {
5
+ font-size: 14px;
6
+
7
+ &-node {
8
+ &-block {
9
+ display: flex;
10
+ align-items: center;
11
+ padding: 2px 4px;
12
+ cursor: pointer;
13
+ user-select: none;
14
+ &:hover {
15
+ background-color: @hover-background;
16
+ color: #fff;
17
+ }
18
+
19
+ &-actived {
20
+ background-color: @hover-background;
21
+ color: #fff;
22
+ }
23
+ }
24
+
25
+ &-switcher {
26
+ margin-right: 2px;
27
+ }
28
+
29
+ &-icon {
30
+ margin-right: 4px;
31
+ display: flex;
32
+ }
33
+
34
+ &-name {
35
+ }
36
+ }
37
+ }
38
+
39
+ .tree-compact {
40
+ margin-left: 4px;
41
+ font-size: 13px;
42
+ font-style: italic;
43
+ color: #49aa19;
44
+ }
@@ -1,57 +1,57 @@
1
- const isHightLight = (hightLightData, highLightLine) => {
2
- const { children, loc = [0, 0, 0, 0] } = hightLightData;
3
- const [lineStart, , lineEnd] = loc;
4
- if (children) {
5
- return isActiveObj(highLightLine, lineStart, lineEnd);
6
- }
7
- return lineStart <= highLightLine && lineEnd >= highLightLine;
8
- };
9
-
10
- const hasHighLightChildren = (hightLightData = {}, highLightLine) => {
11
- const { children, loc = [0, 0, 0, 0] } = hightLightData;
12
- const [lineStart, , lineEnd] = loc;
13
- if (children) {
14
- return (
15
- isActiveObj(highLightLine, lineStart, lineEnd) ||
16
- children.some(v => hasHighLightChildren(v, highLightLine))
17
- );
18
- }
19
- return lineStart <= highLightLine && lineEnd >= highLightLine;
20
- };
21
-
22
- function isActiveObj(highLightLine, start, end) {
23
- return highLightLine === start || highLightLine === end;
24
- }
25
-
26
- function createHighLightTreeData(treeData, highLightLine) {
27
- const data = Array.isArray(treeData) ? [...treeData] : [treeData];
28
-
29
- data.forEach(node => {
30
- if (!node) return;
31
- node.toggled = hasHighLightChildren(node, highLightLine);
32
- node.active = isHightLight(node, highLightLine);
33
- if (node.children) {
34
- if (node.active) {
35
- node.children = clearActiveNode(node.children);
36
- } else {
37
- node.children = createHighLightTreeData(node.children, highLightLine);
38
- }
39
- }
40
- });
41
-
42
- return data;
43
- }
44
-
45
- function clearActiveNode(treeData) {
46
- const data = Array.isArray(treeData) ? [...treeData] : [treeData];
47
- data.forEach(node => {
48
- if (!node) return;
49
- node.active = false;
50
- if (node.children) {
51
- node.children = clearActiveNode(node.children);
52
- }
53
- });
54
- return data;
55
- }
56
-
57
- export { createHighLightTreeData, clearActiveNode };
1
+ const isHightLight = (hightLightData, highLightLine) => {
2
+ const { children, loc = [0, 0, 0, 0] } = hightLightData;
3
+ const [lineStart, , lineEnd] = loc;
4
+ if (children) {
5
+ return isActiveObj(highLightLine, lineStart, lineEnd);
6
+ }
7
+ return lineStart <= highLightLine && lineEnd >= highLightLine;
8
+ };
9
+
10
+ const hasHighLightChildren = (hightLightData = {}, highLightLine) => {
11
+ const { children, loc = [0, 0, 0, 0] } = hightLightData;
12
+ const [lineStart, , lineEnd] = loc;
13
+ if (children) {
14
+ return (
15
+ isActiveObj(highLightLine, lineStart, lineEnd) ||
16
+ children.some(v => hasHighLightChildren(v, highLightLine))
17
+ );
18
+ }
19
+ return lineStart <= highLightLine && lineEnd >= highLightLine;
20
+ };
21
+
22
+ function isActiveObj(highLightLine, start, end) {
23
+ return highLightLine === start || highLightLine === end;
24
+ }
25
+
26
+ function createHighLightTreeData(treeData, highLightLine) {
27
+ const data = Array.isArray(treeData) ? [...treeData] : [treeData];
28
+
29
+ data.forEach(node => {
30
+ if (!node) return;
31
+ node.toggled = hasHighLightChildren(node, highLightLine);
32
+ node.active = isHightLight(node, highLightLine);
33
+ if (node.children) {
34
+ if (node.active) {
35
+ node.children = clearActiveNode(node.children);
36
+ } else {
37
+ node.children = createHighLightTreeData(node.children, highLightLine);
38
+ }
39
+ }
40
+ });
41
+
42
+ return data;
43
+ }
44
+
45
+ function clearActiveNode(treeData) {
46
+ const data = Array.isArray(treeData) ? [...treeData] : [treeData];
47
+ data.forEach(node => {
48
+ if (!node) return;
49
+ node.active = false;
50
+ if (node.children) {
51
+ node.children = clearActiveNode(node.children);
52
+ }
53
+ });
54
+ return data;
55
+ }
56
+
57
+ export { createHighLightTreeData, clearActiveNode };