@bit-sun/business-component 2.4.24 → 2.4.26-beta01

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 (159) hide show
  1. package/dist/components/Business/BsLayouts/service.d.ts +1 -1
  2. package/dist/components/Business/BsSulaQueryTable/index.d.ts +0 -1
  3. package/dist/components/Business/BsSulaQueryTable/setting.d.ts +1 -1
  4. package/dist/components/Business/BsSulaQueryTable/utils.d.ts +0 -1
  5. package/dist/components/Business/columnSettingTable/columnSetting.d.ts +0 -1
  6. package/dist/components/Functional/ExportFunctions/ExportIcon/index.d.ts +1 -1
  7. package/dist/components/Functional/QueryMutipleInput/index.d.ts +1 -2
  8. package/dist/components/Solution/RuleComponent/services.d.ts +1 -1
  9. package/dist/index.esm.js +1185 -1739
  10. package/dist/index.js +1179 -1735
  11. package/dist/utils/TableUtils.d.ts +2 -93
  12. package/dist/utils/index.d.ts +4 -6
  13. package/dist/utils/utils.d.ts +0 -13
  14. package/package.json +4 -7
  15. package/src/assets/32.svg +27 -27
  16. package/src/assets/addIcon.svg +17 -17
  17. package/src/assets/allfunc.svg +27 -27
  18. package/src/assets/arrowRight.svg +24 -24
  19. package/src/assets/btn-delete.svg +29 -29
  20. package/src/assets/btn-edit.svg +19 -19
  21. package/src/assets/btn-more.svg +17 -17
  22. package/src/assets/btn-submit.svg +19 -19
  23. package/src/assets/close.svg +26 -26
  24. package/src/assets/drag.svg +17 -17
  25. package/src/assets/fixed-left.svg +15 -15
  26. package/src/assets/fixed-right.svg +15 -15
  27. package/src/assets/guanbi.svg +15 -15
  28. package/src/assets/icon-quanping.svg +15 -15
  29. package/src/assets/icon-shezhi.svg +17 -17
  30. package/src/assets/label_icon_bottom.svg +25 -25
  31. package/src/assets/list-no-img.svg +21 -21
  32. package/src/assets/morentouxiang-32.svg +23 -23
  33. package/src/assets/scanning.svg +24 -24
  34. package/src/assets/upExport.svg +22 -22
  35. package/src/common/ENUM.ts +41 -41
  36. package/src/components/Business/AddSelectBusiness/index.tsx +22 -40
  37. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  38. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  39. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  40. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  41. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  42. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  43. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  44. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  45. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  46. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +157 -163
  47. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  48. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +2 -19
  49. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  50. package/src/components/Business/BsLayouts/index.less +79 -79
  51. package/src/components/Business/BsLayouts/index.tsx +1484 -1494
  52. package/src/components/Business/BsLayouts/service.ts +2 -2
  53. package/src/components/Business/BsLayouts/utils.tsx +203 -203
  54. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +9 -9
  55. package/src/components/Business/BsSulaQueryTable/index.less +221 -221
  56. package/src/components/Business/BsSulaQueryTable/index.tsx +175 -346
  57. package/src/components/Business/BsSulaQueryTable/setting.tsx +87 -125
  58. package/src/components/Business/BsSulaQueryTable/utils.tsx +34 -57
  59. package/src/components/Business/CommodityEntry/index.md +70 -70
  60. package/src/components/Business/CommodityEntry/index.tsx +81 -80
  61. package/src/components/Business/CommonGuideWrapper/index.less +112 -121
  62. package/src/components/Business/CommonGuideWrapper/index.md +39 -39
  63. package/src/components/Business/CommonGuideWrapper/index.tsx +84 -94
  64. package/src/components/Business/DetailPageWrapper/index.less +1 -9
  65. package/src/components/Business/DetailPageWrapper/index.tsx +110 -121
  66. package/src/components/Business/HomePageWrapper/index.md +45 -45
  67. package/src/components/Business/HomePageWrapper/index.tsx +162 -162
  68. package/src/components/Business/JsonQueryTable/configButton/index.js +20 -20
  69. package/src/components/Business/JsonQueryTable/configTree/component/compactArrayView.js +25 -25
  70. package/src/components/Business/JsonQueryTable/configTree/component/compactObjectView.js +30 -30
  71. package/src/components/Business/JsonQueryTable/configTree/index.js +82 -82
  72. package/src/components/Business/JsonQueryTable/configTree/index.less +44 -44
  73. package/src/components/Business/JsonQueryTable/configTree/parser/highlight.js +57 -57
  74. package/src/components/Business/JsonQueryTable/configTree/parser/index.js +124 -124
  75. package/src/components/Business/JsonQueryTable/configTree/render/iconRender.js +29 -29
  76. package/src/components/Business/JsonQueryTable/configTree/render/nameRender.js +22 -22
  77. package/src/components/Business/JsonQueryTable/configTree/treeNode.js +116 -116
  78. package/src/components/Business/JsonQueryTable/drawer/index.tsx +12 -12
  79. package/src/components/Business/JsonQueryTable/index.less +16 -16
  80. package/src/components/Business/JsonQueryTable/index.md +328 -328
  81. package/src/components/Business/JsonQueryTable/index.tsx +537 -535
  82. package/src/components/Business/JsonQueryTable/jsonEditor/index.js +346 -346
  83. package/src/components/Business/JsonQueryTable/jsonEditor/index.less +22 -22
  84. package/src/components/Business/JsonQueryTable/jsonEditor/lint/basicType.js +147 -147
  85. package/src/components/Business/JsonQueryTable/jsonEditor/lint/index.js +389 -389
  86. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/actions.js +118 -118
  87. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/dependency.js +22 -22
  88. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/index.js +21 -21
  89. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/request.js +65 -65
  90. package/src/components/Business/SearchSelect/utils.ts +3 -3
  91. package/src/components/Business/StateFlow/index.md +60 -60
  92. package/src/components/Business/StateFlow/index.tsx +29 -29
  93. package/src/components/Business/columnSettingTable/columnSetting.tsx +8 -10
  94. package/src/components/Business/columnSettingTable/index.less +247 -247
  95. package/src/components/Business/columnSettingTable/index.md +357 -357
  96. package/src/components/Business/columnSettingTable/utils.tsx +71 -71
  97. package/src/components/Business/moreTreeTable/FixedScrollBar.tsx +87 -87
  98. package/src/components/Business/moreTreeTable/hooks/useSticky.ts +21 -21
  99. package/src/components/Business/moreTreeTable/index.less +99 -99
  100. package/src/components/Business/moreTreeTable/index.tsx +387 -387
  101. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  102. package/src/components/Functional/AddSelect/helps.ts +3 -4
  103. package/src/components/Functional/AddSelect/index.less +367 -367
  104. package/src/components/Functional/AddSelect/index.tsx +33 -79
  105. package/src/components/Functional/BillEntry/index.less +371 -371
  106. package/src/components/Functional/BillEntry/index.tsx +3 -3
  107. package/src/components/Functional/BsAntdSula/index.ts +2 -2
  108. package/src/components/Functional/DataImport/index.less +63 -63
  109. package/src/components/Functional/DataImport/index.tsx +3 -3
  110. package/src/components/Functional/DataValidation/index.less +63 -63
  111. package/src/components/Functional/DataValidation/index.tsx +3 -3
  112. package/src/components/Functional/EllipsisTooltip/index.d.ts +5 -5
  113. package/src/components/Functional/EllipsisTooltip/index.js +36 -36
  114. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +5 -10
  115. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  116. package/src/components/Functional/QueryMutipleInput/index.tsx +1 -2
  117. package/src/components/Functional/SearchSelect/index.less +0 -6
  118. package/src/components/Functional/SearchSelect/index.tsx +45 -152
  119. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  120. package/src/components/Functional/TreeSearchSelect/index.tsx +22 -24
  121. package/src/components/Solution/RuleComponent/Formula.tsx +335 -335
  122. package/src/components/Solution/RuleComponent/index.d.ts +29 -29
  123. package/src/components/Solution/RuleComponent/index.js +652 -7
  124. package/src/components/Solution/RuleComponent/index.less +230 -230
  125. package/src/components/Solution/RuleComponent/renderSpecificAction.js +99 -99
  126. package/src/components/Solution/RuleComponent/services.ts +13 -13
  127. package/src/plugin/TableColumnSetting/index.less +247 -247
  128. package/src/plugin/TableColumnSetting/index.md +50 -50
  129. package/src/plugin/TableColumnSetting/index.tsx +2 -2
  130. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  131. package/src/utils/CheckOneUser/index.md +39 -39
  132. package/src/utils/CheckOneUser/index.ts +51 -51
  133. package/src/utils/LocalstorageUtils.ts +95 -95
  134. package/src/utils/TableUtils.tsx +18 -691
  135. package/src/utils/checkUtils.ts +39 -39
  136. package/src/utils/enumConfig.ts +11 -11
  137. package/src/utils/getFormMode.js +12 -12
  138. package/src/utils/index.ts +4 -6
  139. package/src/utils/requestUtils.ts +2 -29
  140. package/src/utils/serialize.js +7 -7
  141. package/src/utils/utils.ts +21 -64
  142. package/dist/components/Business/BsLayouts/Components/ChooseStore/index.d.ts +0 -3
  143. package/dist/components/Business/BsLayouts/Components/ChooseStore/services.d.ts +0 -1
  144. package/dist/components/Business/BsLayouts/Components/RightContent/i18n.d.ts +0 -9
  145. package/dist/components/Solution/RuleComponent/RenderCompItem.d.ts +0 -2
  146. package/dist/utils/businessUtils.d.ts +0 -27
  147. package/dist/utils/constant.d.ts +0 -37
  148. package/dist/utils/request.d.ts +0 -2
  149. package/src/assets/arrow_top.svg +0 -18
  150. package/src/components/Business/BsLayouts/Components/ChooseStore/index.less +0 -0
  151. package/src/components/Business/BsLayouts/Components/ChooseStore/index.tsx +0 -193
  152. package/src/components/Business/BsLayouts/Components/ChooseStore/services.ts +0 -10
  153. package/src/components/Business/BsLayouts/Components/RightContent/i18n.ts +0 -9
  154. package/src/components/Business/BsSulaQueryTable/bssulaquerytable.less +0 -5
  155. package/src/components/Solution/RuleComponent/RenderCompItem.tsx +0 -637
  156. package/src/utils/TableUtils.less +0 -52
  157. package/src/utils/businessUtils.ts +0 -441
  158. package/src/utils/constant.ts +0 -39
  159. package/src/utils/request.ts +0 -53
