vue2-client 1.15.86 → 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 -452
  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,100 +1,100 @@
1
- const client = require('webpack-theme-color-replacer/client')
2
- const { theme } = require('../config')
3
- const { getMenuColors, getAntdColors, getThemeToggleColors, getFunctionalColors } = require('../utils/colors')
4
- const { ANTD } = require('../config/default')
5
-
6
- function getThemeColors (color, $theme) {
7
- const _color = color || theme.color
8
- const mode = $theme || theme.mode
9
- const replaceColors = getThemeToggleColors(_color, mode)
10
- return [
11
- ...replaceColors.mainColors,
12
- ...replaceColors.subColors,
13
- ...replaceColors.menuColors,
14
- ...replaceColors.contentColors,
15
- ...replaceColors.rgbColors,
16
- ...replaceColors.functionalColors.success,
17
- ...replaceColors.functionalColors.warning,
18
- ...replaceColors.functionalColors.error
19
- ]
20
- }
21
-
22
- function changeThemeColor (newColor, $theme) {
23
- return client.changer.changeColor({ newColors: getThemeColors(newColor, $theme) })
24
- }
25
-
26
- function modifyVars (color) {
27
- const _color = color || theme.color
28
- const palettes = getAntdColors(_color, theme.mode)
29
- const menuColors = getMenuColors(_color, theme.mode)
30
- const { success, warning, error } = getFunctionalColors(theme.mode)
31
- const primary = palettes[5]
32
- return {
33
- 'primary-color': primary,
34
- 'primary-1': palettes[0],
35
- 'primary-2': palettes[1],
36
- 'primary-3': palettes[2],
37
- 'primary-4': palettes[3],
38
- 'primary-5': palettes[4],
39
- 'primary-6': palettes[5],
40
- 'primary-7': palettes[6],
41
- 'primary-8': palettes[7],
42
- 'primary-9': palettes[8],
43
- 'primary-10': palettes[9],
44
- 'info-color': primary,
45
- 'success-color': success[5],
46
- 'warning-color': warning[5],
47
- 'error-color': error[5],
48
- 'alert-info-bg-color': palettes[0],
49
- 'alert-info-border-color': palettes[2],
50
- 'alert-success-bg-color': success[0],
51
- 'alert-success-border-color': success[2],
52
- 'alert-warning-bg-color': warning[0],
53
- 'alert-warning-border-color': warning[2],
54
- 'alert-error-bg-color': error[0],
55
- 'alert-error-border-color': error[2],
56
- 'processing-color': primary,
57
- 'menu-dark-submenu-bg': menuColors[0],
58
- 'layout-header-background': menuColors[1],
59
- 'layout-trigger-background': menuColors[2],
60
- 'btn-danger-bg': error[4],
61
- 'btn-danger-border': error[4],
62
- ...ANTD.theme[theme.mode]
63
- }
64
- }
65
-
66
- function loadLocalTheme (localSetting) {
67
- if (localSetting && localSetting.theme) {
68
- let { color, mode } = localSetting.theme
69
- color = color || theme.color
70
- mode = mode || theme.mode
71
- changeThemeColor(color, mode)
72
- }
73
- }
74
-
75
- /**
76
- * 获取本地保存的配置
77
- * @returns {Object}
78
- * @param loadTheme
79
- */
80
- function getLocalSetting (loadTheme) {
81
- let localSetting = {}
82
- try {
83
- const localSettingStr = localStorage.getItem(process.env.VUE_APP_SETTING_KEY)
84
- localSetting = JSON.parse(localSettingStr)
85
- } catch (e) {
86
- console.error(e)
87
- }
88
- if (loadTheme) {
89
- loadLocalTheme(localSetting)
90
- }
91
- return localSetting
92
- }
93
-
94
- module.exports = {
95
- getThemeColors,
96
- changeThemeColor,
97
- modifyVars,
98
- loadLocalTheme,
99
- getLocalSetting
100
- }
1
+ const client = require('webpack-theme-color-replacer/client')
2
+ const { theme } = require('../config')
3
+ const { getMenuColors, getAntdColors, getThemeToggleColors, getFunctionalColors } = require('../utils/colors')
4
+ const { ANTD } = require('../config/default')
5
+
6
+ function getThemeColors (color, $theme) {
7
+ const _color = color || theme.color
8
+ const mode = $theme || theme.mode
9
+ const replaceColors = getThemeToggleColors(_color, mode)
10
+ return [
11
+ ...replaceColors.mainColors,
12
+ ...replaceColors.subColors,
13
+ ...replaceColors.menuColors,
14
+ ...replaceColors.contentColors,
15
+ ...replaceColors.rgbColors,
16
+ ...replaceColors.functionalColors.success,
17
+ ...replaceColors.functionalColors.warning,
18
+ ...replaceColors.functionalColors.error
19
+ ]
20
+ }
21
+
22
+ function changeThemeColor (newColor, $theme) {
23
+ return client.changer.changeColor({ newColors: getThemeColors(newColor, $theme) })
24
+ }
25
+
26
+ function modifyVars (color) {
27
+ const _color = color || theme.color
28
+ const palettes = getAntdColors(_color, theme.mode)
29
+ const menuColors = getMenuColors(_color, theme.mode)
30
+ const { success, warning, error } = getFunctionalColors(theme.mode)
31
+ const primary = palettes[5]
32
+ return {
33
+ 'primary-color': primary,
34
+ 'primary-1': palettes[0],
35
+ 'primary-2': palettes[1],
36
+ 'primary-3': palettes[2],
37
+ 'primary-4': palettes[3],
38
+ 'primary-5': palettes[4],
39
+ 'primary-6': palettes[5],
40
+ 'primary-7': palettes[6],
41
+ 'primary-8': palettes[7],
42
+ 'primary-9': palettes[8],
43
+ 'primary-10': palettes[9],
44
+ 'info-color': primary,
45
+ 'success-color': success[5],
46
+ 'warning-color': warning[5],
47
+ 'error-color': error[5],
48
+ 'alert-info-bg-color': palettes[0],
49
+ 'alert-info-border-color': palettes[2],
50
+ 'alert-success-bg-color': success[0],
51
+ 'alert-success-border-color': success[2],
52
+ 'alert-warning-bg-color': warning[0],
53
+ 'alert-warning-border-color': warning[2],
54
+ 'alert-error-bg-color': error[0],
55
+ 'alert-error-border-color': error[2],
56
+ 'processing-color': primary,
57
+ 'menu-dark-submenu-bg': menuColors[0],
58
+ 'layout-header-background': menuColors[1],
59
+ 'layout-trigger-background': menuColors[2],
60
+ 'btn-danger-bg': error[4],
61
+ 'btn-danger-border': error[4],
62
+ ...ANTD.theme[theme.mode]
63
+ }
64
+ }
65
+
66
+ function loadLocalTheme (localSetting) {
67
+ if (localSetting && localSetting.theme) {
68
+ let { color, mode } = localSetting.theme
69
+ color = color || theme.color
70
+ mode = mode || theme.mode
71
+ changeThemeColor(color, mode)
72
+ }
73
+ }
74
+
75
+ /**
76
+ * 获取本地保存的配置
77
+ * @returns {Object}
78
+ * @param loadTheme
79
+ */
80
+ function getLocalSetting (loadTheme) {
81
+ let localSetting = {}
82
+ try {
83
+ const localSettingStr = localStorage.getItem(process.env.VUE_APP_SETTING_KEY)
84
+ localSetting = JSON.parse(localSettingStr)
85
+ } catch (e) {
86
+ console.error(e)
87
+ }
88
+ if (loadTheme) {
89
+ loadLocalTheme(localSetting)
90
+ }
91
+ return localSetting
92
+ }
93
+
94
+ module.exports = {
95
+ getThemeColors,
96
+ changeThemeColor,
97
+ modifyVars,
98
+ loadLocalTheme,
99
+ getLocalSetting
100
+ }
package/test/Tree.spec.js CHANGED
@@ -1,168 +1,168 @@
1
- import { nextTick } from 'vue'
2
- import { shallowMount, mount } from '@vue/test-utils'
3
-
4
- import TreeComponent from '@vue2-client/base-client/components/common/Tree'
5
- import * as CommonApi from '@vue2-client/services/api/common'
6
- import { afterEach, beforeEach, describe, expect, it, jest } from '@jest/globals'
7
-
8
- function handleLogic (logicName, parameters) {
9
- // 使用 switch 语句来处理多种业务逻辑
10
- switch (logicName) {
11
- case 'get_root_nodes':
12
- // 返回特定于 'get_root_nodes' 业务逻辑的数据
13
- return Promise.resolve({
14
- data: [{
15
- key: '0-0',
16
- children: [],
17
- title: '某某燃气有限公司',
18
- }],
19
- })
20
-
21
- case 'get_child_nodes':
22
- // 根据 'another_logic' 执行不同的操作
23
- // ...(执行相关操作)
24
- return Promise.resolve({
25
- data: [
26
- { id: '2' },
27
- ],
28
- })
29
-
30
- // ...您可以添加更多的 case 语句来处理更多的业务逻辑
31
-
32
- default:
33
- // 如果传入了一个未处理的业务逻辑名称,您可以有一个默认的行为或返回一个错误。
34
- return Promise.reject(new Error('未知的业务逻辑名称: ' + logicName))
35
- }
36
- }
37
-
38
- describe('TreeComponent', () => {
39
- let runLogicSpy // 将变量声明移动到这里,使其在下面的作用域中可见
40
- let wrapper
41
-
42
- beforeEach(() => {
43
- // 这里,我们使用 'spyOn' 只拦截 'runLogic' 函数,而不影响模块中的其他函数
44
- runLogicSpy = jest.spyOn(CommonApi, 'runLogic')
45
- // 现在,你可以定义这个函数的模拟实现或返回值
46
- runLogicSpy.mockImplementation((logicName, parameters) => {
47
- return handleLogic(logicName, parameters) // 这里是你的模拟实现)
48
- })
49
-
50
- // 在这里,我们通过 propsData 传递 prop
51
- wrapper = mount(TreeComponent, {
52
- propsData: {
53
- configContent: {}, // 这里添加你的配置内容
54
- // ... 如果还有其他 props,也在这里添加 ...
55
- },
56
- })
57
- })
58
-
59
- afterEach(() => {
60
- // 测试之后,你应该清理模拟,以确保它不会影响其他测试
61
- runLogicSpy.mockRestore()
62
- wrapper.destroy()
63
- })
64
-
65
- it('renders a Tree component', () => {
66
- expect(wrapper.findComponent({ name: 'a-tree' }).exists()).toBe(true)
67
- })
68
-
69
- it('calls generateTreeData method on mounted', async () => {
70
- // 首先创建spy
71
- const generateTreeData = jest.spyOn(TreeComponent.methods, 'generateTreeData')
72
-
73
- // 挂载组件,并通过 propsData 传递参数
74
- wrapper = await mount(TreeComponent, {
75
- propsData: {
76
- configContent: {}, // 这里添加实际的配置内容
77
- // ...如果还有其他props,也可以在这里添加...
78
- },
79
- })
80
-
81
- // 现在检查 generateTreeData 是否已被调用
82
- expect(generateTreeData).toHaveBeenCalled()
83
- })
84
-
85
- it('generates treeData correctly', () => {
86
- const expectedTreeData =
87
- [{
88
- key: '0-0',
89
- children: [],
90
- title: '某某燃气有限公司',
91
- }]
92
-
93
- expect(wrapper.vm.treeData).toEqual(expectedTreeData)
94
- })
95
-
96
- it('expands a node and fetches child nodes correctly', async () => {
97
- // 准备一些模拟数据
98
- const mockNode = {
99
- id: '1', // 或其他唯一标识符
100
- children: [], // 初始时假设没有子节点
101
- }
102
-
103
- const mockChildren = [
104
- { id: '2', parentNode: mockNode },
105
- // ...更多子节点
106
- ]
107
-
108
- // 准备handleExpand方法所需的参数
109
- const expandedKeys = ['1'] // 假设这是当前展开的节点keys
110
- const info = {
111
- expanded: true, // 假设节点是被展开的
112
- node: mockNode, // 当前操作的节点
113
- }
114
-
115
- // 现在调用handleExpand方法
116
- await wrapper.vm.handleExpand(expandedKeys, info)
117
-
118
- // 我们还期望mockNode的子节点被更新
119
- expect(mockNode.children).toEqual(mockChildren)
120
-
121
- // 如果handleExpand方法更新了expandedKeys数组,我们也要验证这一点
122
- const expectedExpandedKeys = ['1'] // 假设它应该包含被展开节点的id
123
- expect(wrapper.vm.expandedKeys).toEqual(expectedExpandedKeys)
124
- })
125
-
126
- it('selects a node and emits nodeSelected event correctly', () => {
127
- // 准备 mock 数据
128
- const mockNode = { title: '某某燃气有限公司', parentNode: null }
129
- const selectedKeys = ['1'] // 这个应该基于 mockNode 的数据
130
- const selectInfo = { selected: true, node: mockNode }
131
-
132
- // 调用 handleSelect 方法
133
- wrapper.vm.handleSelect(selectedKeys, selectInfo)
134
-
135
- // 断言已发出正确的事件
136
- const emittedEvents = wrapper.emitted('nodeSelected')
137
- expect(emittedEvents).toBeTruthy() // 确认是否有事件被发出
138
- expect(emittedEvents).toHaveLength(1) // 只有一个事件被发出
139
- expect(emittedEvents[0]).toEqual(['某某燃气有限公司']) // 传出的事件携带了正确的数据
140
-
141
- // 如果 handleSelect 方法更改了内部状态(例如,'selectedKeys'),也要进行断言
142
- expect(wrapper.vm.selectedKeys).toEqual([])
143
- })
144
-
145
- it('expands a node when clicked', async () => {
146
- console.log(wrapper.html()) // 打印组件的 HTML 输出
147
-
148
- // 找到 role 为 "treeitem" 的元素,这代表树节点
149
- const treeNode = wrapper.find('li[role="treeitem"]')
150
-
151
- // 确认我们找到了节点
152
- expect(treeNode.exists()).toBe(true)
153
-
154
- // 模拟用户点击,展开节点
155
- await treeNode.trigger('click')
156
-
157
- // 必须等待 nextTick 以便 Vue 更新 DOM
158
- await nextTick()
159
-
160
- // 现在检查是否更新了 expandedKeys
161
- expect(wrapper.vm.expandedKeys).toContain('0-0') // 假设 '0-0' 是被点击的节点的 key
162
-
163
- // 检查 'expand' 事件是否被正确触发
164
- const expandEvents = wrapper.emitted('expand')
165
- expect(expandEvents).toBeTruthy()
166
- expect(expandEvents.length).toBeGreaterThan(0) // 确认至少触发了一次
167
- })
168
- })
1
+ import { nextTick } from 'vue'
2
+ import { shallowMount, mount } from '@vue/test-utils'
3
+
4
+ import TreeComponent from '@vue2-client/base-client/components/common/Tree'
5
+ import * as CommonApi from '@vue2-client/services/api/common'
6
+ import { afterEach, beforeEach, describe, expect, it, jest } from '@jest/globals'
7
+
8
+ function handleLogic (logicName, parameters) {
9
+ // 使用 switch 语句来处理多种业务逻辑
10
+ switch (logicName) {
11
+ case 'get_root_nodes':
12
+ // 返回特定于 'get_root_nodes' 业务逻辑的数据
13
+ return Promise.resolve({
14
+ data: [{
15
+ key: '0-0',
16
+ children: [],
17
+ title: '某某燃气有限公司',
18
+ }],
19
+ })
20
+
21
+ case 'get_child_nodes':
22
+ // 根据 'another_logic' 执行不同的操作
23
+ // ...(执行相关操作)
24
+ return Promise.resolve({
25
+ data: [
26
+ { id: '2' },
27
+ ],
28
+ })
29
+
30
+ // ...您可以添加更多的 case 语句来处理更多的业务逻辑
31
+
32
+ default:
33
+ // 如果传入了一个未处理的业务逻辑名称,您可以有一个默认的行为或返回一个错误。
34
+ return Promise.reject(new Error('未知的业务逻辑名称: ' + logicName))
35
+ }
36
+ }
37
+
38
+ describe('TreeComponent', () => {
39
+ let runLogicSpy // 将变量声明移动到这里,使其在下面的作用域中可见
40
+ let wrapper
41
+
42
+ beforeEach(() => {
43
+ // 这里,我们使用 'spyOn' 只拦截 'runLogic' 函数,而不影响模块中的其他函数
44
+ runLogicSpy = jest.spyOn(CommonApi, 'runLogic')
45
+ // 现在,你可以定义这个函数的模拟实现或返回值
46
+ runLogicSpy.mockImplementation((logicName, parameters) => {
47
+ return handleLogic(logicName, parameters) // 这里是你的模拟实现)
48
+ })
49
+
50
+ // 在这里,我们通过 propsData 传递 prop
51
+ wrapper = mount(TreeComponent, {
52
+ propsData: {
53
+ configContent: {}, // 这里添加你的配置内容
54
+ // ... 如果还有其他 props,也在这里添加 ...
55
+ },
56
+ })
57
+ })
58
+
59
+ afterEach(() => {
60
+ // 测试之后,你应该清理模拟,以确保它不会影响其他测试
61
+ runLogicSpy.mockRestore()
62
+ wrapper.destroy()
63
+ })
64
+
65
+ it('renders a Tree component', () => {
66
+ expect(wrapper.findComponent({ name: 'a-tree' }).exists()).toBe(true)
67
+ })
68
+
69
+ it('calls generateTreeData method on mounted', async () => {
70
+ // 首先创建spy
71
+ const generateTreeData = jest.spyOn(TreeComponent.methods, 'generateTreeData')
72
+
73
+ // 挂载组件,并通过 propsData 传递参数
74
+ wrapper = await mount(TreeComponent, {
75
+ propsData: {
76
+ configContent: {}, // 这里添加实际的配置内容
77
+ // ...如果还有其他props,也可以在这里添加...
78
+ },
79
+ })
80
+
81
+ // 现在检查 generateTreeData 是否已被调用
82
+ expect(generateTreeData).toHaveBeenCalled()
83
+ })
84
+
85
+ it('generates treeData correctly', () => {
86
+ const expectedTreeData =
87
+ [{
88
+ key: '0-0',
89
+ children: [],
90
+ title: '某某燃气有限公司',
91
+ }]
92
+
93
+ expect(wrapper.vm.treeData).toEqual(expectedTreeData)
94
+ })
95
+
96
+ it('expands a node and fetches child nodes correctly', async () => {
97
+ // 准备一些模拟数据
98
+ const mockNode = {
99
+ id: '1', // 或其他唯一标识符
100
+ children: [], // 初始时假设没有子节点
101
+ }
102
+
103
+ const mockChildren = [
104
+ { id: '2', parentNode: mockNode },
105
+ // ...更多子节点
106
+ ]
107
+
108
+ // 准备handleExpand方法所需的参数
109
+ const expandedKeys = ['1'] // 假设这是当前展开的节点keys
110
+ const info = {
111
+ expanded: true, // 假设节点是被展开的
112
+ node: mockNode, // 当前操作的节点
113
+ }
114
+
115
+ // 现在调用handleExpand方法
116
+ await wrapper.vm.handleExpand(expandedKeys, info)
117
+
118
+ // 我们还期望mockNode的子节点被更新
119
+ expect(mockNode.children).toEqual(mockChildren)
120
+
121
+ // 如果handleExpand方法更新了expandedKeys数组,我们也要验证这一点
122
+ const expectedExpandedKeys = ['1'] // 假设它应该包含被展开节点的id
123
+ expect(wrapper.vm.expandedKeys).toEqual(expectedExpandedKeys)
124
+ })
125
+
126
+ it('selects a node and emits nodeSelected event correctly', () => {
127
+ // 准备 mock 数据
128
+ const mockNode = { title: '某某燃气有限公司', parentNode: null }
129
+ const selectedKeys = ['1'] // 这个应该基于 mockNode 的数据
130
+ const selectInfo = { selected: true, node: mockNode }
131
+
132
+ // 调用 handleSelect 方法
133
+ wrapper.vm.handleSelect(selectedKeys, selectInfo)
134
+
135
+ // 断言已发出正确的事件
136
+ const emittedEvents = wrapper.emitted('nodeSelected')
137
+ expect(emittedEvents).toBeTruthy() // 确认是否有事件被发出
138
+ expect(emittedEvents).toHaveLength(1) // 只有一个事件被发出
139
+ expect(emittedEvents[0]).toEqual(['某某燃气有限公司']) // 传出的事件携带了正确的数据
140
+
141
+ // 如果 handleSelect 方法更改了内部状态(例如,'selectedKeys'),也要进行断言
142
+ expect(wrapper.vm.selectedKeys).toEqual([])
143
+ })
144
+
145
+ it('expands a node when clicked', async () => {
146
+ console.log(wrapper.html()) // 打印组件的 HTML 输出
147
+
148
+ // 找到 role 为 "treeitem" 的元素,这代表树节点
149
+ const treeNode = wrapper.find('li[role="treeitem"]')
150
+
151
+ // 确认我们找到了节点
152
+ expect(treeNode.exists()).toBe(true)
153
+
154
+ // 模拟用户点击,展开节点
155
+ await treeNode.trigger('click')
156
+
157
+ // 必须等待 nextTick 以便 Vue 更新 DOM
158
+ await nextTick()
159
+
160
+ // 现在检查是否更新了 expandedKeys
161
+ expect(wrapper.vm.expandedKeys).toContain('0-0') // 假设 '0-0' 是被点击的节点的 key
162
+
163
+ // 检查 'expand' 事件是否被正确触发
164
+ const expandEvents = wrapper.emitted('expand')
165
+ expect(expandEvents).toBeTruthy()
166
+ expect(expandEvents.length).toBeGreaterThan(0) // 确认至少触发了一次
167
+ })
168
+ })
@@ -1,47 +1,47 @@
1
- import { createLocalVue, mount } from '@vue/test-utils'
2
- import MyConfirm from '@vue2-client/base-client/components/common/XBadge'
3
- import Plugins from '@vue2-client/base-client/plugins'
4
- import Antd from 'ant-design-vue'
5
- import { it, describe, expect, beforeAll, jest } from '@jest/globals'
6
-
7
- const localVue = createLocalVue()
8
-
9
- // 此处与index.js保持一致,保证antd的组件和appdata可以正常载入
10
- localVue.use(Antd)
11
- localVue.use(Plugins)
12
-
13
- describe('MyConfirm', () => {
14
- beforeAll(() => {
15
- // mock localStorage的数据
16
- const getItemSpy = jest.spyOn(window.localStorage.__proto__, 'getItem')
17
- getItemSpy.mockImplementation((key) => {
18
- if (key === process.env.VUE_APP_BADGE_KEY) {
19
- return JSON.stringify({
20
- badgeStyleMap: {
21
- red: {
22
- status: 'red',
23
- text: '红色(Red)'
24
- },
25
- blue: {
26
- status: 'blue',
27
- text: '蓝色(Blue)'
28
- }
29
- }
30
- })
31
- }
32
- })
33
- })
34
- // 测试用例:正确渲染组件
35
- it('renders correctly', () => {
36
- const wrapper = mount(MyConfirm, {
37
- localVue: localVue,
38
- // 组件必要的传参
39
- propsData: {
40
- badgeKey: 'badgeStyleMap',
41
- value: 'red'
42
- }
43
- })
44
- console.debug('返回的组件html:' + wrapper.html())
45
- expect(wrapper.exists()).toBe(true)
46
- })
47
- })
1
+ import { createLocalVue, mount } from '@vue/test-utils'
2
+ import MyConfirm from '@vue2-client/base-client/components/common/XBadge'
3
+ import Plugins from '@vue2-client/base-client/plugins'
4
+ import Antd from 'ant-design-vue'
5
+ import { it, describe, expect, beforeAll, jest } from '@jest/globals'
6
+
7
+ const localVue = createLocalVue()
8
+
9
+ // 此处与index.js保持一致,保证antd的组件和appdata可以正常载入
10
+ localVue.use(Antd)
11
+ localVue.use(Plugins)
12
+
13
+ describe('MyConfirm', () => {
14
+ beforeAll(() => {
15
+ // mock localStorage的数据
16
+ const getItemSpy = jest.spyOn(window.localStorage.__proto__, 'getItem')
17
+ getItemSpy.mockImplementation((key) => {
18
+ if (key === process.env.VUE_APP_BADGE_KEY) {
19
+ return JSON.stringify({
20
+ badgeStyleMap: {
21
+ red: {
22
+ status: 'red',
23
+ text: '红色(Red)'
24
+ },
25
+ blue: {
26
+ status: 'blue',
27
+ text: '蓝色(Blue)'
28
+ }
29
+ }
30
+ })
31
+ }
32
+ })
33
+ })
34
+ // 测试用例:正确渲染组件
35
+ it('renders correctly', () => {
36
+ const wrapper = mount(MyConfirm, {
37
+ localVue: localVue,
38
+ // 组件必要的传参
39
+ propsData: {
40
+ badgeKey: 'badgeStyleMap',
41
+ value: 'red'
42
+ }
43
+ })
44
+ console.debug('返回的组件html:' + wrapper.html())
45
+ expect(wrapper.exists()).toBe(true)
46
+ })
47
+ })
@@ -1,17 +1,17 @@
1
- import EncryptUtil from '@vue2-client/utils/EncryptUtil'
2
- import { test, describe } from '@jest/globals'
3
-
4
- describe('请求加密模块', () => {
5
- const VALID_KEY = 'a964287a2cef8781ed76bd63dcadd578'
6
- const TEST_PAYLOAD = {
7
- username: 'admin',
8
- password: 'P@ssw0rd_测试',
9
- timestamp: Date.now()
10
- }
11
-
12
- // CBC加密测试
13
- test('应生成有效的加密字符串', () => {
14
- const encrypted = EncryptUtil.AESEncryptCBC(TEST_PAYLOAD, VALID_KEY)
15
- console.log(encrypted)
16
- })
17
- })
1
+ import EncryptUtil from '@vue2-client/utils/EncryptUtil'
2
+ import { test, describe } from '@jest/globals'
3
+
4
+ describe('请求加密模块', () => {
5
+ const VALID_KEY = 'a964287a2cef8781ed76bd63dcadd578'
6
+ const TEST_PAYLOAD = {
7
+ username: 'admin',
8
+ password: 'P@ssw0rd_测试',
9
+ timestamp: Date.now()
10
+ }
11
+
12
+ // CBC加密测试
13
+ test('应生成有效的加密字符串', () => {
14
+ const encrypted = EncryptUtil.AESEncryptCBC(TEST_PAYLOAD, VALID_KEY)
15
+ console.log(encrypted)
16
+ })
17
+ })