vue2-client 1.18.3 → 1.18.5

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 (244) hide show
  1. package/.claude/settings.local.json +20 -20
  2. package/.cursorrules +19 -19
  3. package/.env.apply +19 -19
  4. package/.env.gaslink +19 -19
  5. package/.env.his +19 -19
  6. package/.env.liuli +20 -20
  7. package/.env.scada +19 -19
  8. package/.serena/memories/code_style_conventions.md +217 -217
  9. package/.serena/memories/project_overview.md +54 -54
  10. package/.serena/memories/project_structure.md +329 -329
  11. package/.serena/memories/suggested_commands.md +127 -127
  12. package/.serena/memories/task_completion_checklist.md +183 -183
  13. package/.serena/memories/tech_stack.md +94 -94
  14. package/CHANGELOG.md +830 -830
  15. package/CLAUDE.md +97 -97
  16. package/docs/LowCode/lowcode.md +155 -155
  17. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  18. package/jsconfig.json +19 -19
  19. package/package.json +1 -1
  20. package/public/his/editor/editor.html +51 -51
  21. package/public/his/editor/mock/bind_data.html +779 -779
  22. package/public/his/editor/mock/data_table.html +40 -40
  23. package/public/his/editor/mock/sign.html +75 -75
  24. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  25. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  26. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  27. package/public/his/editor/vender/date97/calendar.js +4 -4
  28. package/public/his/editor/vender/date97/lang/en.js +13 -13
  29. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  30. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  31. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  32. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  33. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  34. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  35. package/public/his/editor/vender/diff.js +1627 -1627
  36. package/public/his/editor/vender/editor.js +1 -1
  37. package/public/his/editor/vender/fabric.js +31187 -31187
  38. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  39. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  40. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  41. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  42. package/public/his/editor/vender/mui/mui.min.css +4 -4
  43. package/public/his/editor/vender/mui/mui.min.js +5 -5
  44. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  45. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  46. package/public/his/editor/vender/qrcode.js +7 -7
  47. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  48. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  49. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  50. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  51. package/public/his/editor/vender/validator.js +5094 -5094
  52. package/public/his/editor/vender/weui/weui.css +5659 -5659
  53. package/public/his/editor/vender/weui/weui.min.css +4 -4
  54. package/public/his/editor/vender/weui/weui.min.js +11 -11
  55. package/src/assets/img/paymentMethod/package.info +1 -1
  56. package/src/assets/svg/badtwo.svg +1 -1
  57. package/src/assets/svg/goodtwo.svg +1 -1
  58. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  59. package/src/base-client/components/AI/demo.vue +31 -31
  60. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  61. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  62. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  63. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  64. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  65. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  66. package/src/base-client/components/common/HIS/demo.vue +61 -61
  67. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  68. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  69. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  70. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  71. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  72. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  73. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  74. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  75. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  76. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  77. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  78. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  79. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  80. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  81. package/src/base-client/components/common/Recording/index.js +3 -3
  82. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  83. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +304 -304
  84. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  85. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  86. package/src/base-client/components/common/XAddReport/index.js +3 -3
  87. package/src/base-client/components/common/XAddReport/index.md +56 -56
  88. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  89. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  90. package/src/base-client/components/common/XButtons/index.js +3 -3
  91. package/src/base-client/components/common/XButtons/index.md +61 -61
  92. package/src/base-client/components/common/XCalendar/XCalendar.vue +4 -4
  93. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  94. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  95. package/src/base-client/components/common/XDataCard/index.js +3 -3
  96. package/src/base-client/components/common/XDataCard/index.md +1 -1
  97. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  98. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  99. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  100. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  101. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  102. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  103. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  104. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  105. package/src/base-client/components/common/XFormTable/XFormTable.vue +1258 -1257
  106. package/src/base-client/components/common/XFormTable/index.md +92 -92
  107. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  108. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  109. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  110. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  111. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  112. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  113. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  114. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  115. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  116. package/src/base-client/components/common/XPrint/index.vue +97 -97
  117. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  118. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  119. package/src/base-client/components/common/XReport/index.js +3 -3
  120. package/src/base-client/components/common/XReport/print.js +186 -186
  121. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  122. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  123. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  124. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  125. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  126. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  127. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  128. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  129. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  130. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  131. package/src/base-client/components/common/XTab/index.js +3 -3
  132. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  133. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  134. package/src/base-client/components/common/XTable/XTableWrapper.vue +1 -1
  135. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  136. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  137. package/src/base-client/components/common/XTree/index.js +3 -3
  138. package/src/base-client/components/common/XTree/index.md +36 -36
  139. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  140. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  141. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  142. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  143. package/src/base-client/components/his/XCharge/XChargeDemo.vue +145 -145
  144. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  145. package/src/base-client/components/index.js +51 -51
  146. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  147. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  148. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  149. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  150. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  151. package/src/base-client/plugins/Recording.js +258 -258
  152. package/src/base-client/plugins/index.js +23 -23
  153. package/src/components/CodeMirror/inedx.vue +118 -118
  154. package/src/components/CodeMirror/setting.js +40 -40
  155. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  156. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  157. package/src/components/checkbox/index.js +9 -9
  158. package/src/components/exception/ExceptionPage.vue +70 -70
  159. package/src/components/g2Charts/constants.js +202 -202
  160. package/src/components/g2Charts/demo.vue +808 -808
  161. package/src/components/g2Charts/designer.vue +228 -228
  162. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  163. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  164. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  165. package/src/components/g2Charts/index.vue +397 -397
  166. package/src/components/setting/Setting.vue +234 -234
  167. package/src/config/CreateQueryConfig.js +325 -325
  168. package/src/config/default/antd.config.js +89 -89
  169. package/src/config/default/setting.config.js +55 -55
  170. package/src/font-style/font.css +60 -60
  171. package/src/layouts/PageLayout.vue +151 -151
  172. package/src/layouts/SinglePageView.vue +136 -136
  173. package/src/layouts/header/AdminHeader.vue +132 -132
  174. package/src/layouts/header/InstitutionDetail.vue +181 -181
  175. package/src/layouts/tabs/TabsHead.vue +189 -189
  176. package/src/pages/DefaultExample/index.vue +77 -77
  177. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  178. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  179. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  180. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  181. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  182. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  183. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  184. package/src/pages/DynamicStatistics/index.vue +282 -282
  185. package/src/pages/Example/childIndex.vue +15 -15
  186. package/src/pages/Example/index.vue +30 -30
  187. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  188. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  189. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  190. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  191. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  192. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  193. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  194. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  195. package/src/pages/Recording/index.vue +77 -77
  196. package/src/pages/ServiceReview/index.vue +284 -284
  197. package/src/pages/SubExample/index.vue +26 -26
  198. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  199. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +1815 -1815
  200. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +1014 -1014
  201. package/src/pages/XReportView/index.vue +64 -64
  202. package/src/pages/XTreeOneProExample/index.vue +67 -67
  203. package/src/pages/login/Login.vue +379 -379
  204. package/src/pages/login/LoginV3.vue +389 -389
  205. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  206. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  207. package/src/pages/report/ReportTable.js +124 -124
  208. package/src/pages/resourceManage/orgListManage.vue +98 -98
  209. package/src/pages/system/settings/modifyPassword.vue +117 -117
  210. package/src/pages/system/ticket/index.vue +480 -480
  211. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  212. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  213. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  214. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  215. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  216. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  217. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  218. package/src/plugins/EventLogPlugin.js +33 -33
  219. package/src/plugins/FindParentsData.js +17 -17
  220. package/src/services/DataModel.js +30 -30
  221. package/src/services/LodopFuncs.js +137 -137
  222. package/src/services/api/TicketDetailsViewApi.js +46 -46
  223. package/src/services/api/entity.js +18 -18
  224. package/src/services/api/index.js +17 -17
  225. package/src/store/modules/account.js +121 -121
  226. package/src/store/modules/index.js +5 -5
  227. package/src/store/modules/lowCode.js +33 -33
  228. package/src/theme/default/style.less +58 -58
  229. package/src/theme/global.less +313 -313
  230. package/src/utils/formatter.js +74 -74
  231. package/src/utils/htmlToPDF.js +108 -108
  232. package/src/utils/htmlToPDFApi.js +5 -5
  233. package/src/utils/login.js +188 -188
  234. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  235. package/src/utils/lowcode/lowcodeLog.js +29 -29
  236. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  237. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  238. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  239. package/src/utils/map-utils.js +47 -47
  240. package/src/utils/reg.js +95 -95
  241. package/src/utils/runEvalFunction.js +14 -14
  242. package/src/utils/theme-color-replacer-extend.js +92 -92
  243. package/src/utils/util.js +329 -329
  244. package/src/utils/waterMark.js +31 -31