@@ -1,162 +1,162 @@
1
- // @ts-nocheck
2
- import React, { useEffect, useState, useMemo } from 'react';
3
- import { getMainCrumbNameMap } from '../DetailPageWrapper/utils';
4
- import { memoizeOneFormatter } from '@/utils/utils';
5
- import { Breadcrumb, Space } from 'antd';
6
- import './index.less';
7
- import { useLocation, formatMessage } from 'umi';
8
- import CommonAlert from '../CommonAlert';
9
- import ENUM from '@/utils/enumConfig';
10
-
11
- export default (props: any) => {
12
- const { pathname } = useLocation();
13
- const [id]: any = useState(pathname + 'id');
14
- const { children, ...restProps} = props;
15
-
16
- return (
17
- <div id={id} className={'home_page_wrapper'}>
18
- <HeaderWrapper
19
- pathname={pathname}
20
- {
21
- ...restProps
22
- }
23
- />
24
- {props.children}
25
- </div>
26
- );
27
- };
28
-
29
- const HeaderWrapper = React.memo(
30
- ({
31
- pathname,
32
- routes=[],
33
- itemPath,
34
- alertProps,
35
- extra,
36
- title,
37
- pathToRegexp, //改为从项目代码透传该方法
38
- }: { pathname: string, routes: any[], itemPath: string, alertProps: any }) => {
39
- const [breadcrumbArr, setBreadCrumbArr]: any = useState([]);
40
- const basePath = window.top == window ? '' : `/${itemPath}`;
41
- const menuRoutes =
42
- window.top == window
43
- ? routes.find((item) => item.path === '/')?.routes || []
44
- : JSON.parse(localStorage.getItem(ENUM.BROWSER_CACHE.LIMIT_MENU_DATA) || '[]');
45
-
46
- const breadcrumbNameMap = getMainCrumbNameMap(
47
- memoizeOneFormatter(menuRoutes, ''),
48
- );
49
-
50
- const matchParamsPath = (pathname: string, breadcrumbNameMap: object) => {
51
- const pathKey: any = Object.keys(breadcrumbNameMap).find((key) =>
52
- pathToRegexp ? pathToRegexp(key).test(pathname) : false
53
- );
54
-
55
- return pathKey ? breadcrumbNameMap[pathKey] : undefined;
56
- };
57
-
58
- const getPageTitle = (pathname: string) => {
59
- const currRouterData = matchParamsPath(
60
- `${basePath}${pathname}`,
61
- breadcrumbNameMap,
62
- );
63
-
64
- if (!currRouterData) {
65
- return '';
66
- }
67
-
68
- let breadcrumbArrs = currRouterData.nameMap || [];
69
- if (breadcrumbArrs.length && title) {
70
- breadcrumbArrs.pop();
71
- breadcrumbArrs.push(title)
72
- }
73
- setBreadCrumbArr([...breadcrumbArrs])
74
-
75
- const pageName = formatMessage({
76
- id: currRouterData.locale || currRouterData.name,
77
- defaultMessage: currRouterData.name,
78
- });
79
- return title ? title : window.top === window ? pageName : `${currRouterData.name}`;
80
- };
81
-
82
- const pageTitle = useMemo(() => getPageTitle(pathname), [pathname, title]);
83
-
84
- useEffect(() => {}, [pathname]);
85
-
86
- // const breadcrumbArr = `${basePath}${pathname}`
87
- // .split('/')
88
- // .slice(1)
89
- // .map((_item, index, arr) =>
90
- // matchParamsPath(
91
- // `/${arr.slice(0, index + 1).join('/')}`,
92
- // breadcrumbNameMap,
93
- // ),
94
- // )
95
- // .filter((item) => item);
96
-
97
-
98
- return (
99
- <div>
100
- <div className={'home_page_head'}>
101
- <div>
102
- <div className={'home_page_title'}>{pageTitle}</div>
103
- <Breadcrumb>
104
- {breadcrumbArr.map((item) => (
105
- <Breadcrumb.Item
106
- key={item}
107
- onClick={() => {
108
- // if (
109
- // item.path &&
110
- // !item.children &&
111
- // !pathToRegexp(item.path).test(`${basePath}${pathname}`)
112
- // ) {
113
- // history.push({
114
- // pathname: item.path.replace(basePath, ''),
115
- // });
116
- // }
117
- }}
118
- >
119
- <span
120
- style={{
121
- // color: pathToRegexp(item.path).test(
122
- // `${basePath}${pathname}`,
123
- // )
124
- // ? '#000000d9'
125
- // : '',
126
- }}
127
- className="bread_name"
128
- >
129
- {item}
130
- </span>
131
- </Breadcrumb.Item>
132
- ))}
133
- </Breadcrumb>
134
- </div>
135
- {
136
- extra ?
137
- <Space>
138
- {
139
- extra
140
- }
141
- </Space> : ''
142
- }
143
- </div>
144
- {
145
- alertProps && (
146
- <CommonAlert
147
- {
148
- ...alertProps
149
- }
150
- />
151
- )
152
- }
153
- </div>
154
- );
155
- },
156
- (prevProps, nextProps) => {
157
- if (prevProps.title !== nextProps.title) {
158
- return false;
159
- }
160
- return true;
161
- },
162
- );
1
+ // @ts-nocheck
2
+ import React, { useEffect, useState, useMemo } from 'react';
3
+ import { getMainCrumbNameMap } from '../DetailPageWrapper/utils';
4
+ import { memoizeOneFormatter } from '@/utils/utils';
5
+ import { Breadcrumb, Space } from 'antd';
6
+ import './index.less';
7
+ import { useLocation, formatMessage } from 'umi';
8
+ import CommonAlert from '../CommonAlert';
9
+ import ENUM from '@/utils/enumConfig';
10
+
11
+ export default (props: any) => {
12
+ const { pathname } = useLocation();
13
+ const [id]: any = useState(pathname + 'id');
14
+ const { children, ...restProps} = props;
15
+
16
+ return (
17
+ <div id={id} className={'home_page_wrapper'}>
18
+ <HeaderWrapper
19
+ pathname={pathname}
20
+ {
21
+ ...restProps
22
+ }
23
+ />
24
+ {props.children}
25
+ </div>
26
+ );
27
+ };
28
+
29
+ const HeaderWrapper = React.memo(
30
+ ({
31
+ pathname,
32
+ routes=[],
33
+ itemPath,
34
+ alertProps,
35
+ extra,
36
+ title,
37
+ pathToRegexp, //改为从项目代码透传该方法
38
+ }: { pathname: string, routes: any[], itemPath: string, alertProps: any }) => {
39
+ const [breadcrumbArr, setBreadCrumbArr]: any = useState([]);
40
+ const basePath = window.top == window ? '' : `/${itemPath}`;
41
+ const menuRoutes =
42
+ window.top == window
43
+ ? routes.find((item) => item.path === '/')?.routes || []
44
+ : JSON.parse(localStorage.getItem(ENUM.BROWSER_CACHE.LIMIT_MENU_DATA) || '[]');
45
+
46
+ const breadcrumbNameMap = getMainCrumbNameMap(
47
+ memoizeOneFormatter(menuRoutes, ''),
48
+ );
49
+
50
+ const matchParamsPath = (pathname: string, breadcrumbNameMap: object) => {
51
+ const pathKey: any = Object.keys(breadcrumbNameMap).find((key) =>
52
+ pathToRegexp ? pathToRegexp(key).test(pathname) : false
53
+ );
54
+
55
+ return pathKey ? breadcrumbNameMap[pathKey] : undefined;
56
+ };
57
+
58
+ const getPageTitle = (pathname: string) => {
59
+ const currRouterData = matchParamsPath(
60
+ `${basePath}${pathname}`,
61
+ breadcrumbNameMap,
62
+ );
63
+
64
+ if (!currRouterData) {
65
+ return '';
66
+ }
67
+
68
+ let breadcrumbArrs = currRouterData.nameMap || [];
69
+ if (breadcrumbArrs.length && title) {
70
+ breadcrumbArrs.pop();
71
+ breadcrumbArrs.push(title)
72
+ }
73
+ setBreadCrumbArr([...breadcrumbArrs])
74
+
75
+ const pageName = formatMessage({
76
+ id: currRouterData.locale || currRouterData.name,
77
+ defaultMessage: currRouterData.name,
78
+ });
79
+ return title ? title : window.top === window ? pageName : `${currRouterData.name}`;
80
+ };
81
+
82
+ const pageTitle = useMemo(() => getPageTitle(pathname), [pathname, title]);
83
+
84
+ useEffect(() => {}, [pathname]);
85
+
86
+ // const breadcrumbArr = `${basePath}${pathname}`
87
+ // .split('/')
88
+ // .slice(1)
89
+ // .map((_item, index, arr) =>
90
+ // matchParamsPath(
91
+ // `/${arr.slice(0, index + 1).join('/')}`,
92
+ // breadcrumbNameMap,
93
+ // ),
94
+ // )
95
+ // .filter((item) => item);
96
+
97
+
98
+ return (
99
+ <div>
100
+ <div className={'home_page_head'}>
101
+ <div>
102
+ <div className={'home_page_title'}>{pageTitle}</div>
103
+ <Breadcrumb>
104
+ {breadcrumbArr.map((item) => (
105
+ <Breadcrumb.Item
106
+ key={item}
107
+ onClick={() => {
108
+ // if (
109
+ // item.path &&
110
+ // !item.children &&
111
+ // !pathToRegexp(item.path).test(`${basePath}${pathname}`)
112
+ // ) {
113
+ // history.push({
114
+ // pathname: item.path.replace(basePath, ''),
115
+ // });
116
+ // }
117
+ }}
118
+ >
119
+ <span
120
+ style={{
121
+ // color: pathToRegexp(item.path).test(
122
+ // `${basePath}${pathname}`,
123
+ // )
124
+ // ? '#000000d9'
125
+ // : '',
126
+ }}
127
+ className="bread_name"
128
+ >
129
+ {item}
130
+ </span>
131
+ </Breadcrumb.Item>
132
+ ))}
133
+ </Breadcrumb>
134
+ </div>
135
+ {
136
+ extra ?
137
+ <Space>
138
+ {
139
+ extra
140
+ }
141
+ </Space> : ''
142
+ }
143
+ </div>
144
+ {
145
+ alertProps && (
146
+ <CommonAlert
147
+ {
148
+ ...alertProps
149
+ }
150
+ />
151
+ )
152
+ }
153
+ </div>
154
+ );
155
+ },
156
+ (prevProps, nextProps) => {
157
+ if (prevProps.title !== nextProps.title) {
158
+ return false;
159
+ }
160
+ return true;
161
+ },
162
+ );
@@ -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
+ };