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,475 +1,475 @@
1
- <template>
2
- <!-- <Source src="/code/VitalSigns.vue"></Source>-->
3
- <div>
4
- <a-row class="box">
5
- 病历号&nbsp;&nbsp;<a-input v-model="vitalSignsId" style="width: 160px"></a-input>
6
- <a-button-group style="margin-left: 20px;">
7
- <a-button
8
- v-if="showCreateButton"
9
- plain
10
- type="primary"
11
- @click="showVitalSignsModal('create')"
12
- :loading="loading"
13
- :disabled="!editorReady">创建体温单</a-button>
14
- <a-button
15
- v-if="showUpdateButton"
16
- plain
17
- type="primary"
18
- @click="showVitalSignsModal('update')"
19
- :loading="loading"
20
- :disabled="!editorReady">更新体温单</a-button>
21
- </a-button-group>
22
- <a-button-group v-if="showClearButton" style="margin: 0 20px;">
23
- <a-button plain type="primary" @click="execCommand('print')" :loading="loading" :disabled="!editorReady">打印</a-button>
24
- </a-button-group>
25
- <!-- 修改清空体温单按钮样式,使其更加醒目 -->
26
- <a-button
27
- type="primary"
28
- danger
29
- v-if="showClearButton"
30
- @click="clearVitalSigns"
31
- :loading="loading"
32
- :disabled="!editorReady"
33
- style="margin-left: 10px;">
34
- <a-icon type="delete" /> 清空体温单
35
- </a-button>
36
- </a-row>
37
- <div v-if="!editorReady" style="margin: 10px 0; padding: 10px; background-color: #fffbe6; border: 1px solid #ffe58f;">
38
- <a-icon type="loading" /> 体温单编辑器加载中...
39
- </div>
40
-
41
- <!-- 添加体温单生成加载遮罩 -->
42
- <div v-if="generating" class="generating-mask">
43
- <div class="generating-content">
44
- <a-spin size="large" />
45
- <div class="generating-text">体温单生成中,请稍候...</div>
46
- </div>
47
- </div>
48
-
49
- <Editor @editor-ready="onEditorReady" style="margin: 10px 0;" ref="editorComponent"></Editor>
50
-
51
- <!-- 使用TextBox组件替代原有弹窗 -->
52
- <TextBox
53
- :visible="modalVisible"
54
- :modalType="modalType"
55
- :editorReady="editorReady"
56
- :id="Number(vitalSignsId) || 180"
57
- @submit="handleSubmit"
58
- @cancel="closeModal"
59
- />
60
- </div>
61
- </template>
62
-
63
- <script setup>
64
- import { ref, onMounted } from 'vue'
65
- import Editor from './editor.vue'
66
- import TextBox from './textBox.vue'
67
- import { message } from 'ant-design-vue'
68
-
69
- // 响应式状态
70
- const vitalSignsId = ref(null)
71
- const loading = ref(false)
72
- const editorReady = ref(false)
73
- const editorComponent = ref(null)
74
- const modalVisible = ref(false)
75
- const modalType = ref('create')
76
- const generating = ref(false) // 添加体温单生成中状态
77
- let editor = null
78
- // 定义组件事件
79
- const emit = defineEmits(['submit'])
80
- // 常量
81
- const modalTitles = {
82
- create: '创建体温单',
83
- update: '更新体温单'
84
- }
85
-
86
- // 接受父组件传递的属性
87
- defineProps({
88
- showCreateButton: {
89
- type: Boolean,
90
- default: false
91
- },
92
- showUpdateButton: {
93
- type: Boolean,
94
- default: false
95
- },
96
- // 添加打印按钮是否显示属性
97
- showPrintButton: {
98
- type: Boolean,
99
- default: false
100
- },
101
- showClearButton: {
102
- type: Boolean,
103
- default: false
104
- },
105
- // 时间模式 -2 ~ 2
106
- adjustHour: {
107
- type: Number,
108
- default: 0
109
- }
110
- })
111
-
112
- // 显示弹窗
113
- function showVitalSignsModal (type) {
114
- modalType.value = type
115
- modalVisible.value = true
116
- }
117
-
118
- // 关闭弹窗
119
- function closeModal () {
120
- modalVisible.value = false
121
- }
122
-
123
- // 编辑器初始化
124
- function onEditorReady (editorObj) {
125
- try {
126
- if (!editorObj) {
127
- throw new Error('传入的editor对象为null或undefined')
128
- }
129
-
130
- // 尝试获取编辑器对象
131
- if (typeof editorObj.createVitalSigns === 'function') {
132
- editor = editorObj
133
- } else if (editorObj.getEditor && typeof editorObj.getEditor === 'function') {
134
- const editorFromComponent = editorObj.getEditor()
135
- editor = editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function'
136
- ? editorFromComponent
137
- : (typeof editorObj.createVitalSigns === 'function' ? editorObj : null)
138
- }
139
- if (!editor) {
140
- throw new Error('无法获取有效的editor对象')
141
- }
142
- editorReady.value = true
143
- } catch (err) {
144
- console.error('设置editor对象失败:', err)
145
- message.error('体温单编辑器初始化失败,请刷新页面重试')
146
- }
147
- }
148
-
149
- // 执行命令
150
- function execCommand (cmd) {
151
- if (!editorReady.value || !editor) return
152
- loading.value = true
153
- try {
154
- editor.execCommand(cmd)
155
- } catch (err) {
156
- console.error('执行命令出错:', err)
157
- message.error(`执行${cmd}命令失败`)
158
- } finally {
159
- loading.value = false
160
- }
161
- }
162
-
163
- // 清空体温单
164
- async function clearVitalSigns () {
165
- if (!editorReady.value || !editor) {
166
- message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
167
- return
168
- }
169
- loading.value = true
170
- generating.value = true
171
- try {
172
- // 重新加载editor.html页面来完全重置编辑器
173
- try {
174
- const iframe = editorComponent.value.$refs.editorIframe
175
- if (iframe) {
176
- // 保存当前src
177
- const currentSrc = iframe.src
178
- // 确认提示
179
- message.loading('正在清空体温单...', 1)
180
- // 重新加载iframe
181
- iframe.onload = async () => {
182
- try {
183
- // 等待iframe重新加载完成
184
- await new Promise(resolve => setTimeout(resolve, 500))
185
- // 获取新的editor对象
186
- const newEditorObj = iframe.contentWindow.editor
187
- if (newEditorObj) {
188
- // 等待editor初始化
189
- if (typeof newEditorObj.init === 'function') {
190
- await new Promise((resolve) => {
191
- const checkInterval = setInterval(() => {
192
- if (newEditorObj.isReady) {
193
- clearInterval(checkInterval)
194
- resolve()
195
- }
196
- }, 100)
197
- // 最多等待5秒
198
- setTimeout(() => {
199
- clearInterval(checkInterval)
200
- resolve()
201
- }, 5000)
202
- })
203
- }
204
- // 更新全局editor引用
205
- editor = newEditorObj
206
- window.iframeEditor = newEditorObj
207
- } else {
208
- throw new Error('重新加载后无法获取editor对象')
209
- }
210
- } catch (err) {
211
- console.error('重新加载iframe后清空体温单出错:', err)
212
- message.error(`清空体温单失败: ${err.message || '未知错误'}`)
213
- } finally {
214
- loading.value = false
215
- generating.value = false
216
- // 移除临时onload处理器
217
- iframe.onload = null
218
- }
219
- }
220
- // 重新加载iframe
221
- iframe.src = currentSrc + '?t=' + new Date().getTime()
222
- return
223
- }
224
- } catch (reloadErr) {
225
- console.warn('重新加载iframe失败,将尝试其他方法清空体温单:', reloadErr)
226
- }
227
- // 备用清空方法
228
- try {
229
- const iframe = editorComponent.value.$refs.editorIframe
230
- if (iframe?.contentWindow) {
231
- iframe.contentWindow.eval(`
232
- try {
233
- // 尝试使用编辑器提供的各种可能的清空方法
234
- if (editor) {
235
- if (typeof editor.loadUrl === 'function') {
236
- editor.loadUrl('');
237
- } else if (typeof editor.resetDocument === 'function') {
238
- editor.resetDocument();
239
- } else if (typeof editor.clearContent === 'function') {
240
- editor.clearContent();
241
- } else if (typeof editor.clear === 'function') {
242
- editor.clear();
243
- } else if (typeof editor.setEditorContent === 'function') {
244
- editor.setEditorContent('');
245
- } else if (editor.document) {
246
- try {
247
- editor.document.body.innerHTML = '';
248
- } catch(clearErr) {
249
- console.warn('清空编辑器内容失败');
250
- }
251
- }
252
- }
253
- } catch(e) {
254
- console.error('清空体温单失败:', e);
255
- }
256
- `)
257
- } else if (window.iframeEditor) {
258
- const editorObj = window.iframeEditor
259
- if (typeof editorObj.loadUrl === 'function') {
260
- editorObj.loadUrl('')
261
- } else if (typeof editorObj.resetDocument === 'function') {
262
- editorObj.resetDocument()
263
- } else if (typeof editorObj.clearContent === 'function') {
264
- editorObj.clearContent()
265
- } else if (typeof editorObj.clear === 'function') {
266
- editorObj.clear()
267
- } else if (typeof editorObj.setEditorContent === 'function') {
268
- editorObj.setEditorContent('')
269
- }
270
- } else if (editor) {
271
- if (typeof editor.loadUrl === 'function') {
272
- editor.loadUrl('')
273
- } else if (typeof editor.resetDocument === 'function') {
274
- editor.resetDocument()
275
- } else if (typeof editor.clearContent === 'function') {
276
- editor.clearContent()
277
- } else if (typeof editor.clear === 'function') {
278
- editor.clear()
279
- } else if (typeof editor.setEditorContent === 'function') {
280
- editor.setEditorContent('')
281
- }
282
- } else {
283
- throw new Error('无法获取编辑器对象')
284
- }
285
- } catch (err) {
286
- console.error('清空体温单出错:', err)
287
- message.error(`清空体温单失败: ${err.message || '未知错误'}`)
288
- }
289
- } finally {
290
- loading.value = false
291
- generating.value = false
292
- }
293
- }
294
-
295
- // 处理表单提交
296
- async function handleSubmit (formData) {
297
- console.log('表单数据:', formData)
298
- if (!editorReady.value || !editor) {
299
- message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
300
- return
301
- }
302
- loading.value = true
303
- generating.value = true // 开始生成,显示加载遮罩
304
- try {
305
- let result
306
- try {
307
- const iframe = editorComponent.value.$refs.editorIframe
308
- if (iframe?.contentWindow) {
309
- // 直接传递数据对象,避免使用eval
310
- if (iframe.contentWindow.editor && typeof iframe.contentWindow.editor.createVitalSigns === 'function') {
311
- result = iframe.contentWindow.editor.createVitalSigns(formData)
312
- } else {
313
- throw new Error('编辑器对象无效')
314
- }
315
- } else if (window.iframeEditor) {
316
- result = window.iframeEditor.createVitalSigns(formData)
317
- } else {
318
- throw new Error('无法访问iframe')
319
- }
320
- } catch (err) {
321
- // 备用方案
322
- if (editor && typeof editor.createVitalSigns === 'function') {
323
- editor.createVitalSigns(formData)
324
- } else {
325
- throw new Error('无法调用createVitalSigns方法')
326
- }
327
- }
328
-
329
- vitalSignsId.value = result || formData.id
330
- modalVisible.value = false
331
- message.success(`${modalTitles[modalType.value]}成功`)
332
- emit('submit', formData)
333
- } catch (err) {
334
- console.error('创建体温单出错:', err)
335
- message.error(`创建体温单失败: ${err.message || '未知错误'}`)
336
- } finally {
337
- loading.value = false
338
- generating.value = false // 无论成功失败,都结束加载遮罩
339
- }
340
- }
341
-
342
- // 处理表单数据
343
- function mergeAndTransformData (records, patientInfo, id, date, operateDate) {
344
- // 提取records中的数据
345
- const temperatureList = records.map(record => record.temperature).join(',')
346
- const sphygmusList = records.map(record => record.sphygmus).join(',')
347
- const breathList = records.map(record => record.breath).join(',')
348
- const heartList = records.map(record => record.heart).join(',')
349
- const notesList = records.map(record => record.notes).join(',')
350
- const painList = records.map(record => record.pain).join(',')
351
- const data1List = records.map(record => {
352
- const [systolic, diastolic] = record.data1.split('|')
353
- return `${systolic}/${diastolic}`
354
- }).join(',')
355
- const data2List = records.map(record => record.data2).join(',')
356
- const data3List = records.map(record => record.data3).join(',')
357
- const data4List = records.map(record => record.data4).join(',')
358
- const data5List = records.map(record => record.data5).join(',')
359
- const data6List = records.map(record => record.data6).join(',')
360
- const data7List = records.map(record => record.data7).join(',')
361
- const tempTypeList = records.map(record => record.temptype).join(',')
362
-
363
- // 提取patientInfo中的数据
364
- const name = patientInfo.name || ''
365
- const dept = patientInfo.dept || ''
366
- const bed = patientInfo.bed || ''
367
- const inDate = patientInfo.indate || ''
368
- const diag = patientInfo.diag || ''
369
-
370
- // 生成合并后的对象
371
- const mergedData = {
372
- bed: bed.toString(),
373
- sphygmus: sphygmusList,
374
- notes: notesList,
375
- medicalNo: id, // 示例中的固定值
376
- diag: diag,
377
- type: 'normal', // 示例中的固定值
378
- breath: breathList,
379
- temperature: temperatureList,
380
- id: id, // 示例中的固定值
381
- tempType: tempTypeList,
382
- data7: data7List,
383
- pain: painList,
384
- data6: data6List,
385
- data5: data5List,
386
- data4: data4List,
387
- data3: data3List,
388
- data2: data2List,
389
- inDate: inDate.split(' ')[0], // 只取日期部分
390
- data1: data1List,
391
- dept: dept,
392
- heart: heartList,
393
- labels: '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)|身高(cm)|体重(kg)', // 示例中的固定值
394
- name: name,
395
- begin: date, // 只取日期部分
396
- operateDate: operateDate // 只取日期部分
397
- }
398
- return mergedData
399
- }
400
-
401
- // 生命周期钩子
402
- onMounted(() => {
403
- window.addEventListener('message', (event) => {
404
- if (event.data?.type === 'editorReady' && !editorReady.value && editorComponent.value?.getEditor) {
405
- try {
406
- const editorFromComponent = editorComponent.value.getEditor()
407
- if (editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function') {
408
- editor = editorFromComponent
409
- editorReady.value = true
410
- }
411
- } catch (err) {
412
- console.error('从组件获取editor对象错误:', err)
413
- }
414
- }
415
- })
416
- })
417
-
418
- // 暴露方法和属性给父组件,使父组件可以通过ref访问
419
- defineExpose({
420
- // 属性
421
- vitalSignsId,
422
- // 清空体温单方法
423
- clearVitalSigns,
424
- // 展示更新和创建弹框 创建参数:(String) create, 更新参数:(String) update
425
- showVitalSignsModal,
426
- // 触发打印函数 参数:(String) print
427
- execCommand,
428
- // 获取当前体温单ID的方法
429
- getVitalSignsId: () => vitalSignsId.value,
430
- // 设置体温单ID的方法
431
- setVitalSignsId: (id) => {
432
- vitalSignsId.value = id
433
- },
434
- // 创建体温单 参数:(Object) data
435
- handleSubmit,
436
- // 获取表单数据
437
- mergeAndTransformData
438
- })
439
- </script>
440
-
441
- <style scoped>
442
- .box {
443
- display: flex;
444
- align-items: center;
445
- padding: 1%;
446
- }
447
-
448
- /* 体温单生成加载遮罩样式 */
449
- .generating-mask {
450
- position: fixed;
451
- top: 0;
452
- left: 0;
453
- right: 0;
454
- bottom: 0;
455
- background-color: rgba(0, 0, 0, 0.5);
456
- display: flex;
457
- justify-content: center;
458
- align-items: center;
459
- z-index: 9999;
460
- }
461
-
462
- .generating-content {
463
- background-color: white;
464
- padding: 20px 40px;
465
- border-radius: 4px;
466
- text-align: center;
467
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
468
- }
469
-
470
- .generating-text {
471
- margin-top: 16px;
472
- color: rgba(0, 0, 0, 0.85);
473
- font-size: 16px;
474
- }
475
- </style>
1
+ <template>
2
+ <!-- <Source src="/code/VitalSigns.vue"></Source>-->
3
+ <div>
4
+ <a-row class="box">
5
+ 病历号&nbsp;&nbsp;<a-input v-model="vitalSignsId" style="width: 160px"></a-input>
6
+ <a-button-group style="margin-left: 20px;">
7
+ <a-button
8
+ v-if="showCreateButton"
9
+ plain
10
+ type="primary"
11
+ @click="showVitalSignsModal('create')"
12
+ :loading="loading"
13
+ :disabled="!editorReady">创建体温单</a-button>
14
+ <a-button
15
+ v-if="showUpdateButton"
16
+ plain
17
+ type="primary"
18
+ @click="showVitalSignsModal('update')"
19
+ :loading="loading"
20
+ :disabled="!editorReady">更新体温单</a-button>
21
+ </a-button-group>
22
+ <a-button-group v-if="showClearButton" style="margin: 0 20px;">
23
+ <a-button plain type="primary" @click="execCommand('print')" :loading="loading" :disabled="!editorReady">打印</a-button>
24
+ </a-button-group>
25
+ <!-- 修改清空体温单按钮样式,使其更加醒目 -->
26
+ <a-button
27
+ type="primary"
28
+ danger
29
+ v-if="showClearButton"
30
+ @click="clearVitalSigns"
31
+ :loading="loading"
32
+ :disabled="!editorReady"
33
+ style="margin-left: 10px;">
34
+ <a-icon type="delete" /> 清空体温单
35
+ </a-button>
36
+ </a-row>
37
+ <div v-if="!editorReady" style="margin: 10px 0; padding: 10px; background-color: #fffbe6; border: 1px solid #ffe58f;">
38
+ <a-icon type="loading" /> 体温单编辑器加载中...
39
+ </div>
40
+
41
+ <!-- 添加体温单生成加载遮罩 -->
42
+ <div v-if="generating" class="generating-mask">
43
+ <div class="generating-content">
44
+ <a-spin size="large" />
45
+ <div class="generating-text">体温单生成中,请稍候...</div>
46
+ </div>
47
+ </div>
48
+
49
+ <Editor @editor-ready="onEditorReady" style="margin: 10px 0;" ref="editorComponent"></Editor>
50
+
51
+ <!-- 使用TextBox组件替代原有弹窗 -->
52
+ <TextBox
53
+ :visible="modalVisible"
54
+ :modalType="modalType"
55
+ :editorReady="editorReady"
56
+ :id="Number(vitalSignsId) || 180"
57
+ @submit="handleSubmit"
58
+ @cancel="closeModal"
59
+ />
60
+ </div>
61
+ </template>
62
+
63
+ <script setup>
64
+ import { ref, onMounted } from 'vue'
65
+ import Editor from './editor.vue'
66
+ import TextBox from './textBox.vue'
67
+ import { message } from 'ant-design-vue'
68
+
69
+ // 响应式状态
70
+ const vitalSignsId = ref(null)
71
+ const loading = ref(false)
72
+ const editorReady = ref(false)
73
+ const editorComponent = ref(null)
74
+ const modalVisible = ref(false)
75
+ const modalType = ref('create')
76
+ const generating = ref(false) // 添加体温单生成中状态
77
+ let editor = null
78
+ // 定义组件事件
79
+ const emit = defineEmits(['submit'])
80
+ // 常量
81
+ const modalTitles = {
82
+ create: '创建体温单',
83
+ update: '更新体温单'
84
+ }
85
+
86
+ // 接受父组件传递的属性
87
+ defineProps({
88
+ showCreateButton: {
89
+ type: Boolean,
90
+ default: false
91
+ },
92
+ showUpdateButton: {
93
+ type: Boolean,
94
+ default: false
95
+ },
96
+ // 添加打印按钮是否显示属性
97
+ showPrintButton: {
98
+ type: Boolean,
99
+ default: false
100
+ },
101
+ showClearButton: {
102
+ type: Boolean,
103
+ default: false
104
+ },
105
+ // 时间模式 -2 ~ 2
106
+ adjustHour: {
107
+ type: Number,
108
+ default: 0
109
+ }
110
+ })
111
+
112
+ // 显示弹窗
113
+ function showVitalSignsModal (type) {
114
+ modalType.value = type
115
+ modalVisible.value = true
116
+ }
117
+
118
+ // 关闭弹窗
119
+ function closeModal () {
120
+ modalVisible.value = false
121
+ }
122
+
123
+ // 编辑器初始化
124
+ function onEditorReady (editorObj) {
125
+ try {
126
+ if (!editorObj) {
127
+ throw new Error('传入的editor对象为null或undefined')
128
+ }
129
+
130
+ // 尝试获取编辑器对象
131
+ if (typeof editorObj.createVitalSigns === 'function') {
132
+ editor = editorObj
133
+ } else if (editorObj.getEditor && typeof editorObj.getEditor === 'function') {
134
+ const editorFromComponent = editorObj.getEditor()
135
+ editor = editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function'
136
+ ? editorFromComponent
137
+ : (typeof editorObj.createVitalSigns === 'function' ? editorObj : null)
138
+ }
139
+ if (!editor) {
140
+ throw new Error('无法获取有效的editor对象')
141
+ }
142
+ editorReady.value = true
143
+ } catch (err) {
144
+ console.error('设置editor对象失败:', err)
145
+ message.error('体温单编辑器初始化失败,请刷新页面重试')
146
+ }
147
+ }
148
+
149
+ // 执行命令
150
+ function execCommand (cmd) {
151
+ if (!editorReady.value || !editor) return
152
+ loading.value = true
153
+ try {
154
+ editor.execCommand(cmd)
155
+ } catch (err) {
156
+ console.error('执行命令出错:', err)
157
+ message.error(`执行${cmd}命令失败`)
158
+ } finally {
159
+ loading.value = false
160
+ }
161
+ }
162
+
163
+ // 清空体温单
164
+ async function clearVitalSigns () {
165
+ if (!editorReady.value || !editor) {
166
+ message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
167
+ return
168
+ }
169
+ loading.value = true
170
+ generating.value = true
171
+ try {
172
+ // 重新加载editor.html页面来完全重置编辑器
173
+ try {
174
+ const iframe = editorComponent.value.$refs.editorIframe
175
+ if (iframe) {
176
+ // 保存当前src
177
+ const currentSrc = iframe.src
178
+ // 确认提示
179
+ message.loading('正在清空体温单...', 1)
180
+ // 重新加载iframe
181
+ iframe.onload = async () => {
182
+ try {
183
+ // 等待iframe重新加载完成
184
+ await new Promise(resolve => setTimeout(resolve, 500))
185
+ // 获取新的editor对象
186
+ const newEditorObj = iframe.contentWindow.editor
187
+ if (newEditorObj) {
188
+ // 等待editor初始化
189
+ if (typeof newEditorObj.init === 'function') {
190
+ await new Promise((resolve) => {
191
+ const checkInterval = setInterval(() => {
192
+ if (newEditorObj.isReady) {
193
+ clearInterval(checkInterval)
194
+ resolve()
195
+ }
196
+ }, 100)
197
+ // 最多等待5秒
198
+ setTimeout(() => {
199
+ clearInterval(checkInterval)
200
+ resolve()
201
+ }, 5000)
202
+ })
203
+ }
204
+ // 更新全局editor引用
205
+ editor = newEditorObj
206
+ window.iframeEditor = newEditorObj
207
+ } else {
208
+ throw new Error('重新加载后无法获取editor对象')
209
+ }
210
+ } catch (err) {
211
+ console.error('重新加载iframe后清空体温单出错:', err)
212
+ message.error(`清空体温单失败: ${err.message || '未知错误'}`)
213
+ } finally {
214
+ loading.value = false
215
+ generating.value = false
216
+ // 移除临时onload处理器
217
+ iframe.onload = null
218
+ }
219
+ }
220
+ // 重新加载iframe
221
+ iframe.src = currentSrc + '?t=' + new Date().getTime()
222
+ return
223
+ }
224
+ } catch (reloadErr) {
225
+ console.warn('重新加载iframe失败,将尝试其他方法清空体温单:', reloadErr)
226
+ }
227
+ // 备用清空方法
228
+ try {
229
+ const iframe = editorComponent.value.$refs.editorIframe
230
+ if (iframe?.contentWindow) {
231
+ iframe.contentWindow.eval(`
232
+ try {
233
+ // 尝试使用编辑器提供的各种可能的清空方法
234
+ if (editor) {
235
+ if (typeof editor.loadUrl === 'function') {
236
+ editor.loadUrl('');
237
+ } else if (typeof editor.resetDocument === 'function') {
238
+ editor.resetDocument();
239
+ } else if (typeof editor.clearContent === 'function') {
240
+ editor.clearContent();
241
+ } else if (typeof editor.clear === 'function') {
242
+ editor.clear();
243
+ } else if (typeof editor.setEditorContent === 'function') {
244
+ editor.setEditorContent('');
245
+ } else if (editor.document) {
246
+ try {
247
+ editor.document.body.innerHTML = '';
248
+ } catch(clearErr) {
249
+ console.warn('清空编辑器内容失败');
250
+ }
251
+ }
252
+ }
253
+ } catch(e) {
254
+ console.error('清空体温单失败:', e);
255
+ }
256
+ `)
257
+ } else if (window.iframeEditor) {
258
+ const editorObj = window.iframeEditor
259
+ if (typeof editorObj.loadUrl === 'function') {
260
+ editorObj.loadUrl('')
261
+ } else if (typeof editorObj.resetDocument === 'function') {
262
+ editorObj.resetDocument()
263
+ } else if (typeof editorObj.clearContent === 'function') {
264
+ editorObj.clearContent()
265
+ } else if (typeof editorObj.clear === 'function') {
266
+ editorObj.clear()
267
+ } else if (typeof editorObj.setEditorContent === 'function') {
268
+ editorObj.setEditorContent('')
269
+ }
270
+ } else if (editor) {
271
+ if (typeof editor.loadUrl === 'function') {
272
+ editor.loadUrl('')
273
+ } else if (typeof editor.resetDocument === 'function') {
274
+ editor.resetDocument()
275
+ } else if (typeof editor.clearContent === 'function') {
276
+ editor.clearContent()
277
+ } else if (typeof editor.clear === 'function') {
278
+ editor.clear()
279
+ } else if (typeof editor.setEditorContent === 'function') {
280
+ editor.setEditorContent('')
281
+ }
282
+ } else {
283
+ throw new Error('无法获取编辑器对象')
284
+ }
285
+ } catch (err) {
286
+ console.error('清空体温单出错:', err)
287
+ message.error(`清空体温单失败: ${err.message || '未知错误'}`)
288
+ }
289
+ } finally {
290
+ loading.value = false
291
+ generating.value = false
292
+ }
293
+ }
294
+
295
+ // 处理表单提交
296
+ async function handleSubmit (formData) {
297
+ console.log('表单数据:', formData)
298
+ if (!editorReady.value || !editor) {
299
+ message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
300
+ return
301
+ }
302
+ loading.value = true
303
+ generating.value = true // 开始生成,显示加载遮罩
304
+ try {
305
+ let result
306
+ try {
307
+ const iframe = editorComponent.value.$refs.editorIframe
308
+ if (iframe?.contentWindow) {
309
+ // 直接传递数据对象,避免使用eval
310
+ if (iframe.contentWindow.editor && typeof iframe.contentWindow.editor.createVitalSigns === 'function') {
311
+ result = iframe.contentWindow.editor.createVitalSigns(formData)
312
+ } else {
313
+ throw new Error('编辑器对象无效')
314
+ }
315
+ } else if (window.iframeEditor) {
316
+ result = window.iframeEditor.createVitalSigns(formData)
317
+ } else {
318
+ throw new Error('无法访问iframe')
319
+ }
320
+ } catch (err) {
321
+ // 备用方案
322
+ if (editor && typeof editor.createVitalSigns === 'function') {
323
+ editor.createVitalSigns(formData)
324
+ } else {
325
+ throw new Error('无法调用createVitalSigns方法')
326
+ }
327
+ }
328
+
329
+ vitalSignsId.value = result || formData.id
330
+ modalVisible.value = false
331
+ message.success(`${modalTitles[modalType.value]}成功`)
332
+ emit('submit', formData)
333
+ } catch (err) {
334
+ console.error('创建体温单出错:', err)
335
+ message.error(`创建体温单失败: ${err.message || '未知错误'}`)
336
+ } finally {
337
+ loading.value = false
338
+ generating.value = false // 无论成功失败,都结束加载遮罩
339
+ }
340
+ }
341
+
342
+ // 处理表单数据
343
+ function mergeAndTransformData (records, patientInfo, id, date, operateDate) {
344
+ // 提取records中的数据
345
+ const temperatureList = records.map(record => record.temperature).join(',')
346
+ const sphygmusList = records.map(record => record.sphygmus).join(',')
347
+ const breathList = records.map(record => record.breath).join(',')
348
+ const heartList = records.map(record => record.heart).join(',')
349
+ const notesList = records.map(record => record.notes).join(',')
350
+ const painList = records.map(record => record.pain).join(',')
351
+ const data1List = records.map(record => {
352
+ const [systolic, diastolic] = record.data1.split('|')
353
+ return `${systolic}/${diastolic}`
354
+ }).join(',')
355
+ const data2List = records.map(record => record.data2).join(',')
356
+ const data3List = records.map(record => record.data3).join(',')
357
+ const data4List = records.map(record => record.data4).join(',')
358
+ const data5List = records.map(record => record.data5).join(',')
359
+ const data6List = records.map(record => record.data6).join(',')
360
+ const data7List = records.map(record => record.data7).join(',')
361
+ const tempTypeList = records.map(record => record.temptype).join(',')
362
+
363
+ // 提取patientInfo中的数据
364
+ const name = patientInfo.name || ''
365
+ const dept = patientInfo.dept || ''
366
+ const bed = patientInfo.bed || ''
367
+ const inDate = patientInfo.indate || ''
368
+ const diag = patientInfo.diag || ''
369
+
370
+ // 生成合并后的对象
371
+ const mergedData = {
372
+ bed: bed.toString(),
373
+ sphygmus: sphygmusList,
374
+ notes: notesList,
375
+ medicalNo: id, // 示例中的固定值
376
+ diag: diag,
377
+ type: 'normal', // 示例中的固定值
378
+ breath: breathList,
379
+ temperature: temperatureList,
380
+ id: id, // 示例中的固定值
381
+ tempType: tempTypeList,
382
+ data7: data7List,
383
+ pain: painList,
384
+ data6: data6List,
385
+ data5: data5List,
386
+ data4: data4List,
387
+ data3: data3List,
388
+ data2: data2List,
389
+ inDate: inDate.split(' ')[0], // 只取日期部分
390
+ data1: data1List,
391
+ dept: dept,
392
+ heart: heartList,
393
+ labels: '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)|身高(cm)|体重(kg)', // 示例中的固定值
394
+ name: name,
395
+ begin: date, // 只取日期部分
396
+ operateDate: operateDate // 只取日期部分
397
+ }
398
+ return mergedData
399
+ }
400
+
401
+ // 生命周期钩子
402
+ onMounted(() => {
403
+ window.addEventListener('message', (event) => {
404
+ if (event.data?.type === 'editorReady' && !editorReady.value && editorComponent.value?.getEditor) {
405
+ try {
406
+ const editorFromComponent = editorComponent.value.getEditor()
407
+ if (editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function') {
408
+ editor = editorFromComponent
409
+ editorReady.value = true
410
+ }
411
+ } catch (err) {
412
+ console.error('从组件获取editor对象错误:', err)
413
+ }
414
+ }
415
+ })
416
+ })
417
+
418
+ // 暴露方法和属性给父组件,使父组件可以通过ref访问
419
+ defineExpose({
420
+ // 属性
421
+ vitalSignsId,
422
+ // 清空体温单方法
423
+ clearVitalSigns,
424
+ // 展示更新和创建弹框 创建参数:(String) create, 更新参数:(String) update
425
+ showVitalSignsModal,
426
+ // 触发打印函数 参数:(String) print
427
+ execCommand,
428
+ // 获取当前体温单ID的方法
429
+ getVitalSignsId: () => vitalSignsId.value,
430
+ // 设置体温单ID的方法
431
+ setVitalSignsId: (id) => {
432
+ vitalSignsId.value = id
433
+ },
434
+ // 创建体温单 参数:(Object) data
435
+ handleSubmit,
436
+ // 获取表单数据
437
+ mergeAndTransformData
438
+ })
439
+ </script>
440
+
441
+ <style scoped>
442
+ .box {
443
+ display: flex;
444
+ align-items: center;
445
+ padding: 1%;
446
+ }
447
+
448
+ /* 体温单生成加载遮罩样式 */
449
+ .generating-mask {
450
+ position: fixed;
451
+ top: 0;
452
+ left: 0;
453
+ right: 0;
454
+ bottom: 0;
455
+ background-color: rgba(0, 0, 0, 0.5);
456
+ display: flex;
457
+ justify-content: center;
458
+ align-items: center;
459
+ z-index: 9999;
460
+ }
461
+
462
+ .generating-content {
463
+ background-color: white;
464
+ padding: 20px 40px;
465
+ border-radius: 4px;
466
+ text-align: center;
467
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
468
+ }
469
+
470
+ .generating-text {
471
+ margin-top: 16px;
472
+ color: rgba(0, 0, 0, 0.85);
473
+ font-size: 16px;
474
+ }
475
+ </style>