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,558 +1,558 @@
1
- import T from 'ant-design-vue/es/table/Table'
2
- import get from 'lodash.get'
3
- import { mapState } from 'vuex'
4
- import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
5
-
6
- export default {
7
- data () {
8
- return {
9
- clickedRowKey: null,
10
- needTotalList: [],
11
-
12
- selectedRows: [],
13
- selectedRowKeys: [],
14
-
15
- localLoading: false,
16
- localDataSource: [],
17
- localPagination: Object.assign({}, this.pagination),
18
-
19
- sortField: undefined,
20
- sortOrder: undefined,
21
- pageNum: 1,
22
- pageSize: 10
23
- }
24
- },
25
- props: Object.assign({}, T.props, {
26
- rowKey: {
27
- type: [String, Function],
28
- default: 'key'
29
- },
30
- data: {
31
- type: Function,
32
- required: true
33
- },
34
- setScrollYHeight: {
35
- type: Function,
36
- required: true
37
- },
38
- showSizeChanger: {
39
- type: Boolean,
40
- default: true
41
- },
42
- showSummary: {
43
- type: Boolean,
44
- default: false
45
- },
46
- selectRowMode: {
47
- type: String,
48
- default: 'default'
49
- },
50
- size: {
51
- type: String,
52
- default: 'default'
53
- },
54
- /**
55
- * alert: {
56
- * show: true,
57
- * clear: Function
58
- * }
59
- */
60
- alert: {
61
- type: [Object, Boolean],
62
- default: null
63
- },
64
- rowSelection: {
65
- type: Object,
66
- default: null
67
- },
68
- /** @Deprecated */
69
- showAlertInfo: {
70
- type: Boolean,
71
- default: false
72
- },
73
- showPagination: {
74
- type: [String, Boolean],
75
- default: 'auto'
76
- },
77
- // 是否隐藏翻页,如果隐藏,彻底不显示翻译
78
- hidePagination: {
79
- type: Boolean,
80
- default: false
81
- },
82
- // 是否显示表头已选择部分
83
- showSelected: {
84
- type: Boolean,
85
- default: true
86
- },
87
- /**
88
- * enable page URI mode
89
- *
90
- * e.g:
91
- * /users/1
92
- * /users/2
93
- * /users/3?queryParam=test
94
- * ...
95
- */
96
- pageURI: {
97
- type: Boolean,
98
- default: false
99
- },
100
- // 最大分页大小,如果设置则使用该值作为分页大小并隐藏分页组件
101
- pageMaxSize: {
102
- type: Number,
103
- default: null
104
- },
105
- // 行样式函数,用于控制每行的样式类型
106
- rowStyleFunction: {
107
- type: [Function, String],
108
- default: null
109
- }
110
- }),
111
- computed: {
112
- ...mapState('setting', ['theme']), // 添加 theme 到计算属性
113
-
114
- // 计算点击行的背景色,使用 10% 透明度
115
- clickedRowColor () {
116
- const themeColor = this.$store.state.setting.theme.color
117
- return this.hexToRgba(themeColor || '#1890ff', 0.1)
118
- }
119
- },
120
- watch: {
121
- 'localPagination.current' (val) {
122
- this.pageURI && this.$router.push({
123
- ...this.$route,
124
- name: this.$route.name,
125
- params: Object.assign({}, this.$route.params, {
126
- pageNo: val
127
- })
128
- })
129
- // change pagination, reset total data
130
- this.needTotalList = this.initTotalList(this.columns)
131
- if (this.selectRowMode === 'default') {
132
- this.selectedRowKeys = []
133
- this.selectedRows = []
134
- }
135
- },
136
- pageNum (val) {
137
- Object.assign(this.localPagination, {
138
- current: val
139
- })
140
- },
141
- pageSize (val) {
142
- Object.assign(this.localPagination, {
143
- pageSize: val
144
- })
145
- },
146
- showSizeChanger (val) {
147
- Object.assign(this.localPagination, {
148
- showSizeChanger: val
149
- })
150
- },
151
- pageMaxSize: {
152
- handler (val) {
153
- if (val) {
154
- this.pageSize = val
155
- this.hidePagination = true
156
- // 更新 localPagination
157
- if (this.localPagination) {
158
- Object.assign(this.localPagination, {
159
- pageSize: val
160
- })
161
- }
162
- }
163
- },
164
- immediate: true
165
- }
166
- },
167
- created () {
168
- const { pageNo } = this.$route.params
169
- const localPageNum = this.pageURI && (pageNo && parseInt(pageNo)) || this.pageNum
170
-
171
- // 如果设置了 pageMaxSize,则使用该值作为分页大小并隐藏分页
172
- if (this.pageMaxSize) {
173
- this.pageSize = this.pageMaxSize
174
- this.hidePagination = true
175
- }
176
-
177
- this.localPagination = ['auto', true].includes(this.showPagination) && Object.assign({}, this.localPagination, {
178
- current: localPageNum,
179
- pageSize: this.pageSize,
180
- showSizeChanger: this.showSizeChanger
181
- }) || false
182
- this.needTotalList = this.initTotalList(this.columns)
183
- // this.loadData()
184
- },
185
- methods: {
186
- /**
187
- * 表格重新加载方法
188
- * 如果参数为 true, 则强制刷新到第一页
189
- * @param Boolean bool
190
- */
191
- refresh (bool = false) {
192
- bool && (this.localPagination = Object.assign({}, {
193
- current: 1, pageSize: this.pageSize
194
- }))
195
- this.loadData()
196
- },
197
- /**
198
- * 加载数据方法
199
- * @param {Object} pagination 分页选项器
200
- * @param {Object} filters 过滤条件
201
- * @param {Object} sorter 排序条件
202
- */
203
- loadData (pagination, filters, sorter) {
204
- this.localLoading = true
205
- // 暂存排序方式,避免 refresh 之后排序失效
206
- if (sorter && sorter.field) {
207
- this.sortField = sorter.field
208
- }
209
- if (sorter && sorter.order) {
210
- this.sortOrder = sorter.order
211
- }
212
-
213
- // 确定 pageSize
214
- let finalPageSize = this.pageSize
215
- if (this.showPagination === false) {
216
- // 当 showPagination 为 false 时,优先使用传入的 pageSize
217
- finalPageSize = pagination?.pageSize || this.pageSize
218
- } else if (pagination && pagination.pageSize) {
219
- finalPageSize = pagination.pageSize
220
- } else if (this.localPagination && this.localPagination.pageSize) {
221
- finalPageSize = this.localPagination.pageSize
222
- }
223
-
224
- const parameter = Object.assign({
225
- querySummary: !pagination && this.showSummary, // 分页查询的情况不重新获取汇总数据
226
- pageNo: (pagination && pagination.current) ||
227
- this.showPagination && this.localPagination.current || this.pageNum,
228
- pageSize: finalPageSize
229
- },
230
- (this.sortField && { sortField: this.sortField }) || {},
231
- (this.sortOrder && { sortOrder: this.sortOrder }) || {},
232
- { ...filters }
233
- )
234
-
235
- // 在加载新数据前,将当前数据传递给父组件
236
- if (this.localDataSource && this.localDataSource.length > 0) {
237
- // 变化前的数据: oldData, 分页信息: pagination, 过滤条件: filters, 排序信息: sorter
238
- this.$emit('beforeDataChange', {
239
- oldData: this.localDataSource,
240
- pagination: this.localPagination,
241
- filters: filters,
242
- sorter: sorter
243
- })
244
- }
245
-
246
- const result = this.data(parameter)
247
- // 对接自己的通用数据接口需要修改下方代码中的 r.pageNo, r.totalCount, r.data
248
- // eslint-disable-next-line
249
- if ((typeof result === 'object' || typeof result === 'function') && typeof result.then === 'function') {
250
- result.then(r => {
251
- this.localPagination = this.showPagination && Object.assign({}, this.localPagination, {
252
- current: r.pageNo, // 返回结果中的当前分页数
253
- total: r.totalCount, // 返回结果中的总记录数
254
- showSizeChanger: this.showSizeChanger,
255
- pageSize: finalPageSize
256
- }) || false
257
- // 为防止删除数据后导致页面当前页面数据长度为 0 ,自动翻页到上一页
258
- if (r.data.length === 0 && this.showPagination && this.localPagination.current > 1) {
259
- this.localPagination.current--
260
- this.loadData()
261
- return
262
- }
263
-
264
- // 这里用于判断接口是否有返回 r.totalCount 且 this.showPagination = 'auto' 且 pageNo 和 pageSize 存在 且 totalCount 小于等于 pageNo * pageSize 的大小
265
- // 当情况满足时,表示数据不满足分页大小,关闭 table 分页功能
266
- try {
267
- if ((['auto'].includes(this.showPagination) && r.totalCount <= (r.pageNo * this.localPagination.pageSize))) {
268
- this.localPagination.hideOnSinglePage = true
269
- }
270
- } catch (e) {
271
- this.localPagination = false
272
- }
273
- this.localDataSource = r.data // 返回结果中的数组数据
274
- this.localLoading = false
275
- this.setScrollYHeight({ type: 'default' })
276
- }, () => {
277
- this.localLoading = false
278
- this.setScrollYHeight({ type: 'default' })
279
- })
280
- }
281
- },
282
- setLocalDataSource (data) {
283
- this.localDataSource = data
284
- },
285
- initTotalList (columns) {
286
- const totalList = []
287
- columns && columns instanceof Array && columns.forEach(column => {
288
- if (column.needTotal) {
289
- totalList.push({
290
- ...column,
291
- total: 0
292
- })
293
- }
294
- })
295
- return totalList
296
- },
297
- /**
298
- * 用于更新已选中的列表数据 total 统计
299
- * @param selectedRowKeys
300
- * @param selectedRows
301
- */
302
- updateSelect (selectedRowKeys, selectedRows) {
303
- this.selectedRows = selectedRows
304
- this.selectedRowKeys = selectedRowKeys
305
- const list = this.needTotalList
306
- this.needTotalList = list.map(item => {
307
- return {
308
- ...item,
309
- total: selectedRows.reduce((sum, val) => {
310
- const total = sum + parseInt(get(val, item.dataIndex))
311
- return isNaN(total) ? 0 : total
312
- }, 0)
313
- }
314
- })
315
- },
316
- /**
317
- * 清空 table 已选中项
318
- */
319
- clearSelected () {
320
- if (this.rowSelection) {
321
- this.rowSelection.onChange([], [])
322
- this.updateSelect([], [])
323
- }
324
- },
325
- /**
326
- * 处理交给 table 使用者去处理 clear 事件时,内部选中统计同时调用
327
- * @param callback
328
- * @returns {*}
329
- */
330
- renderClear (callback) {
331
- if (this.selectedRowKeys.length <= 0) return null
332
- return (
333
- <a style="margin-left: 24px" onClick={() => {
334
- callback()
335
- this.clearSelected()
336
- }}>清空</a>
337
- )
338
- },
339
- renderAlert () {
340
- // 绘制统计列数据
341
- const needTotalItems = this.needTotalList.map((item) => {
342
- return (<span style="margin-right: 12px">
343
- {item.title}总计 <a
344
- style="font-weight: 600">{!item.customRender ? item.total : item.customRender(item.total)}</a>
345
- </span>)
346
- })
347
-
348
- // 绘制 清空 按钮
349
- const clearItem = (typeof this.alert.clear === 'boolean' && this.alert.clear) ? (
350
- this.renderClear(this.clearSelected)
351
- ) : (typeof this.alert.clear === 'function') ? (
352
- this.renderClear(this.alert.clear)
353
- ) : null
354
-
355
- // 绘制 alert 组件
356
- return (
357
- <a-alert showIcon={true} style={{ marginBottom: '8px', fontSize: '14px' }}>
358
- <template slot="message">
359
- <span style="margin-right: 12px;">已选择: <a style="font-weight: 600">{this.selectedRows.length}</a></span>
360
- {needTotalItems}
361
- {clearItem}
362
- </template>
363
- </a-alert>
364
- )
365
- },
366
- onExpand (expanded, record) {
367
- this.$emit('expand', expanded, record)
368
- },
369
- handleRowClick (record, index) {
370
- if (this.rowKey === '序号') {
371
- this.clickedRowKey = index
372
- } else {
373
- this.clickedRowKey = record[this.rowKey]
374
- }
375
- this.$emit('rowClick', record)
376
- },
377
- hexToRgba (hex, alpha = 1) {
378
- try {
379
- const r = parseInt(hex.slice(1, 3), 16)
380
- const g = parseInt(hex.slice(3, 5), 16)
381
- const b = parseInt(hex.slice(5, 7), 16)
382
- return `rgba(${r}, ${g}, ${b}, ${alpha})`
383
- } catch (e) {
384
- return '#e6f7ff'
385
- }
386
- },
387
- // 获取行样式类型
388
- getRowStyleType (record, index) {
389
- if (this.rowStyleFunction) {
390
- try {
391
- // 如果是函数对象,直接执行
392
- if (typeof this.rowStyleFunction === 'function') {
393
- return this.rowStyleFunction(record, index)
394
- }
395
- // 如果是字符串函数,使用executeStrFunctionByContext执行
396
- if (typeof this.rowStyleFunction === 'string') {
397
- return executeStrFunctionByContext(this, this.rowStyleFunction, [record, index])
398
- }
399
- } catch (e) {
400
- console.warn('Row style function error:', e)
401
- return 'info'
402
- }
403
- }
404
- return 'info'
405
- },
406
- // 获取行样式类名
407
- getRowStyleClass (record, index) {
408
- const styleType = this.getRowStyleType(record, index)
409
- switch (styleType) {
410
- case 'success':
411
- return 'ant-table-row-success'
412
- case 'warn':
413
- case 'warning':
414
- return 'ant-table-row-warning'
415
- case 'error':
416
- case 'danger':
417
- return 'ant-table-row-error'
418
- case 'magic':
419
- return 'ant-table-row-magic'
420
- case 'info':
421
- default:
422
- return ''
423
- }
424
- },
425
- },
426
-
427
- render () {
428
- const props = {}
429
- const localKeys = Object.keys(this.$data)
430
- const showAlert = (typeof this.alert === 'object' && this.alert !== null && this.alert.show) && typeof this.rowSelection.selectedRowKeys !== 'undefined' || this.alert
431
-
432
- Object.keys(T.props).forEach(k => {
433
- const localKey = `local${k.substring(0, 1).toUpperCase()}${k.substring(1)}`
434
- if (localKeys.includes(localKey)) {
435
- props[k] = this[localKey]
436
- return props[k]
437
- }
438
- if (k === 'rowSelection') {
439
- if (showAlert && this.rowSelection) {
440
- // 如果需要使用alert,则重新绑定 rowSelection 事件
441
- props[k] = {
442
- ...this.rowSelection,
443
- selectedRows: this.selectedRows,
444
- selectedRowKeys: this.selectedRowKeys,
445
- onChange: (selectedRowKeys, selectedRows) => {
446
- this.updateSelect(selectedRowKeys, selectedRows)
447
- typeof this[k].onChange !== 'undefined' && this[k].onChange(selectedRowKeys, selectedRows)
448
- }
449
- }
450
- return props[k]
451
- } else if (!this.rowSelection) {
452
- // 如果没打算开启 rowSelection 则清空默认的选择项
453
- props[k] = null
454
- return props[k]
455
- }
456
- }
457
- this[k] && (props[k] = this[k])
458
- return props[k]
459
- })
460
- // 取消原有的分页组件 产品设计分页组件和汇总在一行 重新分页逻辑
461
- props.pagination = false
462
- // 在 props 中添加自定义行属性
463
- props.customRow = (record, index) => {
464
- const isRowKeySequence = this.rowKey === '序号'
465
- const isCurrentRow = isRowKeySequence
466
- ? this.clickedRowKey === index
467
- : this.clickedRowKey === record[this.rowKey]
468
- const rowStyleClass = this.getRowStyleClass(record, index)
469
-
470
- // 根据行样式类型确定选中时的背景色
471
- let selectedBgColor = ''
472
- if (isCurrentRow && rowStyleClass) {
473
- // 如果有行样式类,使用对应的深色
474
- switch (rowStyleClass) {
475
- case 'ant-table-row-success':
476
- selectedBgColor = '#b8e6a0'
477
- break
478
- case 'ant-table-row-warning':
479
- selectedBgColor = '#ffe066'
480
- break
481
- case 'ant-table-row-error':
482
- selectedBgColor = '#ffb3b3'
483
- break
484
- case 'ant-table-row-magic':
485
- selectedBgColor = '#d9b3ff'
486
- break
487
- default:
488
- selectedBgColor = this.clickedRowColor
489
- }
490
- } else if (isCurrentRow) {
491
- // 没有行样式类时使用默认选中颜色
492
- selectedBgColor = this.clickedRowColor
493
- }
494
-
495
- return {
496
- on: {
497
- click: () => this.handleRowClick(record, index)
498
- },
499
- style: {
500
- 'background-color': selectedBgColor
501
- },
502
- class: rowStyleClass
503
- }
504
- }
505
- // 自定义底部汇总插槽组件
506
- const pagination = (
507
- !!this.showPagination && <a-row type={'flex'} justify={'start'} style={{ marginTop: '8px' }}>
508
- <a-col flex="1" style={{
509
- alignItems: 'center',
510
- display: 'flex',
511
- justifyContent: 'start',
512
- boxSizing: 'border-box',
513
- paddingRight: '2rem'
514
- }}>
515
- {this.$slots.fixedfooter}
516
- </a-col>
517
- <a-col flex="0 0">
518
- <a-pagination
519
- total={this.localPagination.total}
520
- onChange={(page, pageSize) => {
521
- this.pageSize = pageSize
522
- this.pageNum = page
523
- this.loadData({
524
- current: page,
525
- pageSize: pageSize
526
- })
527
- }
528
- }
529
- onShowSizeChange={(page, pageSize) => {
530
- this.pageSize = pageSize
531
- this.pageNum = page
532
- this.loadData({
533
- current: page,
534
- pageSize: pageSize
535
- })
536
- }
537
- }
538
- show-total={(total, range) => range[0] === range[1] ? `${range[0]} | 共 ${total} 项` : `${range[0]}-${range[1]} | 共 ${total} 项`}
539
- default-current={this.localPagination.current}
540
- showSizeChanger={this.localPagination.showSizeChanger}/>
541
- </a-col>
542
- </a-row>
543
- )
544
- const table = (
545
- <a-table {...{ props, scopedSlots: { ...this.$scopedSlots } }} onChange={this.loadData}
546
- onExpand={(expanded, record) => this.onExpand(expanded, record)}>
547
- {Object.keys(this.$slots).map(name => (<template slot={name}>{this.$slots[name]}</template>))}
548
- </a-table>
549
- )
550
- return (
551
- <div class="table-wrapper">
552
- {showAlert && this.showSelected && this.selectRowMode === 'default' ? this.renderAlert() : null}
553
- {table}
554
- {!this.hidePagination ? pagination : null}
555
- </div>
556
- )
557
- }
558
- }
1
+ import T from 'ant-design-vue/es/table/Table'
2
+ import get from 'lodash.get'
3
+ import { mapState } from 'vuex'
4
+ import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
5
+
6
+ export default {
7
+ data () {
8
+ return {
9
+ clickedRowKey: null,
10
+ needTotalList: [],
11
+
12
+ selectedRows: [],
13
+ selectedRowKeys: [],
14
+
15
+ localLoading: false,
16
+ localDataSource: [],
17
+ localPagination: Object.assign({}, this.pagination),
18
+
19
+ sortField: undefined,
20
+ sortOrder: undefined,
21
+ pageNum: 1,
22
+ pageSize: 10
23
+ }
24
+ },
25
+ props: Object.assign({}, T.props, {
26
+ rowKey: {
27
+ type: [String, Function],
28
+ default: 'key'
29
+ },
30
+ data: {
31
+ type: Function,
32
+ required: true
33
+ },
34
+ setScrollYHeight: {
35
+ type: Function,
36
+ required: true
37
+ },
38
+ showSizeChanger: {
39
+ type: Boolean,
40
+ default: true
41
+ },
42
+ showSummary: {
43
+ type: Boolean,
44
+ default: false
45
+ },
46
+ selectRowMode: {
47
+ type: String,
48
+ default: 'default'
49
+ },
50
+ size: {
51
+ type: String,
52
+ default: 'default'
53
+ },
54
+ /**
55
+ * alert: {
56
+ * show: true,
57
+ * clear: Function
58
+ * }
59
+ */
60
+ alert: {
61
+ type: [Object, Boolean],
62
+ default: null
63
+ },
64
+ rowSelection: {
65
+ type: Object,
66
+ default: null
67
+ },
68
+ /** @Deprecated */
69
+ showAlertInfo: {
70
+ type: Boolean,
71
+ default: false
72
+ },
73
+ showPagination: {
74
+ type: [String, Boolean],
75
+ default: 'auto'
76
+ },
77
+ // 是否隐藏翻页,如果隐藏,彻底不显示翻译
78
+ hidePagination: {
79
+ type: Boolean,
80
+ default: false
81
+ },
82
+ // 是否显示表头已选择部分
83
+ showSelected: {
84
+ type: Boolean,
85
+ default: true
86
+ },
87
+ /**
88
+ * enable page URI mode
89
+ *
90
+ * e.g:
91
+ * /users/1
92
+ * /users/2
93
+ * /users/3?queryParam=test
94
+ * ...
95
+ */
96
+ pageURI: {
97
+ type: Boolean,
98
+ default: false
99
+ },
100
+ // 最大分页大小,如果设置则使用该值作为分页大小并隐藏分页组件
101
+ pageMaxSize: {
102
+ type: Number,
103
+ default: null
104
+ },
105
+ // 行样式函数,用于控制每行的样式类型
106
+ rowStyleFunction: {
107
+ type: [Function, String],
108
+ default: null
109
+ }
110
+ }),
111
+ computed: {
112
+ ...mapState('setting', ['theme']), // 添加 theme 到计算属性
113
+
114
+ // 计算点击行的背景色,使用 10% 透明度
115
+ clickedRowColor () {
116
+ const themeColor = this.$store.state.setting.theme.color
117
+ return this.hexToRgba(themeColor || '#1890ff', 0.1)
118
+ }
119
+ },
120
+ watch: {
121
+ 'localPagination.current' (val) {
122
+ this.pageURI && this.$router.push({
123
+ ...this.$route,
124
+ name: this.$route.name,
125
+ params: Object.assign({}, this.$route.params, {
126
+ pageNo: val
127
+ })
128
+ })
129
+ // change pagination, reset total data
130
+ this.needTotalList = this.initTotalList(this.columns)
131
+ if (this.selectRowMode === 'default') {
132
+ this.selectedRowKeys = []
133
+ this.selectedRows = []
134
+ }
135
+ },
136
+ pageNum (val) {
137
+ Object.assign(this.localPagination, {
138
+ current: val
139
+ })
140
+ },
141
+ pageSize (val) {
142
+ Object.assign(this.localPagination, {
143
+ pageSize: val
144
+ })
145
+ },
146
+ showSizeChanger (val) {
147
+ Object.assign(this.localPagination, {
148
+ showSizeChanger: val
149
+ })
150
+ },
151
+ pageMaxSize: {
152
+ handler (val) {
153
+ if (val) {
154
+ this.pageSize = val
155
+ this.hidePagination = true
156
+ // 更新 localPagination
157
+ if (this.localPagination) {
158
+ Object.assign(this.localPagination, {
159
+ pageSize: val
160
+ })
161
+ }
162
+ }
163
+ },
164
+ immediate: true
165
+ }
166
+ },
167
+ created () {
168
+ const { pageNo } = this.$route.params
169
+ const localPageNum = this.pageURI && (pageNo && parseInt(pageNo)) || this.pageNum
170
+
171
+ // 如果设置了 pageMaxSize,则使用该值作为分页大小并隐藏分页
172
+ if (this.pageMaxSize) {
173
+ this.pageSize = this.pageMaxSize
174
+ this.hidePagination = true
175
+ }
176
+
177
+ this.localPagination = ['auto', true].includes(this.showPagination) && Object.assign({}, this.localPagination, {
178
+ current: localPageNum,
179
+ pageSize: this.pageSize,
180
+ showSizeChanger: this.showSizeChanger
181
+ }) || false
182
+ this.needTotalList = this.initTotalList(this.columns)
183
+ // this.loadData()
184
+ },
185
+ methods: {
186
+ /**
187
+ * 表格重新加载方法
188
+ * 如果参数为 true, 则强制刷新到第一页
189
+ * @param Boolean bool
190
+ */
191
+ refresh (bool = false) {
192
+ bool && (this.localPagination = Object.assign({}, {
193
+ current: 1, pageSize: this.pageSize
194
+ }))
195
+ this.loadData()
196
+ },
197
+ /**
198
+ * 加载数据方法
199
+ * @param {Object} pagination 分页选项器
200
+ * @param {Object} filters 过滤条件
201
+ * @param {Object} sorter 排序条件
202
+ */
203
+ loadData (pagination, filters, sorter) {
204
+ this.localLoading = true
205
+ // 暂存排序方式,避免 refresh 之后排序失效
206
+ if (sorter && sorter.field) {
207
+ this.sortField = sorter.field
208
+ }
209
+ if (sorter && sorter.order) {
210
+ this.sortOrder = sorter.order
211
+ }
212
+
213
+ // 确定 pageSize
214
+ let finalPageSize = this.pageSize
215
+ if (this.showPagination === false) {
216
+ // 当 showPagination 为 false 时,优先使用传入的 pageSize
217
+ finalPageSize = pagination?.pageSize || this.pageSize
218
+ } else if (pagination && pagination.pageSize) {
219
+ finalPageSize = pagination.pageSize
220
+ } else if (this.localPagination && this.localPagination.pageSize) {
221
+ finalPageSize = this.localPagination.pageSize
222
+ }
223
+
224
+ const parameter = Object.assign({
225
+ querySummary: !pagination && this.showSummary, // 分页查询的情况不重新获取汇总数据
226
+ pageNo: (pagination && pagination.current) ||
227
+ this.showPagination && this.localPagination.current || this.pageNum,
228
+ pageSize: finalPageSize
229
+ },
230
+ (this.sortField && { sortField: this.sortField }) || {},
231
+ (this.sortOrder && { sortOrder: this.sortOrder }) || {},
232
+ { ...filters }
233
+ )
234
+
235
+ // 在加载新数据前,将当前数据传递给父组件
236
+ if (this.localDataSource && this.localDataSource.length > 0) {
237
+ // 变化前的数据: oldData, 分页信息: pagination, 过滤条件: filters, 排序信息: sorter
238
+ this.$emit('beforeDataChange', {
239
+ oldData: this.localDataSource,
240
+ pagination: this.localPagination,
241
+ filters: filters,
242
+ sorter: sorter
243
+ })
244
+ }
245
+
246
+ const result = this.data(parameter)
247
+ // 对接自己的通用数据接口需要修改下方代码中的 r.pageNo, r.totalCount, r.data
248
+ // eslint-disable-next-line
249
+ if ((typeof result === 'object' || typeof result === 'function') && typeof result.then === 'function') {
250
+ result.then(r => {
251
+ this.localPagination = this.showPagination && Object.assign({}, this.localPagination, {
252
+ current: r.pageNo, // 返回结果中的当前分页数
253
+ total: r.totalCount, // 返回结果中的总记录数
254
+ showSizeChanger: this.showSizeChanger,
255
+ pageSize: finalPageSize
256
+ }) || false
257
+ // 为防止删除数据后导致页面当前页面数据长度为 0 ,自动翻页到上一页
258
+ if (r.data.length === 0 && this.showPagination && this.localPagination.current > 1) {
259
+ this.localPagination.current--
260
+ this.loadData()
261
+ return
262
+ }
263
+
264
+ // 这里用于判断接口是否有返回 r.totalCount 且 this.showPagination = 'auto' 且 pageNo 和 pageSize 存在 且 totalCount 小于等于 pageNo * pageSize 的大小
265
+ // 当情况满足时,表示数据不满足分页大小,关闭 table 分页功能
266
+ try {
267
+ if ((['auto'].includes(this.showPagination) && r.totalCount <= (r.pageNo * this.localPagination.pageSize))) {
268
+ this.localPagination.hideOnSinglePage = true
269
+ }
270
+ } catch (e) {
271
+ this.localPagination = false
272
+ }
273
+ this.localDataSource = r.data // 返回结果中的数组数据
274
+ this.localLoading = false
275
+ this.setScrollYHeight({ type: 'default' })
276
+ }, () => {
277
+ this.localLoading = false
278
+ this.setScrollYHeight({ type: 'default' })
279
+ })
280
+ }
281
+ },
282
+ setLocalDataSource (data) {
283
+ this.localDataSource = data
284
+ },
285
+ initTotalList (columns) {
286
+ const totalList = []
287
+ columns && columns instanceof Array && columns.forEach(column => {
288
+ if (column.needTotal) {
289
+ totalList.push({
290
+ ...column,
291
+ total: 0
292
+ })
293
+ }
294
+ })
295
+ return totalList
296
+ },
297
+ /**
298
+ * 用于更新已选中的列表数据 total 统计
299
+ * @param selectedRowKeys
300
+ * @param selectedRows
301
+ */
302
+ updateSelect (selectedRowKeys, selectedRows) {
303
+ this.selectedRows = selectedRows
304
+ this.selectedRowKeys = selectedRowKeys
305
+ const list = this.needTotalList
306
+ this.needTotalList = list.map(item => {
307
+ return {
308
+ ...item,
309
+ total: selectedRows.reduce((sum, val) => {
310
+ const total = sum + parseInt(get(val, item.dataIndex))
311
+ return isNaN(total) ? 0 : total
312
+ }, 0)
313
+ }
314
+ })
315
+ },
316
+ /**
317
+ * 清空 table 已选中项
318
+ */
319
+ clearSelected () {
320
+ if (this.rowSelection) {
321
+ this.rowSelection.onChange([], [])
322
+ this.updateSelect([], [])
323
+ }
324
+ },
325
+ /**
326
+ * 处理交给 table 使用者去处理 clear 事件时,内部选中统计同时调用
327
+ * @param callback
328
+ * @returns {*}
329
+ */
330
+ renderClear (callback) {
331
+ if (this.selectedRowKeys.length <= 0) return null
332
+ return (
333
+ <a style="margin-left: 24px" onClick={() => {
334
+ callback()
335
+ this.clearSelected()
336
+ }}>清空</a>
337
+ )
338
+ },
339
+ renderAlert () {
340
+ // 绘制统计列数据
341
+ const needTotalItems = this.needTotalList.map((item) => {
342
+ return (<span style="margin-right: 12px">
343
+ {item.title}总计 <a
344
+ style="font-weight: 600">{!item.customRender ? item.total : item.customRender(item.total)}</a>
345
+ </span>)
346
+ })
347
+
348
+ // 绘制 清空 按钮
349
+ const clearItem = (typeof this.alert.clear === 'boolean' && this.alert.clear) ? (
350
+ this.renderClear(this.clearSelected)
351
+ ) : (typeof this.alert.clear === 'function') ? (
352
+ this.renderClear(this.alert.clear)
353
+ ) : null
354
+
355
+ // 绘制 alert 组件
356
+ return (
357
+ <a-alert showIcon={true} style={{ marginBottom: '8px', fontSize: '14px' }}>
358
+ <template slot="message">
359
+ <span style="margin-right: 12px;">已选择: <a style="font-weight: 600">{this.selectedRows.length}</a></span>
360
+ {needTotalItems}
361
+ {clearItem}
362
+ </template>
363
+ </a-alert>
364
+ )
365
+ },
366
+ onExpand (expanded, record) {
367
+ this.$emit('expand', expanded, record)
368
+ },
369
+ handleRowClick (record, index) {
370
+ if (this.rowKey === '序号') {
371
+ this.clickedRowKey = index
372
+ } else {
373
+ this.clickedRowKey = record[this.rowKey]
374
+ }
375
+ this.$emit('rowClick', record)
376
+ },
377
+ hexToRgba (hex, alpha = 1) {
378
+ try {
379
+ const r = parseInt(hex.slice(1, 3), 16)
380
+ const g = parseInt(hex.slice(3, 5), 16)
381
+ const b = parseInt(hex.slice(5, 7), 16)
382
+ return `rgba(${r}, ${g}, ${b}, ${alpha})`
383
+ } catch (e) {
384
+ return '#e6f7ff'
385
+ }
386
+ },
387
+ // 获取行样式类型
388
+ getRowStyleType (record, index) {
389
+ if (this.rowStyleFunction) {
390
+ try {
391
+ // 如果是函数对象,直接执行
392
+ if (typeof this.rowStyleFunction === 'function') {
393
+ return this.rowStyleFunction(record, index)
394
+ }
395
+ // 如果是字符串函数,使用executeStrFunctionByContext执行
396
+ if (typeof this.rowStyleFunction === 'string') {
397
+ return executeStrFunctionByContext(this, this.rowStyleFunction, [record, index])
398
+ }
399
+ } catch (e) {
400
+ console.warn('Row style function error:', e)
401
+ return 'info'
402
+ }
403
+ }
404
+ return 'info'
405
+ },
406
+ // 获取行样式类名
407
+ getRowStyleClass (record, index) {
408
+ const styleType = this.getRowStyleType(record, index)
409
+ switch (styleType) {
410
+ case 'success':
411
+ return 'ant-table-row-success'
412
+ case 'warn':
413
+ case 'warning':
414
+ return 'ant-table-row-warning'
415
+ case 'error':
416
+ case 'danger':
417
+ return 'ant-table-row-error'
418
+ case 'magic':
419
+ return 'ant-table-row-magic'
420
+ case 'info':
421
+ default:
422
+ return ''
423
+ }
424
+ },
425
+ },
426
+
427
+ render () {
428
+ const props = {}
429
+ const localKeys = Object.keys(this.$data)
430
+ const showAlert = (typeof this.alert === 'object' && this.alert !== null && this.alert.show) && typeof this.rowSelection.selectedRowKeys !== 'undefined' || this.alert
431
+
432
+ Object.keys(T.props).forEach(k => {
433
+ const localKey = `local${k.substring(0, 1).toUpperCase()}${k.substring(1)}`
434
+ if (localKeys.includes(localKey)) {
435
+ props[k] = this[localKey]
436
+ return props[k]
437
+ }
438
+ if (k === 'rowSelection') {
439
+ if (showAlert && this.rowSelection) {
440
+ // 如果需要使用alert,则重新绑定 rowSelection 事件
441
+ props[k] = {
442
+ ...this.rowSelection,
443
+ selectedRows: this.selectedRows,
444
+ selectedRowKeys: this.selectedRowKeys,
445
+ onChange: (selectedRowKeys, selectedRows) => {
446
+ this.updateSelect(selectedRowKeys, selectedRows)
447
+ typeof this[k].onChange !== 'undefined' && this[k].onChange(selectedRowKeys, selectedRows)
448
+ }
449
+ }
450
+ return props[k]
451
+ } else if (!this.rowSelection) {
452
+ // 如果没打算开启 rowSelection 则清空默认的选择项
453
+ props[k] = null
454
+ return props[k]
455
+ }
456
+ }
457
+ this[k] && (props[k] = this[k])
458
+ return props[k]
459
+ })
460
+ // 取消原有的分页组件 产品设计分页组件和汇总在一行 重新分页逻辑
461
+ props.pagination = false
462
+ // 在 props 中添加自定义行属性
463
+ props.customRow = (record, index) => {
464
+ const isRowKeySequence = this.rowKey === '序号'
465
+ const isCurrentRow = isRowKeySequence
466
+ ? this.clickedRowKey === index
467
+ : this.clickedRowKey === record[this.rowKey]
468
+ const rowStyleClass = this.getRowStyleClass(record, index)
469
+
470
+ // 根据行样式类型确定选中时的背景色
471
+ let selectedBgColor = ''
472
+ if (isCurrentRow && rowStyleClass) {
473
+ // 如果有行样式类,使用对应的深色
474
+ switch (rowStyleClass) {
475
+ case 'ant-table-row-success':
476
+ selectedBgColor = '#b8e6a0'
477
+ break
478
+ case 'ant-table-row-warning':
479
+ selectedBgColor = '#ffe066'
480
+ break
481
+ case 'ant-table-row-error':
482
+ selectedBgColor = '#ffb3b3'
483
+ break
484
+ case 'ant-table-row-magic':
485
+ selectedBgColor = '#d9b3ff'
486
+ break
487
+ default:
488
+ selectedBgColor = this.clickedRowColor
489
+ }
490
+ } else if (isCurrentRow) {
491
+ // 没有行样式类时使用默认选中颜色
492
+ selectedBgColor = this.clickedRowColor
493
+ }
494
+
495
+ return {
496
+ on: {
497
+ click: () => this.handleRowClick(record, index)
498
+ },
499
+ style: {
500
+ 'background-color': selectedBgColor
501
+ },
502
+ class: rowStyleClass
503
+ }
504
+ }
505
+ // 自定义底部汇总插槽组件
506
+ const pagination = (
507
+ !!this.showPagination && <a-row type={'flex'} justify={'start'} style={{ marginTop: '8px' }}>
508
+ <a-col flex="1" style={{
509
+ alignItems: 'center',
510
+ display: 'flex',
511
+ justifyContent: 'start',
512
+ boxSizing: 'border-box',
513
+ paddingRight: '2rem'
514
+ }}>
515
+ {this.$slots.fixedfooter}
516
+ </a-col>
517
+ <a-col flex="0 0">
518
+ <a-pagination
519
+ total={this.localPagination.total}
520
+ onChange={(page, pageSize) => {
521
+ this.pageSize = pageSize
522
+ this.pageNum = page
523
+ this.loadData({
524
+ current: page,
525
+ pageSize: pageSize
526
+ })
527
+ }
528
+ }
529
+ onShowSizeChange={(page, pageSize) => {
530
+ this.pageSize = pageSize
531
+ this.pageNum = page
532
+ this.loadData({
533
+ current: page,
534
+ pageSize: pageSize
535
+ })
536
+ }
537
+ }
538
+ show-total={(total, range) => range[0] === range[1] ? `${range[0]} | 共 ${total} 项` : `${range[0]}-${range[1]} | 共 ${total} 项`}
539
+ default-current={this.localPagination.current}
540
+ showSizeChanger={this.localPagination.showSizeChanger}/>
541
+ </a-col>
542
+ </a-row>
543
+ )
544
+ const table = (
545
+ <a-table {...{ props, scopedSlots: { ...this.$scopedSlots } }} onChange={this.loadData}
546
+ onExpand={(expanded, record) => this.onExpand(expanded, record)}>
547
+ {Object.keys(this.$slots).map(name => (<template slot={name}>{this.$slots[name]}</template>))}
548
+ </a-table>
549
+ )
550
+ return (
551
+ <div class="table-wrapper">
552
+ {showAlert && this.showSelected && this.selectRowMode === 'default' ? this.renderAlert() : null}
553
+ {table}
554
+ {!this.hidePagination ? pagination : null}
555
+ </div>
556
+ )
557
+ }
558
+ }