vue2-client 1.16.24 → 1.16.25

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 (333) hide show
  1. package/.cursorrules +19 -19
  2. package/.env.apply +19 -19
  3. package/.env.gaslink +19 -19
  4. package/.env.his +19 -19
  5. package/.env.liuli +20 -20
  6. package/.env.scada +19 -19
  7. package/.eslintrc.js +90 -90
  8. package/CHANGELOG.md +824 -824
  9. package/Components.md +60 -60
  10. package/docs/LowCode/lowcode.md +155 -155
  11. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  12. package/docs/index.md +30 -30
  13. package/index.js +31 -31
  14. package/jest-transform-stub.js +8 -8
  15. package/jest.setup.js +7 -7
  16. package/jsconfig.json +19 -19
  17. package/package.json +112 -112
  18. package/public/his/editor/editor.html +51 -51
  19. package/public/his/editor/mock/bind_data.html +779 -779
  20. package/public/his/editor/mock/data_table.html +40 -40
  21. package/public/his/editor/mock/sign.html +75 -75
  22. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  23. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  24. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  25. package/public/his/editor/vender/date97/calendar.js +4 -4
  26. package/public/his/editor/vender/date97/lang/en.js +13 -13
  27. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  29. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  30. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  31. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  32. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  33. package/public/his/editor/vender/diff.js +1627 -1627
  34. package/public/his/editor/vender/editor.js +1 -1
  35. package/public/his/editor/vender/fabric.js +31187 -31187
  36. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  37. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  38. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  39. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  40. package/public/his/editor/vender/mui/mui.min.css +4 -4
  41. package/public/his/editor/vender/mui/mui.min.js +5 -5
  42. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  43. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  44. package/public/his/editor/vender/qrcode.js +7 -7
  45. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  46. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  47. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  48. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  49. package/public/his/editor/vender/validator.js +5094 -5094
  50. package/public/his/editor/vender/weui/weui.css +5659 -5659
  51. package/public/his/editor/vender/weui/weui.min.css +4 -4
  52. package/public/his/editor/vender/weui/weui.min.js +11 -11
  53. package/src/assets/img/querySlotDemo.svg +15 -15
  54. package/src/assets/svg/badtwo.svg +1 -1
  55. package/src/assets/svg/goodtwo.svg +1 -1
  56. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  57. package/src/base-client/components/AI/demo.vue +31 -31
  58. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  59. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  60. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  61. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  62. package/src/base-client/components/common/CitySelect/CitySelect.vue +1 -1
  63. package/src/base-client/components/common/CitySelect/index.js +3 -3
  64. package/src/base-client/components/common/CitySelect/index.md +109 -109
  65. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  66. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  67. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  68. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  69. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  70. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  71. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  72. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  73. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  74. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  75. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  76. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  77. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  78. package/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm.vue +478 -478
  79. package/src/base-client/components/common/HIS/HAddNativeForm/index.js +3 -3
  80. package/src/base-client/components/common/HIS/HButtons/HButtons.vue +365 -365
  81. package/src/base-client/components/common/HIS/HFormTable/HFormTable.vue +219 -219
  82. package/src/base-client/components/common/HIS/HTab/HTab.vue +293 -293
  83. package/src/base-client/components/common/HIS/demo.vue +54 -54
  84. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  85. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  86. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  87. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  88. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  89. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  90. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  96. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  97. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  98. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  99. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  100. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  101. package/src/base-client/components/common/Recording/index.js +3 -3
  102. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  103. package/src/base-client/components/common/Tree/index.js +2 -2
  104. package/src/base-client/components/common/Upload/index.js +3 -3
  105. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  106. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  107. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  108. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  109. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  110. package/src/base-client/components/common/XAddReport/index.js +3 -3
  111. package/src/base-client/components/common/XAddReport/index.md +56 -56
  112. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  113. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  114. package/src/base-client/components/common/XButtons/index.js +3 -3
  115. package/src/base-client/components/common/XButtons/index.md +61 -61
  116. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  117. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  118. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  119. package/src/base-client/components/common/XDataCard/index.js +3 -3
  120. package/src/base-client/components/common/XDataCard/index.md +1 -1
  121. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  122. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  123. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  124. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  125. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  126. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  127. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  128. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  129. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  130. package/src/base-client/components/common/XForm/index.md +178 -178
  131. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  132. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  133. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  134. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  135. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  136. package/src/base-client/components/common/XFormTable/index.md +92 -92
  137. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  138. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  139. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  140. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  141. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  142. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  143. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  144. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  145. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  146. package/src/base-client/components/common/XPrint/index.vue +97 -97
  147. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  148. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  149. package/src/base-client/components/common/XReport/index.js +3 -3
  150. package/src/base-client/components/common/XReport/print.js +186 -186
  151. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  152. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +813 -813
  153. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  154. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  155. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  156. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  157. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  158. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  159. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  160. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  161. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  162. package/src/base-client/components/common/XStepView/index.js +3 -3
  163. package/src/base-client/components/common/XStepView/index.md +31 -31
  164. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  165. package/src/base-client/components/common/XTab/index.js +3 -3
  166. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  167. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  168. package/src/base-client/components/common/XTable/index.md +255 -255
  169. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  170. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  171. package/src/base-client/components/common/XTree/index.js +3 -3
  172. package/src/base-client/components/common/XTree/index.md +36 -36
  173. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  174. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  175. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  176. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  177. package/src/base-client/components/his/XCharge/XCharge.vue +610 -610
  178. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  179. package/src/base-client/components/his/XSidebar/XSidebar.vue +283 -283
  180. package/src/base-client/components/his/XSimpleTable/XSimpleTable.vue +119 -119
  181. package/src/base-client/components/his/XTimeSelect/XTimeSelect.vue +200 -200
  182. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +482 -482
  183. package/src/base-client/components/index.js +51 -51
  184. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  185. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  186. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  187. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  188. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  189. package/src/base-client/plugins/Config.js +19 -19
  190. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  191. package/src/base-client/plugins/Recording.js +258 -258
  192. package/src/base-client/plugins/index.js +23 -23
  193. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  194. package/src/components/Charts/Bar.vue +62 -62
  195. package/src/components/Charts/ChartCard.vue +134 -134
  196. package/src/components/Charts/Liquid.vue +67 -67
  197. package/src/components/Charts/MiniArea.vue +39 -39
  198. package/src/components/Charts/MiniBar.vue +39 -39
  199. package/src/components/Charts/MiniProgress.vue +75 -75
  200. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  201. package/src/components/Charts/Radar.vue +68 -68
  202. package/src/components/Charts/RankList.vue +77 -77
  203. package/src/components/Charts/TagCloud.vue +113 -113
  204. package/src/components/Charts/TransferBar.vue +64 -64
  205. package/src/components/Charts/Trend.vue +82 -82
  206. package/src/components/Charts/chart.less +12 -12
  207. package/src/components/Charts/smooth.area.less +13 -13
  208. package/src/components/CodeMirror/inedx.vue +118 -118
  209. package/src/components/CodeMirror/setting.js +40 -40
  210. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  211. package/src/components/NumberInfo/index.js +3 -3
  212. package/src/components/NumberInfo/index.less +54 -54
  213. package/src/components/NumberInfo/index.md +43 -43
  214. package/src/components/card/ChartCard.vue +79 -79
  215. package/src/components/chart/Bar.vue +60 -60
  216. package/src/components/chart/MiniArea.vue +67 -67
  217. package/src/components/chart/MiniBar.vue +59 -59
  218. package/src/components/chart/MiniProgress.vue +57 -57
  219. package/src/components/chart/Radar.vue +80 -80
  220. package/src/components/chart/RankingList.vue +60 -60
  221. package/src/components/chart/Trend.vue +79 -79
  222. package/src/components/chart/index.less +9 -9
  223. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  224. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  225. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  226. package/src/components/checkbox/index.js +9 -9
  227. package/src/components/exception/ExceptionPage.vue +70 -70
  228. package/src/components/g2Charts/constants.js +202 -202
  229. package/src/components/g2Charts/demo.vue +808 -808
  230. package/src/components/g2Charts/designer.vue +228 -228
  231. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  232. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  233. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  234. package/src/components/g2Charts/index.vue +397 -397
  235. package/src/components/index.js +36 -36
  236. package/src/components/input/IInput.vue +66 -66
  237. package/src/components/menu/SideMenu.vue +75 -75
  238. package/src/components/menu/menu.js +273 -273
  239. package/src/components/setting/Setting.vue +234 -234
  240. package/src/components/tool/AStepItem.vue +60 -60
  241. package/src/config/CreateQueryConfig.js +325 -325
  242. package/src/config/default/antd.config.js +89 -89
  243. package/src/config/default/setting.config.js +55 -55
  244. package/src/font-style/font.css +60 -60
  245. package/src/layouts/CommonLayout.vue +56 -56
  246. package/src/layouts/PageLayout.vue +151 -151
  247. package/src/layouts/SinglePageView.vue +136 -136
  248. package/src/layouts/header/AdminHeader.vue +132 -132
  249. package/src/layouts/header/HeaderNotice.vue +177 -177
  250. package/src/layouts/header/InstitutionDetail.vue +181 -181
  251. package/src/layouts/tabs/TabsHead.vue +189 -189
  252. package/src/lib.js +1 -1
  253. package/src/mock/extend/index.js +84 -84
  254. package/src/mock/goods/index.js +108 -108
  255. package/src/pages/DefaultExample/index.vue +77 -77
  256. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  257. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  258. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  259. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  260. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  261. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  262. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  263. package/src/pages/DynamicStatistics/index.vue +282 -282
  264. package/src/pages/Example/childIndex.vue +15 -15
  265. package/src/pages/Example/index.vue +30 -30
  266. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  267. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  268. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  269. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  270. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  271. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  272. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  273. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  274. package/src/pages/Recording/index.vue +77 -77
  275. package/src/pages/ServiceReview/index.vue +284 -284
  276. package/src/pages/SubExample/index.vue +26 -26
  277. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  278. package/src/pages/XReportView/index.vue +64 -64
  279. package/src/pages/XTreeOneProExample/index.vue +67 -67
  280. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  281. package/src/pages/login/Login.vue +379 -379
  282. package/src/pages/login/LoginV3.vue +389 -389
  283. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  284. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  285. package/src/pages/report/ReportTable.js +124 -124
  286. package/src/pages/resourceManage/orgListManage.vue +98 -98
  287. package/src/pages/system/dictionary/index.vue +44 -44
  288. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  289. package/src/pages/system/monitor/operLog/index.vue +37 -37
  290. package/src/pages/system/settings/modifyPassword.vue +117 -117
  291. package/src/pages/system/ticket/index.vue +480 -480
  292. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  293. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  294. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  295. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  296. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  297. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  298. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  299. package/src/plugins/EventLogPlugin.js +33 -33
  300. package/src/plugins/FindParentsData.js +17 -17
  301. package/src/router/async/config.async.js +35 -35
  302. package/src/router/async/router.map.js +129 -129
  303. package/src/router/index.js +27 -27
  304. package/src/services/DataModel.js +30 -30
  305. package/src/services/LodopFuncs.js +137 -137
  306. package/src/services/api/TicketDetailsViewApi.js +46 -46
  307. package/src/services/api/cas.js +79 -79
  308. package/src/services/api/common.js +346 -346
  309. package/src/services/api/entity.js +18 -18
  310. package/src/services/api/index.js +17 -17
  311. package/src/store/modules/account.js +115 -115
  312. package/src/store/modules/index.js +5 -5
  313. package/src/store/modules/lowCode.js +33 -33
  314. package/src/store/modules/setting.js +119 -119
  315. package/src/theme/default/style.less +58 -58
  316. package/src/utils/authority-utils.js +85 -85
  317. package/src/utils/errorCode.js +6 -6
  318. package/src/utils/formatter.js +74 -74
  319. package/src/utils/htmlToPDF.js +108 -108
  320. package/src/utils/htmlToPDFApi.js +5 -5
  321. package/src/utils/login.js +188 -188
  322. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  323. package/src/utils/lowcode/lowcodeLog.js +29 -29
  324. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  325. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  326. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  327. package/src/utils/map-utils.js +47 -47
  328. package/src/utils/reg.js +95 -95
  329. package/src/utils/runEvalFunction.js +14 -14
  330. package/src/utils/theme-color-replacer-extend.js +92 -92
  331. package/src/utils/util.js +329 -329
  332. package/src/utils/waterMark.js +31 -31
  333. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,482 +1,482 @@