@@ -1,424 +1,424 @@
1
- <script setup>
2
- import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
3
- import { reactive, ref, watch, defineExpose, nextTick } from 'vue'
4
- import { executeStrFunction } from '@vue2-client/utils/runEvalFunction'
5
- import debounce from 'lodash.debounce'
6
-
7
- const config = reactive({})
8
- // 暂存选中的数据
9
- const expandedKeys = ref([])
10
- // 是否加载中
11
- const spinning = ref(false)
12
- // 选中的 key
13
- const checkedKeys = ref([])
14
- // 定义 tree 数据
15
- const _treeData = ref([])
16
- // 存储搜索结果的树数据
17
- const filteredTreeData = ref([])
18
- // 定义最深一层的 数据
19
- const deepestNodes = ref([])
20
- // 定义激活的按钮
21
- const activeButtonIndex = ref({})
22
- // 是否全选
23
- const checkall = ref(false)
24
- // 选了但没有全选
25
- const indeterminate = ref(false)
26
- // 替换字段
27
- let _replaceFields = reactive({ children: 'children', title: 'title', key: 'key' })
28
- // 暂存查询信息
29
- const searchInfo = ref({})
30
- const props = defineProps({
31
- // 树数据
32
- // example: [{ title: '标题', key: '1', children: []}]
33
- treeData: {
34
- type: Array,
35
- required: false,
36
- default: () => []
37
- },
38
- configName: {
39
- type: String,
40
- required: false,
41
- default: undefined
42
- },
43
- env: {
44
- type: String,
45
- default: 'prod'
46
- },
47
- replaceFields: {
48
- type: Object,
49
- default: () => ({ children: 'children', title: 'title', key: 'key' })
50
- }
51
- })
52
- // maxHeight:config.search?'calc(100vh - 200px - 5.6rem)':
53
- // 定义一个计算属性
54
- function heightStore () {
55
- if (config.search) {
56
- if (config.tabBtn && config.tabBtn.length > 0) {
57
- return ['7rem', 'calc(100vh - 200px - 7.6rem)']
58
- } else {
59
- return ['5rem', 'calc(100vh - 200px - 5.6rem)']
60
- }
61
- } else {
62
- if (config.tabBtn && config.tabBtn.length > 0) {
63
- return ['5rem', 'calc(100vh - 200px - 5rem)']
64
- } else {
65
- return ['3rem', 'calc(100vh - 200px - 3rem)']
66
- }
67
- }
68
- }
69
-
70
- // 监听 checkbox 选中 的变化
71
- watch(checkedKeys, (checkedKeys) => {
72
- // 筛选出最底层的数据 返回
73
- const deepNodes = []
74
- const deepKeys = []
75
- checkedKeys.forEach(key => {
76
- const node = deepestNodes.value.find(node => node[_replaceFields.key] === key)
77
- if (node) {
78
- deepNodes.push(node)
79
- deepKeys.push(node[_replaceFields.key])
80
- }
81
- })
82
- nextTick(() => {
83
- if (deepNodes.length === 0) {
84
- checkall.value = false
85
- indeterminate.value = false
86
- } else {
87
- indeterminate.value = !checkall.value
88
- }
89
- })
90
- emit('treeOnChecked', checkedKeys, deepNodes, deepKeys)
91
- }, { immediate: true })
92
- //
93
- // watch(() => props.replaceFields, (newReplaceFields) => {
94
- // if (newReplaceFields) {
95
- // Object.assign(_replaceFields, newReplaceFields)
96
- // }
97
- // }, { immediate: true })
98
- // 如果有configName 要先获取配置
99
- if (props.treeData && props.treeData.length > 0) {
100
- _treeData.value = props.treeData
101
- deepestNodes.value = getDeepestNodes(_treeData.value)
102
- }
103
- if (props.replaceFields) {
104
- _replaceFields = props.replaceFields
105
- }
106
- if (props.configName) {
107
- getConfigByName(props.configName, undefined, (x) => {
108
- Object.assign(config, x)
109
- Object.assign(_replaceFields, x.replaceFields)
110
- if (x.treeData.indexOf('logic@') >= 0) {
111
- // 如果数据源是 logic
112
- getData()
113
- }
114
- }, props.env === 'dev')
115
- }
116
-
117
- const emit = defineEmits(['onSelect'])
118
-
119
- function onSelect (keys, e) {
120
- emit('onSelect', keys, e)
121
- }
122
-
123
- async function getData (param = {}) {
124
- spinning.value = true
125
- const currentUser = JSON.parse(localStorage.getItem(process.env.VUE_APP_USER_KEY))
126
- await runLogic(config.treeData.substring(6), Object.assign(param, {
127
- selectedId: this.$route.query.selected,
128
- orgId: currentUser.orgid,
129
- userId: currentUser.id,
130
- depId: currentUser.f_department_id
131
- }), config.serviceName, props.env === 'dev').then(res => {
132
- _treeData.value = res
133
- deepestNodes.value = getDeepestNodes(_treeData.value)
134
- spinning.value = false
135
- }).catch(e => {
136
- console.error('获取数据失败:' + e)
137
- })
138
- }
139
-
140
- function reLoad () {
141
- getData(searchInfo.value)
142
- }
143
-
144
- function nodeItemClick (e) {
145
- if (this.expandedKeys.includes(e.eventKey)) {
146
- this.expandedKeys = this.expandedKeys.filter(item => item !== e.eventKey)
147
- } else {
148
- this.expandedKeys.push(e.eventKey)
149
- }
150
- }
151
-
152
- const debouncedSearch = debounce((value) => {
153
- console.log('Search:', value)
154
- // 在这里执行你的搜索逻辑
155
- if (value) {
156
- filteredTreeData.value = searchInTree(_treeData.value, value)
157
- } else {
158
- filteredTreeData.value = []
159
- }
160
- }, 233)
161
-
162
- function onChange (e) {
163
- const searchInput = e.target.value
164
- debouncedSearch(searchInput)
165
- }
166
-
167
- function searchInTree (tree, keyword) {
168
- return tree.reduce((acc, node) => {
169
- if (node[_replaceFields.title].includes(keyword)) {
170
- acc.push(node)
171
- } else if (node[_replaceFields.children]) {
172
- const childResults = searchInTree(node[_replaceFields.children], keyword)
173
- if (childResults.length > 0) {
174
- acc.push({
175
- ...node,
176
- children: childResults
177
- })
178
- }
179
- }
180
- return acc
181
- }, [])
182
- }
183
-
184
- function action (record, func) {
185
- emit('action', record, record[_replaceFields.key], null, func)
186
- }
187
-
188
- function getDeepestNodes (treeData) {
189
- const deepestNodes = []
190
-
191
- function traverse (node) {
192
- if (!node[_replaceFields.children] || node[_replaceFields.children].length === 0) {
193
- deepestNodes.push(node)
194
- } else {
195
- node[_replaceFields.children].forEach(child => traverse(child))
196
- }
197
- }
198
-
199
- treeData.forEach(node => traverse(node))
200
- return deepestNodes
201
- }
202
-
203
- function onCheckAllChange (e) {
204
- checkedKeys.value = e.target.checked ? deepestNodes.value.map(node => node[_replaceFields.key]).filter(item => item !== 'noCatch') : []
205
- nextTick(() => {
206
- checkall.value = e.target.checked
207
- indeterminate.value = false
208
- })
209
- }
210
-
211
- async function btnFuncClick (index) {
212
- activeButtonIndex.value = Object.assign({}, activeButtonIndex.value, { [index]: !!!activeButtonIndex.value[index] })
213
- // 组织参数
214
- // 把activeButtonIndex.value groupType 相同的其他值改成 false
215
- Object.keys(activeButtonIndex.value).forEach((key) => {
216
- if (key != index && config.tabBtn[key].groupType === config.tabBtn[index].groupType) {
217
- activeButtonIndex.value[key] = false
218
- }
219
- })
220
- const param = {}
221
- // 循环执行已经激活的自定义方法
222
- Object.keys(activeButtonIndex.value).forEach((key) => {
223
- if (activeButtonIndex.value[key]) {
224
- const item = config.tabBtn[key]
225
- if (item.customFunction) {
226
- Object.assign(param, executeStrFunction(item.customFunction, [param]))
227
- }
228
- }
229
- })
230
- // 获取到 param 执行 getData
231
- await getData(param)
232
- }
233
-
234
- // 使用 defineExpose 暴露方法
235
- defineExpose({
236
- reLoad
237
- })
238
-
239
- </script>
240
-
241
- <template>
242
- <div id="XTreeWarp">
243
- <div class="tree_title" v-if="config.title">
244
- <a-row style="font-size: medium;line-height: 3rem">
245
- <a-col :offset="2">
246
- <span>{{ config.title }}</span>
247
- </a-col>
248
- </a-row>
249
- <a-row v-if="config.search">
250
- <div class="content-search">
251
- <a-checkbox
252
- class="checkbox"
253
- :indeterminate="indeterminate"
254
- :checked="checkall"
255
- @change="onCheckAllChange">
256
- </a-checkbox>
257
- &nbsp;
258
- <a-input
259
- placeholder="请输入搜索关键字"
260
- @change="onChange">
261
- <a-icon slot="prefix" type="search"/>
262
- </a-input>
263
- </div>
264
- </a-row>
265
- </div>
266
- <a-row v-if="config.tabBtn && config.tabBtn.length > 0">
267
- <div class="content-search" style="padding-top:7px;padding-left: 10px">
268
- <a-space>
269
- <a-button
270
- v-for="(item,index) in config.tabBtn"
271
- @click="btnFuncClick(index,item.customFunction)"
272
- :class="{ 'active-button': activeButtonIndex[index] }"
273
- :key="index">{{ item.name }}
274
- </a-button>
275
- </a-space>
276
- </div>
277
- </a-row>
278
- <div
279
- class="tree_main"
280
- :style="{
281
- maxHeight:heightStore()[1]
282
- }">
283
- <a-spin :spinning="spinning">
284
- <a-tree
285
- v-model="checkedKeys"
286
- :tree-data="filteredTreeData && filteredTreeData.length> 0?filteredTreeData: _treeData"
287
- :checkable="config.checkable"
288
- :blockNode="true"
289
- :replaceFields="_replaceFields"
290
- :expandedKeys.sync="expandedKeys"
291
- :default-selected-keys="_treeData && _treeData.length > 0 ? [_treeData[0][_replaceFields.key]] : null"
292
- :default-expand-all="true"
293
- @select="onSelect"
294
- >
295
- <template slot="title" slot-scope="item">
296
- <span @click="nodeItemClick(item)">
297
- <a-tooltip placement="right" :title="item[_replaceFields.title]">
298
- {{
299
- item.dataRef[replaceFields.children] && item.dataRef[replaceFields.children].length > 0 ?
300
- item[_replaceFields.title]
301
- : config.deepNodeMaxWidth && item[_replaceFields.title].length > config.deepNodeMaxWidth ? item[_replaceFields.title].substring(0, config.deepNodeMaxWidth) + '...' : item[_replaceFields.title]
302
- }}{{ item.hasOwnProperty('count') ? ' (' + item.count + ')' : '' }}
303
- </a-tooltip>
304
- </span>
305
- <a-space style="float:right;margin-right: .2rem">
306
- <a-icon
307
- v-for="icon in config.btn"
308
- @click="action(item, icon.func)"
309
- :key="icon.func"
310
- v-if="executeStrFunction( icon.customFunction,[item])"
311
- :type="icon.icon"
312
- :style="{color:icon.color}"></a-icon>
313
- </a-space>
314
- </template>
315
- </a-tree>
316
- </a-spin>
317
- </div>
318
- </div>
319
- </template>
320
-
321
- <style lang="less" scoped>
322
- .tree_title {
323
- background-color: #E0E5EB;
324
- border-radius: 8px 8px 0 0;
325
-
326
- .content-search {
327
- background-color: rgb(224, 229, 235);
328
- height: 2.6rem;
329
- padding: 0 10px;
330
- display: flex;
331
- align-items: center;
332
- justify-content: center;
333
- border-top: 1px solid rgba(0, 0, 0, 0.05);
334
- margin: auto 0;
335
- }
336
- }
337
-
338
- .active-button {
339
- border-color: @primary-color !important;
340
- color: @primary-color !important;
341
- }
342
-
343
- .ant-btn:focus {
344
- color: rgba(0, 0, 0, 0.65);
345
- background-color: #fff;
346
- border-color: #d9d9d9
347
- }
348
-
349
- .tree_main {
350
- width: 100%;
351
- display: inline-block;
352
- overflow-y: auto;
353
- //:deep(.ant-tree-child-tree){
354
- // .ant-space-item {
355
- // display: none;
356
- // }
357
- //
358
- // &:hover {
359
- // .ant-space-item {
360
- // display: block;
361
- // }
362
- // }
363
- //}
364
-
365
- :deep(.ant-tree li .ant-tree-node-content-wrapper) {
366
- color: #000000e0;
367
- }
368
-
369
- :deep(.ant-tree-checkbox) {
370
- top: .5rem !important;
371
- }
372
-
373
- :deep(.ant-tree-node-content-wrapper ) {
374
- display: inline;
375
- }
376
-
377
- :deep(.ant-tree li span.ant-tree-switcher, .ant-tree li span.ant-tree-iconEle) {
378
- color: #0000004d;
379
-
380
- i {
381
- font-size: 16px !important;
382
- line-height: 40px;
383
- }
384
- }
385
-
386
- :deep(.ant-tree.ant-tree-directory > li span.ant-tree-node-content-wrapper::before, .ant-tree.ant-tree-directory .ant-tree-child-tree > li span.ant-tree-node-content-wrapper::before) {
387
- height: 40px;
388
- border-radius: 6px;
389
- }
390
-
391
- :deep(.ant-tree.ant-tree-directory > li.ant-tree-treenode-selected > span.ant-tree-node-content-wrapper::before) {
392
- background: #e6f7ff;
393
- }
394
-
395
- :deep(.ant-tree.ant-tree-directory .ant-tree-child-tree > li.ant-tree-treenode-selected > span.ant-tree-node-content-wrapper::before) {
396
- background: #e6f7ff;
397
- }
398
-
399
- :deep(.ant-tree.ant-tree-directory .ant-tree-child-tree > li.ant-tree-treenode-selected > span.ant-tree-switcher) {
400
- color: #0000004d;
401
- }
402
-
403
- :deep(.ant-tree.ant-tree-directory > li span.ant-tree-node-content-wrapper.ant-tree-node-selected, .ant-tree.ant-tree-directory .ant-tree-child-tree > li span.ant-tree-node-content-wrapper.ant-tree-node-selected) {
404
- color: #000000e0;
405
- }
406
-
407
- :deep(.ant-tree li .ant-tree-node-content-wrapper) {
408
- line-height: 40px;
409
- height: 40px;
410
- }
411
-
412
- :deep(.ant-tree li) {
413
- padding-left: 2px;
414
- }
415
-
416
- :deep(.ant-tree ul) {
417
- padding-left: 10px;
418
- }
419
-
420
- :deep(.ant-tree-icon__customize) {
421
- display: none;
422
- }
423
- }
424
- </style>
1
+ <script setup>
2
+ import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
3
+ import { reactive, ref, watch, defineExpose, nextTick } from 'vue'
4
+ import { executeStrFunction } from '@vue2-client/utils/runEvalFunction'
5
+ import debounce from 'lodash.debounce'
6
+
7
+ const config = reactive({})
8
+ // 暂存选中的数据
9
+ const expandedKeys = ref([])
10
+ // 是否加载中
11
+ const spinning = ref(false)
12
+ // 选中的 key
13
+ const checkedKeys = ref([])
14
+ // 定义 tree 数据
15
+ const _treeData = ref([])
16
+ // 存储搜索结果的树数据
17
+ const filteredTreeData = ref([])
18
+ // 定义最深一层的 数据
19
+ const deepestNodes = ref([])
20
+ // 定义激活的按钮
21
+ const activeButtonIndex = ref({})
22
+ // 是否全选
23
+ const checkall = ref(false)
24
+ // 选了但没有全选
25
+ const indeterminate = ref(false)
26
+ // 替换字段
27
+ let _replaceFields = reactive({ children: 'children', title: 'title', key: 'key' })
28
+ // 暂存查询信息
29
+ const searchInfo = ref({})
30
+ const props = defineProps({
31
+ // 树数据
32
+ // example: [{ title: '标题', key: '1', children: []}]
33
+ treeData: {
34
+ type: Array,
35
+ required: false,
36
+ default: () => []
37
+ },
38
+ configName: {
39
+ type: String,
40
+ required: false,
41
+ default: undefined
42
+ },
43
+ env: {
44
+ type: String,
45
+ default: 'prod'
46
+ },
47
+ replaceFields: {
48
+ type: Object,
49
+ default: () => ({ children: 'children', title: 'title', key: 'key' })
50
+ }
51
+ })
52
+ // maxHeight:config.search?'calc(100vh - 200px - 5.6rem)':
53
+ // 定义一个计算属性
54
+ function heightStore () {
55
+ if (config.search) {
56
+ if (config.tabBtn && config.tabBtn.length > 0) {
57
+ return ['7rem', 'calc(100vh - 200px - 7.6rem)']
58
+ } else {
59
+ return ['5rem', 'calc(100vh - 200px - 5.6rem)']
60
+ }
61
+ } else {
62
+ if (config.tabBtn && config.tabBtn.length > 0) {
63
+ return ['5rem', 'calc(100vh - 200px - 5rem)']
64
+ } else {
65
+ return ['3rem', 'calc(100vh - 200px - 3rem)']
66
+ }
67
+ }
68
+ }
69
+
70
+ // 监听 checkbox 选中 的变化
71
+ watch(checkedKeys, (checkedKeys) => {
72
+ // 筛选出最底层的数据 返回
73
+ const deepNodes = []
74
+ const deepKeys = []
75
+ checkedKeys.forEach(key => {
76
+ const node = deepestNodes.value.find(node => node[_replaceFields.key] === key)
77
+ if (node) {
78
+ deepNodes.push(node)
79
+ deepKeys.push(node[_replaceFields.key])
80
+ }
81
+ })
82
+ nextTick(() => {
83
+ if (deepNodes.length === 0) {
84
+ checkall.value = false
85
+ indeterminate.value = false
86
+ } else {
87
+ indeterminate.value = !checkall.value
88
+ }
89
+ })
90
+ emit('treeOnChecked', checkedKeys, deepNodes, deepKeys)
91
+ }, { immediate: true })
92
+ //
93
+ // watch(() => props.replaceFields, (newReplaceFields) => {
94
+ // if (newReplaceFields) {
95
+ // Object.assign(_replaceFields, newReplaceFields)
96
+ // }
97
+ // }, { immediate: true })
98
+ // 如果有configName 要先获取配置
99
+ if (props.treeData && props.treeData.length > 0) {
100
+ _treeData.value = props.treeData
101
+ deepestNodes.value = getDeepestNodes(_treeData.value)
102
+ }
103
+ if (props.replaceFields) {
104
+ _replaceFields = props.replaceFields
105
+ }
106
+ if (props.configName) {
107
+ getConfigByName(props.configName, undefined, (x) => {
108
+ Object.assign(config, x)
109
+ Object.assign(_replaceFields, x.replaceFields)
110
+ if (x.treeData.indexOf('logic@') >= 0) {
111
+ // 如果数据源是 logic
112
+ getData()
113
+ }
114
+ }, props.env === 'dev')
115
+ }
116
+
117
+ const emit = defineEmits(['onSelect'])
118
+
119
+ function onSelect (keys, e) {
120
+ emit('onSelect', keys, e)
121
+ }
122
+
123
+ async function getData (param = {}) {
124
+ spinning.value = true
125
+ const currentUser = JSON.parse(localStorage.getItem(process.env.VUE_APP_USER_KEY))
126
+ await runLogic(config.treeData.substring(6), Object.assign(param, {
127
+ selectedId: this.$route.query.selected,
128
+ orgId: currentUser.orgid,
129
+ userId: currentUser.id,
130
+ depId: currentUser.f_department_id
131
+ }), config.serviceName, props.env === 'dev').then(res => {
132
+ _treeData.value = res
133
+ deepestNodes.value = getDeepestNodes(_treeData.value)
134
+ spinning.value = false
135
+ }).catch(e => {
136
+ console.error('获取数据失败:' + e)
137
+ })
138
+ }
139
+
140
+ function reLoad () {
141
+ getData(searchInfo.value)
142
+ }
143
+
144
+ function nodeItemClick (e) {
145
+ if (this.expandedKeys.includes(e.eventKey)) {
146
+ this.expandedKeys = this.expandedKeys.filter(item => item !== e.eventKey)
147
+ } else {
148
+ this.expandedKeys.push(e.eventKey)
149
+ }
150
+ }
151
+
152
+ const debouncedSearch = debounce((value) => {
153
+ console.log('Search:', value)
154
+ // 在这里执行你的搜索逻辑
155
+ if (value) {
156
+ filteredTreeData.value = searchInTree(_treeData.value, value)
157
+ } else {
158
+ filteredTreeData.value = []
159
+ }
160
+ }, 233)
161
+
162
+ function onChange (e) {
163
+ const searchInput = e.target.value
164
+ debouncedSearch(searchInput)
165
+ }
166
+
167
+ function searchInTree (tree, keyword) {
168
+ return tree.reduce((acc, node) => {
169
+ if (node[_replaceFields.title].includes(keyword)) {
170
+ acc.push(node)
171
+ } else if (node[_replaceFields.children]) {
172
+ const childResults = searchInTree(node[_replaceFields.children], keyword)
173
+ if (childResults.length > 0) {
174
+ acc.push({
175
+ ...node,
176
+ children: childResults
177
+ })
178
+ }
179
+ }
180
+ return acc
181
+ }, [])
182
+ }
183
+
184
+ function action (record, func) {
185
+ emit('action', record, record[_replaceFields.key], null, func)
186
+ }
187
+
188
+ function getDeepestNodes (treeData) {
189
+ const deepestNodes = []
190
+
191
+ function traverse (node) {
192
+ if (!node[_replaceFields.children] || node[_replaceFields.children].length === 0) {
193
+ deepestNodes.push(node)
194
+ } else {
195
+ node[_replaceFields.children].forEach(child => traverse(child))
196
+ }
197
+ }
198
+
199
+ treeData.forEach(node => traverse(node))
200
+ return deepestNodes
201
+ }
202
+
203
+ function onCheckAllChange (e) {
204
+ checkedKeys.value = e.target.checked ? deepestNodes.value.map(node => node[_replaceFields.key]).filter(item => item !== 'noCatch') : []
205
+ nextTick(() => {
206
+ checkall.value = e.target.checked
207
+ indeterminate.value = false
208
+ })
209
+ }
210
+
211
+ async function btnFuncClick (index) {
212
+ activeButtonIndex.value = Object.assign({}, activeButtonIndex.value, { [index]: !!!activeButtonIndex.value[index] })
213
+ // 组织参数
214
+ // 把activeButtonIndex.value groupType 相同的其他值改成 false
215
+ Object.keys(activeButtonIndex.value).forEach((key) => {
216
+ if (key != index && config.tabBtn[key].groupType === config.tabBtn[index].groupType) {
217
+ activeButtonIndex.value[key] = false
218
+ }
219
+ })
220
+ const param = {}
221
+ // 循环执行已经激活的自定义方法
222
+ Object.keys(activeButtonIndex.value).forEach((key) => {
223
+ if (activeButtonIndex.value[key]) {
224
+ const item = config.tabBtn[key]
225
+ if (item.customFunction) {
226
+ Object.assign(param, executeStrFunction(item.customFunction, [param]))
227
+ }
228
+ }
229
+ })
230
+ // 获取到 param 执行 getData
231
+ await getData(param)
232
+ }
233
+
234
+ // 使用 defineExpose 暴露方法
235
+ defineExpose({
236
+ reLoad
237
+ })
238
+
239
+ </script>
240
+
241
+ <template>
242
+ <div id="XTreeWarp">
243
+ <div class="tree_title" v-if="config.title">
244
+ <a-row style="font-size: medium;line-height: 3rem">
245
+ <a-col :offset="2">
246
+ <span>{{ config.title }}</span>
247
+ </a-col>
248
+ </a-row>
249
+ <a-row v-if="config.search">
250
+ <div class="content-search">
251
+ <a-checkbox
252
+ class="checkbox"
253
+ :indeterminate="indeterminate"
254
+ :checked="checkall"
255
+ @change="onCheckAllChange">
256
+ </a-checkbox>
257
+ &nbsp;
258
+ <a-input
259
+ placeholder="请输入搜索关键字"
260
+ @change="onChange">
261
+ <a-icon slot="prefix" type="search"/>
262
+ </a-input>
263
+ </div>
264
+ </a-row>
265
+ </div>
266
+ <a-row v-if="config.tabBtn && config.tabBtn.length > 0">
267
+ <div class="content-search" style="padding-top:7px;padding-left: 10px">
268
+ <a-space>
269
+ <a-button
270
+ v-for="(item,index) in config.tabBtn"
271
+ @click="btnFuncClick(index,item.customFunction)"
272
+ :class="{ 'active-button': activeButtonIndex[index] }"
273
+ :key="index">{{ item.name }}
274
+ </a-button>
275
+ </a-space>
276
+ </div>
277
+ </a-row>
278
+ <div
279
+ class="tree_main"
280
+ :style="{
281
+ maxHeight:heightStore()[1]
282
+ }">
283
+ <a-spin :spinning="spinning">
284
+ <a-tree
285
+ v-model="checkedKeys"
286
+ :tree-data="filteredTreeData && filteredTreeData.length> 0?filteredTreeData: _treeData"
287
+ :checkable="config.checkable"
288
+ :blockNode="true"
289
+ :replaceFields="_replaceFields"
290
+ :expandedKeys.sync="expandedKeys"
291
+ :default-selected-keys="_treeData && _treeData.length > 0 ? [_treeData[0][_replaceFields.key]] : null"
292
+ :default-expand-all="true"
293
+ @select="onSelect"
294
+ >
295
+ <template slot="title" slot-scope="item">
296
+ <span @click="nodeItemClick(item)">
297
+ <a-tooltip placement="right" :title="item[_replaceFields.title]">
298
+ {{
299
+ item.dataRef[replaceFields.children] && item.dataRef[replaceFields.children].length > 0 ?
300
+ item[_replaceFields.title]
301
+ : config.deepNodeMaxWidth && item[_replaceFields.title].length > config.deepNodeMaxWidth ? item[_replaceFields.title].substring(0, config.deepNodeMaxWidth) + '...' : item[_replaceFields.title]
302
+ }}{{ item.hasOwnProperty('count') ? ' (' + item.count + ')' : '' }}
303
+ </a-tooltip>
304
+ </span>
305
+ <a-space style="float:right;margin-right: .2rem">
306
+ <a-icon
307
+ v-for="icon in config.btn"
308
+ @click="action(item, icon.func)"
309
+ :key="icon.func"
310
+ v-if="executeStrFunction( icon.customFunction,[item])"
311
+ :type="icon.icon"
312
+ :style="{color:icon.color}"></a-icon>
313
+ </a-space>
314
+ </template>
315
+ </a-tree>
316
+ </a-spin>
317
+ </div>
318
+ </div>
319
+ </template>
320
+
321
+ <style lang="less" scoped>
322
+ .tree_title {
323
+ background-color: #E0E5EB;
324
+ border-radius: 8px 8px 0 0;
325
+
326
+ .content-search {
327
+ background-color: rgb(224, 229, 235);
328
+ height: 2.6rem;
329
+ padding: 0 10px;
330
+ display: flex;
331
+ align-items: center;
332
+ justify-content: center;
333
+ border-top: 1px solid rgba(0, 0, 0, 0.05);
334
+ margin: auto 0;
335
+ }
336
+ }
337
+
338
+ .active-button {
339
+ border-color: @primary-color !important;
340
+ color: @primary-color !important;
341
+ }
342
+
343
+ .ant-btn:focus {
344
+ color: rgba(0, 0, 0, 0.65);
345
+ background-color: #fff;
346
+ border-color: #d9d9d9
347
+ }
348
+
349
+ .tree_main {
350
+ width: 100%;
351
+ display: inline-block;
352
+ overflow-y: auto;
353
+ //:deep(.ant-tree-child-tree){
354
+ // .ant-space-item {
355
+ // display: none;
356
+ // }
357
+ //
358
+ // &:hover {
359
+ // .ant-space-item {
360
+ // display: block;
361
+ // }
362
+ // }
363
+ //}
364
+
365
+ :deep(.ant-tree li .ant-tree-node-content-wrapper) {
366
+ color: #000000e0;
367
+ }
368
+
369
+ :deep(.ant-tree-checkbox) {
370
+ top: .5rem !important;
371
+ }
372
+
373
+ :deep(.ant-tree-node-content-wrapper ) {
374
+ display: inline;
375
+ }
376
+
377
+ :deep(.ant-tree li span.ant-tree-switcher, .ant-tree li span.ant-tree-iconEle) {
378
+ color: #0000004d;
379
+
380
+ i {
381
+ font-size: 16px !important;
382
+ line-height: 40px;
383
+ }
384
+ }
385
+
386
+ :deep(.ant-tree.ant-tree-directory > li span.ant-tree-node-content-wrapper::before, .ant-tree.ant-tree-directory .ant-tree-child-tree > li span.ant-tree-node-content-wrapper::before) {
387
+ height: 40px;
388
+ border-radius: 6px;
389
+ }
390
+
391
+ :deep(.ant-tree.ant-tree-directory > li.ant-tree-treenode-selected > span.ant-tree-node-content-wrapper::before) {
392
+ background: #e6f7ff;
393
+ }
394
+
395
+ :deep(.ant-tree.ant-tree-directory .ant-tree-child-tree > li.ant-tree-treenode-selected > span.ant-tree-node-content-wrapper::before) {
396
+ background: #e6f7ff;
397
+ }
398
+
399
+ :deep(.ant-tree.ant-tree-directory .ant-tree-child-tree > li.ant-tree-treenode-selected > span.ant-tree-switcher) {
400
+ color: #0000004d;
401
+ }
402
+
403
+ :deep(.ant-tree.ant-tree-directory > li span.ant-tree-node-content-wrapper.ant-tree-node-selected, .ant-tree.ant-tree-directory .ant-tree-child-tree > li span.ant-tree-node-content-wrapper.ant-tree-node-selected) {
404
+ color: #000000e0;
405
+ }
406
+
407
+ :deep(.ant-tree li .ant-tree-node-content-wrapper) {
408
+ line-height: 40px;
409
+ height: 40px;
410
+ }
411
+
412
+ :deep(.ant-tree li) {
413
+ padding-left: 2px;
414
+ }
415
+
416
+ :deep(.ant-tree ul) {
417
+ padding-left: 10px;
418
+ }
419
+
420
+ :deep(.ant-tree-icon__customize) {
421
+ display: none;
422
+ }
423
+ }
424
+ </style>