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,615 +1,615 @@
1
- <template>
2
- <a-modal
3
- :visible="show"
4
- :dialogStyle="{ top: '1vh' }"
5
- width="50vw"
6
- :footer="null"
7
- :zIndex="1050"
8
- @cancel="handleCancel"
9
- :maskClosable="false"
10
- >
11
- <div class="scanner-container" >
12
- <a-row>
13
- <a-space>
14
- <a-button type="primary" @click="capturePhoto">拍照</a-button>
15
- <a-button type="primary" @click="switchCamera('0')">文档</a-button>
16
- <a-button type="primary" @click="switchCamera('1')">人像</a-button>
17
- <a-button type="primary" @click="getVideoStatus">设备状态</a-button>
18
- <a-button type="primary" @click="closeVideo">关闭设备</a-button>
19
- <a-button type="primary" @click="openApp">开启程序</a-button>
20
- <a-button v-if="showid" type="primary" @click="startReadCard">读身份证</a-button>
21
- <a-button v-if="showid" @click="stopReadCard">停止读卡</a-button>
22
- <a-button type="primary" @click="rotateCamera">画面旋转</a-button>
23
- </a-space>
24
- </a-row>
25
- <a-row>
26
- <a-col :span="12">
27
- <div
28
- style="display: flex; justify-content: center; align-items: center; height: 300px;">
29
- <img
30
- v-if="previewImage"
31
- id="Base64IMG"
32
- :src="previewImage"
33
- height="300"
34
- alt=""
35
- style="display: block;margin: auto;"
36
- />
37
- <a-empty v-else/>
38
- </div>
39
- </a-col>
40
- <a-col :span="12">
41
- <a-textarea
42
- id="Console"
43
- style=" height: 300px; width: 100%; resize: none;border-radius: 0"
44
- :disabled="true"></a-textarea>
45
- </a-col>
46
- <a-col :span="24">
47
- <div
48
- :style="{...heightStyle, display: 'flex', justifyContent: 'center', alignItems: 'center'}">
49
- <img
50
- id="cam"
51
- :src="cameraurl"
52
- :style="rotateStyle"
53
- class="video"
54
- alt=""/>
55
- </div>
56
- </a-col>
57
- <a-col :span="24" v-if="showid">
58
- <a-form layout="horizontal">
59
- <a-form-item label="姓名">
60
- <a-input v-model="idCardForm.name" disabled/>
61
- </a-form-item>
62
- <a-form-item label="性别">
63
- <a-input v-model="idCardForm.sex" disabled/>
64
- </a-form-item>
65
- <a-form-item label="民族">
66
- <a-input v-model="idCardForm.nation" disabled/>
67
- </a-form-item>
68
- <a-form-item label="出生日期">
69
- <a-input v-model="idCardForm.birthday" disabled/>
70
- </a-form-item>
71
- <a-form-item label="地址">
72
- <a-textarea v-model="idCardForm.address" :rows="2" disabled/>
73
- </a-form-item>
74
- <a-form-item label="身份证号">
75
- <a-input v-model="idCardForm.cardID" disabled/>
76
- </a-form-item>
77
- <a-form-item label="签发机关">
78
- <a-input v-model="idCardForm.issueOrgan" disabled/>
79
- </a-form-item>
80
- <a-form-item label="有效期">
81
- <a-input v-model="idCardForm.validStart" disabled/>
82
- <a-input v-model="idCardForm.validEnd" disabled/>
83
- </a-form-item>
84
-
85
- <div class="id-photo-section">
86
- <div class="photo-preview">
87
- <img
88
- id="PhotoDisplay"
89
- :src="idCardForm.photoUrl"
90
- class="id-photo"
91
- alt=""/>
92
- </div>
93
- <a-button type="primary" @click="confirmIdCard">确认信息</a-button>
94
- </div>
95
- </a-form>
96
- </a-col>
97
- </a-row>
98
- </div>
99
- <template #title>
100
- <a-row>
101
- <a-col :span="24">
102
- <a-space>
103
- 高拍仪
104
- <a-button @click="handleOk">上传截图</a-button>
105
- <a-button @click="handleCancel">取消</a-button>
106
- </a-space>
107
- </a-col>
108
- </a-row>
109
- </template>
110
- <div id="result"></div>
111
- </a-modal>
112
- </template>
113
-
114
- <script>
115
- import axios from 'axios'
116
-
117
- let ws
118
- const SERVER_ADDR = 'ws://127.0.0.1:38088'
119
-
120
- export default {
121
- name: 'HeightScanner',
122
-
123
- props: {
124
- show: Boolean,
125
- showid: Boolean
126
- },
127
-
128
- data () {
129
- return {
130
- SERVER_ADDR,
131
- cameraurl: 'http://127.0.0.1:38088/video=stream&camidx=0',
132
- connected: false,
133
- clicked: false,
134
- iswaiting: false,
135
- previewImage: '',
136
- consoleText: '',
137
- idCardForm: {
138
- name: '',
139
- sex: '',
140
- nation: '',
141
- birthday: '',
142
- address: '',
143
- cardID: '',
144
- issueOrgan: '',
145
- validStart: '',
146
- validEnd: '',
147
- photoBuffer: '',
148
- photoUrl: ''
149
- },
150
- callback: {},
151
- context: 0,
152
- rotateAngle: 0,
153
- base_offset: 0,
154
- orgdrawwidth: 0,
155
- orgdrawheight: 0,
156
- containerHeight: 440,
157
-
158
- CLT_MSG: {
159
- // 打开相机 cap:相机ID
160
- BEGIN_CAP: 1,
161
- // 关闭相机 cap:相机ID
162
- STOP_CAP: 2,
163
- // 获取PID
164
- GET_PID: 3,
165
- // 获取分辨率
166
- GET_FBL: 4,
167
- // 设置分辨率
168
- SET_FBL: 5,
169
- // 设置MJPG格式
170
- SET_MJPG: 6,
171
- // 设置视频旋转
172
- SET_TURN: 7,
173
- // 设置视频截图保存的jpg质量
174
- SET_QUALITY: 8,
175
- // 设置自动裁边
176
- SET_AUTOCROP: 9,
177
- // 设置预设框选
178
- SET_PREST: 10,
179
- // 获取当前预设框选
180
- GET_PREST_INFO: 11,
181
- // 视频格式弹窗
182
- FORMAT_DLG: 12,
183
- // 视频属性弹窗
184
- PROPERTY_DLG: 13,
185
- // 设置截图颜色模式 彩色 黑白 灰度
186
- SET_COLOR_MODEL: 14,
187
- // 截图
188
- GET_PICTURE: 15,
189
- // 设置去底色参数
190
- SET_CLEAN_PARAM: 16,
191
- // 内存截图
192
- GET_PICTURE_MEM: 17,
193
- // base64测试
194
- TEST_BASE64: 18,
195
- // 制作PDF的临时目录
196
- SET_TEMPDIR: 19,
197
- // 开始制作PDF
198
- BEGIN_PDF: 20,
199
- // PDF截图 保存到PDF临时目录
200
- GET_PDF_PICTURES: 21,
201
- // 结束制作PDF
202
- END_PDF_PICTURES: 22,
203
- // PDF文件转为文件里的BASE64码
204
- PDF_TO_BASE64: 23,
205
- // 文件里的BASE64码转为PDF文件
206
- BASE64_TO_PDF: 24,
207
- // PDF文件转为BASE64字符串
208
- PDF_TO_BASE64_STR: 25,
209
- // 删除制作PDF的图片文件
210
- DEL_PICTURE_PDF: 26,
211
- // 打印图片
212
- PRINT_IMAGE: 27,
213
- // 设置显示错误弹窗
214
- SHOW_ERROR_BOX: 28,
215
- // 获取视频连接事件
216
- GET_EVENT: 29,
217
- // 预设框选鼠标消息
218
- PRESET_MOUSEDOWN: 30,
219
- PRESET_MOUSEMOVE: 31,
220
- PRESET_MOUSEUP: 32,
221
- // 人证对比
222
- IDCARD_COMPARE: 40,
223
- // 读卡
224
- READ_IDCARD: 51,
225
- // 开始循环读卡
226
- BEGIN_READ_IDCARD: 52,
227
- // 停止循环读卡
228
- STOP_READ_IDCARD: 53,
229
- // 水平
230
- HCOPY_IDCARD: 54,
231
- // 垂直
232
- VCOPY_IDCARD: 55,
233
-
234
- PCOPY_IDCARD: 56,
235
- // 反面
236
- NCOPY_IDCARD: 57
237
- },
238
- SVR_BIN_MSG: {
239
- CAP_FRAME: 1, // 后台帧消息
240
- }
241
- }
242
- },
243
- computed: {
244
- rotateStyle () {
245
- return {
246
- transform: `rotate(${this.rotateAngle}deg)`,
247
- transition: 'transform 0.5s ease',
248
- maxHeight: `${this.rotateAngle % 180 === 0 ? '440px' : '660px'}`
249
- }
250
- },
251
- heightStyle () {
252
- return {
253
- width: '100%',
254
- height: `${this.containerHeight}px`,
255
- }
256
- }
257
- },
258
- methods: {
259
- rotateCamera () {
260
- console.log('>>> 旋转镜头')
261
- // 每次点击增加 90 度,超过 360 度时归零
262
- this.rotateAngle = (this.rotateAngle + 90) % 360
263
- // 根据旋转角度设置不同的高度
264
- this.containerHeight = this.rotateAngle % 180 === 0 ? 440 : 660
265
- },
266
- // handleImgError (e) {
267
- // e.target.style.display = 'none'
268
- // },
269
- // 页面load消息
270
- onLoad () {
271
- return new Promise((resolve, reject) => {
272
- // 添加重试计数器
273
- let retryCount = 0
274
- const maxRetries = 5
275
-
276
- const tryConnect = () => {
277
- if (ws) {
278
- resolve()
279
- return
280
- }
281
-
282
- ws = new WebSocket(this.SERVER_ADDR)
283
-
284
- ws.onopen = (evt) => {
285
- if (this.connected) {
286
- resolve()
287
- }
288
- this.connected = true
289
- this.output('已经连接到服务器')
290
- this.switchCamera(0)
291
- }
292
-
293
- ws.onclose = (evt) => {
294
- if (!this.connected) {
295
- // 检查重试次数
296
- if (retryCount < maxRetries) {
297
- retryCount++
298
- this.output(`连接失败,正在进行第${retryCount}次重试...`)
299
- window.location.href = 'FLShell://'
300
- setTimeout(tryConnect, 3 * 1000)
301
- } else {
302
- this.output('连接失败,已达到最大重试次数')
303
- reject(new Error('连接失败,已达到最大重试次数'))
304
- }
305
- } else {
306
- this.output('已断开服务器连接')
307
- this.connected = false
308
- }
309
- ws = null
310
- }
311
-
312
- ws.onerror = (evt) => {
313
- this.output('高拍仪连接错误')
314
- reject(new Error('连接错误'))
315
- }
316
- ws.onmessage = (evt) => {
317
- if (evt.data.length === 0) {
318
- return
319
- }
320
- if (typeof evt.data === 'string') {
321
- const msg = JSON.parse(evt.data)
322
- console.log('msg1:', msg)
323
- if (msg.err && msg.err !== 0) {
324
- this.output('错误 - ' + msg.err + ', ' + msg.msg)
325
- reject(new Error('错误 - ' + msg.err + ', ' + msg.msg))
326
- } else if (msg.msg) {
327
- console.log('msg2:', msg)
328
- this.output(msg.msg)
329
- }
330
- if (msg.user_data) {
331
- this.callback[msg.user_data](msg)
332
- if (typeof msg.user_data === 'number') {
333
- this.callback[msg.user_data] = undefined
334
- }
335
- }
336
- } else {
337
- const file = new FileReader()
338
- file.onload = (evt) => {
339
- if (evt.target.readyState == FileReader.DONE) {
340
- const data = new Uint8Array(evt.target.result)
341
- if (data[0] == this.SVR_BIN_MSG.CAP_FRAME) {
342
- return this.drawImage(data)
343
- }
344
- }
345
- }
346
- file.readAsArrayBuffer(evt.data)
347
- }
348
- }
349
- const canvas = document.getElementById('cam')
350
- canvas.onmousedown = (e) => {
351
- canvas.style.cursor = 'crosshair'
352
- this.clicked = true
353
- this.sendMsg(this.CLT_MSG.PRESET_MOUSEDOWN, { origX: e.layerX, origY: e.layerY }, (msg) => {
354
- if (msg.err !== 0) {
355
- console.warn('鼠标按下事件出错:', msg.err)
356
- }
357
- })
358
- }
359
- canvas.onmousemove = (e) => {
360
- if (!this.clicked) {
361
- canvas.style.cursor = 'default'
362
- return
363
- }
364
- canvas.style.cursor = 'crosshair'
365
- this.sendMsg(this.CLT_MSG.PRESET_MOUSEMOVE, { offx: e.layerX, offy: e.layerY }, (msg) => {
366
- if (msg.err !== 0) {
367
- console.warn('鼠标移动事件出错:', msg.err)
368
- }
369
- })
370
- }
371
- onmouseout = canvas.onmouseup = (e) => {
372
- canvas.style.cursor = 'default'
373
- if (!this.clicked) {
374
- return
375
- }
376
- this.sendMsg(this.CLT_MSG.PRESET_MOUSEUP, { offx: e.layerX, offy: e.layerY }, (msg) => {
377
- if (msg.err !== 0) {
378
- console.warn('鼠标抬起事件出错:', msg.err)
379
- }
380
- })
381
- this.clicked = false
382
- }
383
- }
384
-
385
- tryConnect() // 开始首次连接
386
- })
387
- },
388
- newInstancePost (url, data) {
389
- // 重新创建是为了 避免axios的拦截器影响写卡读卡请求
390
- // 请求 如果携带了 Cookie,token到卡服务 会导致请求失败
391
- // 需要注意的是因为没有增加响应拦截器 所以返回结果的res里面会多一层data
392
- const instance = axios.create()
393
- return instance.post(url, data, {
394
- withCredentials: false,
395
- headers: {
396
- 'Content-Type': 'text/plain;charset=UTF-8',
397
- Accept: '*/*',
398
- }
399
- })
400
- },
401
- // 打开视频
402
- switchCamera (data) {
403
- this.cameraurl = 'http://127.0.0.1:38088/video=stream&camidx=' + data + '&tid=' + Date.parse(new Date())
404
- },
405
- // 关闭视频
406
- async closeVideo () {
407
- const params = ''
408
- // const url = this.cameraurl.replace('stream', 'close')
409
- this.cameraurl = ''
410
- const msg = await this.newInstancePost('http://127.0.0.1:38088/card=idcard', params)
411
- if (msg.data.code != '0') {
412
- document.getElementById('result').innerHTML = msg.data.message
413
- }
414
- },
415
- // 获取设备状态
416
- async getVideoStatus () {
417
- document.getElementById('result').innerHTML = ''
418
- const params = ''
419
- const url = 'http://127.0.0.1:38088/video=status'
420
- this.cameraurl = ''
421
- const msg = await this.newInstancePost(url, params)
422
- if (msg.data.code != '0') {
423
- document.getElementById('result').innerHTML = '获取设备状态失败,返回代码 = ' + msg.data.code + ',返回信息 = ' + msg.data.message
424
- } else {
425
- document.getElementById('result').innerHTML = '文档摄像头:' + msg.data.video0 +
426
- ', 人像1:' + msg.data.video1
427
- }
428
- },
429
- openApp () {
430
- window.location.href = 'cameraServicetis:0' // 启动 CameraService 服务程序
431
- },
432
- async capturePhoto () {
433
- // if (!this.name) {
434
- // return this.$showMessage('请输入照片名称')
435
- // }
436
- // if (!this.useType) {
437
- // return this.$showMessage('请选择文件使用类型')
438
- // }
439
- let camidx = 0
440
- if (this.cameraurl.indexOf('http://127.0.0.1:38088/video=stream&camidx=0') != -1) {
441
- camidx = 0
442
- } else if (this.cameraurl.indexOf('http://127.0.0.1:38088/video=stream&camidx=1') != -1) {
443
- camidx = 1
444
- } else {
445
- this.$message.info('请先打开视频')
446
- return
447
- }
448
- const param = {
449
- camidx: camidx,
450
- image_process_info: {
451
- cut_type: '0',
452
- multi_object: '0',
453
- rotate: `${this.rotateAngle}`,
454
- },
455
- }
456
- const msg = await this.newInstancePost('http://127.0.0.1:38088/video=grabimage', param)
457
- if (msg.data.code != '0') {
458
- this.$message.info(msg.data.message)
459
- return
460
- }
461
- console.log('msg========================>', msg)
462
- this.previewImage = 'data:image/jpg;base64,' + msg.data.images[0].base64
463
- this.output('base64 长度 : ' + this.previewImage)
464
- this.$emit('photo-finish', { img: this.previewImage })
465
- this.name = ''
466
- // post('http://127.0.0.1:38088/video=grabimage', param)
467
- },
468
- // 读身份证
469
- async startReadCard () {
470
- const msg = await this.newInstancePost('http://127.0.0.1:38088/card=idcard', {})
471
- if (msg.data.code != '0') {
472
- this.$message.info(msg.data.message, 2000)
473
- return
474
- } else {
475
- this.updateIdCardInfo(msg.data.IDCardInfo)
476
- }
477
- this.output('读取身份证')
478
- this.output('开始读卡')
479
- },
480
- // 停止读身份证
481
- stopReadCard () {
482
- this.sendMsg(this.CLT_MSG.STOP_READ_IDCARD, (msg) => {
483
- if (msg.err !== 0) {
484
- return
485
- }
486
- this.output('停止读卡')
487
- })
488
- },
489
- // 视频帧绘制函数
490
- drawImage (data) {
491
- // 校验视频是否在一定时间内的
492
- if (!this.checkTimestamp(data[2] * 256 + data[1])) {
493
- return
494
- }
495
- // 视频帧头有时间戳 注意偏移 和 大小端处理
496
- const width = data[this.base_offset + 1] * 256 + data[this.base_offset]
497
- const height = data[this.base_offset + 3] * 256 + data[this.base_offset + 2]
498
-
499
- const cam = document.getElementById('cam')
500
- const context = cam.getContext('2d')
501
- if (this.orgdrawwidth != width || this.orgdrawheight != height) {
502
- this.orgdrawwidth = width
503
- this.orgdrawheight = height
504
- }
505
-
506
- const image = context.createImageData(width, height)
507
- for (let n = 0; n != height; ++n) {
508
- for (let m = 0; m != width; ++m) {
509
- const imageOffset = ((height - n - 1) * width + m) * 4
510
- const dataOffset = (n * width + m) * 3 + this.baseOffset + 4
511
- image.data[imageOffset] = data[dataOffset + 2]
512
- image.data[imageOffset + 1] = data[imageOffset + 1]
513
- image.data[imageOffset + 2] = data[imageOffset]
514
- image.data[imageOffset + 3] = 255
515
- }
516
- }
517
- context.putImageData(image, 0, 0)
518
- },
519
- checkTimestamp (svrTime) {
520
- const myDate = new Date()
521
- let cltTime = myDate.getSeconds() * 1000 + myDate.getMilliseconds()
522
- if (cltTime < svrTime) {
523
- cltTime += 60 * 1000
524
- }
525
- return cltTime - svrTime < 3000
526
- },
527
- sendMsg (proto, msg, cb) {
528
- if (!ws) {
529
- return
530
- }
531
-
532
- if (typeof msg !== 'object') {
533
- if (typeof msg === 'function') {
534
- cb = msg
535
- msg = {}
536
- } else {
537
- msg = {}
538
- }
539
- }
540
-
541
- msg.proto = proto
542
- if (typeof cb === 'function') {
543
- this.callback[++this.context] = cb
544
- msg.user_data = this.context
545
- }
546
-
547
- ws.send(JSON.stringify(msg))
548
- },
549
- output (content) {
550
- if (content.length == 0) {
551
- return
552
- }
553
- const console = document.getElementById('Console')
554
- console.value += content
555
- console.value += '\r'
556
- console.scrollTop = console.scrollHeight
557
- },
558
- // 显示读到的身份证信息
559
- updateIdCardInfo (msg) {
560
- document.getElementById('Name').value = msg.name
561
- document.getElementById('Sex').value = msg.sex
562
- document.getElementById('Nation').value = msg.nation
563
- document.getElementById('Born').value = msg.birthday
564
- document.getElementById('Address').value = msg.address
565
- document.getElementById('CardNo').value = msg.cardID
566
- document.getElementById('Police').value = msg.issueOrgan
567
- document.getElementById('ActivityLFrom').value = msg.validStart
568
- document.getElementById('ActivityLTo').value = msg.validEnd
569
- // document.getElementById('DeviceNo').value = msg.validEnd
570
- document.getElementById('PhotoBuffer').value = msg.fingerBase64
571
- document.getElementById('PhotoDisplay').src = 'data:image/jpg;base64,' + msg.photoBase64
572
- this.IdCardInfo = msg
573
- },
574
- confirmIdCard () {
575
- const param = this.IdCardInfo
576
- if (this.IdCardInfo) {
577
- this.$emit('confirm-info', param)
578
- this.IdCardInfo = {}
579
- }
580
- },
581
- handleOk () {
582
- this.$emit('confirmPhoto', this.previewImage)
583
- },
584
- handleCancel () {
585
- this.show = false
586
- }
587
- },
588
-
589
- mounted () {
590
- this.onLoad().then(() => {
591
- this.$emit('ready')
592
- }).catch(error => {
593
- this.$emit('error', error)
594
- })
595
- },
596
-
597
- beforeDestroy () {
598
- if (ws) {
599
- ws.close()
600
- ws = null
601
- }
602
- }
603
- }
604
- </script>
605
- <style lang="less" scoped>
606
- .video {
607
- width: 70%;
608
- height: 440px;
609
- display: flex;
610
- flex-direction: column;
611
- background-size: contain;
612
- background-repeat: no-repeat;
613
- background-position: center;
614
- }
615
- </style>
1
+ <template>
2
+ <a-modal
3
+ :visible="show"
4
+ :dialogStyle="{ top: '1vh' }"
5
+ width="50vw"
6
+ :footer="null"
7
+ :zIndex="1050"
8
+ @cancel="handleCancel"
9
+ :maskClosable="false"
10
+ >
11
+ <div class="scanner-container" >
12
+ <a-row>
13
+ <a-space>
14
+ <a-button type="primary" @click="capturePhoto">拍照</a-button>
15
+ <a-button type="primary" @click="switchCamera('0')">文档</a-button>
16
+ <a-button type="primary" @click="switchCamera('1')">人像</a-button>
17
+ <a-button type="primary" @click="getVideoStatus">设备状态</a-button>
18
+ <a-button type="primary" @click="closeVideo">关闭设备</a-button>
19
+ <a-button type="primary" @click="openApp">开启程序</a-button>
20
+ <a-button v-if="showid" type="primary" @click="startReadCard">读身份证</a-button>
21
+ <a-button v-if="showid" @click="stopReadCard">停止读卡</a-button>
22
+ <a-button type="primary" @click="rotateCamera">画面旋转</a-button>
23
+ </a-space>
24
+ </a-row>
25
+ <a-row>
26
+ <a-col :span="12">
27
+ <div
28
+ style="display: flex; justify-content: center; align-items: center; height: 300px;">
29
+ <img
30
+ v-if="previewImage"
31
+ id="Base64IMG"
32
+ :src="previewImage"
33
+ height="300"
34
+ alt=""
35
+ style="display: block;margin: auto;"
36
+ />
37
+ <a-empty v-else/>
38
+ </div>
39
+ </a-col>
40
+ <a-col :span="12">
41
+ <a-textarea
42
+ id="Console"
43
+ style=" height: 300px; width: 100%; resize: none;border-radius: 0"
44
+ :disabled="true"></a-textarea>
45
+ </a-col>
46
+ <a-col :span="24">
47
+ <div
48
+ :style="{...heightStyle, display: 'flex', justifyContent: 'center', alignItems: 'center'}">
49
+ <img
50
+ id="cam"
51
+ :src="cameraurl"
52
+ :style="rotateStyle"
53
+ class="video"
54
+ alt=""/>
55
+ </div>
56
+ </a-col>
57
+ <a-col :span="24" v-if="showid">
58
+ <a-form layout="horizontal">
59
+ <a-form-item label="姓名">
60
+ <a-input v-model="idCardForm.name" disabled/>
61
+ </a-form-item>
62
+ <a-form-item label="性别">
63
+ <a-input v-model="idCardForm.sex" disabled/>
64
+ </a-form-item>
65
+ <a-form-item label="民族">
66
+ <a-input v-model="idCardForm.nation" disabled/>
67
+ </a-form-item>
68
+ <a-form-item label="出生日期">
69
+ <a-input v-model="idCardForm.birthday" disabled/>
70
+ </a-form-item>
71
+ <a-form-item label="地址">
72
+ <a-textarea v-model="idCardForm.address" :rows="2" disabled/>
73
+ </a-form-item>
74
+ <a-form-item label="身份证号">
75
+ <a-input v-model="idCardForm.cardID" disabled/>
76
+ </a-form-item>
77
+ <a-form-item label="签发机关">
78
+ <a-input v-model="idCardForm.issueOrgan" disabled/>
79
+ </a-form-item>
80
+ <a-form-item label="有效期">
81
+ <a-input v-model="idCardForm.validStart" disabled/>
82
+ <a-input v-model="idCardForm.validEnd" disabled/>
83
+ </a-form-item>
84
+
85
+ <div class="id-photo-section">
86
+ <div class="photo-preview">
87
+ <img
88
+ id="PhotoDisplay"
89
+ :src="idCardForm.photoUrl"
90
+ class="id-photo"
91
+ alt=""/>
92
+ </div>
93
+ <a-button type="primary" @click="confirmIdCard">确认信息</a-button>
94
+ </div>
95
+ </a-form>
96
+ </a-col>
97
+ </a-row>
98
+ </div>
99
+ <template #title>
100
+ <a-row>
101
+ <a-col :span="24">
102
+ <a-space>
103
+ 高拍仪
104
+ <a-button @click="handleOk">上传截图</a-button>
105
+ <a-button @click="handleCancel">取消</a-button>
106
+ </a-space>
107
+ </a-col>
108
+ </a-row>
109
+ </template>
110
+ <div id="result"></div>
111
+ </a-modal>
112
+ </template>
113
+
114
+ <script>
115
+ import axios from 'axios'
116
+
117
+ let ws
118
+ const SERVER_ADDR = 'ws://127.0.0.1:38088'
119
+
120
+ export default {
121
+ name: 'HeightScanner',
122
+
123
+ props: {
124
+ show: Boolean,
125
+ showid: Boolean
126
+ },
127
+
128
+ data () {
129
+ return {
130
+ SERVER_ADDR,
131
+ cameraurl: 'http://127.0.0.1:38088/video=stream&camidx=0',
132
+ connected: false,
133
+ clicked: false,
134
+ iswaiting: false,
135
+ previewImage: '',
136
+ consoleText: '',
137
+ idCardForm: {
138
+ name: '',
139
+ sex: '',
140
+ nation: '',
141
+ birthday: '',
142
+ address: '',
143
+ cardID: '',
144
+ issueOrgan: '',
145
+ validStart: '',
146
+ validEnd: '',
147
+ photoBuffer: '',
148
+ photoUrl: ''
149
+ },
150
+ callback: {},
151
+ context: 0,
152
+ rotateAngle: 0,
153
+ base_offset: 0,
154
+ orgdrawwidth: 0,
155
+ orgdrawheight: 0,
156
+ containerHeight: 440,
157
+
158
+ CLT_MSG: {
159
+ // 打开相机 cap:相机ID
160
+ BEGIN_CAP: 1,
161
+ // 关闭相机 cap:相机ID
162
+ STOP_CAP: 2,
163
+ // 获取PID
164
+ GET_PID: 3,
165
+ // 获取分辨率
166
+ GET_FBL: 4,
167
+ // 设置分辨率
168
+ SET_FBL: 5,
169
+ // 设置MJPG格式
170
+ SET_MJPG: 6,
171
+ // 设置视频旋转
172
+ SET_TURN: 7,
173
+ // 设置视频截图保存的jpg质量
174
+ SET_QUALITY: 8,
175
+ // 设置自动裁边
176
+ SET_AUTOCROP: 9,
177
+ // 设置预设框选
178
+ SET_PREST: 10,
179
+ // 获取当前预设框选
180
+ GET_PREST_INFO: 11,
181
+ // 视频格式弹窗
182
+ FORMAT_DLG: 12,
183
+ // 视频属性弹窗
184
+ PROPERTY_DLG: 13,
185
+ // 设置截图颜色模式 彩色 黑白 灰度
186
+ SET_COLOR_MODEL: 14,
187
+ // 截图
188
+ GET_PICTURE: 15,
189
+ // 设置去底色参数
190
+ SET_CLEAN_PARAM: 16,
191
+ // 内存截图
192
+ GET_PICTURE_MEM: 17,
193
+ // base64测试
194
+ TEST_BASE64: 18,
195
+ // 制作PDF的临时目录
196
+ SET_TEMPDIR: 19,
197
+ // 开始制作PDF
198
+ BEGIN_PDF: 20,
199
+ // PDF截图 保存到PDF临时目录
200
+ GET_PDF_PICTURES: 21,
201
+ // 结束制作PDF
202
+ END_PDF_PICTURES: 22,
203
+ // PDF文件转为文件里的BASE64码
204
+ PDF_TO_BASE64: 23,
205
+ // 文件里的BASE64码转为PDF文件
206
+ BASE64_TO_PDF: 24,
207
+ // PDF文件转为BASE64字符串
208
+ PDF_TO_BASE64_STR: 25,
209
+ // 删除制作PDF的图片文件
210
+ DEL_PICTURE_PDF: 26,
211
+ // 打印图片
212
+ PRINT_IMAGE: 27,
213
+ // 设置显示错误弹窗
214
+ SHOW_ERROR_BOX: 28,
215
+ // 获取视频连接事件
216
+ GET_EVENT: 29,
217
+ // 预设框选鼠标消息
218
+ PRESET_MOUSEDOWN: 30,
219
+ PRESET_MOUSEMOVE: 31,
220
+ PRESET_MOUSEUP: 32,
221
+ // 人证对比
222
+ IDCARD_COMPARE: 40,
223
+ // 读卡
224
+ READ_IDCARD: 51,
225
+ // 开始循环读卡
226
+ BEGIN_READ_IDCARD: 52,
227
+ // 停止循环读卡
228
+ STOP_READ_IDCARD: 53,
229
+ // 水平
230
+ HCOPY_IDCARD: 54,
231
+ // 垂直
232
+ VCOPY_IDCARD: 55,
233
+
234
+ PCOPY_IDCARD: 56,
235
+ // 反面
236
+ NCOPY_IDCARD: 57
237
+ },
238
+ SVR_BIN_MSG: {
239
+ CAP_FRAME: 1, // 后台帧消息
240
+ }
241
+ }
242
+ },
243
+ computed: {
244
+ rotateStyle () {
245
+ return {
246
+ transform: `rotate(${this.rotateAngle}deg)`,
247
+ transition: 'transform 0.5s ease',
248
+ maxHeight: `${this.rotateAngle % 180 === 0 ? '440px' : '660px'}`
249
+ }
250
+ },
251
+ heightStyle () {
252
+ return {
253
+ width: '100%',
254
+ height: `${this.containerHeight}px`,
255
+ }
256
+ }
257
+ },
258
+ methods: {
259
+ rotateCamera () {
260
+ console.log('>>> 旋转镜头')
261
+ // 每次点击增加 90 度,超过 360 度时归零
262
+ this.rotateAngle = (this.rotateAngle + 90) % 360
263
+ // 根据旋转角度设置不同的高度
264
+ this.containerHeight = this.rotateAngle % 180 === 0 ? 440 : 660
265
+ },
266
+ // handleImgError (e) {
267
+ // e.target.style.display = 'none'
268
+ // },
269
+ // 页面load消息
270
+ onLoad () {
271
+ return new Promise((resolve, reject) => {
272
+ // 添加重试计数器
273
+ let retryCount = 0
274
+ const maxRetries = 5
275
+
276
+ const tryConnect = () => {
277
+ if (ws) {
278
+ resolve()
279
+ return
280
+ }
281
+
282
+ ws = new WebSocket(this.SERVER_ADDR)
283
+
284
+ ws.onopen = (evt) => {
285
+ if (this.connected) {
286
+ resolve()
287
+ }
288
+ this.connected = true
289
+ this.output('已经连接到服务器')
290
+ this.switchCamera(0)
291
+ }
292
+
293
+ ws.onclose = (evt) => {
294
+ if (!this.connected) {
295
+ // 检查重试次数
296
+ if (retryCount < maxRetries) {
297
+ retryCount++
298
+ this.output(`连接失败,正在进行第${retryCount}次重试...`)
299
+ window.location.href = 'FLShell://'
300
+ setTimeout(tryConnect, 3 * 1000)
301
+ } else {
302
+ this.output('连接失败,已达到最大重试次数')
303
+ reject(new Error('连接失败,已达到最大重试次数'))
304
+ }
305
+ } else {
306
+ this.output('已断开服务器连接')
307
+ this.connected = false
308
+ }
309
+ ws = null
310
+ }
311
+
312
+ ws.onerror = (evt) => {
313
+ this.output('高拍仪连接错误')
314
+ reject(new Error('连接错误'))
315
+ }
316
+ ws.onmessage = (evt) => {
317
+ if (evt.data.length === 0) {
318
+ return
319
+ }
320
+ if (typeof evt.data === 'string') {
321
+ const msg = JSON.parse(evt.data)
322
+ console.log('msg1:', msg)
323
+ if (msg.err && msg.err !== 0) {
324
+ this.output('错误 - ' + msg.err + ', ' + msg.msg)
325
+ reject(new Error('错误 - ' + msg.err + ', ' + msg.msg))
326
+ } else if (msg.msg) {
327
+ console.log('msg2:', msg)
328
+ this.output(msg.msg)
329
+ }
330
+ if (msg.user_data) {
331
+ this.callback[msg.user_data](msg)
332
+ if (typeof msg.user_data === 'number') {
333
+ this.callback[msg.user_data] = undefined
334
+ }
335
+ }
336
+ } else {
337
+ const file = new FileReader()
338
+ file.onload = (evt) => {
339
+ if (evt.target.readyState == FileReader.DONE) {
340
+ const data = new Uint8Array(evt.target.result)
341
+ if (data[0] == this.SVR_BIN_MSG.CAP_FRAME) {
342
+ return this.drawImage(data)
343
+ }
344
+ }
345
+ }
346
+ file.readAsArrayBuffer(evt.data)
347
+ }
348
+ }
349
+ const canvas = document.getElementById('cam')
350
+ canvas.onmousedown = (e) => {
351
+ canvas.style.cursor = 'crosshair'
352
+ this.clicked = true
353
+ this.sendMsg(this.CLT_MSG.PRESET_MOUSEDOWN, { origX: e.layerX, origY: e.layerY }, (msg) => {
354
+ if (msg.err !== 0) {
355
+ console.warn('鼠标按下事件出错:', msg.err)
356
+ }
357
+ })
358
+ }
359
+ canvas.onmousemove = (e) => {
360
+ if (!this.clicked) {
361
+ canvas.style.cursor = 'default'
362
+ return
363
+ }
364
+ canvas.style.cursor = 'crosshair'
365
+ this.sendMsg(this.CLT_MSG.PRESET_MOUSEMOVE, { offx: e.layerX, offy: e.layerY }, (msg) => {
366
+ if (msg.err !== 0) {
367
+ console.warn('鼠标移动事件出错:', msg.err)
368
+ }
369
+ })
370
+ }
371
+ onmouseout = canvas.onmouseup = (e) => {
372
+ canvas.style.cursor = 'default'
373
+ if (!this.clicked) {
374
+ return
375
+ }
376
+ this.sendMsg(this.CLT_MSG.PRESET_MOUSEUP, { offx: e.layerX, offy: e.layerY }, (msg) => {
377
+ if (msg.err !== 0) {
378
+ console.warn('鼠标抬起事件出错:', msg.err)
379
+ }
380
+ })
381
+ this.clicked = false
382
+ }
383
+ }
384
+
385
+ tryConnect() // 开始首次连接
386
+ })
387
+ },
388
+ newInstancePost (url, data) {
389
+ // 重新创建是为了 避免axios的拦截器影响写卡读卡请求
390
+ // 请求 如果携带了 Cookie,token到卡服务 会导致请求失败
391
+ // 需要注意的是因为没有增加响应拦截器 所以返回结果的res里面会多一层data
392
+ const instance = axios.create()
393
+ return instance.post(url, data, {
394
+ withCredentials: false,
395
+ headers: {
396
+ 'Content-Type': 'text/plain;charset=UTF-8',
397
+ Accept: '*/*',
398
+ }
399
+ })
400
+ },
401
+ // 打开视频
402
+ switchCamera (data) {
403
+ this.cameraurl = 'http://127.0.0.1:38088/video=stream&camidx=' + data + '&tid=' + Date.parse(new Date())
404
+ },
405
+ // 关闭视频
406
+ async closeVideo () {
407
+ const params = ''
408
+ // const url = this.cameraurl.replace('stream', 'close')
409
+ this.cameraurl = ''
410
+ const msg = await this.newInstancePost('http://127.0.0.1:38088/card=idcard', params)
411
+ if (msg.data.code != '0') {
412
+ document.getElementById('result').innerHTML = msg.data.message
413
+ }
414
+ },
415
+ // 获取设备状态
416
+ async getVideoStatus () {
417
+ document.getElementById('result').innerHTML = ''
418
+ const params = ''
419
+ const url = 'http://127.0.0.1:38088/video=status'
420
+ this.cameraurl = ''
421
+ const msg = await this.newInstancePost(url, params)
422
+ if (msg.data.code != '0') {
423
+ document.getElementById('result').innerHTML = '获取设备状态失败,返回代码 = ' + msg.data.code + ',返回信息 = ' + msg.data.message
424
+ } else {
425
+ document.getElementById('result').innerHTML = '文档摄像头:' + msg.data.video0 +
426
+ ', 人像1:' + msg.data.video1
427
+ }
428
+ },
429
+ openApp () {
430
+ window.location.href = 'cameraServicetis:0' // 启动 CameraService 服务程序
431
+ },
432
+ async capturePhoto () {
433
+ // if (!this.name) {
434
+ // return this.$showMessage('请输入照片名称')
435
+ // }
436
+ // if (!this.useType) {
437
+ // return this.$showMessage('请选择文件使用类型')
438
+ // }
439
+ let camidx = 0
440
+ if (this.cameraurl.indexOf('http://127.0.0.1:38088/video=stream&camidx=0') != -1) {
441
+ camidx = 0
442
+ } else if (this.cameraurl.indexOf('http://127.0.0.1:38088/video=stream&camidx=1') != -1) {
443
+ camidx = 1
444
+ } else {
445
+ this.$message.info('请先打开视频')
446
+ return
447
+ }
448
+ const param = {
449
+ camidx: camidx,
450
+ image_process_info: {
451
+ cut_type: '0',
452
+ multi_object: '0',
453
+ rotate: `${this.rotateAngle}`,
454
+ },
455
+ }
456
+ const msg = await this.newInstancePost('http://127.0.0.1:38088/video=grabimage', param)
457
+ if (msg.data.code != '0') {
458
+ this.$message.info(msg.data.message)
459
+ return
460
+ }
461
+ console.log('msg========================>', msg)
462
+ this.previewImage = 'data:image/jpg;base64,' + msg.data.images[0].base64
463
+ this.output('base64 长度 : ' + this.previewImage)
464
+ this.$emit('photo-finish', { img: this.previewImage })
465
+ this.name = ''
466
+ // post('http://127.0.0.1:38088/video=grabimage', param)
467
+ },
468
+ // 读身份证
469
+ async startReadCard () {
470
+ const msg = await this.newInstancePost('http://127.0.0.1:38088/card=idcard', {})
471
+ if (msg.data.code != '0') {
472
+ this.$message.info(msg.data.message, 2000)
473
+ return
474
+ } else {
475
+ this.updateIdCardInfo(msg.data.IDCardInfo)
476
+ }
477
+ this.output('读取身份证')
478
+ this.output('开始读卡')
479
+ },
480
+ // 停止读身份证
481
+ stopReadCard () {
482
+ this.sendMsg(this.CLT_MSG.STOP_READ_IDCARD, (msg) => {
483
+ if (msg.err !== 0) {
484
+ return
485
+ }
486
+ this.output('停止读卡')
487
+ })
488
+ },
489
+ // 视频帧绘制函数
490
+ drawImage (data) {
491
+ // 校验视频是否在一定时间内的
492
+ if (!this.checkTimestamp(data[2] * 256 + data[1])) {
493
+ return
494
+ }
495
+ // 视频帧头有时间戳 注意偏移 和 大小端处理
496
+ const width = data[this.base_offset + 1] * 256 + data[this.base_offset]
497
+ const height = data[this.base_offset + 3] * 256 + data[this.base_offset + 2]
498
+
499
+ const cam = document.getElementById('cam')
500
+ const context = cam.getContext('2d')
501
+ if (this.orgdrawwidth != width || this.orgdrawheight != height) {
502
+ this.orgdrawwidth = width
503
+ this.orgdrawheight = height
504
+ }
505
+
506
+ const image = context.createImageData(width, height)
507
+ for (let n = 0; n != height; ++n) {
508
+ for (let m = 0; m != width; ++m) {
509
+ const imageOffset = ((height - n - 1) * width + m) * 4
510
+ const dataOffset = (n * width + m) * 3 + this.baseOffset + 4
511
+ image.data[imageOffset] = data[dataOffset + 2]
512
+ image.data[imageOffset + 1] = data[imageOffset + 1]
513
+ image.data[imageOffset + 2] = data[imageOffset]
514
+ image.data[imageOffset + 3] = 255
515
+ }
516
+ }
517
+ context.putImageData(image, 0, 0)
518
+ },
519
+ checkTimestamp (svrTime) {
520
+ const myDate = new Date()
521
+ let cltTime = myDate.getSeconds() * 1000 + myDate.getMilliseconds()
522
+ if (cltTime < svrTime) {
523
+ cltTime += 60 * 1000
524
+ }
525
+ return cltTime - svrTime < 3000
526
+ },
527
+ sendMsg (proto, msg, cb) {
528
+ if (!ws) {
529
+ return
530
+ }
531
+
532
+ if (typeof msg !== 'object') {
533
+ if (typeof msg === 'function') {
534
+ cb = msg
535
+ msg = {}
536
+ } else {
537
+ msg = {}
538
+ }
539
+ }
540
+
541
+ msg.proto = proto
542
+ if (typeof cb === 'function') {
543
+ this.callback[++this.context] = cb
544
+ msg.user_data = this.context
545
+ }
546
+
547
+ ws.send(JSON.stringify(msg))
548
+ },
549
+ output (content) {
550
+ if (content.length == 0) {
551
+ return
552
+ }
553
+ const console = document.getElementById('Console')
554
+ console.value += content
555
+ console.value += '\r'
556
+ console.scrollTop = console.scrollHeight
557
+ },
558
+ // 显示读到的身份证信息
559
+ updateIdCardInfo (msg) {
560
+ document.getElementById('Name').value = msg.name
561
+ document.getElementById('Sex').value = msg.sex
562
+ document.getElementById('Nation').value = msg.nation
563
+ document.getElementById('Born').value = msg.birthday
564
+ document.getElementById('Address').value = msg.address
565
+ document.getElementById('CardNo').value = msg.cardID
566
+ document.getElementById('Police').value = msg.issueOrgan
567
+ document.getElementById('ActivityLFrom').value = msg.validStart
568
+ document.getElementById('ActivityLTo').value = msg.validEnd
569
+ // document.getElementById('DeviceNo').value = msg.validEnd
570
+ document.getElementById('PhotoBuffer').value = msg.fingerBase64
571
+ document.getElementById('PhotoDisplay').src = 'data:image/jpg;base64,' + msg.photoBase64
572
+ this.IdCardInfo = msg
573
+ },
574
+ confirmIdCard () {
575
+ const param = this.IdCardInfo
576
+ if (this.IdCardInfo) {
577
+ this.$emit('confirm-info', param)
578
+ this.IdCardInfo = {}
579
+ }
580
+ },
581
+ handleOk () {
582
+ this.$emit('confirmPhoto', this.previewImage)
583
+ },
584
+ handleCancel () {
585
+ this.show = false
586
+ }
587
+ },
588
+
589
+ mounted () {
590
+ this.onLoad().then(() => {
591
+ this.$emit('ready')
592
+ }).catch(error => {
593
+ this.$emit('error', error)
594
+ })
595
+ },
596
+
597
+ beforeDestroy () {
598
+ if (ws) {
599
+ ws.close()
600
+ ws = null
601
+ }
602
+ }
603
+ }
604
+ </script>
605
+ <style lang="less" scoped>
606
+ .video {
607
+ width: 70%;
608
+ height: 440px;
609
+ display: flex;
610
+ flex-direction: column;
611
+ background-size: contain;
612
+ background-repeat: no-repeat;
613
+ background-position: center;
614
+ }
615
+ </style>