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,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
+ })