@bit-sun/business-component 2.4.13 → 2.4.15-beta

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 (274) 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/index.js +336 -265
  9. package/docs/index.md +21 -21
  10. package/lib/assets/drag.svg +17 -17
  11. package/lib/assets/exportFail.svg +37 -37
  12. package/lib/assets/exportProcessing.svg +28 -28
  13. package/lib/assets/exportSuccess.svg +34 -34
  14. package/lib/assets/label_icon_bottom.svg +25 -25
  15. package/lib/assets/upExport.svg +22 -22
  16. package/package.json +79 -79
  17. package/src/assets/32.svg +27 -27
  18. package/src/assets/addIcon.svg +17 -17
  19. package/src/assets/allfunc.svg +27 -27
  20. package/src/assets/arrowRight.svg +24 -24
  21. package/src/assets/btn-delete.svg +29 -29
  22. package/src/assets/btn-edit.svg +19 -19
  23. package/src/assets/btn-more.svg +17 -17
  24. package/src/assets/btn-submit.svg +19 -19
  25. package/src/assets/caidan.svg +11 -11
  26. package/src/assets/close.svg +26 -26
  27. package/src/assets/drag.svg +17 -17
  28. package/src/assets/exportFail.svg +37 -37
  29. package/src/assets/exportProcessing.svg +28 -28
  30. package/src/assets/exportSuccess.svg +34 -34
  31. package/src/assets/fixed-left-active.svg +11 -11
  32. package/src/assets/fixed-left.svg +15 -15
  33. package/src/assets/fixed-right-active.svg +11 -11
  34. package/src/assets/fixed-right.svg +15 -15
  35. package/src/assets/guanbi.svg +15 -15
  36. package/src/assets/icon-quanping.svg +15 -15
  37. package/src/assets/icon-shezhi.svg +17 -17
  38. package/src/assets/label_icon_bottom.svg +25 -25
  39. package/src/assets/list-no-img.svg +21 -21
  40. package/src/assets/morentouxiang-32.svg +23 -23
  41. package/src/assets/scanning.svg +24 -24
  42. package/src/assets/upExport.svg +22 -22
  43. package/src/common/ENUM.ts +41 -41
  44. package/src/components/Business/AddSelectBusiness/index.md +162 -162
  45. package/src/components/Business/AddSelectBusiness/index.tsx +1061 -1061
  46. package/src/components/Business/BsLayouts/Components/AllFunc/drawContent.tsx +111 -111
  47. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  48. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  49. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  50. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  51. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  52. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  53. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.tsx +285 -285
  54. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  55. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/drawContent.less +170 -170
  56. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  57. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  58. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +72 -72
  59. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +157 -157
  60. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  61. package/src/components/Business/BsLayouts/Components/RightContent/home.less +218 -218
  62. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +155 -155
  63. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +160 -160
  64. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  65. package/src/components/Business/BsLayouts/index.less +79 -79
  66. package/src/components/Business/BsLayouts/index.tsx +1484 -1484
  67. package/src/components/Business/BsLayouts/service.ts +10 -10
  68. package/src/components/Business/BsLayouts/utils.tsx +203 -203
  69. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +566 -566
  70. package/src/components/Business/BsSulaQueryTable/index.less +221 -221
  71. package/src/components/Business/BsSulaQueryTable/index.tsx +538 -538
  72. package/src/components/Business/BsSulaQueryTable/setting.tsx +854 -854
  73. package/src/components/Business/BsSulaQueryTable/utils.less +65 -65
  74. package/src/components/Business/BsSulaQueryTable/utils.tsx +690 -690
  75. package/src/components/Business/CommodityEntry/index.md +70 -70
  76. package/src/components/Business/CommodityEntry/index.tsx +80 -80
  77. package/src/components/Business/CommonAlert/index.tsx +23 -23
  78. package/src/components/Business/CommonGuideWrapper/index.less +111 -111
  79. package/src/components/Business/CommonGuideWrapper/index.md +39 -39
  80. package/src/components/Business/CommonGuideWrapper/index.tsx +83 -83
  81. package/src/components/Business/DetailPageWrapper/index.less +79 -79
  82. package/src/components/Business/DetailPageWrapper/index.tsx +315 -315
  83. package/src/components/Business/DetailPageWrapper/utils.tsx +100 -100
  84. package/src/components/Business/HomePageWrapper/index.less +33 -33
  85. package/src/components/Business/HomePageWrapper/index.md +45 -45
  86. package/src/components/Business/HomePageWrapper/index.tsx +162 -162
  87. package/src/components/Business/JsonQueryTable/components/FieldsModifyModal.tsx +824 -824
  88. package/src/components/Business/JsonQueryTable/components/FieldsSettingsTable.tsx +205 -205
  89. package/src/components/Business/JsonQueryTable/components/Formula.tsx +206 -206
  90. package/src/components/Business/JsonQueryTable/components/MaintainOptions.tsx +127 -127
  91. package/src/components/Business/JsonQueryTable/configButton/index.js +20 -20
  92. package/src/components/Business/JsonQueryTable/configTree/component/compactArrayView.js +25 -25
  93. package/src/components/Business/JsonQueryTable/configTree/component/compactObjectView.js +30 -30
  94. package/src/components/Business/JsonQueryTable/configTree/index.js +82 -82
  95. package/src/components/Business/JsonQueryTable/configTree/index.less +44 -44
  96. package/src/components/Business/JsonQueryTable/configTree/parser/highlight.js +57 -57
  97. package/src/components/Business/JsonQueryTable/configTree/parser/index.js +124 -124
  98. package/src/components/Business/JsonQueryTable/configTree/render/iconRender.js +29 -29
  99. package/src/components/Business/JsonQueryTable/configTree/render/nameRender.js +22 -22
  100. package/src/components/Business/JsonQueryTable/configTree/treeNode.js +116 -116
  101. package/src/components/Business/JsonQueryTable/drawer/index.tsx +12 -12
  102. package/src/components/Business/JsonQueryTable/function.ts +62 -62
  103. package/src/components/Business/JsonQueryTable/index.less +16 -16
  104. package/src/components/Business/JsonQueryTable/index.md +328 -328
  105. package/src/components/Business/JsonQueryTable/index.tsx +537 -537
  106. package/src/components/Business/JsonQueryTable/jsonEditor/index.js +346 -346
  107. package/src/components/Business/JsonQueryTable/jsonEditor/index.less +22 -22
  108. package/src/components/Business/JsonQueryTable/jsonEditor/lint/basicType.js +147 -147
  109. package/src/components/Business/JsonQueryTable/jsonEditor/lint/index.js +389 -389
  110. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/actions.js +118 -118
  111. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/dependency.js +22 -22
  112. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/index.js +21 -21
  113. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/request.js +65 -65
  114. package/src/components/Business/JsonQueryTable/static.ts +450 -450
  115. package/src/components/Business/SearchSelect/BusinessUtils.ts +1903 -1836
  116. package/src/components/Business/SearchSelect/common.ts +75 -75
  117. package/src/components/Business/SearchSelect/index.md +1387 -1387
  118. package/src/components/Business/SearchSelect/index.tsx +55 -55
  119. package/src/components/Business/SearchSelect/utils.ts +101 -101
  120. package/src/components/Business/StateFlow/index.less +130 -130
  121. package/src/components/Business/StateFlow/index.md +60 -60
  122. package/src/components/Business/StateFlow/index.tsx +29 -29
  123. package/src/components/Business/TreeSearchSelect/index.md +185 -185
  124. package/src/components/Business/TreeSearchSelect/index.tsx +33 -33
  125. package/src/components/Business/TreeSearchSelect/utils.ts +104 -104
  126. package/src/components/Business/columnSettingTable/columnSetting.tsx +766 -766
  127. package/src/components/Business/columnSettingTable/index.less +247 -247
  128. package/src/components/Business/columnSettingTable/index.md +357 -357
  129. package/src/components/Business/columnSettingTable/index.tsx +234 -234
  130. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +242 -242
  131. package/src/components/Business/columnSettingTable/utils.tsx +71 -71
  132. package/src/components/Business/moreTreeTable/FixedScrollBar.tsx +87 -87
  133. package/src/components/Business/moreTreeTable/hooks/useSticky.ts +21 -21
  134. package/src/components/Business/moreTreeTable/index.less +99 -99
  135. package/src/components/Business/moreTreeTable/index.md +448 -448
  136. package/src/components/Business/moreTreeTable/index.tsx +387 -387
  137. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  138. package/src/components/Functional/AddSelect/helps.ts +80 -80
  139. package/src/components/Functional/AddSelect/index.less +367 -367
  140. package/src/components/Functional/AddSelect/index.md +155 -155
  141. package/src/components/Functional/AddSelect/index.tsx +1171 -1171
  142. package/src/components/Functional/BillEntry/index.less +371 -371
  143. package/src/components/Functional/BillEntry/index.md +39 -39
  144. package/src/components/Functional/BillEntry/index.tsx +773 -773
  145. package/src/components/Functional/BsAntdSula/BsCascader/index.md +62 -62
  146. package/src/components/Functional/BsAntdSula/BsCascader/index.tsx +178 -178
  147. package/src/components/Functional/BsAntdSula/index.ts +2 -2
  148. package/src/components/Functional/DataImport/index.less +63 -63
  149. package/src/components/Functional/DataImport/index.md +44 -44
  150. package/src/components/Functional/DataImport/index.tsx +696 -696
  151. package/src/components/Functional/DataValidation/index.less +63 -63
  152. package/src/components/Functional/DataValidation/index.md +39 -39
  153. package/src/components/Functional/DataValidation/index.tsx +688 -688
  154. package/src/components/Functional/EllipsisTooltip/index.d.ts +5 -5
  155. package/src/components/Functional/EllipsisTooltip/index.js +36 -36
  156. package/src/components/Functional/EllipsisTooltip/index.md +30 -30
  157. package/src/components/Functional/ExportFunctions/ExportIcon/index.md +37 -37
  158. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +60 -60
  159. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  160. package/src/components/Functional/QueryMutipleInput/index.md +33 -33
  161. package/src/components/Functional/QueryMutipleInput/index.tsx +128 -128
  162. package/src/components/Functional/SearchSelect/index.less +115 -115
  163. package/src/components/Functional/SearchSelect/index.md +141 -141
  164. package/src/components/Functional/SearchSelect/index.tsx +896 -896
  165. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  166. package/src/components/Functional/TreeSearchSelect/index.md +47 -47
  167. package/src/components/Functional/TreeSearchSelect/index.tsx +204 -201
  168. package/src/components/Solution/RuleComponent/Formula.tsx +335 -335
  169. package/src/components/Solution/RuleComponent/InnerSelect.tsx +62 -62
  170. package/src/components/Solution/RuleComponent/index.d.ts +29 -29
  171. package/src/components/Solution/RuleComponent/index.js +2073 -2073
  172. package/src/components/Solution/RuleComponent/index.less +230 -230
  173. package/src/components/Solution/RuleComponent/renderSpecificAction.js +99 -99
  174. package/src/components/Solution/RuleComponent/ruleFiled.js +2281 -2281
  175. package/src/components/Solution/RuleComponent/services.ts +13 -13
  176. package/src/components/Solution/RuleComponent/util.js +143 -143
  177. package/src/index.ts +38 -38
  178. package/src/plugin/TableColumnSetting/index.less +247 -247
  179. package/src/plugin/TableColumnSetting/index.md +50 -50
  180. package/src/plugin/TableColumnSetting/index.tsx +725 -725
  181. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  182. package/src/styles/bsDefault.less +1912 -1912
  183. package/src/utils/CheckOneUser/index.md +39 -39
  184. package/src/utils/CheckOneUser/index.ts +51 -51
  185. package/src/utils/CustomLoginInfo.ts +55 -55
  186. package/src/utils/LocalstorageUtils.ts +95 -95
  187. package/src/utils/TableUtils.tsx +18 -18
  188. package/src/utils/checkUtils.ts +39 -39
  189. package/src/utils/enumConfig.ts +11 -11
  190. package/src/utils/getFormMode.js +12 -12
  191. package/src/utils/index.ts +4 -4
  192. package/src/utils/requestUtils.ts +166 -166
  193. package/src/utils/serialize.js +7 -7
  194. package/src/utils/utils.ts +195 -195
  195. package/tsconfig.json +29 -29
  196. package/typings.d.ts +4 -4
  197. package/dist/common/ENUM.d.ts +0 -40
  198. package/dist/components/Business/AddSelectBusiness/index.d.ts +0 -4
  199. package/dist/components/Business/BsLayouts/Components/AllFunc/drawContent.d.ts +0 -5
  200. package/dist/components/Business/BsLayouts/Components/AllFunc/index.d.ts +0 -4
  201. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.d.ts +0 -4
  202. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.d.ts +0 -17
  203. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.d.ts +0 -30
  204. package/dist/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.d.ts +0 -4
  205. package/dist/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.d.ts +0 -3
  206. package/dist/components/Business/BsLayouts/Components/CustomerMenu/index.d.ts +0 -4
  207. package/dist/components/Business/BsLayouts/Components/GlobalHeader/index.d.ts +0 -5
  208. package/dist/components/Business/BsLayouts/Components/RightContent/LoginModal.d.ts +0 -3
  209. package/dist/components/Business/BsLayouts/Components/RightContent/index.d.ts +0 -8
  210. package/dist/components/Business/BsLayouts/Components/SearchFunc/index.d.ts +0 -8
  211. package/dist/components/Business/BsLayouts/index.d.ts +0 -18
  212. package/dist/components/Business/BsLayouts/service.d.ts +0 -1
  213. package/dist/components/Business/BsLayouts/utils.d.ts +0 -10
  214. package/dist/components/Business/BsSulaQueryTable/SearchItemSetting.d.ts +0 -60
  215. package/dist/components/Business/BsSulaQueryTable/index.d.ts +0 -3
  216. package/dist/components/Business/BsSulaQueryTable/setting.d.ts +0 -60
  217. package/dist/components/Business/BsSulaQueryTable/utils.d.ts +0 -99
  218. package/dist/components/Business/CommodityEntry/index.d.ts +0 -3
  219. package/dist/components/Business/CommonAlert/index.d.ts +0 -4
  220. package/dist/components/Business/CommonGuideWrapper/index.d.ts +0 -6
  221. package/dist/components/Business/DetailPageWrapper/index.d.ts +0 -10
  222. package/dist/components/Business/DetailPageWrapper/utils.d.ts +0 -8
  223. package/dist/components/Business/HomePageWrapper/index.d.ts +0 -4
  224. package/dist/components/Business/JsonQueryTable/components/FieldsModifyModal.d.ts +0 -3
  225. package/dist/components/Business/JsonQueryTable/components/FieldsSettingsTable.d.ts +0 -3
  226. package/dist/components/Business/JsonQueryTable/components/Formula.d.ts +0 -7
  227. package/dist/components/Business/JsonQueryTable/components/MaintainOptions.d.ts +0 -3
  228. package/dist/components/Business/JsonQueryTable/drawer/index.d.ts +0 -3
  229. package/dist/components/Business/JsonQueryTable/function.d.ts +0 -37
  230. package/dist/components/Business/JsonQueryTable/index.d.ts +0 -4
  231. package/dist/components/Business/JsonQueryTable/static.d.ts +0 -44
  232. package/dist/components/Business/SearchSelect/BusinessUtils.d.ts +0 -5
  233. package/dist/components/Business/SearchSelect/common.d.ts +0 -25
  234. package/dist/components/Business/SearchSelect/index.d.ts +0 -3
  235. package/dist/components/Business/SearchSelect/utils.d.ts +0 -5
  236. package/dist/components/Business/StateFlow/index.d.ts +0 -4
  237. package/dist/components/Business/TreeSearchSelect/index.d.ts +0 -3
  238. package/dist/components/Business/TreeSearchSelect/utils.d.ts +0 -4
  239. package/dist/components/Business/columnSettingTable/columnSetting.d.ts +0 -54
  240. package/dist/components/Business/columnSettingTable/index.d.ts +0 -16
  241. package/dist/components/Business/columnSettingTable/sulaSettingTable.d.ts +0 -17
  242. package/dist/components/Business/columnSettingTable/utils.d.ts +0 -9
  243. package/dist/components/Business/moreTreeTable/FixedScrollBar.d.ts +0 -3
  244. package/dist/components/Business/moreTreeTable/hooks/useSticky.d.ts +0 -8
  245. package/dist/components/Business/moreTreeTable/index.d.ts +0 -4
  246. package/dist/components/Business/moreTreeTable/utils.d.ts +0 -9
  247. package/dist/components/Functional/AddSelect/helps.d.ts +0 -14
  248. package/dist/components/Functional/AddSelect/index.d.ts +0 -4
  249. package/dist/components/Functional/BillEntry/index.d.ts +0 -4
  250. package/dist/components/Functional/BsAntdSula/BsCascader/index.d.ts +0 -18
  251. package/dist/components/Functional/BsAntdSula/index.d.ts +0 -1
  252. package/dist/components/Functional/DataImport/index.d.ts +0 -144
  253. package/dist/components/Functional/DataValidation/index.d.ts +0 -144
  254. package/dist/components/Functional/ExportFunctions/ExportIcon/index.d.ts +0 -13
  255. package/dist/components/Functional/QueryMutipleInput/index.d.ts +0 -6
  256. package/dist/components/Functional/SearchSelect/index.d.ts +0 -4
  257. package/dist/components/Functional/SearchSelect/utils.d.ts +0 -1
  258. package/dist/components/Functional/TreeSearchSelect/index.d.ts +0 -3
  259. package/dist/components/Solution/RuleComponent/Formula.d.ts +0 -9
  260. package/dist/components/Solution/RuleComponent/InnerSelect.d.ts +0 -12
  261. package/dist/components/Solution/RuleComponent/services.d.ts +0 -1
  262. package/dist/index.d.ts +0 -28
  263. package/dist/index.esm.js +0 -31379
  264. package/dist/plugin/TableColumnSetting/index.d.ts +0 -64
  265. package/dist/plugin/TableColumnSetting/utils.d.ts +0 -1
  266. package/dist/utils/CheckOneUser/index.d.ts +0 -2
  267. package/dist/utils/CustomLoginInfo.d.ts +0 -11
  268. package/dist/utils/LocalstorageUtils.d.ts +0 -17
  269. package/dist/utils/TableUtils.d.ts +0 -11
  270. package/dist/utils/checkUtils.d.ts +0 -3
  271. package/dist/utils/enumConfig.d.ts +0 -12
  272. package/dist/utils/index.d.ts +0 -4
  273. package/dist/utils/requestUtils.d.ts +0 -29
  274. package/dist/utils/utils.d.ts +0 -17
