vue2-client 1.15.84 → 1.15.86

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/.claude/settings.local.json +12 -0
  2. package/.editorconfig +9 -9
  3. package/.env +20 -20
  4. package/.env.development +1 -1
  5. package/.env.iot +19 -19
  6. package/.env.message +19 -19
  7. package/.env.revenue +19 -19
  8. package/.env.runtime +19 -19
  9. package/.eslintrc.json +5 -5
  10. package/CLAUDE.md +89 -89
  11. package/README.md +65 -65
  12. package/babel.config.js +21 -21
  13. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +46 -46
  14. package/docs/notice.md +22 -22
  15. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +179 -179
  16. package/jest.config.js +22 -22
  17. package/package.json +111 -111
  18. package/src/App.vue +196 -196
  19. package/src/ReportView.js +13 -13
  20. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +532 -532
  21. package/src/base-client/components/common/AddressSearchCombobox/index.js +3 -3
  22. package/src/base-client/components/common/AmapMarker/index.js +3 -3
  23. package/src/base-client/components/common/CitySelect/CitySelect.vue +376 -376
  24. package/src/base-client/components/common/CitySelect/demo.vue +43 -43
  25. package/src/base-client/components/common/ColorPickerCombobox/ColorPickerCombobox.vue +99 -99
  26. package/src/base-client/components/common/ColorPickerCombobox/demo.vue +34 -34
  27. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +146 -146
  28. package/src/base-client/components/common/JSONToTree/index.js +3 -3
  29. package/src/base-client/components/common/Upload/Upload.vue +323 -323
  30. package/src/base-client/components/common/XAddForm/index.js +3 -3
  31. package/src/base-client/components/common/XAddForm/index.md +61 -61
  32. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +1169 -1169
  33. package/src/base-client/components/common/XAddNativeForm/demo.vue +54 -40
  34. package/src/base-client/components/common/XAddNativeForm/index.js +3 -3
  35. package/src/base-client/components/common/XAddReport/XAddReport.vue +212 -212
  36. package/src/base-client/components/common/XBadge/index.js +3 -3
  37. package/src/base-client/components/common/XBadge/index.md +39 -39
  38. package/src/base-client/components/common/XButtons/XButtons.vue +284 -284
  39. package/src/base-client/components/common/XCalendar/XCalendar.vue +369 -369
  40. package/src/base-client/components/common/XCalendar/index.md +284 -284
  41. package/src/base-client/components/common/XCard/index.js +3 -3
  42. package/src/base-client/components/common/XCard/index.md +43 -43
  43. package/src/base-client/components/common/XCardSet/XCardSet.vue +300 -300
  44. package/src/base-client/components/common/XCollapse/XCollapse.vue +354 -354
  45. package/src/base-client/components/common/XConversation/XConversation.vue +576 -576
  46. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  47. package/src/base-client/components/common/XDataCard/XDataCard.vue +629 -629
  48. package/src/base-client/components/common/XDatePicker/index.vue +276 -276
  49. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +174 -174
  50. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +314 -314
  51. package/src/base-client/components/common/XDescriptions/demo.vue +51 -51
  52. package/src/base-client/components/common/XForm/XForm.vue +420 -420
  53. package/src/base-client/components/common/XForm/XFormItem.vue +1474 -1390
  54. package/src/base-client/components/common/XForm/XTreeSelect.vue +276 -276
  55. package/src/base-client/components/common/XForm/demo.vue +105 -105
  56. package/src/base-client/components/common/XForm/index.js +3 -3
  57. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -157
  58. package/src/base-client/components/common/XFormCol/index.js +3 -3
  59. package/src/base-client/components/common/XFormCol/index.md +35 -35
  60. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +301 -301
  61. package/src/base-client/components/common/XFormGroup/demo.vue +41 -41
  62. package/src/base-client/components/common/XFormTable/XFormTable.vue +938 -938
  63. package/src/base-client/components/common/XFormTable/demo.vue +87 -87
  64. package/src/base-client/components/common/XFormTable/index.js +3 -3
  65. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +174 -174
  66. package/src/base-client/components/common/XImportExcel/index.js +3 -3
  67. package/src/base-client/components/common/XImportExcel/index.md +38 -38
  68. package/src/base-client/components/common/XInput/XInput.vue +128 -128
  69. package/src/base-client/components/common/XInput/index.js +3 -3
  70. package/src/base-client/components/common/XInput/index.md +97 -97
  71. package/src/base-client/components/common/XIntervalPicker/XIntervalPicker.vue +121 -121
  72. package/src/base-client/components/common/XLicensePlate/index.js +3 -3
  73. package/src/base-client/components/common/XLicensePlate/index.md +38 -38
  74. package/src/base-client/components/common/XPrint/Demo.vue +41 -41
  75. package/src/base-client/components/common/XPrint/PrintBill.vue +308 -308
  76. package/src/base-client/components/common/XRate/demo.vue +102 -102
  77. package/src/base-client/components/common/XRate/index.vue +149 -149
  78. package/src/base-client/components/common/XReport/XReport.vue +963 -963
  79. package/src/base-client/components/common/XReport/XReportDemo.vue +70 -70
  80. package/src/base-client/components/common/XReport/XReportTrGroup.vue +1005 -1005
  81. package/src/base-client/components/common/XReport/index.md +103 -103
  82. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  83. package/src/base-client/components/common/XReportGrid/XReport.vue +1075 -1075
  84. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +44 -44
  85. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +620 -620
  86. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +723 -723
  87. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  88. package/src/base-client/components/common/XTab/XTab.vue +299 -299
  89. package/src/base-client/components/common/XTable/ExportExcel.vue +283 -283
  90. package/src/base-client/components/common/XTable/XTable.vue +1599 -1599
  91. package/src/base-client/components/common/XTable/XTableWrapper.vue +597 -597
  92. package/src/base-client/components/common/XTable/index.js +3 -3
  93. package/src/base-client/components/common/XTimeline/XTimeline.vue +358 -358
  94. package/src/base-client/components/common/XTimeline/index.md +191 -191
  95. package/src/base-client/components/common/XTree/XTreePro.vue +452 -452
  96. package/src/base-client/components/common/XTreeOne/index.js +3 -3
  97. package/src/base-client/components/common/XUploadFilesView/index.vue +485 -485
  98. package/src/base-client/components/his/XCharge/XCharge.vue +238 -238
  99. package/src/base-client/components/his/XCheckbox/XCheckbox.vue +105 -105
  100. package/src/base-client/components/his/XCheckbox/index.md +253 -253
  101. package/src/base-client/components/his/XHDescriptions/XHDescriptions.vue +430 -430
  102. package/src/base-client/components/his/XHDescriptions/index.md +217 -217
  103. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +629 -629
  104. package/src/base-client/components/his/XHisEditor/diagnosisAutocomplete.js +263 -263
  105. package/src/base-client/components/his/XList/XList.vue +495 -495
  106. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.json +3 -3
  107. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.vue +106 -106
  108. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireDemo.vue +51 -51
  109. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireItem.vue +269 -269
  110. package/src/base-client/components/his/XRadio/XRadio.vue +125 -125
  111. package/src/base-client/components/his/XRadio/index.md +234 -234
  112. package/src/base-client/components/his/XSelect/XSelect.vue +72 -72
  113. package/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +234 -234
  114. package/src/base-client/components/his/XShiftSchedule/dome.vue +29 -29
  115. package/src/base-client/components/his/XSidebar/XSidebar.vue +240 -240
  116. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  117. package/src/base-client/components/his/XTimeSelect/XTimeSelect.vue +162 -162
  118. package/src/base-client/components/his/XTimeSelect/XTimeSelectDemo.vue +23 -23
  119. package/src/base-client/components/his/XTitle/README.md +113 -113
  120. package/src/base-client/components/his/XTitle/XTitle.vue +123 -123
  121. package/src/base-client/components/his/XTreeRows/TreeNode.vue +107 -107
  122. package/src/base-client/components/his/XTreeRows/XTreeRows.vue +307 -307
  123. package/src/base-client/components/his/threeTestOrders/dome.vue +68 -68
  124. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  125. package/src/base-client/components/his/threeTestOrders/textBox.vue +457 -457
  126. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +475 -475
  127. package/src/base-client/components/layout/XPageView/RenderRow.vue +88 -88
  128. package/src/base-client/components/layout/XPageView/XErrorView.vue +22 -22
  129. package/src/base-client/components/layout/XPageView/XPageRowTemplate.vue +37 -37
  130. package/src/base-client/components/layout/XPageView/XPageView.vue +223 -223
  131. package/src/base-client/components/layout/XPageView/XTab/XTab.vue +96 -96
  132. package/src/base-client/components/layout/XPageView/XTab/index.js +3 -3
  133. package/src/base-client/components/layout/XPageView/componentTypes.js +22 -22
  134. package/src/base-client/components/layout/XPageView/index.js +2 -2
  135. package/src/base-client/components/layout/XPageView/index.md +96 -96
  136. package/src/base-client/components/system/DictionaryDetailsView/index.js +3 -3
  137. package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -41
  138. package/src/base-client/components/system/LogDetailsView/LogDetailsView.vue +376 -376
  139. package/src/base-client/components/system/LogDetailsView/index.js +3 -3
  140. package/src/base-client/components/system/LogDetailsView/index.md +41 -41
  141. package/src/base-client/components/system/QueryParamsDetailsView/index.js +3 -3
  142. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  143. package/src/base-client/components/ticket/TicketDetailsView/index.js +3 -3
  144. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  145. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  146. package/src/base-client/components/ticket/TicketDetailsView/part/index.js +3 -3
  147. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  148. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.js +3 -3
  149. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  150. package/src/base-client/plugins/AppData.js +126 -126
  151. package/src/base-client/plugins/PagedList.js +177 -177
  152. package/src/base-client/plugins/__tests__/selectValueTypeHelper.test.js +154 -0
  153. package/src/base-client/plugins/authority-plugin.js +167 -167
  154. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  155. package/src/base-client/plugins/i18n-extend.js +32 -32
  156. package/src/base-client/plugins/moment.js +8 -8
  157. package/src/base-client/plugins/selectValueTypeHelper.js +281 -0
  158. package/src/bootstrap.js +51 -51
  159. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  160. package/src/components/Ellipsis/index.js +3 -3
  161. package/src/components/Ellipsis/index.md +38 -38
  162. package/src/components/FileImageItem/FileItem.vue +320 -320
  163. package/src/components/FileImageItem/FileItemGroup.vue +197 -197
  164. package/src/components/FileImageItem/ImageItem.vue +107 -107
  165. package/src/components/FileImageItem/index.js +4 -4
  166. package/src/components/FilePreview/FilePreview.vue +181 -181
  167. package/src/components/FilePreview/FilePreviewDemo.vue +30 -30
  168. package/src/components/FilePreview/index.js +3 -3
  169. package/src/components/HeightScanner/index.vue +615 -615
  170. package/src/components/STable/README.md +341 -341
  171. package/src/components/STable/index.js +558 -558
  172. package/src/components/TableSetting/TableSetting.vue +143 -143
  173. package/src/components/TableSetting/index.js +3 -3
  174. package/src/components/Trend/Trend.vue +41 -41
  175. package/src/components/Trend/index.js +3 -3
  176. package/src/components/Trend/index.less +41 -41
  177. package/src/components/Trend/index.md +45 -45
  178. package/src/components/_util/util.js +46 -46
  179. package/src/components/cache/AKeepAlive.js +179 -179
  180. package/src/components/exception/typeConfig.js +19 -19
  181. package/src/components/form/FormRow.vue +52 -52
  182. package/src/components/index.less +5 -5
  183. package/src/components/menu/Contextmenu.vue +84 -84
  184. package/src/components/menu/index.less +38 -38
  185. package/src/components/page/header/PageHeader.vue +64 -64
  186. package/src/components/page/header/index.less +40 -40
  187. package/src/components/result/Result.vue +77 -77
  188. package/src/components/setting/SettingItem.vue +26 -26
  189. package/src/components/setting/i18n.js +117 -117
  190. package/src/components/table/StandardTable.vue +141 -141
  191. package/src/components/table/advance/ActionColumns.vue +158 -158
  192. package/src/components/table/advance/ActionSize.vue +45 -45
  193. package/src/components/table/advance/AdvanceTable.vue +275 -275
  194. package/src/components/table/advance/SearchArea.vue +355 -355
  195. package/src/components/table/advance/index.js +2 -2
  196. package/src/components/table/api/ApiTable.vue +50 -50
  197. package/src/components/task/TaskGroup.vue +80 -80
  198. package/src/components/task/TaskItem.vue +26 -26
  199. package/src/components/tool/AvatarList.vue +68 -68
  200. package/src/components/tool/DetailList.vue +157 -157
  201. package/src/components/tool/Drawer.vue +142 -142
  202. package/src/components/tool/FooterToolBar.vue +30 -30
  203. package/src/components/tool/HeadInfo.vue +35 -35
  204. package/src/components/tool/TagSelect.vue +83 -83
  205. package/src/components/tool/TagSelectOption.vue +33 -33
  206. package/src/components/transition/PageToggleTransition.vue +97 -97
  207. package/src/config/default/admin.config.js +18 -18
  208. package/src/config/default/animate.config.js +21 -21
  209. package/src/config/default/index.js +6 -6
  210. package/src/config/index.js +3 -3
  211. package/src/config/replacer/index.js +10 -10
  212. package/src/config/replacer/resolve.config.js +67 -67
  213. package/src/expression/ExpressionRunner.js +26 -26
  214. package/src/expression/TestExpression.js +509 -509
  215. package/src/expression/core/Delegate.js +115 -115
  216. package/src/expression/core/Expression.js +1358 -1358
  217. package/src/expression/core/Program.js +932 -932
  218. package/src/expression/core/Token.js +27 -27
  219. package/src/expression/enums/ExpressionType.js +81 -81
  220. package/src/expression/enums/TokenType.js +11 -11
  221. package/src/expression/exception/BreakWayException.js +2 -2
  222. package/src/expression/exception/ContinueWayException.js +2 -2
  223. package/src/expression/exception/ExpressionException.js +28 -28
  224. package/src/expression/exception/ReturnWayException.js +14 -14
  225. package/src/expression/exception/ServiceException.js +22 -22
  226. package/src/expression/instances/LogicConsole.js +44 -44
  227. package/src/expression/ts/ExpressionRunner.ts +28 -28
  228. package/src/expression/ts/TestExpression.ts +509 -509
  229. package/src/expression/ts/core/Delegate.ts +114 -114
  230. package/src/expression/ts/core/Expression.ts +1309 -1309
  231. package/src/expression/ts/core/Program.ts +950 -950
  232. package/src/expression/ts/core/Token.ts +29 -29
  233. package/src/expression/ts/enums/ExpressionType.ts +81 -81
  234. package/src/expression/ts/enums/TokenType.ts +13 -13
  235. package/src/expression/ts/exception/BreakWayException.ts +2 -2
  236. package/src/expression/ts/exception/ContinueWayException.ts +2 -2
  237. package/src/expression/ts/exception/ExpressionException.ts +28 -28
  238. package/src/expression/ts/exception/ReturnWayException.ts +14 -14
  239. package/src/expression/ts/exception/ServiceException.ts +22 -22
  240. package/src/expression/ts/instances/JSONArray.ts +48 -48
  241. package/src/expression/ts/instances/JSONObject.ts +109 -109
  242. package/src/expression/ts/instances/LogicConsole.ts +32 -32
  243. package/src/layouts/AdminLayout.vue +176 -176
  244. package/src/layouts/BlankView.vue +79 -79
  245. package/src/layouts/ComponentLayoutOne.vue +47 -47
  246. package/src/layouts/GridView.vue +43 -43
  247. package/src/layouts/PageView.vue +55 -55
  248. package/src/layouts/footer/PageFooter.vue +49 -49
  249. package/src/layouts/header/HeaderAvatar.vue +64 -64
  250. package/src/layouts/header/HeaderSearch.vue +67 -67
  251. package/src/layouts/header/index.less +92 -92
  252. package/src/layouts/tabs/TabsView.vue +383 -383
  253. package/src/layouts/tabs/i18n.js +25 -25
  254. package/src/layouts/tabs/index.js +2 -2
  255. package/src/logic/LogicRunner.js +62 -62
  256. package/src/logic/TestLogic.js +13 -13
  257. package/src/logic/plugins/common/DateTools.js +35 -35
  258. package/src/logic/plugins/common/VueTools.js +30 -30
  259. package/src/logic/plugins/index.js +7 -7
  260. package/src/logic/ts/LogicRunner.ts +67 -67
  261. package/src/logic/ts/TestLogic.ts +13 -13
  262. package/src/main.js +33 -33
  263. package/src/mixins/formValidationMixin.js +46 -46
  264. package/src/mock/common/activityData.js +32 -32
  265. package/src/mock/common/index.js +89 -89
  266. package/src/mock/common/reportData.js +20 -20
  267. package/src/mock/common/tableData.js +118 -118
  268. package/src/mock/index.js +12 -12
  269. package/src/mock/project/index.js +17 -17
  270. package/src/mock/user/current.js +13 -13
  271. package/src/mock/user/login.js +39 -39
  272. package/src/mock/user/routes.js +61 -61
  273. package/src/mock/workplace/index.js +15 -15
  274. package/src/pages/LogicCallExample/index.vue +46 -46
  275. package/src/pages/ReportGrid/index.vue +76 -76
  276. package/src/pages/ReportView.vue +50 -50
  277. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +47 -47
  278. package/src/pages/WorkflowDetail/WorkFlowDemo2.vue +204 -204
  279. package/src/pages/WorkflowDetail/WorkFlowDemo3.vue +203 -203
  280. package/src/pages/WorkflowDetail/WorkflowDetail.vue +391 -391
  281. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +388 -388
  282. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +415 -415
  283. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +1766 -1765
  284. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +975 -975
  285. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowPreview.vue +109 -109
  286. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +929 -929
  287. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +222 -222
  288. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +243 -243
  289. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +188 -188
  290. package/src/pages/WorkflowDetail/WorkflowPageDetail/components/WorkflowPersonSelector.vue +109 -109
  291. package/src/pages/WorkflowDetail/WorkflowPageDetail/worklog.vue +97 -97
  292. package/src/pages/XPageViewExample/index.vue +149 -149
  293. package/src/pages/addressSelect/addressDemo.vue +24 -24
  294. package/src/pages/addressSelect/index.vue +270 -270
  295. package/src/pages/dashboard/workplace/i18n.js +40 -40
  296. package/src/pages/dashboard/workplace/index.js +2 -2
  297. package/src/pages/dashboard/workplace/index.less +59 -59
  298. package/src/pages/exception/403.vue +21 -21
  299. package/src/pages/exception/404.vue +24 -24
  300. package/src/pages/exception/500.vue +21 -21
  301. package/src/pages/login/index.js +2 -2
  302. package/src/pages/report/ReportTableHome.vue +28 -28
  303. package/src/pages/resourceManage/depListManage.vue +23 -23
  304. package/src/pages/resourceManage/funListManage.vue +23 -23
  305. package/src/pages/resourceManage/index.js +15 -15
  306. package/src/pages/resourceManage/resourceManageMain.vue +57 -57
  307. package/src/pages/resourceManage/roleListManage.vue +23 -23
  308. package/src/pages/resourceManage/staffListManage.vue +23 -23
  309. package/src/pages/system/file/Info.vue +56 -56
  310. package/src/pages/system/file/index.vue +317 -317
  311. package/src/pages/system/settings/index.vue +126 -126
  312. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +77 -77
  313. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +75 -75
  314. package/src/pages/userInfoDetailManage/InsuranceDetailQuery/index.vue +64 -64
  315. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +75 -75
  316. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +75 -75
  317. package/src/pages/userInfoDetailManage/PriceAdjustments/index.vue +64 -64
  318. package/src/pages/userInfoDetailManage/UserChargeRecordQuery/index.vue +94 -94
  319. package/src/pages/userInfoDetailManage/UserException/index.vue +64 -64
  320. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +87 -87
  321. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +74 -74
  322. package/src/pages/userInfoDetailManage/index.vue +290 -290
  323. package/src/pages/userInfoDetailManage/uploadFilesHistory/ImagePreview.vue +101 -101
  324. package/src/pages/userInfoDetailManage/uploadFilesHistory/index.vue +129 -129
  325. package/src/pages/userInfoDetailManage/userInfoDetailQueryTabs.vue +144 -144
  326. package/src/plugins/HiPrintPlugin.js +164 -164
  327. package/src/router/async/router.map.js +126 -126
  328. package/src/router/guards.js +262 -262
  329. package/src/router/i18n.js +57 -57
  330. package/src/router.js +17 -17
  331. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  332. package/src/services/api/LogDetailsViewApi.js +10 -10
  333. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  334. package/src/services/api/logininfor/index.js +6 -6
  335. package/src/services/api/manage.js +8 -8
  336. package/src/services/api/restTools.js +215 -215
  337. package/src/services/api/workFlow.js +57 -57
  338. package/src/services/apiService.js +16 -16
  339. package/src/services/dataSource.js +12 -12
  340. package/src/services/index.js +7 -7
  341. package/src/services/user.js +92 -92
  342. package/src/services/v3Api.js +116 -116
  343. package/src/store/index.js +5 -5
  344. package/src/store/mutation-types.js +4 -4
  345. package/src/theme/antd/ant-menu.less +2 -2
  346. package/src/theme/antd/ant-message.less +3 -3
  347. package/src/theme/antd/ant-table.less +22 -22
  348. package/src/theme/antd/ant-time-picker.less +3 -3
  349. package/src/theme/antd/index.less +3 -3
  350. package/src/theme/default/color.less +43 -43
  351. package/src/theme/default/index.less +3 -3
  352. package/src/theme/default/nprogress.less +76 -76
  353. package/src/theme/global.less +279 -279
  354. package/src/theme/index.less +5 -5
  355. package/src/theme/reportTable.less +58 -58
  356. package/src/theme/theme.less +1 -1
  357. package/src/utils/EncryptUtil.js +162 -162
  358. package/src/utils/Objects.js +25 -25
  359. package/src/utils/axios-interceptors.js +100 -100
  360. package/src/utils/colors.js +107 -107
  361. package/src/utils/common.js +10 -10
  362. package/src/utils/excel/Blob.js +180 -180
  363. package/src/utils/excel/Export2Excel.js +141 -141
  364. package/src/utils/filter.js +21 -21
  365. package/src/utils/i18n.js +80 -80
  366. package/src/utils/indexedDB.js +549 -549
  367. package/src/utils/microAppUtils.js +49 -49
  368. package/src/utils/request.js +395 -395
  369. package/src/utils/routerUtil.js +553 -553
  370. package/src/utils/themeUtil.js +100 -100
  371. package/test/Tree.spec.js +168 -168
  372. package/test/myDialog.spec.js +47 -47
  373. package/test/request.test.js +17 -17
  374. package/test/util.test.js +53 -53
  375. package/test/v3Api.test.js +1984 -1984
  376. package/tests/unit/ReportTable.spec.js +16 -16
  377. package/vue.config.js +222 -222
@@ -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
+ }