1
- <template>
2
- <!-- <Source src="/code/VitalSigns.vue"></Source>-->
3
- <div>
4
- <a-row class="box">
5
- <!-- 病历号输入框已隐藏,通过setMedicalRecordId方法设置vitalSignsId -->
6
- <!-- 病历号&nbsp;&nbsp;<a-input v-model="vitalSignsId" style="width: 160px"></a-input> -->
7
- <a-button-group style="margin-left: 20px;">
8
- <a-button
9
- v-if="showCreateButton"
10
- plain
11
- type="primary"
12
- @click="showVitalSignsModal('create')"
13
- :loading="loading"
14
- :disabled="!editorReady">创建体温单</a-button>
15
- <a-button
16
- v-if="showUpdateButton"
17
- plain
18
- type="primary"
19
- @click="showVitalSignsModal('update')"
20
- :loading="loading"
21
- :disabled="!editorReady">更新体温单</a-button>
22
- </a-button-group>
23
- <a-button-group v-if="showClearButton" style="margin: 0 20px;">
24
- <a-button plain type="primary" @click="execCommand('print')" :loading="loading" :disabled="!editorReady">打印</a-button>
25
- </a-button-group>
26
- <!-- 修改清空体温单按钮样式,使其更加醒目 -->
27
- <a-button
28
- type="primary"
29
- danger
30
- v-if="showClearButton"
31
- @click="clearVitalSigns"
32
- :loading="loading"
33
- :disabled="!editorReady"
34
- style="margin-left: 10px;">
35
- <a-icon type="delete" /> 清空体温单
36
- </a-button>
37
- </a-row>
38
- <div v-if="!editorReady" style="margin: 10px 0; padding: 10px; background-color: #fffbe6; border: 1px solid #ffe58f;">
39
- <a-icon type="loading" /> 体温单编辑器加载中...
40
- </div>
41
-
42
- <!-- 添加体温单生成加载遮罩 -->
43
- <div v-if="generating" class="generating-mask">
44
- <div class="generating-content">
45
- <a-spin size="large" />
46
- <div class="generating-text">体温单生成中,请稍候...</div>
47
- </div>
48
- </div>
49
-
50
- <Editor @editor-ready="onEditorReady" style="margin: 10px 0;" ref="editorComponent"></Editor>
51
-
52
- <!-- 使用TextBox组件替代原有弹窗 -->
53
- <TextBox
54
- :visible="modalVisible"
55
- :modalType="modalType"
56
- :editorReady="editorReady"
57
- :id="Number(vitalSignsId) || 180"
58
- @submit="handleSubmit"
59
- @cancel="closeModal"
60
- />
61
- </div>
62
- </template>
63
-
64
- <script setup>
65
- import { ref, onMounted } from 'vue'
66
- import Editor from './editor.vue'
67
- import TextBox from './textBox.vue'
68
- import { message } from 'ant-design-vue'
69
-
70
- // 响应式状态
71
- const vitalSignsId = ref(null)
72
- const loading = ref(false)
73
- const editorReady = ref(false)
74
- const editorComponent = ref(null)
75
- const modalVisible = ref(false)
76
- const modalType = ref('create')
77
- const generating = ref(false) // 添加体温单生成中状态
78
- let editor = null
79
- // 定义组件事件
80
- const emit = defineEmits(['submit'])
81
- // 常量
82
- const modalTitles = {
83
- create: '创建体温单',
84
- update: '更新体温单'
85
- }
86
-
87
- // 接受父组件传递的属性
88
- defineProps({
89
- showCreateButton: {
90
- type: Boolean,
91
- default: false
92
- },
93
- showUpdateButton: {
94
- type: Boolean,
95
- default: false
96
- },
97
- // 添加打印按钮是否显示属性
98
- showPrintButton: {
99
- type: Boolean,
100
- default: false
101
- },
102
- showClearButton: {
103
- type: Boolean,
104
- default: false
105
- },
106
- // 时间模式 -2 ~ 2
107
- adjustHour: {
108
- type: Number,
109
- default: 0
110
- }
111
- })
112
-
113
- // 显示弹窗
114
- function showVitalSignsModal (type) {
115
- modalType.value = type
116
- modalVisible.value = true
117
- }
118
-
119
- // 关闭弹窗
120
- function closeModal () {
121
- modalVisible.value = false
122
- }
123
-
124
- // 编辑器初始化
125
- function onEditorReady (editorObj) {
126
- try {
127
- if (!editorObj) {
128
- throw new Error('传入的editor对象为null或undefined')
129
- }
130
-
131
- // 尝试获取编辑器对象
132
- if (typeof editorObj.createVitalSigns === 'function') {
133
- editor = editorObj
134
- } else if (editorObj.getEditor && typeof editorObj.getEditor === 'function') {
135
- const editorFromComponent = editorObj.getEditor()
136
- editor = editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function'
137
- ? editorFromComponent
138
- : (typeof editorObj.createVitalSigns === 'function' ? editorObj : null)
139
- }
140
- if (!editor) {
141
- throw new Error('无法获取有效的editor对象')
142
- }
143
- editorReady.value = true
144
- } catch (err) {
145
- console.error('设置editor对象失败:', err)
146
- message.error('体温单编辑器初始化失败,请刷新页面重试')
147
- }
148
- }
149
-
150
- // 执行命令
151
- function execCommand (cmd) {
152
- if (!editorReady.value || !editor) return
153
- loading.value = true
154
- try {
155
- editor.execCommand(cmd)
156
- } catch (err) {
157
- console.error('执行命令出错:', err)
158
- message.error(`执行${cmd}命令失败`)
159
- } finally {
160
- loading.value = false
161
- }
162
- }
163
-
164
- // 清空体温单
165
- async function clearVitalSigns () {
166
- if (!editorReady.value || !editor) {
167
- message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
168
- return
169
- }
170
- loading.value = true
171
- generating.value = true
172
- try {
173
- // 重新加载editor.html页面来完全重置编辑器
174
- try {
175
- const iframe = editorComponent.value.$refs.editorIframe
176
- if (iframe) {
177
- // 保存当前src
178
- const currentSrc = iframe.src
179
- // 确认提示
180
- message.loading('正在清空体温单...', 1)
181
- // 重新加载iframe
182
- iframe.onload = async () => {
183
- try {
184
- // 等待iframe重新加载完成
185
- await new Promise(resolve => setTimeout(resolve, 500))
186
- // 获取新的editor对象
187
- const newEditorObj = iframe.contentWindow.editor
188
- if (newEditorObj) {
189
- // 等待editor初始化
190
- if (typeof newEditorObj.init === 'function') {
191
- await new Promise((resolve) => {
192
- const checkInterval = setInterval(() => {
193
- if (newEditorObj.isReady) {
194
- clearInterval(checkInterval)
195
- resolve()
196
- }
197
- }, 100)
198
- // 最多等待5秒
199
- setTimeout(() => {
200
- clearInterval(checkInterval)
201
- resolve()
202
- }, 5000)
203
- })
204
- }
205
- // 更新全局editor引用
206
- editor = newEditorObj
207
- window.iframeEditor = newEditorObj
208
- } else {
209
- throw new Error('重新加载后无法获取editor对象')
210
- }
211
- } catch (err) {
212
- console.error('重新加载iframe后清空体温单出错:', err)
213
- message.error(`清空体温单失败: ${err.message || '未知错误'}`)
214
- } finally {
215
- loading.value = false
216
- generating.value = false
217
- // 移除临时onload处理器
218
- iframe.onload = null
219
- }
220
- }
221
- // 重新加载iframe
222
- iframe.src = currentSrc + '?t=' + new Date().getTime()
223
- return
224
- }
225
- } catch (reloadErr) {
226
- console.warn('重新加载iframe失败,将尝试其他方法清空体温单:', reloadErr)
227
- }
228
- // 备用清空方法
229
- try {
230
- const iframe = editorComponent.value.$refs.editorIframe
231
- if (iframe?.contentWindow) {
232
- iframe.contentWindow.eval(`
233
- try {
234
- // 尝试使用编辑器提供的各种可能的清空方法
235
- if (editor) {
236
- if (typeof editor.loadUrl === 'function') {
237
- editor.loadUrl('');
238
- } else if (typeof editor.resetDocument === 'function') {
239
- editor.resetDocument();
240
- } else if (typeof editor.clearContent === 'function') {
241
- editor.clearContent();
242
- } else if (typeof editor.clear === 'function') {
243
- editor.clear();
244
- } else if (typeof editor.setEditorContent === 'function') {
245
- editor.setEditorContent('');
246
- } else if (editor.document) {
247
- try {
248
- editor.document.body.innerHTML = '';
249
- } catch(clearErr) {
250
- console.warn('清空编辑器内容失败');
251
- }
252
- }
253
- }
254
- } catch(e) {
255
- console.error('清空体温单失败:', e);
256
- }
257
- `)
258
- } else if (window.iframeEditor) {
259
- const editorObj = window.iframeEditor
260
- if (typeof editorObj.loadUrl === 'function') {
261
- editorObj.loadUrl('')
262
- } else if (typeof editorObj.resetDocument === 'function') {
263
- editorObj.resetDocument()
264
- } else if (typeof editorObj.clearContent === 'function') {
265
- editorObj.clearContent()
266
- } else if (typeof editorObj.clear === 'function') {
267
- editorObj.clear()
268
- } else if (typeof editorObj.setEditorContent === 'function') {
269
- editorObj.setEditorContent('')
270
- }
271
- } else if (editor) {
272
- if (typeof editor.loadUrl === 'function') {
273
- editor.loadUrl('')
274
- } else if (typeof editor.resetDocument === 'function') {
275
- editor.resetDocument()
276
- } else if (typeof editor.clearContent === 'function') {
277
- editor.clearContent()
278
- } else if (typeof editor.clear === 'function') {
279
- editor.clear()
280
- } else if (typeof editor.setEditorContent === 'function') {
281
- editor.setEditorContent('')
282
- }
283
- } else {
284
- throw new Error('无法获取编辑器对象')
285
- }
286
- } catch (err) {
287
- console.error('清空体温单出错:', err)
288
- message.error(`清空体温单失败: ${err.message || '未知错误'}`)
289
- }
290
- } finally {
291
- loading.value = false
292
- generating.value = false
293
- }
294
- }
295
-
296
- // 处理表单提交
297
- async function handleSubmit (formData) {
298
- console.log('表单数据:', formData)
299
- if (!editorReady.value || !editor) {
300
- message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
301
- return
302
- }
303
- loading.value = true
304
- generating.value = true // 开始生成,显示加载遮罩
305
- try {
306
- let result
307
- try {
308
- const iframe = editorComponent.value.$refs.editorIframe
309
- if (iframe?.contentWindow) {
310
- // 直接传递数据对象,避免使用eval
311
- if (iframe.contentWindow.editor && typeof iframe.contentWindow.editor.createVitalSigns === 'function') {
312
- result = iframe.contentWindow.editor.createVitalSigns(formData)
313
- } else {
314
- throw new Error('编辑器对象无效')
315
- }
316
- } else if (window.iframeEditor) {
317
- result = window.iframeEditor.createVitalSigns(formData)
318
- } else {
319
- throw new Error('无法访问iframe')
320
- }
321
- } catch (err) {
322
- // 备用方案
323
- if (editor && typeof editor.createVitalSigns === 'function') {
324
- editor.createVitalSigns(formData)
325
- } else {
326
- throw new Error('无法调用createVitalSigns方法')
327
- }
328
- }
329
-
330
- vitalSignsId.value = result || formData.id
331
- modalVisible.value = false
332
- message.success(`${modalTitles[modalType.value]}成功`)
333
- emit('submit', formData)
334
- } catch (err) {
335
- console.error('创建体温单出错:', err)
336
- message.error(`创建体温单失败: ${err.message || '未知错误'}`)
337
- } finally {
338
- loading.value = false
339
- generating.value = false // 无论成功失败,都结束加载遮罩
340
- }
341
- }
342
-
343
- // 处理表单数据
344
- function mergeAndTransformData (records, patientInfo, id, date, operateDate) {
345
- // 提取records中的数据
346
- const temperatureList = records.map(record => record.temperature).join(',')
347
- const sphygmusList = records.map(record => record.sphygmus).join(',')
348
- const breathList = records.map(record => record.breath).join(',')
349
- const heartList = records.map(record => record.heart).join(',')
350
- const notesList = records.map(record => record.notes).join(',')
351
- const painList = records.map(record => record.pain).join(',')
352
- const data1List = records.map(record => {
353
- const [systolic, diastolic] = record.data1.split('|')
354
- return `${systolic}/${diastolic}`
355
- }).join(',')
356
- const data2List = records.map(record => record.data2).join(',')
357
- const data3List = records.map(record => record.data3).join(',')
358
- const data4List = records.map(record => record.data4).join(',')
359
- const data5List = records.map(record => record.data5).join(',')
360
- const data6List = records.map(record => record.data6).join(',')
361
- const data7List = records.map(record => record.data7).join(',')
362
- const tempTypeList = records.map(record => record.temptype).join(',')
363
-
364
- // 提取patientInfo中的数据
365
- const name = patientInfo.name || ''
366
- const dept = patientInfo.dept || ''
367
- const bed = patientInfo.bed || ''
368
- const inDate = patientInfo.indate || ''
369
- const diag = patientInfo.diag || ''
370
-
371
- // 生成合并后的对象
372
- const mergedData = {
373
- bed: bed.toString(),
374
- sphygmus: sphygmusList,
375
- notes: notesList,
376
- medicalNo: id, // 示例中的固定值
377
- diag: diag,
378
- type: 'normal', // 示例中的固定值
379
- breath: breathList,
380
- temperature: temperatureList,
381
- id: id, // 示例中的固定值
382
- tempType: tempTypeList,
383
- data7: data7List,
384
- pain: painList,
385
- data6: data6List,
386
- data5: data5List,
387
- data4: data4List,
388
- data3: data3List,
389
- data2: data2List,
390
- inDate: inDate.split(' ')[0], // 只取日期部分
391
- data1: data1List,
392
- dept: dept,
393
- heart: heartList,
394
- labels: '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)|身高(cm)|体重(kg)', // 示例中的固定值
395
- name: name,
396
- begin: date, // 只取日期部分
397
- operateDate: operateDate // 只取日期部分
398
- }
399
- return mergedData
400
- }
401
- // 设置病历号的方法
402
- function setMedicalRecordId (id) {
403
- vitalSignsId.value = id
404
- // console.log('病历号已设置为:', vitalSignsId.value)
405
- }
406
- // 生命周期钩子
407
- onMounted(() => {
408
- window.addEventListener('message', (event) => {
409
- if (event.data?.type === 'editorReady' && !editorReady.value && editorComponent.value?.getEditor) {
410
- try {
411
- const editorFromComponent = editorComponent.value.getEditor()
412
- if (editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function') {
413
- editor = editorFromComponent
414
- editorReady.value = true
415
- }
416
- } catch (err) {
417
- console.error('从组件获取editor对象错误:', err)
418
- }
419
- }
420
- })
421
- })
422
-
423
- // 暴露方法和属性给父组件,使父组件可以通过ref访问
424
- defineExpose({
425
- // 属性
426
- vitalSignsId,
427
- // 清空体温单方法
428
- clearVitalSigns,
429
- // 展示更新和创建弹框 创建参数:(String) create, 更新参数:(String) update
430
- showVitalSignsModal,
431
- // 触发打印函数 参数:(String) print
432
- execCommand,
433
- // 获取当前体温单ID的方法
434
- getVitalSignsId: () => vitalSignsId.value,
435
- // 设置体温单ID的方法
436
- setVitalSignsId: (id) => {
437
- vitalSignsId.value = id
438
- },
439
- // 创建体温单 参数:(Object) data
440
- handleSubmit,
441
- // 设置病历号
442
- setMedicalRecordId,
443
- // 获取表单数据
444
- mergeAndTransformData
445
- })
446
- </script>
447
-
448
- <style scoped>
449
- .box {
450
- display: flex;
451
- align-items: center;
452
- padding: 1%;
453
- }
454
-
455
- /* 体温单生成加载遮罩样式 */
456
- .generating-mask {
457
- position: fixed;
458
- top: 0;
459
- left: 0;
460
- right: 0;
461
- bottom: 0;
462
- background-color: rgba(0, 0, 0, 0.5);
463
- display: flex;
464
- justify-content: center;
465
- align-items: center;
466
- z-index: 9999;
467
- }
468
-
469
- .generating-content {
470
- background-color: white;
471
- padding: 20px 40px;
472
- border-radius: 4px;
473
- text-align: center;
474
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
475
- }
476
-
477
- .generating-text {
478
- margin-top: 16px;
479
- color: rgba(0, 0, 0, 0.85);
480
- font-size: 16px;
481
- }
482
- </style>
1
+ <template>
2
+ <!-- <Source src="/code/VitalSigns.vue"></Source>-->
3
+ <div>
4
+ <a-row class="box">
5
+ <!-- 病历号输入框已隐藏,通过setMedicalRecordId方法设置vitalSignsId -->
6
+ <!-- 病历号&nbsp;&nbsp;<a-input v-model="vitalSignsId" style="width: 160px"></a-input> -->
7
+ <a-button-group style="margin-left: 20px;">
8
+ <a-button
9
+ v-if="showCreateButton"
10
+ plain
11
+ type="primary"
12
+ @click="showVitalSignsModal('create')"
13
+ :loading="loading"
14
+ :disabled="!editorReady">创建体温单</a-button>
15
+ <a-button
16
+ v-if="showUpdateButton"
17
+ plain
18
+ type="primary"
19
+ @click="showVitalSignsModal('update')"
20
+ :loading="loading"
21
+ :disabled="!editorReady">更新体温单</a-button>
22
+ </a-button-group>
23
+ <a-button-group v-if="showClearButton" style="margin: 0 20px;">
24
+ <a-button plain type="primary" @click="execCommand('print')" :loading="loading" :disabled="!editorReady">打印</a-button>
25
+ </a-button-group>
26
+ <!-- 修改清空体温单按钮样式,使其更加醒目 -->
27
+ <a-button
28
+ type="primary"
29
+ danger
30
+ v-if="showClearButton"
31
+ @click="clearVitalSigns"
32
+ :loading="loading"
33
+ :disabled="!editorReady"
34
+ style="margin-left: 10px;">
35
+ <a-icon type="delete" /> 清空体温单
36
+ </a-button>
37
+ </a-row>
38
+ <div v-if="!editorReady" style="margin: 10px 0; padding: 10px; background-color: #fffbe6; border: 1px solid #ffe58f;">
39
+ <a-icon type="loading" /> 体温单编辑器加载中...
40
+ </div>
41
+
42
+ <!-- 添加体温单生成加载遮罩 -->
43
+ <div v-if="generating" class="generating-mask">
44
+ <div class="generating-content">
45
+ <a-spin size="large" />
46
+ <div class="generating-text">体温单生成中,请稍候...</div>
47
+ </div>
48
+ </div>
49
+
50
+ <Editor @editor-ready="onEditorReady" style="margin: 10px 0;" ref="editorComponent"></Editor>
51
+
52
+ <!-- 使用TextBox组件替代原有弹窗 -->
53
+ <TextBox
54
+ :visible="modalVisible"
55
+ :modalType="modalType"
56
+ :editorReady="editorReady"
57
+ :id="Number(vitalSignsId) || 180"
58
+ @submit="handleSubmit"
59
+ @cancel="closeModal"
60
+ />
61
+ </div>
62
+ </template>
63
+
64
+ <script setup>
65
+ import { ref, onMounted } from 'vue'
66
+ import Editor from './editor.vue'
67
+ import TextBox from './textBox.vue'
68
+ import { message } from 'ant-design-vue'
69
+
70
+ // 响应式状态
71
+ const vitalSignsId = ref(null)
72
+ const loading = ref(false)
73
+ const editorReady = ref(false)
74
+ const editorComponent = ref(null)
75
+ const modalVisible = ref(false)
76
+ const modalType = ref('create')
77
+ const generating = ref(false) // 添加体温单生成中状态
78
+ let editor = null
79
+ // 定义组件事件
80
+ const emit = defineEmits(['submit'])
81
+ // 常量
82
+ const modalTitles = {
83
+ create: '创建体温单',
84
+ update: '更新体温单'
85
+ }
86
+
87
+ // 接受父组件传递的属性
88
+ defineProps({
89
+ showCreateButton: {
90
+ type: Boolean,
91
+ default: false
92
+ },
93
+ showUpdateButton: {
94
+ type: Boolean,
95
+ default: false
96
+ },
97
+ // 添加打印按钮是否显示属性
98
+ showPrintButton: {
99
+ type: Boolean,
100
+ default: false
101
+ },
102
+ showClearButton: {
103
+ type: Boolean,
104
+ default: false
105
+ },
106
+ // 时间模式 -2 ~ 2
107
+ adjustHour: {
108
+ type: Number,
109
+ default: 0
110
+ }
111
+ })
112
+
113
+ // 显示弹窗
114
+ function showVitalSignsModal (type) {
115
+ modalType.value = type
116
+ modalVisible.value = true
117
+ }
118
+
119
+ // 关闭弹窗
120
+ function closeModal () {
121
+ modalVisible.value = false
122
+ }
123
+
124
+ // 编辑器初始化
125
+ function onEditorReady (editorObj) {
126
+ try {
127
+ if (!editorObj) {
128
+ throw new Error('传入的editor对象为null或undefined')
129
+ }
130
+
131
+ // 尝试获取编辑器对象
132
+ if (typeof editorObj.createVitalSigns === 'function') {
133
+ editor = editorObj
134
+ } else if (editorObj.getEditor && typeof editorObj.getEditor === 'function') {
135
+ const editorFromComponent = editorObj.getEditor()
136
+ editor = editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function'
137
+ ? editorFromComponent
138
+ : (typeof editorObj.createVitalSigns === 'function' ? editorObj : null)
139
+ }
140
+ if (!editor) {
141
+ throw new Error('无法获取有效的editor对象')
142
+ }
143
+ editorReady.value = true
144
+ } catch (err) {
145
+ console.error('设置editor对象失败:', err)
146
+ message.error('体温单编辑器初始化失败,请刷新页面重试')
147
+ }
148
+ }
149
+
150
+ // 执行命令
151
+ function execCommand (cmd) {
152
+ if (!editorReady.value || !editor) return
153
+ loading.value = true
154
+ try {
155
+ editor.execCommand(cmd)
156
+ } catch (err) {
157
+ console.error('执行命令出错:', err)
158
+ message.error(`执行${cmd}命令失败`)
159
+ } finally {
160
+ loading.value = false
161
+ }
162
+ }
163
+
164
+ // 清空体温单
165
+ async function clearVitalSigns () {
166
+ if (!editorReady.value || !editor) {
167
+ message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
168
+ return
169
+ }
170
+ loading.value = true
171
+ generating.value = true
172
+ try {
173
+ // 重新加载editor.html页面来完全重置编辑器
174
+ try {
175
+ const iframe = editorComponent.value.$refs.editorIframe
176
+ if (iframe) {
177
+ // 保存当前src
178
+ const currentSrc = iframe.src
179
+ // 确认提示
180
+ message.loading('正在清空体温单...', 1)
181
+ // 重新加载iframe
182
+ iframe.onload = async () => {
183
+ try {
184
+ // 等待iframe重新加载完成
185
+ await new Promise(resolve => setTimeout(resolve, 500))
186
+ // 获取新的editor对象
187
+ const newEditorObj = iframe.contentWindow.editor
188
+ if (newEditorObj) {
189
+ // 等待editor初始化
190
+ if (typeof newEditorObj.init === 'function') {
191
+ await new Promise((resolve) => {
192
+ const checkInterval = setInterval(() => {
193
+ if (newEditorObj.isReady) {
194
+ clearInterval(checkInterval)
195
+ resolve()
196
+ }
197
+ }, 100)
198
+ // 最多等待5秒
199
+ setTimeout(() => {
200
+ clearInterval(checkInterval)
201
+ resolve()
202
+ }, 5000)
203
+ })
204
+ }
205
+ // 更新全局editor引用
206
+ editor = newEditorObj
207
+ window.iframeEditor = newEditorObj
208
+ } else {
209
+ throw new Error('重新加载后无法获取editor对象')
210
+ }
211
+ } catch (err) {
212
+ console.error('重新加载iframe后清空体温单出错:', err)
213
+ message.error(`清空体温单失败: ${err.message || '未知错误'}`)
214
+ } finally {
215
+ loading.value = false
216
+ generating.value = false
217
+ // 移除临时onload处理器
218
+ iframe.onload = null
219
+ }
220
+ }
221
+ // 重新加载iframe
222
+ iframe.src = currentSrc + '?t=' + new Date().getTime()
223
+ return
224
+ }
225
+ } catch (reloadErr) {
226
+ console.warn('重新加载iframe失败,将尝试其他方法清空体温单:', reloadErr)
227
+ }
228
+ // 备用清空方法
229
+ try {
230
+ const iframe = editorComponent.value.$refs.editorIframe
231
+ if (iframe?.contentWindow) {
232
+ iframe.contentWindow.eval(`
233
+ try {
234
+ // 尝试使用编辑器提供的各种可能的清空方法
235
+ if (editor) {
236
+ if (typeof editor.loadUrl === 'function') {
237
+ editor.loadUrl('');
238
+ } else if (typeof editor.resetDocument === 'function') {
239
+ editor.resetDocument();
240
+ } else if (typeof editor.clearContent === 'function') {
241
+ editor.clearContent();
242
+ } else if (typeof editor.clear === 'function') {
243
+ editor.clear();
244
+ } else if (typeof editor.setEditorContent === 'function') {
245
+ editor.setEditorContent('');
246
+ } else if (editor.document) {
247
+ try {
248
+ editor.document.body.innerHTML = '';
249
+ } catch(clearErr) {
250
+ console.warn('清空编辑器内容失败');
251
+ }
252
+ }
253
+ }
254
+ } catch(e) {
255
+ console.error('清空体温单失败:', e);
256
+ }
257
+ `)
258
+ } else if (window.iframeEditor) {
259
+ const editorObj = window.iframeEditor
260
+ if (typeof editorObj.loadUrl === 'function') {
261
+ editorObj.loadUrl('')
262
+ } else if (typeof editorObj.resetDocument === 'function') {
263
+ editorObj.resetDocument()
264
+ } else if (typeof editorObj.clearContent === 'function') {
265
+ editorObj.clearContent()
266
+ } else if (typeof editorObj.clear === 'function') {
267
+ editorObj.clear()
268
+ } else if (typeof editorObj.setEditorContent === 'function') {
269
+ editorObj.setEditorContent('')
270
+ }
271
+ } else if (editor) {
272
+ if (typeof editor.loadUrl === 'function') {
273
+ editor.loadUrl('')
274
+ } else if (typeof editor.resetDocument === 'function') {
275
+ editor.resetDocument()
276
+ } else if (typeof editor.clearContent === 'function') {
277
+ editor.clearContent()
278
+ } else if (typeof editor.clear === 'function') {
279
+ editor.clear()
280
+ } else if (typeof editor.setEditorContent === 'function') {
281
+ editor.setEditorContent('')
282
+ }
283
+ } else {
284
+ throw new Error('无法获取编辑器对象')
285
+ }
286
+ } catch (err) {
287
+ console.error('清空体温单出错:', err)
288
+ message.error(`清空体温单失败: ${err.message || '未知错误'}`)
289
+ }
290
+ } finally {
291
+ loading.value = false
292
+ generating.value = false
293
+ }
294
+ }
295
+
296
+ // 处理表单提交
297
+ async function handleSubmit (formData) {
298
+ console.log('表单数据:', formData)
299
+ if (!editorReady.value || !editor) {
300
+ message.error('体温单编辑器未加载完成,请等待或刷新页面重试')
301
+ return
302
+ }
303
+ loading.value = true
304
+ generating.value = true // 开始生成,显示加载遮罩
305
+ try {
306
+ let result
307
+ try {
308
+ const iframe = editorComponent.value.$refs.editorIframe
309
+ if (iframe?.contentWindow) {
310
+ // 直接传递数据对象,避免使用eval
311
+ if (iframe.contentWindow.editor && typeof iframe.contentWindow.editor.createVitalSigns === 'function') {
312
+ result = iframe.contentWindow.editor.createVitalSigns(formData)
313
+ } else {
314
+ throw new Error('编辑器对象无效')
315
+ }
316
+ } else if (window.iframeEditor) {
317
+ result = window.iframeEditor.createVitalSigns(formData)
318
+ } else {
319
+ throw new Error('无法访问iframe')
320
+ }
321
+ } catch (err) {
322
+ // 备用方案
323
+ if (editor && typeof editor.createVitalSigns === 'function') {
324
+ editor.createVitalSigns(formData)
325
+ } else {
326
+ throw new Error('无法调用createVitalSigns方法')
327
+ }
328
+ }
329
+
330
+ vitalSignsId.value = result || formData.id
331
+ modalVisible.value = false
332
+ message.success(`${modalTitles[modalType.value]}成功`)
333
+ emit('submit', formData)
334
+ } catch (err) {
335
+ console.error('创建体温单出错:', err)
336
+ message.error(`创建体温单失败: ${err.message || '未知错误'}`)
337
+ } finally {
338
+ loading.value = false
339
+ generating.value = false // 无论成功失败,都结束加载遮罩
340
+ }
341
+ }
342
+
343
+ // 处理表单数据
344
+ function mergeAndTransformData (records, patientInfo, id, date, operateDate) {
345
+ // 提取records中的数据
346
+ const temperatureList = records.map(record => record.temperature).join(',')
347
+ const sphygmusList = records.map(record => record.sphygmus).join(',')
348
+ const breathList = records.map(record => record.breath).join(',')
349
+ const heartList = records.map(record => record.heart).join(',')
350
+ const notesList = records.map(record => record.notes).join(',')
351
+ const painList = records.map(record => record.pain).join(',')
352
+ const data1List = records.map(record => {
353
+ const [systolic, diastolic] = record.data1.split('|')
354
+ return `${systolic}/${diastolic}`
355
+ }).join(',')
356
+ const data2List = records.map(record => record.data2).join(',')
357
+ const data3List = records.map(record => record.data3).join(',')
358
+ const data4List = records.map(record => record.data4).join(',')
359
+ const data5List = records.map(record => record.data5).join(',')
360
+ const data6List = records.map(record => record.data6).join(',')
361
+ const data7List = records.map(record => record.data7).join(',')
362
+ const tempTypeList = records.map(record => record.temptype).join(',')
363
+
364
+ // 提取patientInfo中的数据
365
+ const name = patientInfo.name || ''
366
+ const dept = patientInfo.dept || ''
367
+ const bed = patientInfo.bed || ''
368
+ const inDate = patientInfo.indate || ''
369
+ const diag = patientInfo.diag || ''
370
+
371
+ // 生成合并后的对象
372
+ const mergedData = {
373
+ bed: bed.toString(),
374
+ sphygmus: sphygmusList,
375
+ notes: notesList,
376
+ medicalNo: id, // 示例中的固定值
377
+ diag: diag,
378
+ type: 'normal', // 示例中的固定值
379
+ breath: breathList,
380
+ temperature: temperatureList,
381
+ id: id, // 示例中的固定值
382
+ tempType: tempTypeList,
383
+ data7: data7List,
384
+ pain: painList,
385
+ data6: data6List,
386
+ data5: data5List,
387
+ data4: data4List,
388
+ data3: data3List,
389
+ data2: data2List,
390
+ inDate: inDate.split(' ')[0], // 只取日期部分
391
+ data1: data1List,
392
+ dept: dept,
393
+ heart: heartList,
394
+ labels: '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)|身高(cm)|体重(kg)', // 示例中的固定值
395
+ name: name,
396
+ begin: date, // 只取日期部分
397
+ operateDate: operateDate // 只取日期部分
398
+ }
399
+ return mergedData
400
+ }
401
+ // 设置病历号的方法
402
+ function setMedicalRecordId (id) {
403
+ vitalSignsId.value = id
404
+ // console.log('病历号已设置为:', vitalSignsId.value)
405
+ }
406
+ // 生命周期钩子
407
+ onMounted(() => {
408
+ window.addEventListener('message', (event) => {
409
+ if (event.data?.type === 'editorReady' && !editorReady.value && editorComponent.value?.getEditor) {
410
+ try {
411
+ const editorFromComponent = editorComponent.value.getEditor()
412
+ if (editorFromComponent && typeof editorFromComponent.createVitalSigns === 'function') {
413
+ editor = editorFromComponent
414
+ editorReady.value = true
415
+ }
416
+ } catch (err) {
417
+ console.error('从组件获取editor对象错误:', err)
418
+ }
419
+ }
420
+ })
421
+ })
422
+
423
+ // 暴露方法和属性给父组件,使父组件可以通过ref访问
424
+ defineExpose({
425
+ // 属性
426
+ vitalSignsId,
427
+ // 清空体温单方法
428
+ clearVitalSigns,
429
+ // 展示更新和创建弹框 创建参数:(String) create, 更新参数:(String) update
430
+ showVitalSignsModal,
431
+ // 触发打印函数 参数:(String) print
432
+ execCommand,
433
+ // 获取当前体温单ID的方法
434
+ getVitalSignsId: () => vitalSignsId.value,
435
+ // 设置体温单ID的方法
436
+ setVitalSignsId: (id) => {
437
+ vitalSignsId.value = id
438
+ },
439
+ // 创建体温单 参数:(Object) data
440
+ handleSubmit,
441
+ // 设置病历号
442
+ setMedicalRecordId,
443
+ // 获取表单数据
444
+ mergeAndTransformData
445
+ })
446
+ </script>
447
+
448
+ <style scoped>
449
+ .box {
450
+ display: flex;
451
+ align-items: center;
452
+ padding: 1%;
453
+ }
454
+
455
+ /* 体温单生成加载遮罩样式 */
456
+ .generating-mask {
457
+ position: fixed;
458
+ top: 0;
459
+ left: 0;
460
+ right: 0;
461
+ bottom: 0;
462
+ background-color: rgba(0, 0, 0, 0.5);
463
+ display: flex;
464
+ justify-content: center;
465
+ align-items: center;
466
+ z-index: 9999;
467
+ }
468
+
469
+ .generating-content {
470
+ background-color: white;
471
+ padding: 20px 40px;
472
+ border-radius: 4px;
473
+ text-align: center;
474
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
475
+ }
476
+
477
+ .generating-text {
478
+ margin-top: 16px;
479
+ color: rgba(0, 0, 0, 0.85);
480
+ font-size: 16px;
481
+ }
482
+ </style>