@@ -1,3 +1,3 @@
1
- export const handleSourceName = (sName: any) => {
2
- return sName
3
- }
1
+ export const handleSourceName = (sName: any) => {
2
+ return sName
3
+ }
@@ -1,47 +1,47 @@
1
- ---
2
- nav:
3
- title: '组件'
4
- order: 1
5
- group:
6
- title: 功能组件
7
- order: 0
8
- title: 树型选择器
9
- order: 4
10
- ---
11
-
12
- ## TreeSearchSelect
13
-
14
- 部门选择器Demo:
15
-
16
- ```tsx
17
- import React, { useState } from 'react';
18
- import { TreeSearchSelect } from '../../../index';
19
-
20
- export default () => {
21
-
22
- const [value, setValue] = useState();
23
-
24
- const props = {
25
- mode: 'create',
26
- remoteSource: {
27
- url: `/user/orgViewNode/common/getTreeForOrgViewAndTenant`,
28
- initialParams: { 'orgViewCode': 'administrative-organization-view' },
29
- resKeyValue: ['code', 'name'],
30
- },
31
- value,
32
- isChoose: false, // 控制是否父节点可选中,默认不可选中
33
- treeCheckable: true,
34
- onChange: (v) => {
35
- setValue(v)
36
- }
37
- };
38
-
39
- return (
40
- <div>
41
- <TreeSearchSelect {...props} />
42
- </div>
43
- );
44
- };
45
- ```
46
-
47
- More skills for writing demo: https://d.umijs.org/guide/demo-principle
1
+ ---
2
+ nav:
3
+ title: '组件'
4
+ order: 1
5
+ group:
6
+ title: 功能组件
7
+ order: 0
8
+ title: 树型选择器
9
+ order: 4
10
+ ---
11
+
12
+ ## TreeSearchSelect
13
+
14
+ 部门选择器Demo:
15
+
16
+ ```tsx
17
+ import React, { useState } from 'react';
18
+ import { TreeSearchSelect } from '../../../index';
19
+
20
+ export default () => {
21
+
22
+ const [value, setValue] = useState();
23
+
24
+ const props = {
25
+ mode: 'create',
26
+ remoteSource: {
27
+ url: `/user/orgViewNode/common/getTreeForOrgViewAndTenant`,
28
+ initialParams: { 'orgViewCode': 'administrative-organization-view' },
29
+ resKeyValue: ['code', 'name'],
30
+ },
31
+ value,
32
+ isChoose: false, // 控制是否父节点可选中,默认不可选中
33
+ treeCheckable: true,
34
+ onChange: (v) => {
35
+ setValue(v)
36
+ }
37
+ };
38
+
39
+ return (
40
+ <div>
41
+ <TreeSearchSelect {...props} />
42
+ </div>
43
+ );
44
+ };
45
+ ```
46
+
47
+ More skills for writing demo: https://d.umijs.org/guide/demo-principle
@@ -1,201 +1,204 @@
1
- import React, { useState, useEffect } from 'react';
2
- import { TreeSelect, Tooltip, Tag } from 'antd';
3
- import axios from 'axios';
4
- import { stringify } from 'querystring';
5
- import _ from "lodash"
6
- import { judgeIsRequestSuccess } from '@/utils/requestUtils';
7
-
8
- const TreeSearchSelect = (props: any) => {
9
- const [treeData, setTreeData] = useState([]);
10
- const {
11
- ctx, // ctx中有自己的name
12
- value,
13
- valueName, // 当labelInValue为true时,值为null
14
- onChange,
15
- onChangeName, // 当labelInValue为true时,此函数无意义,故无需传
16
- placeholder,
17
- remoteSource,
18
- initialValue,
19
- treeCheckable = false,
20
- showSearch = true,
21
- maxTagCount = 1,
22
- multiple = false,
23
- isChoose = false, // 默认父节点不可选;传true则不限制
24
- rootDisabled = false, // 默认根节点可选
25
- mode,
26
- getPopupContainer,
27
- labelInValue = false,
28
- showArrow = true,
29
- allowClear = true,
30
- showCheckedStrategy = props?.treeCheckStrictly ? TreeSelect.SHOW_ALL : TreeSelect.SHOW_PARENT,
31
- style = { width: '100%' },
32
- getTreeData,
33
- disabled,
34
- ...restProps
35
- } = props;
36
-
37
- const {
38
- url,
39
- headers,
40
- paramsKey = 'qp-name-like',
41
- resKeyValue = ['id', 'name'],
42
- initialParams = {},
43
- treeChildrenRoom = 'children',// 树状结构的子集容器 默认为 'children'
44
- } = remoteSource;
45
-
46
- const mapSearchTree = (treeDataItem: any) => {
47
- const haveChildren = Array.isArray(treeDataItem[treeChildrenRoom]) && treeDataItem[treeChildrenRoom].length > 0; // 盘算是否为父节点
48
- const isRoot = treeDataItem?.id == '0'; // 判断是否为根节点
49
- return {
50
- title: treeDataItem[resKeyValue[1]],
51
- key: treeDataItem[resKeyValue[0]],
52
- value: treeDataItem[resKeyValue[0]],
53
- parentId: treeDataItem.parent,
54
- data: { ...treeDataItem },
55
- isLeaf: !haveChildren,
56
- disabled: isDisabled(haveChildren,isRoot),
57
- children: haveChildren ? treeDataItem[treeChildrenRoom].map((i: any) => mapSearchTree(i)) : [],
58
- };
59
- };
60
-
61
- const isDisabled = (isParent: boolean,isRoot: boolean) => {
62
- if (isChoose) {
63
- if(rootDisabled && isRoot){
64
- return rootDisabled
65
- }
66
- return false;
67
- }
68
- return isParent;
69
- }
70
-
71
- /* 实时查询 但是目前用的直接是完整数据源, 所以没有使用 */
72
- const handleSearch = (q: string) => {
73
- const paramsData = {
74
- [`${paramsKey}`]: q,
75
- ...initialParams,
76
- }
77
- axios.get(`${url}?${stringify(paramsData)}`, {headers}).then(async (res: any) => {
78
- const resData = res?.data || [];
79
- let coverData;
80
-
81
- if(judgeIsRequestSuccess(resData)) {
82
- const { data } = resData;
83
- if (remoteSource.converter) {
84
- coverData = await remoteSource.converter({ data: [data] })
85
- } else {
86
- const dataList = (data && Array.isArray(data)) ? data : (data && [data] || []);
87
- coverData = dataList.length && dataList.map((ites: any) => mapSearchTree(ites)) || [];
88
- }
89
- } else {
90
- coverData = []
91
- }
92
-
93
- setTreeData(coverData);
94
- ctx?.form?.setFieldSource(ctx.name, coverData);
95
- });
96
- };
97
-
98
- const formatData = (value: any) => {
99
- if (labelInValue) {
100
- const formatResult = multiple||treeCheckable ? value.map((i: any) => ({...i, key: i.value})) : { ...value, key: value?.value };
101
- return formatResult
102
- } else {
103
- const formatResult = multiple||treeCheckable ? value.map((i: any) => (i?.value || i)) : (_.get(value?.[0], 'value') || value)
104
- return formatResult
105
- }
106
- }
107
- const parallelData = (data: any,result: any) => {
108
- data.forEach((i: any) => {
109
- result.push(i);
110
- if (i[treeChildrenRoom]) {
111
- parallelData(i[treeChildrenRoom], result);
112
- }
113
- });
114
- return result;
115
- }
116
- const getSelectItem = (tData: any,selectValue: any) => {
117
- const handleList = tData||[];
118
- let result = [];
119
- if(labelInValue) {
120
- result = multiple||treeCheckable ? (selectValue?.map((i: any) => {
121
- if(handleList.some((s: any) => s.key == i.value)){
122
- return handleList.find((s: any) => s.key == i.value)
123
- }
124
- }) || []) : (handleList?.find((s: any) => s.key == selectValue?.value)||{})
125
- } else {
126
- const cValue = _.get(selectValue?.[0], 'value', selectValue);
127
- result = multiple||treeCheckable ? (selectValue?.map((i: any) => {
128
- if(handleList.some((s: any) => s.key == i)){
129
- return handleList.find((s: any) => s.key == i)
130
- }
131
- }) || []) : (handleList?.find((s: any) => s.key == cValue)||{})
132
- }
133
- return result;
134
- }
135
- const handleChange = (data: any, dataName: any) => {
136
- const handleData = formatData(data);
137
- // 获取选中树节点当条数据,并返回给调用业务
138
- const parallelTreeData = parallelData(treeData,[])
139
- const currentItem = getSelectItem(parallelTreeData,data)
140
- onChange(handleData,data,currentItem,parallelTreeData);
141
- onChangeName && onChangeName(dataName);
142
- getTreeData && getTreeData(treeData); // 把树节点暴露出去
143
- ctx?.form?.setFieldValue(ctx.name, handleData);
144
- };
145
-
146
- useEffect(() => {
147
- handleSearch(initialValue);
148
- }, []);
149
-
150
- const maxTagPlaceholder = (selectedValues: any) => {
151
- const onClose = (e: any,item: any) => {
152
- e.preventDefault();
153
- const newValue = labelInValue ? JSON.parse(JSON.stringify(value)).filter((i: any) => i.value !== item.value): JSON.parse(JSON.stringify(value)).filter((i: any) => i !== item.value)
154
- const newValueName = labelInValue ? null: JSON.parse(JSON.stringify(valueName)).filter((i: any) => i !== item.label)
155
- handleChange(newValue, newValueName);
156
- }
157
- return (
158
- <Tooltip title={selectedValues.map((i: any) => (
159
- <Tag
160
- closable={true}
161
- onClose={(e) => onClose(e,i)}
162
- style={{ marginRight: 3, background: '#f5f5f5', height: '24px', border: '1px solid #f0f0f0' }}
163
- >
164
- {i.label}
165
- </Tag>
166
- ))}>
167
- {`+ ${selectedValues?.length}`}
168
- </Tooltip>
169
- )
170
- }
171
-
172
- return (
173
- <div className={'tree_search_select'}>
174
- <TreeSelect
175
- {...restProps}
176
- treeCheckable={treeCheckable}
177
- maxTagCount={maxTagCount}
178
- showSearch={showSearch}
179
- style={style}
180
- value={value}
181
- dropdownStyle={{ maxHeight: 400, maxWidth: 100, overflow: 'auto' }}
182
- treeData={treeData}
183
- placeholder={placeholder}
184
- allowClear={allowClear}
185
- labelInValue={labelInValue}
186
- showArrow={showArrow}
187
- showCheckedStrategy={showCheckedStrategy}
188
- treeNodeFilterProp={'title'}
189
- treeDefaultExpandAll
190
- multiple={multiple} // 支持多选(当设置 treeCheckable 时自动变为 true)
191
- maxTagPlaceholder={maxTagPlaceholder}
192
- onChange={handleChange}
193
- disabled={disabled || mode==='view' || ctx?.mode === 'view'}
194
- getPopupContainer={(triggerNode) => (getPopupContainer && getPopupContainer(triggerNode)) || document.body}
195
- >
196
- </TreeSelect>
197
- </div>
198
- );
199
- };
200
-
201
- export default TreeSearchSelect;
1
+ import React, { useState, useEffect } from 'react';
2
+ import { TreeSelect, Tooltip, Tag } from 'antd';
3
+ import axios from 'axios';
4
+ import { stringify } from 'querystring';
5
+ import _ from "lodash"
6
+ import { judgeIsRequestSuccess } from '@/utils/requestUtils';
7
+
8
+ const TreeSearchSelect = (props: any) => {
9
+ const [treeData, setTreeData] = useState([]);
10
+ const {
11
+ ctx, // ctx中有自己的name
12
+ value,
13
+ valueName, // 当labelInValue为true时,值为null
14
+ onChange,
15
+ onChangeName, // 当labelInValue为true时,此函数无意义,故无需传
16
+ placeholder,
17
+ remoteSource,
18
+ initialValue,
19
+ treeCheckable = false,
20
+ showSearch = true,
21
+ maxTagCount = 1,
22
+ multiple = false,
23
+ isChoose = false, // 默认父节点不可选;传true则不限制
24
+ rootDisabled = false, // 默认根节点可选
25
+ mode,
26
+ getPopupContainer,
27
+ labelInValue = false,
28
+ showArrow = true,
29
+ allowClear = true,
30
+ showCheckedStrategy = props?.treeCheckStrictly ? TreeSelect.SHOW_ALL : TreeSelect.SHOW_PARENT,
31
+ style = { width: '100%' },
32
+ getTreeData,
33
+ disabled,
34
+ ...restProps
35
+ } = props;
36
+
37
+ const {
38
+ url,
39
+ headers,
40
+ paramsKey = 'qp-name-like',
41
+ resKeyValue = ['id', 'name'],
42
+ initialParams = {},
43
+ treeChildrenRoom = 'children',// 树状结构的子集容器 默认为 'children'
44
+ specialBracket = false
45
+ } = remoteSource;
46
+
47
+ const mapSearchTree = (treeDataItem: any) => {
48
+ const haveChildren = Array.isArray(treeDataItem[treeChildrenRoom]) && treeDataItem[treeChildrenRoom].length > 0; // 盘算是否为父节点
49
+ const isRoot = treeDataItem?.id == '0'; // 判断是否为根节点
50
+ return {
51
+ title: specialBracket
52
+ ? `【${treeDataItem[resKeyValue[0]]}】${treeDataItem[resKeyValue[1]]}`
53
+ : treeDataItem[resKeyValue[1]],
54
+ key: treeDataItem[resKeyValue[0]],
55
+ value: treeDataItem[resKeyValue[0]],
56
+ parentId: treeDataItem.parent,
57
+ data: { ...treeDataItem },
58
+ isLeaf: !haveChildren,
59
+ disabled: isDisabled(haveChildren, isRoot),
60
+ children: haveChildren ? treeDataItem[treeChildrenRoom].map((i: any) => mapSearchTree(i)) : [],
61
+ };
62
+ };
63
+
64
+ const isDisabled = (isParent: boolean, isRoot: boolean) => {
65
+ if (isChoose) {
66
+ if (rootDisabled && isRoot) {
67
+ return rootDisabled
68
+ }
69
+ return false;
70
+ }
71
+ return isParent;
72
+ }
73
+
74
+ /* 实时查询 但是目前用的直接是完整数据源, 所以没有使用 */
75
+ const handleSearch = (q: string) => {
76
+ const paramsData = {
77
+ [`${paramsKey}`]: q,
78
+ ...initialParams,
79
+ }
80
+ axios.get(`${url}?${stringify(paramsData)}`, { headers }).then(async (res: any) => {
81
+ const resData = res?.data || [];
82
+ let coverData;
83
+
84
+ if (judgeIsRequestSuccess(resData)) {
85
+ const { data } = resData;
86
+ if (remoteSource.converter) {
87
+ coverData = await remoteSource.converter({ data: [data] })
88
+ } else {
89
+ const dataList = (data && Array.isArray(data)) ? data : (data && [data] || []);
90
+ coverData = dataList.length && dataList.map((ites: any) => mapSearchTree(ites)) || [];
91
+ }
92
+ } else {
93
+ coverData = []
94
+ }
95
+
96
+ setTreeData(coverData);
97
+ ctx?.form?.setFieldSource(ctx.name, coverData);
98
+ });
99
+ };
100
+
101
+ const formatData = (value: any) => {
102
+ if (labelInValue) {
103
+ const formatResult = multiple || treeCheckable ? value.map((i: any) => ({ ...i, key: i.value })) : { ...value, key: value?.value };
104
+ return formatResult
105
+ } else {
106
+ const formatResult = multiple || treeCheckable ? value.map((i: any) => (i?.value || i)) : (_.get(value?.[0], 'value') || value)
107
+ return formatResult
108
+ }
109
+ }
110
+ const parallelData = (data: any, result: any) => {
111
+ data.forEach((i: any) => {
112
+ result.push(i);
113
+ if (i[treeChildrenRoom]) {
114
+ parallelData(i[treeChildrenRoom], result);
115
+ }
116
+ });
117
+ return result;
118
+ }
119
+ const getSelectItem = (tData: any, selectValue: any) => {
120
+ const handleList = tData || [];
121
+ let result = [];
122
+ if (labelInValue) {
123
+ result = multiple || treeCheckable ? (selectValue?.map((i: any) => {
124
+ if (handleList.some((s: any) => s.key == i.value)) {
125
+ return handleList.find((s: any) => s.key == i.value)
126
+ }
127
+ }) || []) : (handleList?.find((s: any) => s.key == selectValue?.value) || {})
128
+ } else {
129
+ const cValue = _.get(selectValue?.[0], 'value', selectValue);
130
+ result = multiple || treeCheckable ? (selectValue?.map((i: any) => {
131
+ if (handleList.some((s: any) => s.key == i)) {
132
+ return handleList.find((s: any) => s.key == i)
133
+ }
134
+ }) || []) : (handleList?.find((s: any) => s.key == cValue) || {})
135
+ }
136
+ return result;
137
+ }
138
+ const handleChange = (data: any, dataName: any) => {
139
+ const handleData = formatData(data);
140
+ // 获取选中树节点当条数据,并返回给调用业务
141
+ const parallelTreeData = parallelData(treeData, [])
142
+ const currentItem = getSelectItem(parallelTreeData, data)
143
+ onChange(handleData, data, currentItem, parallelTreeData);
144
+ onChangeName && onChangeName(dataName);
145
+ getTreeData && getTreeData(treeData); // 把树节点暴露出去
146
+ ctx?.form?.setFieldValue(ctx.name, handleData);
147
+ };
148
+
149
+ useEffect(() => {
150
+ handleSearch(initialValue);
151
+ }, []);
152
+
153
+ const maxTagPlaceholder = (selectedValues: any) => {
154
+ const onClose = (e: any, item: any) => {
155
+ e.preventDefault();
156
+ const newValue = labelInValue ? JSON.parse(JSON.stringify(value)).filter((i: any) => i.value !== item.value) : JSON.parse(JSON.stringify(value)).filter((i: any) => i !== item.value)
157
+ const newValueName = labelInValue ? null : JSON.parse(JSON.stringify(valueName)).filter((i: any) => i !== item.label)
158
+ handleChange(newValue, newValueName);
159
+ }
160
+ return (
161
+ <Tooltip title={selectedValues.map((i: any) => (
162
+ <Tag
163
+ closable={true}
164
+ onClose={(e) => onClose(e, i)}
165
+ style={{ marginRight: 3, background: '#f5f5f5', height: '24px', border: '1px solid #f0f0f0' }}
166
+ >
167
+ {i.label}
168
+ </Tag>
169
+ ))}>
170
+ {`+ ${selectedValues?.length}`}
171
+ </Tooltip>
172
+ )
173
+ }
174
+
175
+ return (
176
+ <div className={'tree_search_select'}>
177
+ <TreeSelect
178
+ {...restProps}
179
+ treeCheckable={treeCheckable}
180
+ maxTagCount={maxTagCount}
181
+ showSearch={showSearch}
182
+ style={style}
183
+ value={value}
184
+ dropdownStyle={{ maxHeight: 400, maxWidth: 100, overflow: 'auto' }}
185
+ treeData={treeData}
186
+ placeholder={placeholder}
187
+ allowClear={allowClear}
188
+ labelInValue={labelInValue}
189
+ showArrow={showArrow}
190
+ showCheckedStrategy={showCheckedStrategy}
191
+ treeNodeFilterProp={'title'}
192
+ treeDefaultExpandAll
193
+ multiple={multiple} // 支持多选(当设置 treeCheckable 时自动变为 true)
194
+ maxTagPlaceholder={maxTagPlaceholder}
195
+ onChange={handleChange}
196
+ disabled={disabled || mode === 'view' || ctx?.mode === 'view'}
197
+ getPopupContainer={(triggerNode) => (getPopupContainer && getPopupContainer(triggerNode)) || document.body}
198
+ >
199
+ </TreeSelect>
200
+ </div>
201
+ );
202
+ };
203
+
204
+ export default TreeSearchSelect;