@bit-sun/business-component 3.1.4 → 3.1.6

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 (225) 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/.yarnclean +45 -0
  8. package/README.md +27 -27
  9. package/dist/components/Business/DetailPageWrapper/utils.d.ts +3 -1
  10. package/dist/components/Functional/DataImport/index.d.ts +2 -0
  11. package/dist/components/Functional/DataValidation/index.d.ts +2 -0
  12. package/dist/index.esm.js +403 -43
  13. package/dist/index.js +405 -41
  14. package/dist/utils/LocalstorageUtils.d.ts +1 -0
  15. package/dist/utils/enumConfig.d.ts +1 -0
  16. package/dist/utils/index.d.ts +2 -0
  17. package/dist/utils/xlsxUtil.d.ts +6 -0
  18. package/docs/index.md +21 -21
  19. package/lib/assets/drag.svg +17 -17
  20. package/lib/assets/exportFail.svg +37 -37
  21. package/lib/assets/exportProcessing.svg +28 -28
  22. package/lib/assets/exportSuccess.svg +34 -34
  23. package/lib/assets/label_icon_bottom.svg +25 -25
  24. package/lib/assets/upExport.svg +22 -22
  25. package/package.json +88 -87
  26. package/src/assets/32.svg +27 -27
  27. package/src/assets/addIcon.svg +17 -17
  28. package/src/assets/allfunc.svg +27 -27
  29. package/src/assets/arrowRight.svg +24 -24
  30. package/src/assets/arrow_top.svg +17 -17
  31. package/src/assets/btn-delete.svg +29 -29
  32. package/src/assets/btn-edit.svg +19 -19
  33. package/src/assets/btn-more.svg +17 -17
  34. package/src/assets/btn-submit.svg +19 -19
  35. package/src/assets/caidan.svg +11 -11
  36. package/src/assets/close.svg +26 -26
  37. package/src/assets/drag.svg +17 -17
  38. package/src/assets/exportFail.svg +37 -37
  39. package/src/assets/exportProcessing.svg +28 -28
  40. package/src/assets/exportSuccess.svg +34 -34
  41. package/src/assets/fixed-left-active.svg +11 -11
  42. package/src/assets/fixed-left.svg +15 -15
  43. package/src/assets/fixed-right-active.svg +11 -11
  44. package/src/assets/fixed-right.svg +15 -15
  45. package/src/assets/guanbi.svg +15 -15
  46. package/src/assets/icon-quanping.svg +15 -15
  47. package/src/assets/icon-shezhi.svg +17 -17
  48. package/src/assets/label_icon_bottom.svg +25 -25
  49. package/src/assets/list-no-img.svg +21 -21
  50. package/src/assets/morentouxiang-32.svg +23 -23
  51. package/src/assets/scanning.svg +24 -24
  52. package/src/assets/upExport.svg +22 -22
  53. package/src/common/ENUM.ts +41 -41
  54. package/src/components/Business/AddSelectBusiness/index.md +398 -398
  55. package/src/components/Business/AddSelectBusiness/index.tsx +1116 -1116
  56. package/src/components/Business/BsLayouts/Components/AllFunc/drawContent.tsx +112 -112
  57. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  58. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  59. package/src/components/Business/BsLayouts/Components/ChooseStore/index.tsx +193 -193
  60. package/src/components/Business/BsLayouts/Components/ChooseStore/services.ts +10 -10
  61. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  62. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  63. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  64. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  65. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.tsx +285 -285
  66. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  67. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/drawContent.less +170 -170
  68. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  69. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  70. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +72 -72
  71. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +163 -163
  72. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  73. package/src/components/Business/BsLayouts/Components/RightContent/home.less +218 -218
  74. package/src/components/Business/BsLayouts/Components/RightContent/i18n.ts +8 -8
  75. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +172 -172
  76. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +160 -160
  77. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  78. package/src/components/Business/BsLayouts/index.less +79 -79
  79. package/src/components/Business/BsLayouts/index.tsx +1606 -1606
  80. package/src/components/Business/BsLayouts/service.ts +10 -10
  81. package/src/components/Business/BsLayouts/utils.tsx +205 -205
  82. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +566 -566
  83. package/src/components/Business/BsSulaQueryTable/bssulaquerytable.less +5 -5
  84. package/src/components/Business/BsSulaQueryTable/index.less +227 -227
  85. package/src/components/Business/BsSulaQueryTable/index.tsx +772 -772
  86. package/src/components/Business/BsSulaQueryTable/setting.tsx +888 -888
  87. package/src/components/Business/BsSulaQueryTable/utils.less +65 -65
  88. package/src/components/Business/BsSulaQueryTable/utils.tsx +709 -709
  89. package/src/components/Business/CommodityEntry/index.md +84 -84
  90. package/src/components/Business/CommodityEntry/index.tsx +82 -82
  91. package/src/components/Business/CommonAlert/index.tsx +23 -23
  92. package/src/components/Business/CommonGuideWrapper/index.less +121 -121
  93. package/src/components/Business/CommonGuideWrapper/index.md +39 -39
  94. package/src/components/Business/CommonGuideWrapper/index.tsx +94 -94
  95. package/src/components/Business/DetailPageWrapper/index.less +87 -87
  96. package/src/components/Business/DetailPageWrapper/index.tsx +327 -326
  97. package/src/components/Business/DetailPageWrapper/utils.tsx +166 -164
  98. package/src/components/Business/HomePageWrapper/index.less +33 -33
  99. package/src/components/Business/HomePageWrapper/index.md +45 -45
  100. package/src/components/Business/HomePageWrapper/index.tsx +162 -162
  101. package/src/components/Business/JsonQueryTable/components/FieldsModifyModal.tsx +823 -823
  102. package/src/components/Business/JsonQueryTable/components/FieldsSettingsTable.tsx +205 -205
  103. package/src/components/Business/JsonQueryTable/components/Formula.tsx +205 -205
  104. package/src/components/Business/JsonQueryTable/components/MaintainOptions.tsx +127 -127
  105. package/src/components/Business/JsonQueryTable/configButton/index.js +20 -20
  106. package/src/components/Business/JsonQueryTable/configTree/component/compactArrayView.js +25 -25
  107. package/src/components/Business/JsonQueryTable/configTree/component/compactObjectView.js +30 -30
  108. package/src/components/Business/JsonQueryTable/configTree/index.js +82 -82
  109. package/src/components/Business/JsonQueryTable/configTree/index.less +44 -44
  110. package/src/components/Business/JsonQueryTable/configTree/parser/highlight.js +57 -57
  111. package/src/components/Business/JsonQueryTable/configTree/parser/index.js +124 -124
  112. package/src/components/Business/JsonQueryTable/configTree/render/iconRender.js +29 -29
  113. package/src/components/Business/JsonQueryTable/configTree/render/nameRender.js +22 -22
  114. package/src/components/Business/JsonQueryTable/configTree/treeNode.js +116 -116
  115. package/src/components/Business/JsonQueryTable/drawer/index.tsx +12 -12
  116. package/src/components/Business/JsonQueryTable/function.ts +62 -62
  117. package/src/components/Business/JsonQueryTable/index.less +16 -16
  118. package/src/components/Business/JsonQueryTable/index.md +328 -328
  119. package/src/components/Business/JsonQueryTable/index.tsx +534 -534
  120. package/src/components/Business/JsonQueryTable/jsonEditor/index.js +346 -346
  121. package/src/components/Business/JsonQueryTable/jsonEditor/index.less +22 -22
  122. package/src/components/Business/JsonQueryTable/jsonEditor/lint/basicType.js +147 -147
  123. package/src/components/Business/JsonQueryTable/jsonEditor/lint/index.js +389 -389
  124. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/actions.js +118 -118
  125. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/dependency.js +22 -22
  126. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/index.js +21 -21
  127. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/request.js +65 -65
  128. package/src/components/Business/JsonQueryTable/static.ts +450 -450
  129. package/src/components/Business/SearchSelect/BusinessUtils.tsx +2162 -2160
  130. package/src/components/Business/SearchSelect/common.ts +134 -134
  131. package/src/components/Business/SearchSelect/index.md +1512 -1512
  132. package/src/components/Business/SearchSelect/index.tsx +55 -55
  133. package/src/components/Business/SearchSelect/utils.ts +125 -125
  134. package/src/components/Business/StateFlow/index.less +130 -130
  135. package/src/components/Business/StateFlow/index.md +60 -60
  136. package/src/components/Business/StateFlow/index.tsx +29 -29
  137. package/src/components/Business/TreeSearchSelect/index.md +211 -211
  138. package/src/components/Business/TreeSearchSelect/index.tsx +33 -33
  139. package/src/components/Business/TreeSearchSelect/utils.ts +104 -104
  140. package/src/components/Business/columnSettingTable/columnSetting.tsx +816 -816
  141. package/src/components/Business/columnSettingTable/index.less +253 -253
  142. package/src/components/Business/columnSettingTable/index.md +357 -357
  143. package/src/components/Business/columnSettingTable/index.tsx +226 -226
  144. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +233 -233
  145. package/src/components/Business/columnSettingTable/utils.tsx +87 -87
  146. package/src/components/Business/moreTreeTable/FixedScrollBar.tsx +87 -87
  147. package/src/components/Business/moreTreeTable/hooks/useSticky.ts +21 -21
  148. package/src/components/Business/moreTreeTable/index.less +99 -99
  149. package/src/components/Business/moreTreeTable/index.md +448 -448
  150. package/src/components/Business/moreTreeTable/index.tsx +387 -387
  151. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  152. package/src/components/Functional/AccessWrapper/index.tsx +33 -33
  153. package/src/components/Functional/AddSelect/helps.ts +81 -81
  154. package/src/components/Functional/AddSelect/index.less +367 -367
  155. package/src/components/Functional/AddSelect/index.md +155 -155
  156. package/src/components/Functional/AddSelect/index.tsx +1065 -1065
  157. package/src/components/Functional/AuthButton/index.tsx +15 -15
  158. package/src/components/Functional/BillEntry/index.less +371 -371
  159. package/src/components/Functional/BillEntry/index.md +39 -39
  160. package/src/components/Functional/BillEntry/index.tsx +772 -772
  161. package/src/components/Functional/BsAntdSula/BsCascader/index.md +62 -62
  162. package/src/components/Functional/BsAntdSula/BsCascader/index.tsx +178 -178
  163. package/src/components/Functional/BsAntdSula/index.ts +2 -2
  164. package/src/components/Functional/DataImport/index.less +63 -63
  165. package/src/components/Functional/DataImport/index.md +44 -44
  166. package/src/components/Functional/DataImport/index.tsx +783 -706
  167. package/src/components/Functional/DataValidation/index.less +63 -63
  168. package/src/components/Functional/DataValidation/index.md +52 -52
  169. package/src/components/Functional/DataValidation/index.tsx +788 -708
  170. package/src/components/Functional/EllipsisTooltip/index.d.ts +5 -5
  171. package/src/components/Functional/EllipsisTooltip/index.js +36 -36
  172. package/src/components/Functional/EllipsisTooltip/index.md +30 -30
  173. package/src/components/Functional/ExportFunctions/ExportIcon/index.md +37 -37
  174. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +65 -65
  175. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  176. package/src/components/Functional/QueryMutipleInput/index.md +33 -33
  177. package/src/components/Functional/QueryMutipleInput/index.tsx +129 -129
  178. package/src/components/Functional/SearchSelect/index.less +121 -121
  179. package/src/components/Functional/SearchSelect/index.md +141 -141
  180. package/src/components/Functional/SearchSelect/index.tsx +1034 -1034
  181. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  182. package/src/components/Functional/TreeSearchSelect/index.md +47 -47
  183. package/src/components/Functional/TreeSearchSelect/index.tsx +224 -224
  184. package/src/components/Solution/RuleComponent/Formula.tsx +335 -335
  185. package/src/components/Solution/RuleComponent/InnerSelect.tsx +62 -62
  186. package/src/components/Solution/RuleComponent/RenderCompItem.tsx +670 -670
  187. package/src/components/Solution/RuleComponent/index.d.ts +29 -29
  188. package/src/components/Solution/RuleComponent/index.js +1601 -1601
  189. package/src/components/Solution/RuleComponent/index.less +247 -247
  190. package/src/components/Solution/RuleComponent/renderSpecificAction.js +99 -99
  191. package/src/components/Solution/RuleComponent/ruleFiled.js +2293 -2293
  192. package/src/components/Solution/RuleComponent/services.ts +13 -13
  193. package/src/components/Solution/RuleComponent/util.js +143 -143
  194. package/src/components/Solution/RuleSetter/RuleInstance.tsx +6 -6
  195. package/src/components/Solution/RuleSetter/baseRule.tsx +394 -394
  196. package/src/components/Solution/RuleSetter/function.ts +437 -437
  197. package/src/components/Solution/RuleSetter/index.less +221 -221
  198. package/src/components/Solution/RuleSetter/index.tsx +208 -208
  199. package/src/components/Solution/RuleSetter/service.js +276 -276
  200. package/src/index.ts +41 -41
  201. package/src/plugin/TableColumnSetting/index.less +247 -247
  202. package/src/plugin/TableColumnSetting/index.md +50 -50
  203. package/src/plugin/TableColumnSetting/index.tsx +725 -725
  204. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  205. package/src/styles/bsDefault.less +1933 -1933
  206. package/src/utils/CheckOneUser/index.md +39 -39
  207. package/src/utils/CheckOneUser/index.ts +51 -51
  208. package/src/utils/CustomLoginInfo.ts +55 -55
  209. package/src/utils/LocalstorageUtils.ts +134 -128
  210. package/src/utils/TableUtils.less +51 -51
  211. package/src/utils/TableUtils.tsx +691 -691
  212. package/src/utils/auth.ts +38 -38
  213. package/src/utils/businessUtils.ts +434 -434
  214. package/src/utils/checkUtils.ts +39 -39
  215. package/src/utils/constant.ts +38 -38
  216. package/src/utils/enumConfig.ts +17 -16
  217. package/src/utils/getFormMode.js +12 -12
  218. package/src/utils/index.ts +19 -16
  219. package/src/utils/request.ts +53 -53
  220. package/src/utils/requestUtils.ts +193 -193
  221. package/src/utils/serialize.js +7 -7
  222. package/src/utils/utils.ts +238 -238
  223. package/src/utils/xlsxUtil.tsx +146 -0
  224. package/tsconfig.json +29 -29
  225. 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 };