vue2-client 1.15.87 → 1.15.88

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 (377) hide show
  1. package/.editorconfig +9 -9
  2. package/.env +20 -20
  3. package/.env.development +1 -1
  4. package/.env.iot +19 -19
  5. package/.env.message +19 -19
  6. package/.env.revenue +19 -19
  7. package/.env.runtime +19 -19
  8. package/.eslintrc.json +5 -5
  9. package/CLAUDE.md +89 -89
  10. package/README.md +65 -65
  11. package/babel.config.js +21 -21
  12. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +46 -46
  13. package/docs/notice.md +22 -22
  14. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +179 -179
  15. package/jest.config.js +22 -22
  16. package/package.json +111 -111
  17. package/src/App.vue +196 -196
  18. package/src/ReportView.js +13 -13
  19. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +532 -532
  20. package/src/base-client/components/common/AddressSearchCombobox/index.js +3 -3
  21. package/src/base-client/components/common/AmapMarker/index.js +3 -3
  22. package/src/base-client/components/common/CitySelect/CitySelect.vue +376 -376
  23. package/src/base-client/components/common/CitySelect/demo.vue +43 -43
  24. package/src/base-client/components/common/ColorPickerCombobox/ColorPickerCombobox.vue +99 -99
  25. package/src/base-client/components/common/ColorPickerCombobox/demo.vue +34 -34
  26. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +146 -146
  27. package/src/base-client/components/common/JSONToTree/index.js +3 -3
  28. package/src/base-client/components/common/Upload/Upload.vue +323 -323
  29. package/src/base-client/components/common/XAddForm/index.js +3 -3
  30. package/src/base-client/components/common/XAddForm/index.md +61 -61
  31. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +1169 -1169
  32. package/src/base-client/components/common/XAddNativeForm/demo.vue +54 -54
  33. package/src/base-client/components/common/XAddNativeForm/index.js +3 -3
  34. package/src/base-client/components/common/XAddReport/XAddReport.vue +212 -212
  35. package/src/base-client/components/common/XBadge/index.js +3 -3
  36. package/src/base-client/components/common/XBadge/index.md +39 -39
  37. package/src/base-client/components/common/XButtons/XButtons.vue +284 -284
  38. package/src/base-client/components/common/XCalendar/XCalendar.vue +369 -369
  39. package/src/base-client/components/common/XCalendar/index.md +284 -284
  40. package/src/base-client/components/common/XCard/index.js +3 -3
  41. package/src/base-client/components/common/XCard/index.md +43 -43
  42. package/src/base-client/components/common/XCardSet/XCardSet.vue +300 -300
  43. package/src/base-client/components/common/XCollapse/XCollapse.vue +354 -354
  44. package/src/base-client/components/common/XConversation/XConversation.vue +576 -576
  45. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  46. package/src/base-client/components/common/XDataCard/XDataCard.vue +629 -629
  47. package/src/base-client/components/common/XDatePicker/index.vue +276 -276
  48. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +174 -174
  49. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +314 -314
  50. package/src/base-client/components/common/XDescriptions/demo.vue +51 -51
  51. package/src/base-client/components/common/XForm/XForm.vue +420 -420
  52. package/src/base-client/components/common/XForm/XFormItem.vue +1474 -1474
  53. package/src/base-client/components/common/XForm/XTreeSelect.vue +276 -276
  54. package/src/base-client/components/common/XForm/demo.vue +105 -105
  55. package/src/base-client/components/common/XForm/index.js +3 -3
  56. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -157
  57. package/src/base-client/components/common/XFormCol/index.js +3 -3
  58. package/src/base-client/components/common/XFormCol/index.md +35 -35
  59. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +301 -301
  60. package/src/base-client/components/common/XFormGroup/demo.vue +41 -41
  61. package/src/base-client/components/common/XFormTable/XFormTable.vue +938 -938
  62. package/src/base-client/components/common/XFormTable/demo.vue +87 -87
  63. package/src/base-client/components/common/XFormTable/index.js +3 -3
  64. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +174 -174
  65. package/src/base-client/components/common/XImportExcel/index.js +3 -3
  66. package/src/base-client/components/common/XImportExcel/index.md +38 -38
  67. package/src/base-client/components/common/XInput/XInput.vue +128 -128
  68. package/src/base-client/components/common/XInput/index.js +3 -3
  69. package/src/base-client/components/common/XInput/index.md +97 -97
  70. package/src/base-client/components/common/XIntervalPicker/XIntervalPicker.vue +121 -121
  71. package/src/base-client/components/common/XLicensePlate/index.js +3 -3
  72. package/src/base-client/components/common/XLicensePlate/index.md +38 -38
  73. package/src/base-client/components/common/XPrint/Demo.vue +41 -41
  74. package/src/base-client/components/common/XPrint/PrintBill.vue +308 -308
  75. package/src/base-client/components/common/XRate/demo.vue +102 -102
  76. package/src/base-client/components/common/XRate/index.vue +149 -149
  77. package/src/base-client/components/common/XReport/XReport.vue +963 -963
  78. package/src/base-client/components/common/XReport/XReportDemo.vue +70 -70
  79. package/src/base-client/components/common/XReport/XReportTrGroup.vue +1005 -1005
  80. package/src/base-client/components/common/XReport/index.md +103 -103
  81. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  82. package/src/base-client/components/common/XReportGrid/XReport.vue +1075 -1075
  83. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +44 -44
  84. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +620 -620
  85. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +723 -723
  86. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  87. package/src/base-client/components/common/XTab/XTab.vue +299 -299
  88. package/src/base-client/components/common/XTable/ExportExcel.vue +283 -283
  89. package/src/base-client/components/common/XTable/XTable.vue +1599 -1599
  90. package/src/base-client/components/common/XTable/XTableWrapper.vue +597 -597
  91. package/src/base-client/components/common/XTable/index.js +3 -3
  92. package/src/base-client/components/common/XTimeline/XTimeline.vue +358 -358
  93. package/src/base-client/components/common/XTimeline/index.md +191 -191
  94. package/src/base-client/components/common/XTree/XTreePro.vue +452 -450
  95. package/src/base-client/components/common/XTreeOne/index.js +3 -3
  96. package/src/base-client/components/common/XUploadFilesView/index.vue +485 -485
  97. package/src/base-client/components/his/XCharge/XCharge.vue +238 -238
  98. package/src/base-client/components/his/XCheckbox/XCheckbox.vue +105 -105
  99. package/src/base-client/components/his/XCheckbox/index.md +253 -253
  100. package/src/base-client/components/his/XHDescriptions/XHDescriptions.vue +430 -430
  101. package/src/base-client/components/his/XHDescriptions/index.md +217 -217
  102. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +629 -629
  103. package/src/base-client/components/his/XHisEditor/diagnosisAutocomplete.js +263 -263
  104. package/src/base-client/components/his/XList/XList.vue +495 -495
  105. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.json +3 -3
  106. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.vue +106 -106
  107. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireDemo.vue +51 -51
  108. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireItem.vue +269 -269
  109. package/src/base-client/components/his/XRadio/XRadio.vue +125 -125
  110. package/src/base-client/components/his/XRadio/index.md +234 -234
  111. package/src/base-client/components/his/XSelect/XSelect.vue +72 -72
  112. package/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +234 -234
  113. package/src/base-client/components/his/XShiftSchedule/dome.vue +29 -29
  114. package/src/base-client/components/his/XSidebar/XSidebar.vue +240 -240
  115. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  116. package/src/base-client/components/his/XTimeSelect/XTimeSelect.vue +162 -162
  117. package/src/base-client/components/his/XTimeSelect/XTimeSelectDemo.vue +23 -23
  118. package/src/base-client/components/his/XTitle/README.md +113 -113
  119. package/src/base-client/components/his/XTitle/XTitle.vue +123 -123
  120. package/src/base-client/components/his/XTreeRows/TreeNode.vue +107 -107
  121. package/src/base-client/components/his/XTreeRows/XTreeRows.vue +307 -307
  122. package/src/base-client/components/his/threeTestOrders/dome.vue +68 -68
  123. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  124. package/src/base-client/components/his/threeTestOrders/textBox.vue +457 -457
  125. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +475 -475
  126. package/src/base-client/components/layout/XPageView/RenderRow.vue +88 -88
  127. package/src/base-client/components/layout/XPageView/XErrorView.vue +22 -22
  128. package/src/base-client/components/layout/XPageView/XPageRowTemplate.vue +37 -37
  129. package/src/base-client/components/layout/XPageView/XPageView.vue +223 -223
  130. package/src/base-client/components/layout/XPageView/XTab/XTab.vue +96 -96
  131. package/src/base-client/components/layout/XPageView/XTab/index.js +3 -3
  132. package/src/base-client/components/layout/XPageView/componentTypes.js +22 -22
  133. package/src/base-client/components/layout/XPageView/index.js +2 -2
  134. package/src/base-client/components/layout/XPageView/index.md +96 -96
  135. package/src/base-client/components/system/DictionaryDetailsView/index.js +3 -3
  136. package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -41
  137. package/src/base-client/components/system/LogDetailsView/LogDetailsView.vue +376 -376
  138. package/src/base-client/components/system/LogDetailsView/index.js +3 -3
  139. package/src/base-client/components/system/LogDetailsView/index.md +41 -41
  140. package/src/base-client/components/system/QueryParamsDetailsView/index.js +3 -3
  141. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  142. package/src/base-client/components/ticket/TicketDetailsView/index.js +3 -3
  143. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  144. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  145. package/src/base-client/components/ticket/TicketDetailsView/part/index.js +3 -3
  146. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  147. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.js +3 -3
  148. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  149. package/src/base-client/plugins/AppData.js +126 -126
  150. package/src/base-client/plugins/PagedList.js +177 -177
  151. package/src/base-client/plugins/__tests__/selectValueTypeHelper.test.js +154 -154
  152. package/src/base-client/plugins/authority-plugin.js +167 -167
  153. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  154. package/src/base-client/plugins/i18n-extend.js +32 -32
  155. package/src/base-client/plugins/moment.js +8 -8
  156. package/src/base-client/plugins/selectValueTypeHelper.js +281 -281
  157. package/src/bootstrap.js +51 -51
  158. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  159. package/src/components/Ellipsis/index.js +3 -3
  160. package/src/components/Ellipsis/index.md +38 -38
  161. package/src/components/FileImageItem/FileItem.vue +320 -320
  162. package/src/components/FileImageItem/FileItemGroup.vue +197 -197
  163. package/src/components/FileImageItem/ImageItem.vue +107 -107
  164. package/src/components/FileImageItem/index.js +4 -4
  165. package/src/components/FilePreview/FilePreview.vue +181 -181
  166. package/src/components/FilePreview/FilePreviewDemo.vue +30 -30
  167. package/src/components/FilePreview/index.js +3 -3
  168. package/src/components/HeightScanner/index.vue +615 -615
  169. package/src/components/STable/README.md +341 -341
  170. package/src/components/STable/index.js +558 -558
  171. package/src/components/TableSetting/TableSetting.vue +143 -143
  172. package/src/components/TableSetting/index.js +3 -3
  173. package/src/components/Trend/Trend.vue +41 -41
  174. package/src/components/Trend/index.js +3 -3
  175. package/src/components/Trend/index.less +41 -41
  176. package/src/components/Trend/index.md +45 -45
  177. package/src/components/_util/util.js +46 -46
  178. package/src/components/cache/AKeepAlive.js +179 -179
  179. package/src/components/exception/typeConfig.js +19 -19
  180. package/src/components/form/FormRow.vue +52 -52
  181. package/src/components/index.less +5 -5
  182. package/src/components/menu/Contextmenu.vue +84 -84
  183. package/src/components/menu/index.less +38 -38
  184. package/src/components/page/header/PageHeader.vue +64 -64
  185. package/src/components/page/header/index.less +40 -40
  186. package/src/components/result/Result.vue +77 -77
  187. package/src/components/setting/SettingItem.vue +26 -26
  188. package/src/components/setting/i18n.js +117 -117
  189. package/src/components/table/StandardTable.vue +141 -141
  190. package/src/components/table/advance/ActionColumns.vue +158 -158
  191. package/src/components/table/advance/ActionSize.vue +45 -45
  192. package/src/components/table/advance/AdvanceTable.vue +275 -275
  193. package/src/components/table/advance/SearchArea.vue +355 -355
  194. package/src/components/table/advance/index.js +2 -2
  195. package/src/components/table/api/ApiTable.vue +50 -50
  196. package/src/components/task/TaskGroup.vue +80 -80
  197. package/src/components/task/TaskItem.vue +26 -26
  198. package/src/components/tool/AvatarList.vue +68 -68
  199. package/src/components/tool/DetailList.vue +157 -157
  200. package/src/components/tool/Drawer.vue +142 -142
  201. package/src/components/tool/FooterToolBar.vue +30 -30
  202. package/src/components/tool/HeadInfo.vue +35 -35
  203. package/src/components/tool/TagSelect.vue +83 -83
  204. package/src/components/tool/TagSelectOption.vue +33 -33
  205. package/src/components/transition/PageToggleTransition.vue +97 -97
  206. package/src/config/default/admin.config.js +18 -18
  207. package/src/config/default/animate.config.js +21 -21
  208. package/src/config/default/index.js +6 -6
  209. package/src/config/index.js +3 -3
  210. package/src/config/replacer/index.js +10 -10
  211. package/src/config/replacer/resolve.config.js +67 -67
  212. package/src/expression/ExpressionRunner.js +26 -26
  213. package/src/expression/TestExpression.js +509 -509
  214. package/src/expression/core/Delegate.js +115 -115
  215. package/src/expression/core/Expression.js +1358 -1358
  216. package/src/expression/core/Program.js +932 -932
  217. package/src/expression/core/Token.js +27 -27
  218. package/src/expression/enums/ExpressionType.js +81 -81
  219. package/src/expression/enums/TokenType.js +11 -11
  220. package/src/expression/exception/BreakWayException.js +2 -2
  221. package/src/expression/exception/ContinueWayException.js +2 -2
  222. package/src/expression/exception/ExpressionException.js +28 -28
  223. package/src/expression/exception/ReturnWayException.js +14 -14
  224. package/src/expression/exception/ServiceException.js +22 -22
  225. package/src/expression/instances/LogicConsole.js +44 -44
  226. package/src/expression/ts/ExpressionRunner.ts +28 -28
  227. package/src/expression/ts/TestExpression.ts +509 -509
  228. package/src/expression/ts/core/Delegate.ts +114 -114
  229. package/src/expression/ts/core/Expression.ts +1309 -1309
  230. package/src/expression/ts/core/Program.ts +950 -950
  231. package/src/expression/ts/core/Token.ts +29 -29
  232. package/src/expression/ts/enums/ExpressionType.ts +81 -81
  233. package/src/expression/ts/enums/TokenType.ts +13 -13
  234. package/src/expression/ts/exception/BreakWayException.ts +2 -2
  235. package/src/expression/ts/exception/ContinueWayException.ts +2 -2
  236. package/src/expression/ts/exception/ExpressionException.ts +28 -28
  237. package/src/expression/ts/exception/ReturnWayException.ts +14 -14
  238. package/src/expression/ts/exception/ServiceException.ts +22 -22
  239. package/src/expression/ts/instances/JSONArray.ts +48 -48
  240. package/src/expression/ts/instances/JSONObject.ts +109 -109
  241. package/src/expression/ts/instances/LogicConsole.ts +32 -32
  242. package/src/layouts/AdminLayout.vue +176 -176
  243. package/src/layouts/BlankView.vue +79 -79
  244. package/src/layouts/ComponentLayoutOne.vue +47 -47
  245. package/src/layouts/GridView.vue +43 -43
  246. package/src/layouts/PageView.vue +55 -55
  247. package/src/layouts/footer/PageFooter.vue +49 -49
  248. package/src/layouts/header/HeaderAvatar.vue +64 -64
  249. package/src/layouts/header/HeaderSearch.vue +67 -67
  250. package/src/layouts/header/index.less +92 -92
  251. package/src/layouts/tabs/TabsView.vue +383 -383
  252. package/src/layouts/tabs/i18n.js +25 -25
  253. package/src/layouts/tabs/index.js +2 -2
  254. package/src/logic/LogicRunner.js +62 -62
  255. package/src/logic/TestLogic.js +13 -13
  256. package/src/logic/plugins/common/DateTools.js +35 -35
  257. package/src/logic/plugins/common/VueTools.js +30 -30
  258. package/src/logic/plugins/index.js +7 -7
  259. package/src/logic/ts/LogicRunner.ts +67 -67
  260. package/src/logic/ts/TestLogic.ts +13 -13
  261. package/src/main.js +33 -33
  262. package/src/mixins/formValidationMixin.js +46 -46
  263. package/src/mock/common/activityData.js +32 -32
  264. package/src/mock/common/index.js +89 -89
  265. package/src/mock/common/reportData.js +20 -20
  266. package/src/mock/common/tableData.js +118 -118
  267. package/src/mock/index.js +12 -12
  268. package/src/mock/project/index.js +17 -17
  269. package/src/mock/user/current.js +13 -13
  270. package/src/mock/user/login.js +39 -39
  271. package/src/mock/user/routes.js +61 -61
  272. package/src/mock/workplace/index.js +15 -15
  273. package/src/pages/LogicCallExample/index.vue +46 -46
  274. package/src/pages/ReportGrid/index.vue +76 -76
  275. package/src/pages/ReportView.vue +50 -50
  276. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +47 -47
  277. package/src/pages/WorkflowDetail/WorkFlowDemo2.vue +204 -204
  278. package/src/pages/WorkflowDetail/WorkFlowDemo3.vue +203 -203
  279. package/src/pages/WorkflowDetail/WorkflowDetail.vue +391 -391
  280. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +388 -388
  281. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +415 -415
  282. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +1766 -1766
  283. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +975 -975
  284. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowPreview.vue +109 -109
  285. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +929 -929
  286. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +222 -222
  287. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +243 -243
  288. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +188 -188
  289. package/src/pages/WorkflowDetail/WorkflowPageDetail/components/WorkflowPersonSelector.vue +109 -109
  290. package/src/pages/WorkflowDetail/WorkflowPageDetail/worklog.vue +97 -97
  291. package/src/pages/XPageViewExample/index.vue +149 -149
  292. package/src/pages/addressSelect/addressDemo.vue +24 -24
  293. package/src/pages/addressSelect/index.vue +270 -270
  294. package/src/pages/dashboard/workplace/i18n.js +40 -40
  295. package/src/pages/dashboard/workplace/index.js +2 -2
  296. package/src/pages/dashboard/workplace/index.less +59 -59
  297. package/src/pages/exception/403.vue +21 -21
  298. package/src/pages/exception/404.vue +24 -24
  299. package/src/pages/exception/500.vue +21 -21
  300. package/src/pages/login/index.js +2 -2
  301. package/src/pages/report/ReportTableHome.vue +28 -28
  302. package/src/pages/resourceManage/depListManage.vue +23 -23
  303. package/src/pages/resourceManage/funListManage.vue +23 -23
  304. package/src/pages/resourceManage/index.js +15 -15
  305. package/src/pages/resourceManage/resourceManageMain.vue +57 -57
  306. package/src/pages/resourceManage/roleListManage.vue +23 -23
  307. package/src/pages/resourceManage/staffListManage.vue +23 -23
  308. package/src/pages/system/file/Info.vue +56 -56
  309. package/src/pages/system/file/index.vue +317 -317
  310. package/src/pages/system/settings/index.vue +126 -126
  311. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +77 -77
  312. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +75 -75
  313. package/src/pages/userInfoDetailManage/InsuranceDetailQuery/index.vue +64 -64
  314. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +75 -75
  315. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +75 -75
  316. package/src/pages/userInfoDetailManage/PriceAdjustments/index.vue +64 -64
  317. package/src/pages/userInfoDetailManage/UserChargeRecordQuery/index.vue +94 -94
  318. package/src/pages/userInfoDetailManage/UserException/index.vue +64 -64
  319. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +87 -87
  320. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +74 -74
  321. package/src/pages/userInfoDetailManage/index.vue +290 -290
  322. package/src/pages/userInfoDetailManage/uploadFilesHistory/ImagePreview.vue +101 -101
  323. package/src/pages/userInfoDetailManage/uploadFilesHistory/index.vue +129 -129
  324. package/src/pages/userInfoDetailManage/userInfoDetailQueryTabs.vue +144 -144
  325. package/src/plugins/HiPrintPlugin.js +164 -164
  326. package/src/router/async/router.map.js +126 -126
  327. package/src/router/guards.js +262 -262
  328. package/src/router/i18n.js +57 -57
  329. package/src/router.js +17 -17
  330. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  331. package/src/services/api/LogDetailsViewApi.js +10 -10
  332. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  333. package/src/services/api/logininfor/index.js +6 -6
  334. package/src/services/api/manage.js +8 -8
  335. package/src/services/api/restTools.js +215 -215
  336. package/src/services/api/workFlow.js +57 -57
  337. package/src/services/apiService.js +16 -16
  338. package/src/services/dataSource.js +12 -12
  339. package/src/services/index.js +7 -7
  340. package/src/services/user.js +92 -92
  341. package/src/services/v3Api.js +116 -116
  342. package/src/store/index.js +5 -5
  343. package/src/store/mutation-types.js +4 -4
  344. package/src/theme/antd/ant-menu.less +2 -2
  345. package/src/theme/antd/ant-message.less +3 -3
  346. package/src/theme/antd/ant-table.less +22 -22
  347. package/src/theme/antd/ant-time-picker.less +3 -3
  348. package/src/theme/antd/index.less +3 -3
  349. package/src/theme/default/color.less +43 -43
  350. package/src/theme/default/index.less +3 -3
  351. package/src/theme/default/nprogress.less +76 -76
  352. package/src/theme/global.less +279 -279
  353. package/src/theme/index.less +5 -5
  354. package/src/theme/reportTable.less +58 -58
  355. package/src/theme/theme.less +1 -1
  356. package/src/utils/EncryptUtil.js +162 -162
  357. package/src/utils/Objects.js +25 -25
  358. package/src/utils/axios-interceptors.js +100 -100
  359. package/src/utils/colors.js +107 -107
  360. package/src/utils/common.js +10 -10
  361. package/src/utils/excel/Blob.js +180 -180
  362. package/src/utils/excel/Export2Excel.js +141 -141
  363. package/src/utils/filter.js +21 -21
  364. package/src/utils/i18n.js +80 -80
  365. package/src/utils/indexedDB.js +549 -549
  366. package/src/utils/microAppUtils.js +49 -49
  367. package/src/utils/request.js +395 -395
  368. package/src/utils/routerUtil.js +553 -553
  369. package/src/utils/themeUtil.js +100 -100
  370. package/test/Tree.spec.js +168 -168
  371. package/test/myDialog.spec.js +47 -47
  372. package/test/request.test.js +17 -17
  373. package/test/util.test.js +53 -53
  374. package/test/v3Api.test.js +1984 -1984
  375. package/tests/unit/ReportTable.spec.js +16 -16
  376. package/vue.config.js +222 -222
  377. package/.claude/settings.local.json +0 -12
@@ -1,938 +1,938 @@
1
- <template>
2
- <a-row type="flex" :gutter="{ xs: 8, sm: 10, md: 12, lg: 16 }">
3
- <a-col
4
- :xs="14"
5
- :sm="14"
6
- :md="12"
7
- :lg="9"
8
- :xl="6"
9
- :xxl="5"
10
- v-if="xTreeConfigName"
11
- :style="{ maxWidth: '400px'}">
12
- <x-tree-pro
13
- :config-name="xTreeConfigName"
14
- :env="env"
15
- @action="action"
16
- @btnFuncClick="treeBtnFuncClick"
17
- @treeOnChecked="treeOnChecked"
18
- ref="xtree"
19
- ></x-tree-pro>
20
- </a-col>
21
- <a-col
22
- :xs="xTreeConfigName ? 10 : 24"
23
- :sm="xTreeConfigName ? 10 : 24"
24
- :md="xTreeConfigName ? 12 : 24"
25
- :lg="xTreeConfigName ? 15 : 24"
26
- :xl="xTreeConfigName ? 18 : 24"
27
- :xxl="xTreeConfigName ? 19 : 24">
28
- <a-skeleton :loading="loading" :paragraph="{ rows: 4 }"/>
29
- <a-row style="height: 12px" v-if="xTreeConfigName"></a-row>
30
- <div v-show="!loading">
31
- <template v-if="!loadError">
32
- <x-add-form
33
- ref="xAddForm"
34
- @onLocalSubmit="onLocalSubmit"
35
- @x-form-item-emit-func="emitFunc"
36
- @afterSubmit="onAddOrEditSubmitAfterSubmit"
37
- >
38
- <template slot="groupFormItems" slot-scope="{form, model, rules, modifyModelData}">
39
- <slot
40
- name="groupFormItems"
41
- :form="form"
42
- :model="model"
43
- :rules="rules"
44
- :modifyModelData="modifyModelData"></slot>
45
- </template>
46
- </x-add-form>
47
- <x-add-report
48
- v-if="moveType"
49
- ref="xAddReport"
50
- >
51
- </x-add-report>
52
- <div v-if="crudTitle" class="crud_title">
53
- {{ crudTitle }}
54
- </div>
55
- <x-form
56
- ref="xForm"
57
- @toggleAdvanced="toggleAdvanced"
58
- @onSubmit="onSearchSubmit">
59
- <slot name="formBtnExpand"></slot>
60
- </x-form>
61
- <x-table
62
- ref="xTable"
63
- :fixedQueryForm="fixedQueryForm"
64
- :queryParamsName="queryParamsName"
65
- :query-params-json="queryParamsJson"
66
- :show-pagination="showPagination"
67
- :customDelete="customDelete"
68
- :extraHeight="extraHeight"
69
- :serviceName="serviceName"
70
- :pageMaxSize="realQueryConfig.queryPagesSize"
71
- :externalSelectedRowKeys="externalSelectedRowKeys"
72
- @add="add"
73
- @move="move"
74
- @edit="edit"
75
- @del="del"
76
- @rowChoose="rowChoose"
77
- @customEvent="customEvent"
78
- @afterDelete="afterDelete"
79
- @action="action"
80
- @selectRow="selectRow"
81
- @afterQuery="afterQuery"
82
- @columnClick="columnClick"
83
- @gotoUserDetail="gotoUserDetail"
84
- @editButtonStateDataClick="editButtonStateDataClick"
85
- @importExcelOk="importExcelOk"
86
- @rowClick="handleRowClick"
87
- @beforeDataChange="beforeDataChange"
88
- @expand="onExpand">
89
- <template slot="leftButton" slot-scope="{selectedRowKeys, selectedRows}">
90
- <slot name="leftButton" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
91
- </template>
92
- <template slot="button" slot-scope="{selectedRowKeys, selectedRows}">
93
- <slot name="button" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
94
- </template>
95
- <template slot="rightBtnExpand" slot-scope="{selectedRowKeys, selectedRows}">
96
- <slot name="rightBtnExpand" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
97
- <a-tooltip title="收起查询条件" placement="bottom">
98
- <a-button @click="toggleIsFormShow">
99
- <a-icon :style="iconStyle" :type="toggleIsFormIcon"/>
100
- </a-button>
101
- </a-tooltip>
102
- </template>
103
- <!-- 底部插槽 -->
104
- <template slot="footer" slot-scope="{selectedRowKeys, selectedRows}">
105
- <slot name="footer" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
106
- </template>
107
- <!-- excel导入说明插槽 -->
108
- <template #importExcelSlot>
109
- <slot name="importExcelSlot"></slot>
110
- </template>
111
- </x-table>
112
- </template>
113
- <template v-else>
114
- <a-empty>
115
- <span slot="description"> 页面配置不存在,请联系系统管理员</span>
116
- </a-empty>
117
- </template>
118
- </div>
119
- </a-col>
120
- <UserInfoDetailManage ref="userInfo" @close="refresh(false)"/>
121
- </a-row>
122
- </template>
123
- <script>
124
- import XForm from '@vue2-client/base-client/components/common/XForm'
125
- import XAddForm from '@vue2-client/base-client/components/common/XAddForm'
126
- import XAddReport from '@vue2-client/base-client/components/common/XAddReport'
127
- import XTable from '@vue2-client/base-client/components/common/XTable'
128
- import XTree from '@vue2-client/base-client/components/common/XTree'
129
- import XImportExcel from '@vue2-client/base-client/components/common/XImportExcel'
130
- import {
131
- getConfigByName,
132
- getConfigByLogic,
133
- parseConfig, runLogic, getConfigByNameAsync,
134
- } from '@vue2-client/services/api/common'
135
- import { mapState } from 'vuex'
136
- import XTreePro from '@vue2-client/base-client/components/common/XTree/XTreePro.vue'
137
- import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
138
- import { getRealKeyData } from '@vue2-client/utils/util'
139
- import * as util from '@vue2-client/utils/util'
140
- import UserInfoDetailManage from '@vue2-client/pages/userInfoDetailManage/index.vue'
141
-
142
- export default {
143
- name: 'XFormTable',
144
- components: {
145
- UserInfoDetailManage,
146
- XTreePro,
147
- XTable,
148
- XForm,
149
- XTree,
150
- XAddForm,
151
- XAddReport,
152
- XImportExcel
153
- },
154
- provide () {
155
- return {
156
- getSelf: () => this,
157
- emitEvent: this.emitEvent.bind(this)
158
- }
159
- },
160
- inject: {
161
- getSelectedId: {
162
- default: () => () => {
163
- console.warn('getSelectedId is not provided.')
164
- return null
165
- },
166
- },
167
- setGlobalData: {
168
- default: () => () => {
169
- console.warn('setGlobalData is not provided.')
170
- return null
171
- },
172
- },
173
- getGlobalData: {
174
- default: () => () => {
175
- console.warn('getGlobalData is not provided.')
176
- return null
177
- },
178
- },
179
- getSelectedData: {
180
- default: () => () => {
181
- console.warn('getSelectedData is not provided.')
182
- return null
183
- },
184
- },
185
- getMixinData: {
186
- default: () => () => {
187
- console.warn('getMixinData is not provided.')
188
- return {}
189
- },
190
- },
191
- getOutEnv: {
192
- default: () => () => {
193
- console.warn('getOutEnv is not provided.')
194
- return {}
195
- },
196
- },
197
- currUser: {
198
- default: () => {
199
- console.warn('currUser is not provided.')
200
- return { id: null, name: 'Guest' }
201
- },
202
- },
203
-
204
- /**
205
- * 祖先组件注入的自定义函数对象
206
- * 此对象包含祖先组件通过provide/inject机制注入的各种自定义函数
207
- * 子组件可以通过this.generalFunction来访问这些函数
208
- * 使用示例:
209
- * - this.generalFunction.handleCustomEvent(data)
210
- * - this.generalFunction.submitForm(formData)
211
- * - this.generalFunction.validateData(data)
212
- */
213
- generalFunction: {
214
- default: () => {
215
- console.warn('generalFunction is not provided.')
216
- return null
217
- }
218
- }
219
- },
220
- data () {
221
- return {
222
- // 加载状态
223
- loading: false,
224
- // 图标样式
225
- iconStyle: {
226
- position: 'relative',
227
- top: '1px'
228
- },
229
- loadError: false,
230
- moveType: false,
231
- // 添加按钮对应的配置名
232
- moveconfig: '',
233
- // 实际查询配置内容
234
- realQueryConfig: {},
235
- toggleIsFormIcon: 'vertical-align-top',
236
- table_selectedRowKeys: [],
237
- table_selectedRows: [],
238
- // 数据只有一页时是否展示分页,true:展示,auto:隐藏
239
- showPagination: true,
240
- isMounted: false
241
- }
242
- },
243
- computed: {
244
- ...mapState('setting', ['isMobile'])
245
- },
246
- props: {
247
- // 业务名称
248
- title: {
249
- type: String,
250
- default: ''
251
- },
252
- // 外部传入的选中行keys
253
- externalSelectedRowKeys: {
254
- type: Array,
255
- default: () => []
256
- },
257
- // 卡片标题
258
- crudTitle: {
259
- type: String,
260
- default: null
261
- },
262
- // 查询配置文件名
263
- queryParamsName: {
264
- type: String,
265
- default: null
266
- },
267
- // 配置所属命名空间
268
- serviceName: {
269
- type: String,
270
- default: process.env.VUE_APP_SYSTEM_NAME
271
- },
272
- // 查询配置文件Json,用于查询配置生成器的预览
273
- queryParamsJson: {
274
- type: Object,
275
- default: null
276
- },
277
- // xTree 配置
278
- xTreeConfigName: {
279
- type: String,
280
- default: null
281
- },
282
- // 业务逻辑名称, 通过logic获取表单表格配置
283
- logicName: {
284
- type: String,
285
- default: null
286
- },
287
- // 执行logic传递的参数
288
- logicParam: {
289
- type: Object,
290
- default: () => {
291
- }
292
- },
293
- // 固定新增表单
294
- fixedAddForm: {
295
- type: Object,
296
- default: () => {
297
- return {}
298
- }
299
- },
300
- // 固定查询表单
301
- fixedQueryForm: {
302
- type: Object,
303
- default: () => {
304
- return {}
305
- }
306
- },
307
- // 预览模式
308
- viewMode: {
309
- type: Boolean,
310
- default: () => {
311
- return false
312
- }
313
- },
314
- // 本地编辑模式
315
- localEditMode: {
316
- type: Boolean,
317
- default: () => {
318
- return false
319
- }
320
- },
321
- // 行选择模式
322
- rowSelectMode: {
323
- type: Boolean,
324
- default: () => {
325
- return false
326
- }
327
- },
328
- // 行选择模式-允许选中行数量,0:任意数量行,大于0:指定值数量的行
329
- allowSelectRowNum: {
330
- type: Number,
331
- default: () => {
332
- return 0
333
- }
334
- },
335
- // 环境
336
- env: {
337
- type: String,
338
- default: () => {
339
- return 'prod'
340
- }
341
- },
342
- // 调用logic获取数据源的追加参数
343
- getDataParams: {
344
- type: Object,
345
- default: undefined
346
- },
347
- // 可以控制组件中导出等按钮的隐藏
348
- buttonState: {
349
- type: Object,
350
- default: undefined
351
- },
352
- // 是否自定义新增按钮的功能
353
- customAdd: {
354
- type: Boolean,
355
- default: false
356
- },
357
- reportQueryName: {
358
- type: String,
359
- default: undefined,
360
- },
361
- // 是否自定义删除按钮的功能
362
- customDelete: {
363
- type: Boolean,
364
- default: false
365
- },
366
- // 是否自定义修改按钮的功能
367
- customEdit: {
368
- type: Boolean,
369
- default: false
370
- },
371
- // 是否自定义增加按钮
372
- customMove: {
373
- type: Boolean,
374
- default: false
375
- },
376
- // 自适应底部边距
377
- extraHeight: {
378
- type: Number,
379
- default: 80
380
- },
381
- // 是否禁用右侧操作行为
382
- disableAction: {
383
- type: Boolean,
384
- default: false
385
- },
386
- // 额外参数,用于控制组件行为
387
- extraParams: {
388
- type: Object,
389
- default: () => {
390
- return {}
391
- }
392
- },
393
- /**
394
- * 额外数据对象
395
- * 类型:Object
396
- * 默认值:返回一个空对象
397
- * 用途:用于传递组件需要的额外数据参数,此参数在点击导入时会将对象传入到自定义前后置插槽业务中
398
- */
399
- extraData: {
400
- type: Object,
401
- default: () => {
402
- return {}
403
- }
404
- }
405
- },
406
- watch: {
407
- logicParam: {
408
- handler () {
409
- this.initConfig()
410
- },
411
- deep: true
412
- },
413
- queryParamsJson: {
414
- handler () {
415
- this.initConfig()
416
- },
417
- deep: true
418
- },
419
- queryParamsName: {
420
- handler () {
421
- this.initConfig()
422
- }
423
- },
424
- serviceName: {
425
- handler () {
426
- this.initConfig()
427
- }
428
- }
429
- },
430
- methods: {
431
- runLogic,
432
- getRealKeyData,
433
- getConfigByNameAsync,
434
- getConfigByName,
435
- customEvent (func, data) {
436
- this.$emit(func, data)
437
- },
438
- columnClick (key, value, record) {
439
- this.$emit('columnClick', key, value, record)
440
- },
441
- gotoUserDetail (key, value, record) {
442
- this.$refs.userInfo.init(getRealKeyData(record))
443
- },
444
- // 获取主表的数据内容,去掉主表别名
445
- getPrimaryData (rows) {
446
- const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
447
- const prefix = `${alias}_` // 构建前缀
448
- const result = []
449
-
450
- // 遍历 rows 的每一项,提取符合条件的数据
451
- rows.forEach(row => {
452
- const itemResult = {}
453
- Object.keys(row).forEach(key => {
454
- if (key.startsWith(prefix)) {
455
- const newKey = key.slice(prefix.length) // 去掉前缀
456
- itemResult[newKey] = row[key] // 添加到结果对象中
457
- }
458
- })
459
- result.push(itemResult) // 将处理后的项添加到结果数组中
460
- })
461
-
462
- return result // 返回去掉前缀后的对象数组
463
- },
464
-
465
- // 给数据区域添加主表数据,给的数据没有主表别名,放着时添加主表别名
466
- pushPrimaryData (rows) {
467
- const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
468
- const prefix = `${alias}_` // 构建前缀
469
- const result = rows.map(row => {
470
- const itemResult = {}
471
- Object.keys(row).forEach(key => {
472
- itemResult[prefix + key] = row[key] // 复制原始数据
473
- })
474
- return itemResult // 返回添加了主表别名的数据
475
- })
476
- // 把结果添加到数据区
477
- this.getTableData().push(...result)
478
- },
479
-
480
- // 设置固定查询条件,主表别名自动带
481
- setFixedQueryForm (data) {
482
- const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
483
- const prefixedData = {}
484
-
485
- // 为每个键添加主表别名
486
- Object.keys(data).forEach(key => {
487
- prefixedData[`${alias}_${key}`] = data[key]
488
- })
489
-
490
- Object.assign(this.fixedQueryForm, prefixedData)
491
- },
492
-
493
- importExcelOk (data) {
494
- this.$emit('importExcelOk', data)
495
- },
496
- initConfig () {
497
- this.loading = true
498
- this.loadError = false
499
- if (this.queryParamsName) {
500
- this.getConfig()
501
- } else if (this.queryParamsJson) {
502
- this.getConfigBySource()
503
- } else if (this.logicName && this.logicParam) {
504
- this.getColumnJsonByLogic()
505
- } else {
506
- this.loading = false
507
- this.loadError = true
508
- }
509
- },
510
-
511
- getConfig () {
512
- getConfigByName(this.queryParamsName, this.serviceName, (res) => {
513
- if (!res) {
514
- this.loading = false
515
- this.loadError = true
516
- return
517
- }
518
- this.updateComponents(res)
519
- }, this.env === 'dev')
520
- },
521
- getConfigBySource () {
522
- parseConfig(this.queryParamsJson, 'CRUD_FORM', this.serviceName, this.env === 'dev').then(res => {
523
- if (!res) {
524
- this.loading = false
525
- this.loadError = true
526
- return
527
- }
528
- this.updateComponents(res, true)
529
- })
530
- },
531
- getColumnJsonByLogic () {
532
- getConfigByLogic(this.logicName, this.logicParam, this.serviceName, (res) => {
533
- if (!res) {
534
- this.loading = false
535
- this.loadError = true
536
- return
537
- }
538
- this.updateComponents(res, true)
539
- }, this.env === 'dev')
540
- },
541
-
542
- /**
543
- * 更新子组件
544
- * @param res 参数
545
- * @param setQueryParams 是否设置queryParams参数
546
- */
547
- updateComponents (res, setQueryParams) {
548
- this.realQueryConfig = res
549
- if (this.$refs.xTable && this.$refs.xForm && this.$refs.xAddForm) {
550
- // 设置添加按钮对应的配置名
551
- this.moveconfig = res.moveconfig
552
- this.showPagination = res.showPagination === null ? true : res.showPagination
553
- // 是否展示排序按钮控制
554
- if (res.showSortIcon !== null && !res.showSortIcon) {
555
- res.columnJson.forEach(item => {
556
- item.sorter = false
557
- })
558
- }
559
- const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
560
- const initTable = () => {
561
- // 初始化 xTable 子组件
562
- this.$refs.xTable.init({
563
- formItems: res.formJson,
564
- queryParams: setQueryParams ? res : null,
565
- tableColumns: res.columnJson,
566
- buttonState: Object.assign(res.buttonState, this.buttonState),
567
- title: this.title || res.title,
568
- viewMode: this.viewMode,
569
- localEditMode: localEditMode,
570
- rowSelectMode: this.rowSelectMode,
571
- allowSelectRowNum: this.allowSelectRowNum,
572
- tableSummaryMap: res.tableSummaryMap,
573
- serviceName: this.serviceName,
574
- env: this.env,
575
- form: this.$refs.xForm.form,
576
- summaryUpdate: true,
577
- disableAction: this.disableAction,
578
- extraData: this.extraData,
579
- rowStyleFunction: res.rowStyleFunction,
580
- ...res
581
- })
582
- if (this.realQueryConfig?.funcData?.pageMounted) {
583
- executeStrFunctionByContext(this, this.realQueryConfig.funcData.pageMounted, [util, runLogic, getConfigByNameAsync])
584
- }
585
- this.$emit('afterTableInit')
586
- }
587
- // 初始化 xForm 子组件
588
- if (!localEditMode && !this.rowSelectMode) {
589
- this.$refs.xForm.init({
590
- queryParamsName: this.queryParamsName || 'localConfig',
591
- formItems: res.formJson,
592
- serviceName: this.serviceName,
593
- getDataParams: this.getDataParams,
594
- simpleMode: res.simpleMode,
595
- funcData: res.funcData,
596
- env: this.env
597
- })
598
- } else {
599
- // TODO 此处应删除
600
- initTable()
601
- }
602
- // 初始化 xTable 子组件
603
- // 等待 x-from-item 的 mounted 完成
604
- this.$refs.xForm.$on('itemsMounted', initTable)
605
- }
606
- this.loading = false
607
- },
608
- // 自定义按钮
609
- editButtonStateDataClick (functionName, rows) {
610
- console.log('functionName', functionName)
611
- console.log('rows', rows)
612
- this.$emit(functionName, rows)
613
- },
614
-
615
- /**
616
- * 提交查询表单事件
617
- * @param res 参数
618
- */
619
- onSearchSubmit (res) {
620
- if (res.valid) {
621
- // 表单赋值
622
- this.$refs.xTable.setQueryForm(res.form)
623
- this.$refs.xTable.summaryUpdate = true
624
- // commit
625
- this.$emit('afterSearchSubmit', res)
626
- } else {
627
- return false
628
- }
629
- },
630
- active (props) {
631
- let num = false
632
- for (const key in props) {
633
- // eslint-disable-next-line no-prototype-builtins
634
- if (this.$props.hasOwnProperty(key)) {
635
- if (this.$props[key] instanceof Object) {
636
- this.$props[key] = JSON.parse(props[key])
637
- } else {
638
- this.$props[key] = props[key]
639
- }
640
- num = true
641
- }
642
- }
643
- if (num) {
644
- this.initConfig()
645
- }
646
- },
647
- /**
648
- * 提交新增/修改表单后事件
649
- */
650
- onAddOrEditSubmitAfterSubmit (res) {
651
- this.refreshTable(res.businessType === '新增')
652
- // commit
653
- this.$emit('afterSubmit', res)
654
- },
655
- /**
656
- * 表格查询后事件
657
- * @param res 参数
658
- * @param conditionParams 查询条件
659
- */
660
- afterQuery (res, conditionParams) {
661
- this.$emit('afterQuery', res, conditionParams)
662
- },
663
- /**
664
- * 详情按钮事件
665
- * @param record 本条数据
666
- * @param id 数据标识
667
- * @param actionType 操作类型
668
- * @param fun 向上级传递的事件
669
- */
670
- action (record, id, actionType, fun = 'action', index) {
671
- this.$emit('innerXFormTableEmit', fun, record, id, actionType, index, this)
672
- this.$emit(fun, record, id, actionType, index, this)
673
- },
674
- treeOnChecked (checkedKeys, deepNodes, deepKeys) {
675
- this.$emit('treeOnChecked', checkedKeys, deepNodes, deepKeys)
676
- },
677
- treeBtnFuncClick (index, func) {
678
- this.$emit('treeBtnFuncClick', index, func)
679
- },
680
- /**
681
- * 新增按钮事件
682
- */
683
- add () {
684
- if (this.customAdd) {
685
- this.$emit('add')
686
- } else {
687
- if (this.$listeners.curdAddBefore) {
688
- this.$emit('curdAddBefore', this.addFormInit)
689
- } else {
690
- this.addFormInit()
691
- }
692
- }
693
- },
694
- addFormInit () {
695
- const res = this.realQueryConfig
696
- const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
697
- this.$refs.xAddForm.init({
698
- businessType: '新增',
699
- title: this.title || res.title,
700
- isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
701
- configName: this.queryParamsName,
702
- configContent: this.queryParamsJson,
703
- formItems: res.formJson,
704
- viewMode: this.viewMode,
705
- localEditMode: localEditMode,
706
- isKeyHandle: !Boolean(localEditMode),
707
- serviceName: this.serviceName,
708
- fixedAddForm: this.fixedAddForm,
709
- getDataParams: this.getDataParams,
710
- layout: res.xAddFormLayout || 'horizontal',
711
- xAddFormLayoutWidth: res.xAddFormLayoutWidth,
712
- formItemLayout: res.formItemLayout || {},
713
- env: this.env
714
- })
715
- },
716
- /**
717
- * 添加按钮事件
718
- */
719
- move () {
720
- this.moveType = true
721
- this.$nextTick(
722
- () => {
723
- this.$refs.xAddReport.init({
724
- configName: this.moveconfig,
725
- selectedId: this.fixedAddForm.selected_id
726
- })
727
- }
728
- )
729
- },
730
- /**
731
- * 修改按钮事件
732
- * @param modifyModelData 修改表单数据
733
- */
734
- edit (modifyModelData) {
735
- if (this.customEdit) {
736
- this.$emit('edit')
737
- } else {
738
- const res = this.realQueryConfig
739
- const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
740
- this.$refs.xAddForm.init({
741
- businessType: '修改',
742
- title: this.title || res.title,
743
- isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
744
- configName: this.queryParamsName,
745
- configContent: this.queryParamsJson,
746
- formItems: res.formJson,
747
- viewMode: this.viewMode,
748
- localEditMode: localEditMode,
749
- isKeyHandle: !Boolean(localEditMode),
750
- serviceName: this.serviceName,
751
- fixedAddForm: this.fixedAddForm,
752
- getDataParams: this.getDataParams,
753
- modifyModelData: modifyModelData,
754
- layout: res.xAddFormLayout || 'horizontal',
755
- env: this.env
756
- })
757
- }
758
- },
759
- /**
760
- * 删除按钮事件
761
- */
762
- del (keys, callback) {
763
- if (this.customDelete) {
764
- this.$emit('del', keys, callback)
765
- }
766
- },
767
- /**
768
- * 删除后事件
769
- * @param res
770
- */
771
- afterDelete (res) {
772
- this.$emit('afterDelete', res)
773
- },
774
- /**
775
- * 行选择事件
776
- * @param row 选中行
777
- */
778
- rowChoose (row) {
779
- this.$emit('rowChoose', row)
780
- },
781
- /**
782
- * 本地编辑模式下校验表格并同步本地数据
783
- * @param currRow 当前行
784
- * @param defaultAppendRowData 默认追加的行数据
785
- */
786
- validateTableAndSyncData (currRow, defaultAppendRowData) {
787
- this.$refs.xTable.validateTableAndSyncData(currRow, defaultAppendRowData)
788
- },
789
- /**
790
- * 更多条件是否展示
791
- */
792
- toggleAdvanced () {
793
- this.$refs.xTable.setScrollYHeight({})
794
- },
795
- /**
796
- * 查询表单部分显示/隐藏切换
797
- */
798
- toggleIsFormShow () {
799
- this.toggleIsFormIcon = this.toggleIsFormIcon === 'vertical-align-top' ? 'vertical-align-bottom' : 'vertical-align-top'
800
- this.$refs.xForm.toggleVisible()
801
- this.$refs.xTable.setScrollYHeight({})
802
- },
803
- /**
804
- * 选择列事件
805
- * @param selectedRowKeys 选中列Key集合
806
- * @param selectedRows 选中列
807
- */
808
- selectRow (selectedRowKeys, selectedRows) {
809
- this.table_selectedRowKeys = selectedRowKeys
810
- this.table_selectedRows = selectedRows
811
- this.$emit('selectRow', selectedRowKeys, selectedRows)
812
- },
813
- /**
814
- * 清除勾选数据
815
- */
816
- clearRowKeys () {
817
- this.$refs.xTable.clearRowKeys()
818
- },
819
- /**
820
- * 刷新表格
821
- * @param toFirstPage 是否到第一页
822
- */
823
- refreshTable (toFirstPage = true) {
824
- this.$refs.xTable.refresh(toFirstPage)
825
- },
826
- /**
827
- * 刷新表格
828
- * @param toFirstPage 是否到第一页
829
- */
830
- refresh (toFirstPage = true) {
831
- this.$refs.xTable.refresh(toFirstPage)
832
- },
833
- /**
834
- * 获取表格数据
835
- */
836
- getTableData () {
837
- return this.$refs.xTable.getTableData()
838
- },
839
- // 在行编辑等情况下,让界面生效
840
- update () {
841
- this.getTableData().push(...[])
842
- },
843
-
844
- /**
845
- * 设置表格数据
846
- */
847
- setTableData (data) {
848
- this.$refs.xTable.setTableData(data)
849
- },
850
- /**
851
- * 表单本地提交
852
- */
853
- onLocalSubmit (res, callback) {
854
- const form = res.realForm
855
- if (res.businessType === '新增') {
856
- this.$refs.xTable.appendLocalData(form)
857
- } else {
858
- this.$refs.xTable.modifyLocalData(form['序号'], form)
859
- }
860
- this.$message.success(res.businessType + '成功!')
861
- this.onAddOrEditSubmitAfterSubmit(res, callback)
862
- if (callback) {
863
- callback()
864
- }
865
- },
866
- emitFunc (func, data, value) {
867
- this.$emit(func, data, value)
868
- this.$emit('getEmitFuncData', func, data, value)
869
- },
870
- // 直接转发事件的函数
871
- emitEvent (event, ...args) {
872
- this.$emit(event, ...args)
873
- },
874
- // 添加处理 rowClick 的方法
875
- handleRowClick (record) {
876
- this.$emit('rowClick', record)
877
- },
878
- beforeDataChange (record) {
879
- this.$emit('beforeDataChange', record)
880
- },
881
- onExpand (expanded, record) {
882
- this.$emit('expand', expanded, record)
883
- }
884
- },
885
- action: {
886
- /**
887
- * 实现doAction方法
888
- */
889
- doAction (actionType, args, data) {
890
- switch (actionType) {
891
- case 'refreshTable':
892
- for (const item in args) {
893
- console.log('item', item)
894
- }
895
- break
896
- default:
897
- break
898
- }
899
- }
900
- },
901
- mounted () {
902
- if (!this.isMounted) {
903
- // 防止多次调用
904
- // 不知道为啥他会执行两次 mounted 暂时处理方式
905
- this.initConfig()
906
- this.isMounted = true
907
- }
908
- if (this.getSelectedData && typeof this.getSelectedData === 'function') {
909
- const selectedId = this.getSelectedData()
910
- if (!selectedId) {
911
- return
912
- }
913
- if (typeof selectedId === 'object') {
914
- const data = JSON.parse(JSON.stringify(selectedId))
915
- if (data.selectedId) {
916
- data.selected_id = data.selectedId
917
- delete data.selectedId
918
- }
919
- Object.assign(this.fixedAddForm, data)
920
- Object.assign(this.fixedQueryForm, data)
921
- } else {
922
- Object.assign(this.fixedAddForm, { selected_id: selectedId })
923
- Object.assign(this.fixedQueryForm, { selected_id: selectedId })
924
- }
925
- }
926
- }
927
- }
928
- </script>
929
- <style lang="less" scoped>
930
- .crud_title {
931
- height: 32px;
932
- font-size: 16px;
933
- font-weight: 500;
934
- color: #000000d9;
935
- line-height: 32px;
936
- margin-bottom: 12px;
937
- }
938
- </style>
1
+ <template>
2
+ <a-row type="flex" :gutter="{ xs: 8, sm: 10, md: 12, lg: 16 }">
3
+ <a-col
4
+ :xs="14"
5
+ :sm="14"
6
+ :md="12"
7
+ :lg="9"
8
+ :xl="6"
9
+ :xxl="5"
10
+ v-if="xTreeConfigName"
11
+ :style="{ maxWidth: '400px'}">
12
+ <x-tree-pro
13
+ :config-name="xTreeConfigName"
14
+ :env="env"
15
+ @action="action"
16
+ @btnFuncClick="treeBtnFuncClick"
17
+ @treeOnChecked="treeOnChecked"
18
+ ref="xtree"
19
+ ></x-tree-pro>
20
+ </a-col>
21
+ <a-col
22
+ :xs="xTreeConfigName ? 10 : 24"
23
+ :sm="xTreeConfigName ? 10 : 24"
24
+ :md="xTreeConfigName ? 12 : 24"
25
+ :lg="xTreeConfigName ? 15 : 24"
26
+ :xl="xTreeConfigName ? 18 : 24"
27
+ :xxl="xTreeConfigName ? 19 : 24">
28
+ <a-skeleton :loading="loading" :paragraph="{ rows: 4 }"/>
29
+ <a-row style="height: 12px" v-if="xTreeConfigName"></a-row>
30
+ <div v-show="!loading">
31
+ <template v-if="!loadError">
32
+ <x-add-form
33
+ ref="xAddForm"
34
+ @onLocalSubmit="onLocalSubmit"
35
+ @x-form-item-emit-func="emitFunc"
36
+ @afterSubmit="onAddOrEditSubmitAfterSubmit"
37
+ >
38
+ <template slot="groupFormItems" slot-scope="{form, model, rules, modifyModelData}">
39
+ <slot
40
+ name="groupFormItems"
41
+ :form="form"
42
+ :model="model"
43
+ :rules="rules"
44
+ :modifyModelData="modifyModelData"></slot>
45
+ </template>
46
+ </x-add-form>
47
+ <x-add-report
48
+ v-if="moveType"
49
+ ref="xAddReport"
50
+ >
51
+ </x-add-report>
52
+ <div v-if="crudTitle" class="crud_title">
53
+ {{ crudTitle }}
54
+ </div>
55
+ <x-form
56
+ ref="xForm"
57
+ @toggleAdvanced="toggleAdvanced"
58
+ @onSubmit="onSearchSubmit">
59
+ <slot name="formBtnExpand"></slot>
60
+ </x-form>
61
+ <x-table
62
+ ref="xTable"
63
+ :fixedQueryForm="fixedQueryForm"
64
+ :queryParamsName="queryParamsName"
65
+ :query-params-json="queryParamsJson"
66
+ :show-pagination="showPagination"
67
+ :customDelete="customDelete"
68
+ :extraHeight="extraHeight"
69
+ :serviceName="serviceName"
70
+ :pageMaxSize="realQueryConfig.queryPagesSize"
71
+ :externalSelectedRowKeys="externalSelectedRowKeys"
72
+ @add="add"
73
+ @move="move"
74
+ @edit="edit"
75
+ @del="del"
76
+ @rowChoose="rowChoose"
77
+ @customEvent="customEvent"
78
+ @afterDelete="afterDelete"
79
+ @action="action"
80
+ @selectRow="selectRow"
81
+ @afterQuery="afterQuery"
82
+ @columnClick="columnClick"
83
+ @gotoUserDetail="gotoUserDetail"
84
+ @editButtonStateDataClick="editButtonStateDataClick"
85
+ @importExcelOk="importExcelOk"
86
+ @rowClick="handleRowClick"
87
+ @beforeDataChange="beforeDataChange"
88
+ @expand="onExpand">
89
+ <template slot="leftButton" slot-scope="{selectedRowKeys, selectedRows}">
90
+ <slot name="leftButton" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
91
+ </template>
92
+ <template slot="button" slot-scope="{selectedRowKeys, selectedRows}">
93
+ <slot name="button" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
94
+ </template>
95
+ <template slot="rightBtnExpand" slot-scope="{selectedRowKeys, selectedRows}">
96
+ <slot name="rightBtnExpand" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
97
+ <a-tooltip title="收起查询条件" placement="bottom">
98
+ <a-button @click="toggleIsFormShow">
99
+ <a-icon :style="iconStyle" :type="toggleIsFormIcon"/>
100
+ </a-button>
101
+ </a-tooltip>
102
+ </template>
103
+ <!-- 底部插槽 -->
104
+ <template slot="footer" slot-scope="{selectedRowKeys, selectedRows}">
105
+ <slot name="footer" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
106
+ </template>
107
+ <!-- excel导入说明插槽 -->
108
+ <template #importExcelSlot>
109
+ <slot name="importExcelSlot"></slot>
110
+ </template>
111
+ </x-table>
112
+ </template>
113
+ <template v-else>
114
+ <a-empty>
115
+ <span slot="description"> 页面配置不存在,请联系系统管理员</span>
116
+ </a-empty>
117
+ </template>
118
+ </div>
119
+ </a-col>
120
+ <UserInfoDetailManage ref="userInfo" @close="refresh(false)"/>
121
+ </a-row>
122
+ </template>
123
+ <script>
124
+ import XForm from '@vue2-client/base-client/components/common/XForm'
125
+ import XAddForm from '@vue2-client/base-client/components/common/XAddForm'
126
+ import XAddReport from '@vue2-client/base-client/components/common/XAddReport'
127
+ import XTable from '@vue2-client/base-client/components/common/XTable'
128
+ import XTree from '@vue2-client/base-client/components/common/XTree'
129
+ import XImportExcel from '@vue2-client/base-client/components/common/XImportExcel'
130
+ import {
131
+ getConfigByName,
132
+ getConfigByLogic,
133
+ parseConfig, runLogic, getConfigByNameAsync,
134
+ } from '@vue2-client/services/api/common'
135
+ import { mapState } from 'vuex'
136
+ import XTreePro from '@vue2-client/base-client/components/common/XTree/XTreePro.vue'
137
+ import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
138
+ import { getRealKeyData } from '@vue2-client/utils/util'
139
+ import * as util from '@vue2-client/utils/util'
140
+ import UserInfoDetailManage from '@vue2-client/pages/userInfoDetailManage/index.vue'
141
+
142
+ export default {
143
+ name: 'XFormTable',
144
+ components: {
145
+ UserInfoDetailManage,
146
+ XTreePro,
147
+ XTable,
148
+ XForm,
149
+ XTree,
150
+ XAddForm,
151
+ XAddReport,
152
+ XImportExcel
153
+ },
154
+ provide () {
155
+ return {
156
+ getSelf: () => this,
157
+ emitEvent: this.emitEvent.bind(this)
158
+ }
159
+ },
160
+ inject: {
161
+ getSelectedId: {
162
+ default: () => () => {
163
+ console.warn('getSelectedId is not provided.')
164
+ return null
165
+ },
166
+ },
167
+ setGlobalData: {
168
+ default: () => () => {
169
+ console.warn('setGlobalData is not provided.')
170
+ return null
171
+ },
172
+ },
173
+ getGlobalData: {
174
+ default: () => () => {
175
+ console.warn('getGlobalData is not provided.')
176
+ return null
177
+ },
178
+ },
179
+ getSelectedData: {
180
+ default: () => () => {
181
+ console.warn('getSelectedData is not provided.')
182
+ return null
183
+ },
184
+ },
185
+ getMixinData: {
186
+ default: () => () => {
187
+ console.warn('getMixinData is not provided.')
188
+ return {}
189
+ },
190
+ },
191
+ getOutEnv: {
192
+ default: () => () => {
193
+ console.warn('getOutEnv is not provided.')
194
+ return {}
195
+ },
196
+ },
197
+ currUser: {
198
+ default: () => {
199
+ console.warn('currUser is not provided.')
200
+ return { id: null, name: 'Guest' }
201
+ },
202
+ },
203
+
204
+ /**
205
+ * 祖先组件注入的自定义函数对象
206
+ * 此对象包含祖先组件通过provide/inject机制注入的各种自定义函数
207
+ * 子组件可以通过this.generalFunction来访问这些函数
208
+ * 使用示例:
209
+ * - this.generalFunction.handleCustomEvent(data)
210
+ * - this.generalFunction.submitForm(formData)
211
+ * - this.generalFunction.validateData(data)
212
+ */
213
+ generalFunction: {
214
+ default: () => {
215
+ console.warn('generalFunction is not provided.')
216
+ return null
217
+ }
218
+ }
219
+ },
220
+ data () {
221
+ return {
222
+ // 加载状态
223
+ loading: false,
224
+ // 图标样式
225
+ iconStyle: {
226
+ position: 'relative',
227
+ top: '1px'
228
+ },
229
+ loadError: false,
230
+ moveType: false,
231
+ // 添加按钮对应的配置名
232
+ moveconfig: '',
233
+ // 实际查询配置内容
234
+ realQueryConfig: {},
235
+ toggleIsFormIcon: 'vertical-align-top',
236
+ table_selectedRowKeys: [],
237
+ table_selectedRows: [],
238
+ // 数据只有一页时是否展示分页,true:展示,auto:隐藏
239
+ showPagination: true,
240
+ isMounted: false
241
+ }
242
+ },
243
+ computed: {
244
+ ...mapState('setting', ['isMobile'])
245
+ },
246
+ props: {
247
+ // 业务名称
248
+ title: {
249
+ type: String,
250
+ default: ''
251
+ },
252
+ // 外部传入的选中行keys
253
+ externalSelectedRowKeys: {
254
+ type: Array,
255
+ default: () => []
256
+ },
257
+ // 卡片标题
258
+ crudTitle: {
259
+ type: String,
260
+ default: null
261
+ },
262
+ // 查询配置文件名
263
+ queryParamsName: {
264
+ type: String,
265
+ default: null
266
+ },
267
+ // 配置所属命名空间
268
+ serviceName: {
269
+ type: String,
270
+ default: process.env.VUE_APP_SYSTEM_NAME
271
+ },
272
+ // 查询配置文件Json,用于查询配置生成器的预览
273
+ queryParamsJson: {
274
+ type: Object,
275
+ default: null
276
+ },
277
+ // xTree 配置
278
+ xTreeConfigName: {
279
+ type: String,
280
+ default: null
281
+ },
282
+ // 业务逻辑名称, 通过logic获取表单表格配置
283
+ logicName: {
284
+ type: String,
285
+ default: null
286
+ },
287
+ // 执行logic传递的参数
288
+ logicParam: {
289
+ type: Object,
290
+ default: () => {
291
+ }
292
+ },
293
+ // 固定新增表单
294
+ fixedAddForm: {
295
+ type: Object,
296
+ default: () => {
297
+ return {}
298
+ }
299
+ },
300
+ // 固定查询表单
301
+ fixedQueryForm: {
302
+ type: Object,
303
+ default: () => {
304
+ return {}
305
+ }
306
+ },
307
+ // 预览模式
308
+ viewMode: {
309
+ type: Boolean,
310
+ default: () => {
311
+ return false
312
+ }
313
+ },
314
+ // 本地编辑模式
315
+ localEditMode: {
316
+ type: Boolean,
317
+ default: () => {
318
+ return false
319
+ }
320
+ },
321
+ // 行选择模式
322
+ rowSelectMode: {
323
+ type: Boolean,
324
+ default: () => {
325
+ return false
326
+ }
327
+ },
328
+ // 行选择模式-允许选中行数量,0:任意数量行,大于0:指定值数量的行
329
+ allowSelectRowNum: {
330
+ type: Number,
331
+ default: () => {
332
+ return 0
333
+ }
334
+ },
335
+ // 环境
336
+ env: {
337
+ type: String,
338
+ default: () => {
339
+ return 'prod'
340
+ }
341
+ },
342
+ // 调用logic获取数据源的追加参数
343
+ getDataParams: {
344
+ type: Object,
345
+ default: undefined
346
+ },
347
+ // 可以控制组件中导出等按钮的隐藏
348
+ buttonState: {
349
+ type: Object,
350
+ default: undefined
351
+ },
352
+ // 是否自定义新增按钮的功能
353
+ customAdd: {
354
+ type: Boolean,
355
+ default: false
356
+ },
357
+ reportQueryName: {
358
+ type: String,
359
+ default: undefined,
360
+ },
361
+ // 是否自定义删除按钮的功能
362
+ customDelete: {
363
+ type: Boolean,
364
+ default: false
365
+ },
366
+ // 是否自定义修改按钮的功能
367
+ customEdit: {
368
+ type: Boolean,
369
+ default: false
370
+ },
371
+ // 是否自定义增加按钮
372
+ customMove: {
373
+ type: Boolean,
374
+ default: false
375
+ },
376
+ // 自适应底部边距
377
+ extraHeight: {
378
+ type: Number,
379
+ default: 80
380
+ },
381
+ // 是否禁用右侧操作行为
382
+ disableAction: {
383
+ type: Boolean,
384
+ default: false
385
+ },
386
+ // 额外参数,用于控制组件行为
387
+ extraParams: {
388
+ type: Object,
389
+ default: () => {
390
+ return {}
391
+ }
392
+ },
393
+ /**
394
+ * 额外数据对象
395
+ * 类型:Object
396
+ * 默认值:返回一个空对象
397
+ * 用途:用于传递组件需要的额外数据参数,此参数在点击导入时会将对象传入到自定义前后置插槽业务中
398
+ */
399
+ extraData: {
400
+ type: Object,
401
+ default: () => {
402
+ return {}
403
+ }
404
+ }
405
+ },
406
+ watch: {
407
+ logicParam: {
408
+ handler () {
409
+ this.initConfig()
410
+ },
411
+ deep: true
412
+ },
413
+ queryParamsJson: {
414
+ handler () {
415
+ this.initConfig()
416
+ },
417
+ deep: true
418
+ },
419
+ queryParamsName: {
420
+ handler () {
421
+ this.initConfig()
422
+ }
423
+ },
424
+ serviceName: {
425
+ handler () {
426
+ this.initConfig()
427
+ }
428
+ }
429
+ },
430
+ methods: {
431
+ runLogic,
432
+ getRealKeyData,
433
+ getConfigByNameAsync,
434
+ getConfigByName,
435
+ customEvent (func, data) {
436
+ this.$emit(func, data)
437
+ },
438
+ columnClick (key, value, record) {
439
+ this.$emit('columnClick', key, value, record)
440
+ },
441
+ gotoUserDetail (key, value, record) {
442
+ this.$refs.userInfo.init(getRealKeyData(record))
443
+ },
444
+ // 获取主表的数据内容,去掉主表别名
445
+ getPrimaryData (rows) {
446
+ const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
447
+ const prefix = `${alias}_` // 构建前缀
448
+ const result = []
449
+
450
+ // 遍历 rows 的每一项,提取符合条件的数据
451
+ rows.forEach(row => {
452
+ const itemResult = {}
453
+ Object.keys(row).forEach(key => {
454
+ if (key.startsWith(prefix)) {
455
+ const newKey = key.slice(prefix.length) // 去掉前缀
456
+ itemResult[newKey] = row[key] // 添加到结果对象中
457
+ }
458
+ })
459
+ result.push(itemResult) // 将处理后的项添加到结果数组中
460
+ })
461
+
462
+ return result // 返回去掉前缀后的对象数组
463
+ },
464
+
465
+ // 给数据区域添加主表数据,给的数据没有主表别名,放着时添加主表别名
466
+ pushPrimaryData (rows) {
467
+ const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
468
+ const prefix = `${alias}_` // 构建前缀
469
+ const result = rows.map(row => {
470
+ const itemResult = {}
471
+ Object.keys(row).forEach(key => {
472
+ itemResult[prefix + key] = row[key] // 复制原始数据
473
+ })
474
+ return itemResult // 返回添加了主表别名的数据
475
+ })
476
+ // 把结果添加到数据区
477
+ this.getTableData().push(...result)
478
+ },
479
+
480
+ // 设置固定查询条件,主表别名自动带
481
+ setFixedQueryForm (data) {
482
+ const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
483
+ const prefixedData = {}
484
+
485
+ // 为每个键添加主表别名
486
+ Object.keys(data).forEach(key => {
487
+ prefixedData[`${alias}_${key}`] = data[key]
488
+ })
489
+
490
+ Object.assign(this.fixedQueryForm, prefixedData)
491
+ },
492
+
493
+ importExcelOk (data) {
494
+ this.$emit('importExcelOk', data)
495
+ },
496
+ initConfig () {
497
+ this.loading = true
498
+ this.loadError = false
499
+ if (this.queryParamsName) {
500
+ this.getConfig()
501
+ } else if (this.queryParamsJson) {
502
+ this.getConfigBySource()
503
+ } else if (this.logicName && this.logicParam) {
504
+ this.getColumnJsonByLogic()
505
+ } else {
506
+ this.loading = false
507
+ this.loadError = true
508
+ }
509
+ },
510
+
511
+ getConfig () {
512
+ getConfigByName(this.queryParamsName, this.serviceName, (res) => {
513
+ if (!res) {
514
+ this.loading = false
515
+ this.loadError = true
516
+ return
517
+ }
518
+ this.updateComponents(res)
519
+ }, this.env === 'dev')
520
+ },
521
+ getConfigBySource () {
522
+ parseConfig(this.queryParamsJson, 'CRUD_FORM', this.serviceName, this.env === 'dev').then(res => {
523
+ if (!res) {
524
+ this.loading = false
525
+ this.loadError = true
526
+ return
527
+ }
528
+ this.updateComponents(res, true)
529
+ })
530
+ },
531
+ getColumnJsonByLogic () {
532
+ getConfigByLogic(this.logicName, this.logicParam, this.serviceName, (res) => {
533
+ if (!res) {
534
+ this.loading = false
535
+ this.loadError = true
536
+ return
537
+ }
538
+ this.updateComponents(res, true)
539
+ }, this.env === 'dev')
540
+ },
541
+
542
+ /**
543
+ * 更新子组件
544
+ * @param res 参数
545
+ * @param setQueryParams 是否设置queryParams参数
546
+ */
547
+ updateComponents (res, setQueryParams) {
548
+ this.realQueryConfig = res
549
+ if (this.$refs.xTable && this.$refs.xForm && this.$refs.xAddForm) {
550
+ // 设置添加按钮对应的配置名
551
+ this.moveconfig = res.moveconfig
552
+ this.showPagination = res.showPagination === null ? true : res.showPagination
553
+ // 是否展示排序按钮控制
554
+ if (res.showSortIcon !== null && !res.showSortIcon) {
555
+ res.columnJson.forEach(item => {
556
+ item.sorter = false
557
+ })
558
+ }
559
+ const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
560
+ const initTable = () => {
561
+ // 初始化 xTable 子组件
562
+ this.$refs.xTable.init({
563
+ formItems: res.formJson,
564
+ queryParams: setQueryParams ? res : null,
565
+ tableColumns: res.columnJson,
566
+ buttonState: Object.assign(res.buttonState, this.buttonState),
567
+ title: this.title || res.title,
568
+ viewMode: this.viewMode,
569
+ localEditMode: localEditMode,
570
+ rowSelectMode: this.rowSelectMode,
571
+ allowSelectRowNum: this.allowSelectRowNum,
572
+ tableSummaryMap: res.tableSummaryMap,
573
+ serviceName: this.serviceName,
574
+ env: this.env,
575
+ form: this.$refs.xForm.form,
576
+ summaryUpdate: true,
577
+ disableAction: this.disableAction,
578
+ extraData: this.extraData,
579
+ rowStyleFunction: res.rowStyleFunction,
580
+ ...res
581
+ })
582
+ if (this.realQueryConfig?.funcData?.pageMounted) {
583
+ executeStrFunctionByContext(this, this.realQueryConfig.funcData.pageMounted, [util, runLogic, getConfigByNameAsync])
584
+ }
585
+ this.$emit('afterTableInit')
586
+ }
587
+ // 初始化 xForm 子组件
588
+ if (!localEditMode && !this.rowSelectMode) {
589
+ this.$refs.xForm.init({
590
+ queryParamsName: this.queryParamsName || 'localConfig',
591
+ formItems: res.formJson,
592
+ serviceName: this.serviceName,
593
+ getDataParams: this.getDataParams,
594
+ simpleMode: res.simpleMode,
595
+ funcData: res.funcData,
596
+ env: this.env
597
+ })
598
+ } else {
599
+ // TODO 此处应删除
600
+ initTable()
601
+ }
602
+ // 初始化 xTable 子组件
603
+ // 等待 x-from-item 的 mounted 完成
604
+ this.$refs.xForm.$on('itemsMounted', initTable)
605
+ }
606
+ this.loading = false
607
+ },
608
+ // 自定义按钮
609
+ editButtonStateDataClick (functionName, rows) {
610
+ console.log('functionName', functionName)
611
+ console.log('rows', rows)
612
+ this.$emit(functionName, rows)
613
+ },
614
+
615
+ /**
616
+ * 提交查询表单事件
617
+ * @param res 参数
618
+ */
619
+ onSearchSubmit (res) {
620
+ if (res.valid) {
621
+ // 表单赋值
622
+ this.$refs.xTable.setQueryForm(res.form)
623
+ this.$refs.xTable.summaryUpdate = true
624
+ // commit
625
+ this.$emit('afterSearchSubmit', res)
626
+ } else {
627
+ return false
628
+ }
629
+ },
630
+ active (props) {
631
+ let num = false
632
+ for (const key in props) {
633
+ // eslint-disable-next-line no-prototype-builtins
634
+ if (this.$props.hasOwnProperty(key)) {
635
+ if (this.$props[key] instanceof Object) {
636
+ this.$props[key] = JSON.parse(props[key])
637
+ } else {
638
+ this.$props[key] = props[key]
639
+ }
640
+ num = true
641
+ }
642
+ }
643
+ if (num) {
644
+ this.initConfig()
645
+ }
646
+ },
647
+ /**
648
+ * 提交新增/修改表单后事件
649
+ */
650
+ onAddOrEditSubmitAfterSubmit (res) {
651
+ this.refreshTable(res.businessType === '新增')
652
+ // commit
653
+ this.$emit('afterSubmit', res)
654
+ },
655
+ /**
656
+ * 表格查询后事件
657
+ * @param res 参数
658
+ * @param conditionParams 查询条件
659
+ */
660
+ afterQuery (res, conditionParams) {
661
+ this.$emit('afterQuery', res, conditionParams)
662
+ },
663
+ /**
664
+ * 详情按钮事件
665
+ * @param record 本条数据
666
+ * @param id 数据标识
667
+ * @param actionType 操作类型
668
+ * @param fun 向上级传递的事件
669
+ */
670
+ action (record, id, actionType, fun = 'action', index) {
671
+ this.$emit('innerXFormTableEmit', fun, record, id, actionType, index, this)
672
+ this.$emit(fun, record, id, actionType, index, this)
673
+ },
674
+ treeOnChecked (checkedKeys, deepNodes, deepKeys) {
675
+ this.$emit('treeOnChecked', checkedKeys, deepNodes, deepKeys)
676
+ },
677
+ treeBtnFuncClick (index, func) {
678
+ this.$emit('treeBtnFuncClick', index, func)
679
+ },
680
+ /**
681
+ * 新增按钮事件
682
+ */
683
+ add () {
684
+ if (this.customAdd) {
685
+ this.$emit('add')
686
+ } else {
687
+ if (this.$listeners.curdAddBefore) {
688
+ this.$emit('curdAddBefore', this.addFormInit)
689
+ } else {
690
+ this.addFormInit()
691
+ }
692
+ }
693
+ },
694
+ addFormInit () {
695
+ const res = this.realQueryConfig
696
+ const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
697
+ this.$refs.xAddForm.init({
698
+ businessType: '新增',
699
+ title: this.title || res.title,
700
+ isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
701
+ configName: this.queryParamsName,
702
+ configContent: this.queryParamsJson,
703
+ formItems: res.formJson,
704
+ viewMode: this.viewMode,
705
+ localEditMode: localEditMode,
706
+ isKeyHandle: !Boolean(localEditMode),
707
+ serviceName: this.serviceName,
708
+ fixedAddForm: this.fixedAddForm,
709
+ getDataParams: this.getDataParams,
710
+ layout: res.xAddFormLayout || 'horizontal',
711
+ xAddFormLayoutWidth: res.xAddFormLayoutWidth,
712
+ formItemLayout: res.formItemLayout || {},
713
+ env: this.env
714
+ })
715
+ },
716
+ /**
717
+ * 添加按钮事件
718
+ */
719
+ move () {
720
+ this.moveType = true
721
+ this.$nextTick(
722
+ () => {
723
+ this.$refs.xAddReport.init({
724
+ configName: this.moveconfig,
725
+ selectedId: this.fixedAddForm.selected_id
726
+ })
727
+ }
728
+ )
729
+ },
730
+ /**
731
+ * 修改按钮事件
732
+ * @param modifyModelData 修改表单数据
733
+ */
734
+ edit (modifyModelData) {
735
+ if (this.customEdit) {
736
+ this.$emit('edit')
737
+ } else {
738
+ const res = this.realQueryConfig
739
+ const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
740
+ this.$refs.xAddForm.init({
741
+ businessType: '修改',
742
+ title: this.title || res.title,
743
+ isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
744
+ configName: this.queryParamsName,
745
+ configContent: this.queryParamsJson,
746
+ formItems: res.formJson,
747
+ viewMode: this.viewMode,
748
+ localEditMode: localEditMode,
749
+ isKeyHandle: !Boolean(localEditMode),
750
+ serviceName: this.serviceName,
751
+ fixedAddForm: this.fixedAddForm,
752
+ getDataParams: this.getDataParams,
753
+ modifyModelData: modifyModelData,
754
+ layout: res.xAddFormLayout || 'horizontal',
755
+ env: this.env
756
+ })
757
+ }
758
+ },
759
+ /**
760
+ * 删除按钮事件
761
+ */
762
+ del (keys, callback) {
763
+ if (this.customDelete) {
764
+ this.$emit('del', keys, callback)
765
+ }
766
+ },
767
+ /**
768
+ * 删除后事件
769
+ * @param res
770
+ */
771
+ afterDelete (res) {
772
+ this.$emit('afterDelete', res)
773
+ },
774
+ /**
775
+ * 行选择事件
776
+ * @param row 选中行
777
+ */
778
+ rowChoose (row) {
779
+ this.$emit('rowChoose', row)
780
+ },
781
+ /**
782
+ * 本地编辑模式下校验表格并同步本地数据
783
+ * @param currRow 当前行
784
+ * @param defaultAppendRowData 默认追加的行数据
785
+ */
786
+ validateTableAndSyncData (currRow, defaultAppendRowData) {
787
+ this.$refs.xTable.validateTableAndSyncData(currRow, defaultAppendRowData)
788
+ },
789
+ /**
790
+ * 更多条件是否展示
791
+ */
792
+ toggleAdvanced () {
793
+ this.$refs.xTable.setScrollYHeight({})
794
+ },
795
+ /**
796
+ * 查询表单部分显示/隐藏切换
797
+ */
798
+ toggleIsFormShow () {
799
+ this.toggleIsFormIcon = this.toggleIsFormIcon === 'vertical-align-top' ? 'vertical-align-bottom' : 'vertical-align-top'
800
+ this.$refs.xForm.toggleVisible()
801
+ this.$refs.xTable.setScrollYHeight({})
802
+ },
803
+ /**
804
+ * 选择列事件
805
+ * @param selectedRowKeys 选中列Key集合
806
+ * @param selectedRows 选中列
807
+ */
808
+ selectRow (selectedRowKeys, selectedRows) {
809
+ this.table_selectedRowKeys = selectedRowKeys
810
+ this.table_selectedRows = selectedRows
811
+ this.$emit('selectRow', selectedRowKeys, selectedRows)
812
+ },
813
+ /**
814
+ * 清除勾选数据
815
+ */
816
+ clearRowKeys () {
817
+ this.$refs.xTable.clearRowKeys()
818
+ },
819
+ /**
820
+ * 刷新表格
821
+ * @param toFirstPage 是否到第一页
822
+ */
823
+ refreshTable (toFirstPage = true) {
824
+ this.$refs.xTable.refresh(toFirstPage)
825
+ },
826
+ /**
827
+ * 刷新表格
828
+ * @param toFirstPage 是否到第一页
829
+ */
830
+ refresh (toFirstPage = true) {
831
+ this.$refs.xTable.refresh(toFirstPage)
832
+ },
833
+ /**
834
+ * 获取表格数据
835
+ */
836
+ getTableData () {
837
+ return this.$refs.xTable.getTableData()
838
+ },
839
+ // 在行编辑等情况下,让界面生效
840
+ update () {
841
+ this.getTableData().push(...[])
842
+ },
843
+
844
+ /**
845
+ * 设置表格数据
846
+ */
847
+ setTableData (data) {
848
+ this.$refs.xTable.setTableData(data)
849
+ },
850
+ /**
851
+ * 表单本地提交
852
+ */
853
+ onLocalSubmit (res, callback) {
854
+ const form = res.realForm
855
+ if (res.businessType === '新增') {
856
+ this.$refs.xTable.appendLocalData(form)
857
+ } else {
858
+ this.$refs.xTable.modifyLocalData(form['序号'], form)
859
+ }
860
+ this.$message.success(res.businessType + '成功!')
861
+ this.onAddOrEditSubmitAfterSubmit(res, callback)
862
+ if (callback) {
863
+ callback()
864
+ }
865
+ },
866
+ emitFunc (func, data, value) {
867
+ this.$emit(func, data, value)
868
+ this.$emit('getEmitFuncData', func, data, value)
869
+ },
870
+ // 直接转发事件的函数
871
+ emitEvent (event, ...args) {
872
+ this.$emit(event, ...args)
873
+ },
874
+ // 添加处理 rowClick 的方法
875
+ handleRowClick (record) {
876
+ this.$emit('rowClick', record)
877
+ },
878
+ beforeDataChange (record) {
879
+ this.$emit('beforeDataChange', record)
880
+ },
881
+ onExpand (expanded, record) {
882
+ this.$emit('expand', expanded, record)
883
+ }
884
+ },
885
+ action: {
886
+ /**
887
+ * 实现doAction方法
888
+ */
889
+ doAction (actionType, args, data) {
890
+ switch (actionType) {
891
+ case 'refreshTable':
892
+ for (const item in args) {
893
+ console.log('item', item)
894
+ }
895
+ break
896
+ default:
897
+ break
898
+ }
899
+ }
900
+ },
901
+ mounted () {
902
+ if (!this.isMounted) {
903
+ // 防止多次调用
904
+ // 不知道为啥他会执行两次 mounted 暂时处理方式
905
+ this.initConfig()
906
+ this.isMounted = true
907
+ }
908
+ if (this.getSelectedData && typeof this.getSelectedData === 'function') {
909
+ const selectedId = this.getSelectedData()
910
+ if (!selectedId) {
911
+ return
912
+ }
913
+ if (typeof selectedId === 'object') {
914
+ const data = JSON.parse(JSON.stringify(selectedId))
915
+ if (data.selectedId) {
916
+ data.selected_id = data.selectedId
917
+ delete data.selectedId
918
+ }
919
+ Object.assign(this.fixedAddForm, data)
920
+ Object.assign(this.fixedQueryForm, data)
921
+ } else {
922
+ Object.assign(this.fixedAddForm, { selected_id: selectedId })
923
+ Object.assign(this.fixedQueryForm, { selected_id: selectedId })
924
+ }
925
+ }
926
+ }
927
+ }
928
+ </script>
929
+ <style lang="less" scoped>
930
+ .crud_title {
931
+ height: 32px;
932
+ font-size: 16px;
933
+ font-weight: 500;
934
+ color: #000000d9;
935
+ line-height: 32px;
936
+ margin-bottom: 12px;
937
+ }
938
+ </style>