vue2-client 1.15.87 → 1.15.88

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (377) hide show
  1. package/.editorconfig +9 -9
  2. package/.env +20 -20
  3. package/.env.development +1 -1
  4. package/.env.iot +19 -19
  5. package/.env.message +19 -19
  6. package/.env.revenue +19 -19
  7. package/.env.runtime +19 -19
  8. package/.eslintrc.json +5 -5
  9. package/CLAUDE.md +89 -89
  10. package/README.md +65 -65
  11. package/babel.config.js +21 -21
  12. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +46 -46
  13. package/docs/notice.md +22 -22
  14. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +179 -179
  15. package/jest.config.js +22 -22
  16. package/package.json +111 -111
  17. package/src/App.vue +196 -196
  18. package/src/ReportView.js +13 -13
  19. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +532 -532
  20. package/src/base-client/components/common/AddressSearchCombobox/index.js +3 -3
  21. package/src/base-client/components/common/AmapMarker/index.js +3 -3
  22. package/src/base-client/components/common/CitySelect/CitySelect.vue +376 -376
  23. package/src/base-client/components/common/CitySelect/demo.vue +43 -43
  24. package/src/base-client/components/common/ColorPickerCombobox/ColorPickerCombobox.vue +99 -99
  25. package/src/base-client/components/common/ColorPickerCombobox/demo.vue +34 -34
  26. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +146 -146
  27. package/src/base-client/components/common/JSONToTree/index.js +3 -3
  28. package/src/base-client/components/common/Upload/Upload.vue +323 -323
  29. package/src/base-client/components/common/XAddForm/index.js +3 -3
  30. package/src/base-client/components/common/XAddForm/index.md +61 -61
  31. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +1169 -1169
  32. package/src/base-client/components/common/XAddNativeForm/demo.vue +54 -54
  33. package/src/base-client/components/common/XAddNativeForm/index.js +3 -3
  34. package/src/base-client/components/common/XAddReport/XAddReport.vue +212 -212
  35. package/src/base-client/components/common/XBadge/index.js +3 -3
  36. package/src/base-client/components/common/XBadge/index.md +39 -39
  37. package/src/base-client/components/common/XButtons/XButtons.vue +284 -284
  38. package/src/base-client/components/common/XCalendar/XCalendar.vue +369 -369
  39. package/src/base-client/components/common/XCalendar/index.md +284 -284
  40. package/src/base-client/components/common/XCard/index.js +3 -3
  41. package/src/base-client/components/common/XCard/index.md +43 -43
  42. package/src/base-client/components/common/XCardSet/XCardSet.vue +300 -300
  43. package/src/base-client/components/common/XCollapse/XCollapse.vue +354 -354
  44. package/src/base-client/components/common/XConversation/XConversation.vue +576 -576
  45. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  46. package/src/base-client/components/common/XDataCard/XDataCard.vue +629 -629
  47. package/src/base-client/components/common/XDatePicker/index.vue +276 -276
  48. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +174 -174
  49. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +314 -314
  50. package/src/base-client/components/common/XDescriptions/demo.vue +51 -51
  51. package/src/base-client/components/common/XForm/XForm.vue +420 -420
  52. package/src/base-client/components/common/XForm/XFormItem.vue +1474 -1474
  53. package/src/base-client/components/common/XForm/XTreeSelect.vue +276 -276
  54. package/src/base-client/components/common/XForm/demo.vue +105 -105
  55. package/src/base-client/components/common/XForm/index.js +3 -3
  56. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -157
  57. package/src/base-client/components/common/XFormCol/index.js +3 -3
  58. package/src/base-client/components/common/XFormCol/index.md +35 -35
  59. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +301 -301
  60. package/src/base-client/components/common/XFormGroup/demo.vue +41 -41
  61. package/src/base-client/components/common/XFormTable/XFormTable.vue +938 -938
  62. package/src/base-client/components/common/XFormTable/demo.vue +87 -87
  63. package/src/base-client/components/common/XFormTable/index.js +3 -3
  64. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +174 -174
  65. package/src/base-client/components/common/XImportExcel/index.js +3 -3
  66. package/src/base-client/components/common/XImportExcel/index.md +38 -38
  67. package/src/base-client/components/common/XInput/XInput.vue +128 -128
  68. package/src/base-client/components/common/XInput/index.js +3 -3
  69. package/src/base-client/components/common/XInput/index.md +97 -97
  70. package/src/base-client/components/common/XIntervalPicker/XIntervalPicker.vue +121 -121
  71. package/src/base-client/components/common/XLicensePlate/index.js +3 -3
  72. package/src/base-client/components/common/XLicensePlate/index.md +38 -38
  73. package/src/base-client/components/common/XPrint/Demo.vue +41 -41
  74. package/src/base-client/components/common/XPrint/PrintBill.vue +308 -308
  75. package/src/base-client/components/common/XRate/demo.vue +102 -102
  76. package/src/base-client/components/common/XRate/index.vue +149 -149
  77. package/src/base-client/components/common/XReport/XReport.vue +963 -963
  78. package/src/base-client/components/common/XReport/XReportDemo.vue +70 -70
  79. package/src/base-client/components/common/XReport/XReportTrGroup.vue +1005 -1005
  80. package/src/base-client/components/common/XReport/index.md +103 -103
  81. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  82. package/src/base-client/components/common/XReportGrid/XReport.vue +1075 -1075
  83. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +44 -44
  84. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +620 -620
  85. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +723 -723
  86. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  87. package/src/base-client/components/common/XTab/XTab.vue +299 -299
  88. package/src/base-client/components/common/XTable/ExportExcel.vue +283 -283
  89. package/src/base-client/components/common/XTable/XTable.vue +1599 -1599
  90. package/src/base-client/components/common/XTable/XTableWrapper.vue +597 -597
  91. package/src/base-client/components/common/XTable/index.js +3 -3
  92. package/src/base-client/components/common/XTimeline/XTimeline.vue +358 -358
  93. package/src/base-client/components/common/XTimeline/index.md +191 -191
  94. package/src/base-client/components/common/XTree/XTreePro.vue +452 -450
  95. package/src/base-client/components/common/XTreeOne/index.js +3 -3
  96. package/src/base-client/components/common/XUploadFilesView/index.vue +485 -485
  97. package/src/base-client/components/his/XCharge/XCharge.vue +238 -238
  98. package/src/base-client/components/his/XCheckbox/XCheckbox.vue +105 -105
  99. package/src/base-client/components/his/XCheckbox/index.md +253 -253
  100. package/src/base-client/components/his/XHDescriptions/XHDescriptions.vue +430 -430
  101. package/src/base-client/components/his/XHDescriptions/index.md +217 -217
  102. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +629 -629
  103. package/src/base-client/components/his/XHisEditor/diagnosisAutocomplete.js +263 -263
  104. package/src/base-client/components/his/XList/XList.vue +495 -495
  105. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.json +3 -3
  106. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.vue +106 -106
  107. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireDemo.vue +51 -51
  108. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireItem.vue +269 -269
  109. package/src/base-client/components/his/XRadio/XRadio.vue +125 -125
  110. package/src/base-client/components/his/XRadio/index.md +234 -234
  111. package/src/base-client/components/his/XSelect/XSelect.vue +72 -72
  112. package/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +234 -234
  113. package/src/base-client/components/his/XShiftSchedule/dome.vue +29 -29
  114. package/src/base-client/components/his/XSidebar/XSidebar.vue +240 -240
  115. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  116. package/src/base-client/components/his/XTimeSelect/XTimeSelect.vue +162 -162
  117. package/src/base-client/components/his/XTimeSelect/XTimeSelectDemo.vue +23 -23
  118. package/src/base-client/components/his/XTitle/README.md +113 -113
  119. package/src/base-client/components/his/XTitle/XTitle.vue +123 -123
  120. package/src/base-client/components/his/XTreeRows/TreeNode.vue +107 -107
  121. package/src/base-client/components/his/XTreeRows/XTreeRows.vue +307 -307
  122. package/src/base-client/components/his/threeTestOrders/dome.vue +68 -68
  123. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  124. package/src/base-client/components/his/threeTestOrders/textBox.vue +457 -457
  125. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +475 -475
  126. package/src/base-client/components/layout/XPageView/RenderRow.vue +88 -88
  127. package/src/base-client/components/layout/XPageView/XErrorView.vue +22 -22
  128. package/src/base-client/components/layout/XPageView/XPageRowTemplate.vue +37 -37
  129. package/src/base-client/components/layout/XPageView/XPageView.vue +223 -223
  130. package/src/base-client/components/layout/XPageView/XTab/XTab.vue +96 -96
  131. package/src/base-client/components/layout/XPageView/XTab/index.js +3 -3
  132. package/src/base-client/components/layout/XPageView/componentTypes.js +22 -22
  133. package/src/base-client/components/layout/XPageView/index.js +2 -2
  134. package/src/base-client/components/layout/XPageView/index.md +96 -96
  135. package/src/base-client/components/system/DictionaryDetailsView/index.js +3 -3
  136. package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -41
  137. package/src/base-client/components/system/LogDetailsView/LogDetailsView.vue +376 -376
  138. package/src/base-client/components/system/LogDetailsView/index.js +3 -3
  139. package/src/base-client/components/system/LogDetailsView/index.md +41 -41
  140. package/src/base-client/components/system/QueryParamsDetailsView/index.js +3 -3
  141. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  142. package/src/base-client/components/ticket/TicketDetailsView/index.js +3 -3
  143. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  144. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  145. package/src/base-client/components/ticket/TicketDetailsView/part/index.js +3 -3
  146. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  147. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.js +3 -3
  148. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  149. package/src/base-client/plugins/AppData.js +126 -126
  150. package/src/base-client/plugins/PagedList.js +177 -177
  151. package/src/base-client/plugins/__tests__/selectValueTypeHelper.test.js +154 -154
  152. package/src/base-client/plugins/authority-plugin.js +167 -167
  153. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  154. package/src/base-client/plugins/i18n-extend.js +32 -32
  155. package/src/base-client/plugins/moment.js +8 -8
  156. package/src/base-client/plugins/selectValueTypeHelper.js +281 -281
  157. package/src/bootstrap.js +51 -51
  158. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  159. package/src/components/Ellipsis/index.js +3 -3
  160. package/src/components/Ellipsis/index.md +38 -38
  161. package/src/components/FileImageItem/FileItem.vue +320 -320
  162. package/src/components/FileImageItem/FileItemGroup.vue +197 -197
  163. package/src/components/FileImageItem/ImageItem.vue +107 -107
  164. package/src/components/FileImageItem/index.js +4 -4
  165. package/src/components/FilePreview/FilePreview.vue +181 -181
  166. package/src/components/FilePreview/FilePreviewDemo.vue +30 -30
  167. package/src/components/FilePreview/index.js +3 -3
  168. package/src/components/HeightScanner/index.vue +615 -615
  169. package/src/components/STable/README.md +341 -341
  170. package/src/components/STable/index.js +558 -558
  171. package/src/components/TableSetting/TableSetting.vue +143 -143
  172. package/src/components/TableSetting/index.js +3 -3
  173. package/src/components/Trend/Trend.vue +41 -41
  174. package/src/components/Trend/index.js +3 -3
  175. package/src/components/Trend/index.less +41 -41
  176. package/src/components/Trend/index.md +45 -45
  177. package/src/components/_util/util.js +46 -46
  178. package/src/components/cache/AKeepAlive.js +179 -179
  179. package/src/components/exception/typeConfig.js +19 -19
  180. package/src/components/form/FormRow.vue +52 -52
  181. package/src/components/index.less +5 -5
  182. package/src/components/menu/Contextmenu.vue +84 -84
  183. package/src/components/menu/index.less +38 -38
  184. package/src/components/page/header/PageHeader.vue +64 -64
  185. package/src/components/page/header/index.less +40 -40
  186. package/src/components/result/Result.vue +77 -77
  187. package/src/components/setting/SettingItem.vue +26 -26
  188. package/src/components/setting/i18n.js +117 -117
  189. package/src/components/table/StandardTable.vue +141 -141
  190. package/src/components/table/advance/ActionColumns.vue +158 -158
  191. package/src/components/table/advance/ActionSize.vue +45 -45
  192. package/src/components/table/advance/AdvanceTable.vue +275 -275
  193. package/src/components/table/advance/SearchArea.vue +355 -355
  194. package/src/components/table/advance/index.js +2 -2
  195. package/src/components/table/api/ApiTable.vue +50 -50
  196. package/src/components/task/TaskGroup.vue +80 -80
  197. package/src/components/task/TaskItem.vue +26 -26
  198. package/src/components/tool/AvatarList.vue +68 -68
  199. package/src/components/tool/DetailList.vue +157 -157
  200. package/src/components/tool/Drawer.vue +142 -142
  201. package/src/components/tool/FooterToolBar.vue +30 -30
  202. package/src/components/tool/HeadInfo.vue +35 -35
  203. package/src/components/tool/TagSelect.vue +83 -83
  204. package/src/components/tool/TagSelectOption.vue +33 -33
  205. package/src/components/transition/PageToggleTransition.vue +97 -97
  206. package/src/config/default/admin.config.js +18 -18
  207. package/src/config/default/animate.config.js +21 -21
  208. package/src/config/default/index.js +6 -6
  209. package/src/config/index.js +3 -3
  210. package/src/config/replacer/index.js +10 -10
  211. package/src/config/replacer/resolve.config.js +67 -67
  212. package/src/expression/ExpressionRunner.js +26 -26
  213. package/src/expression/TestExpression.js +509 -509
  214. package/src/expression/core/Delegate.js +115 -115
  215. package/src/expression/core/Expression.js +1358 -1358
  216. package/src/expression/core/Program.js +932 -932
  217. package/src/expression/core/Token.js +27 -27
  218. package/src/expression/enums/ExpressionType.js +81 -81
  219. package/src/expression/enums/TokenType.js +11 -11
  220. package/src/expression/exception/BreakWayException.js +2 -2
  221. package/src/expression/exception/ContinueWayException.js +2 -2
  222. package/src/expression/exception/ExpressionException.js +28 -28
  223. package/src/expression/exception/ReturnWayException.js +14 -14
  224. package/src/expression/exception/ServiceException.js +22 -22
  225. package/src/expression/instances/LogicConsole.js +44 -44
  226. package/src/expression/ts/ExpressionRunner.ts +28 -28
  227. package/src/expression/ts/TestExpression.ts +509 -509
  228. package/src/expression/ts/core/Delegate.ts +114 -114
  229. package/src/expression/ts/core/Expression.ts +1309 -1309
  230. package/src/expression/ts/core/Program.ts +950 -950
  231. package/src/expression/ts/core/Token.ts +29 -29
  232. package/src/expression/ts/enums/ExpressionType.ts +81 -81
  233. package/src/expression/ts/enums/TokenType.ts +13 -13
  234. package/src/expression/ts/exception/BreakWayException.ts +2 -2
  235. package/src/expression/ts/exception/ContinueWayException.ts +2 -2
  236. package/src/expression/ts/exception/ExpressionException.ts +28 -28
  237. package/src/expression/ts/exception/ReturnWayException.ts +14 -14
  238. package/src/expression/ts/exception/ServiceException.ts +22 -22
  239. package/src/expression/ts/instances/JSONArray.ts +48 -48
  240. package/src/expression/ts/instances/JSONObject.ts +109 -109
  241. package/src/expression/ts/instances/LogicConsole.ts +32 -32
  242. package/src/layouts/AdminLayout.vue +176 -176
  243. package/src/layouts/BlankView.vue +79 -79
  244. package/src/layouts/ComponentLayoutOne.vue +47 -47
  245. package/src/layouts/GridView.vue +43 -43
  246. package/src/layouts/PageView.vue +55 -55
  247. package/src/layouts/footer/PageFooter.vue +49 -49
  248. package/src/layouts/header/HeaderAvatar.vue +64 -64
  249. package/src/layouts/header/HeaderSearch.vue +67 -67
  250. package/src/layouts/header/index.less +92 -92
  251. package/src/layouts/tabs/TabsView.vue +383 -383
  252. package/src/layouts/tabs/i18n.js +25 -25
  253. package/src/layouts/tabs/index.js +2 -2
  254. package/src/logic/LogicRunner.js +62 -62
  255. package/src/logic/TestLogic.js +13 -13
  256. package/src/logic/plugins/common/DateTools.js +35 -35
  257. package/src/logic/plugins/common/VueTools.js +30 -30
  258. package/src/logic/plugins/index.js +7 -7
  259. package/src/logic/ts/LogicRunner.ts +67 -67
  260. package/src/logic/ts/TestLogic.ts +13 -13
  261. package/src/main.js +33 -33
  262. package/src/mixins/formValidationMixin.js +46 -46
  263. package/src/mock/common/activityData.js +32 -32
  264. package/src/mock/common/index.js +89 -89
  265. package/src/mock/common/reportData.js +20 -20
  266. package/src/mock/common/tableData.js +118 -118
  267. package/src/mock/index.js +12 -12
  268. package/src/mock/project/index.js +17 -17
  269. package/src/mock/user/current.js +13 -13
  270. package/src/mock/user/login.js +39 -39
  271. package/src/mock/user/routes.js +61 -61
  272. package/src/mock/workplace/index.js +15 -15
  273. package/src/pages/LogicCallExample/index.vue +46 -46
  274. package/src/pages/ReportGrid/index.vue +76 -76
  275. package/src/pages/ReportView.vue +50 -50
  276. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +47 -47
  277. package/src/pages/WorkflowDetail/WorkFlowDemo2.vue +204 -204
  278. package/src/pages/WorkflowDetail/WorkFlowDemo3.vue +203 -203
  279. package/src/pages/WorkflowDetail/WorkflowDetail.vue +391 -391
  280. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +388 -388
  281. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +415 -415
  282. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +1766 -1766
  283. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +975 -975
  284. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowPreview.vue +109 -109
  285. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +929 -929
  286. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +222 -222
  287. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +243 -243
  288. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +188 -188
  289. package/src/pages/WorkflowDetail/WorkflowPageDetail/components/WorkflowPersonSelector.vue +109 -109
  290. package/src/pages/WorkflowDetail/WorkflowPageDetail/worklog.vue +97 -97
  291. package/src/pages/XPageViewExample/index.vue +149 -149
  292. package/src/pages/addressSelect/addressDemo.vue +24 -24
  293. package/src/pages/addressSelect/index.vue +270 -270
  294. package/src/pages/dashboard/workplace/i18n.js +40 -40
  295. package/src/pages/dashboard/workplace/index.js +2 -2
  296. package/src/pages/dashboard/workplace/index.less +59 -59
  297. package/src/pages/exception/403.vue +21 -21
  298. package/src/pages/exception/404.vue +24 -24
  299. package/src/pages/exception/500.vue +21 -21
  300. package/src/pages/login/index.js +2 -2
  301. package/src/pages/report/ReportTableHome.vue +28 -28
  302. package/src/pages/resourceManage/depListManage.vue +23 -23
  303. package/src/pages/resourceManage/funListManage.vue +23 -23
  304. package/src/pages/resourceManage/index.js +15 -15
  305. package/src/pages/resourceManage/resourceManageMain.vue +57 -57
  306. package/src/pages/resourceManage/roleListManage.vue +23 -23
  307. package/src/pages/resourceManage/staffListManage.vue +23 -23
  308. package/src/pages/system/file/Info.vue +56 -56
  309. package/src/pages/system/file/index.vue +317 -317
  310. package/src/pages/system/settings/index.vue +126 -126
  311. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +77 -77
  312. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +75 -75
  313. package/src/pages/userInfoDetailManage/InsuranceDetailQuery/index.vue +64 -64
  314. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +75 -75
  315. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +75 -75
  316. package/src/pages/userInfoDetailManage/PriceAdjustments/index.vue +64 -64
  317. package/src/pages/userInfoDetailManage/UserChargeRecordQuery/index.vue +94 -94
  318. package/src/pages/userInfoDetailManage/UserException/index.vue +64 -64
  319. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +87 -87
  320. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +74 -74
  321. package/src/pages/userInfoDetailManage/index.vue +290 -290
  322. package/src/pages/userInfoDetailManage/uploadFilesHistory/ImagePreview.vue +101 -101
  323. package/src/pages/userInfoDetailManage/uploadFilesHistory/index.vue +129 -129
  324. package/src/pages/userInfoDetailManage/userInfoDetailQueryTabs.vue +144 -144
  325. package/src/plugins/HiPrintPlugin.js +164 -164
  326. package/src/router/async/router.map.js +126 -126
  327. package/src/router/guards.js +262 -262
  328. package/src/router/i18n.js +57 -57
  329. package/src/router.js +17 -17
  330. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  331. package/src/services/api/LogDetailsViewApi.js +10 -10
  332. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  333. package/src/services/api/logininfor/index.js +6 -6
  334. package/src/services/api/manage.js +8 -8
  335. package/src/services/api/restTools.js +215 -215
  336. package/src/services/api/workFlow.js +57 -57
  337. package/src/services/apiService.js +16 -16
  338. package/src/services/dataSource.js +12 -12
  339. package/src/services/index.js +7 -7
  340. package/src/services/user.js +92 -92
  341. package/src/services/v3Api.js +116 -116
  342. package/src/store/index.js +5 -5
  343. package/src/store/mutation-types.js +4 -4
  344. package/src/theme/antd/ant-menu.less +2 -2
  345. package/src/theme/antd/ant-message.less +3 -3
  346. package/src/theme/antd/ant-table.less +22 -22
  347. package/src/theme/antd/ant-time-picker.less +3 -3
  348. package/src/theme/antd/index.less +3 -3
  349. package/src/theme/default/color.less +43 -43
  350. package/src/theme/default/index.less +3 -3
  351. package/src/theme/default/nprogress.less +76 -76
  352. package/src/theme/global.less +279 -279
  353. package/src/theme/index.less +5 -5
  354. package/src/theme/reportTable.less +58 -58
  355. package/src/theme/theme.less +1 -1
  356. package/src/utils/EncryptUtil.js +162 -162
  357. package/src/utils/Objects.js +25 -25
  358. package/src/utils/axios-interceptors.js +100 -100
  359. package/src/utils/colors.js +107 -107
  360. package/src/utils/common.js +10 -10
  361. package/src/utils/excel/Blob.js +180 -180
  362. package/src/utils/excel/Export2Excel.js +141 -141
  363. package/src/utils/filter.js +21 -21
  364. package/src/utils/i18n.js +80 -80
  365. package/src/utils/indexedDB.js +549 -549
  366. package/src/utils/microAppUtils.js +49 -49
  367. package/src/utils/request.js +395 -395
  368. package/src/utils/routerUtil.js +553 -553
  369. package/src/utils/themeUtil.js +100 -100
  370. package/test/Tree.spec.js +168 -168
  371. package/test/myDialog.spec.js +47 -47
  372. package/test/request.test.js +17 -17
  373. package/test/util.test.js +53 -53
  374. package/test/v3Api.test.js +1984 -1984
  375. package/tests/unit/ReportTable.spec.js +16 -16
  376. package/vue.config.js +222 -222
  377. package/.claude/settings.local.json +0 -12
@@ -1,430 +1,430 @@
1
- <template>
2
- <div class="patient-info-descriptions">
3
- <div class="descriptions-container">
4
- <!-- 详情/收起按钮 -->
5
- <div v-if="hasMoreItems" class="detail-button-wrapper">
6
- <a-button
7
- :type="config?.detailsConfig?.buttonType || 'link'"
8
- @click="toggleDetails"
9
- >
10
- <a-icon :type="showAllItems ? 'up' : 'down'" />
11
- {{ showAllItems ? '收起' : (config?.detailsConfig?.buttonText || '详情') }}
12
- </a-button>
13
- </div>
14
-
15
- <!-- 当有 layout 配置时使用 a-descriptions -->
16
- <template v-if="config?.layout">
17
- <a-descriptions
18
- :column="config.layout"
19
- :size="config?.style?.size"
20
- :bordered="config?.style?.bordered"
21
- layout="horizontal">
22
- <template v-if="data">
23
- <!-- 显示前N个标签 -->
24
- <a-descriptions-item
25
- v-for="(item) in visibleItems"
26
- :key="item.field"
27
- :colon="item.colon !== false"
28
- :class="{ 'with-divider': item.isLine }"
29
- v-if="data[item.field] !== null && data[item.field] !== undefined && (!showAllItems || showAllItems && !hiddenItems.some(i => i.field === item.field))">
30
- <template #label>
31
- <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
32
- <a-avatar
33
- v-if="item.showAvatar"
34
- :size="item.avatar.size"
35
- :icon="item.avatar.icon"
36
- :style="{ background: item.avatar.background }"
37
- />
38
- <span class="label-text">{{ item.label }}</span>
39
- </div>
40
- </template>
41
- <div class="content-wrapper">
42
- {{ data[item.field] }}
43
- </div>
44
- </a-descriptions-item>
45
-
46
- <!-- 展开后显示剩余标签 -->
47
- <template v-if="showAllItems">
48
- <a-descriptions-item
49
- v-for="item in hiddenItems"
50
- :key="item.field"
51
- :colon="item.colon !== false"
52
- v-if="data[item.field] !== null && data[item.field] !== undefined">
53
- <template #label>
54
- <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
55
- <a-avatar
56
- v-if="item.showAvatar"
57
- :size="item.avatar.size"
58
- :icon="item.avatar.icon"
59
- :style="{ background: item.avatar.background }"
60
- />
61
- <span class="label-text">{{ item.label }}</span>
62
- </div>
63
- </template>
64
- <div class="content-wrapper">
65
- {{ data[item.field] }}
66
- </div>
67
- </a-descriptions-item>
68
- </template>
69
- </template>
70
- </a-descriptions>
71
- </template>
72
-
73
- <!-- 当没有 layout 配置时使用自适应布局 -->
74
- <template v-else>
75
- <div class="flex-descriptions">
76
- <template v-if="data">
77
- <!-- 显示可见的标签 -->
78
- <div
79
- v-for="(item) in visibleItems"
80
- :key="item.field"
81
- :class="['description-item', { 'with-divider': item.isLine }]"
82
- v-if="data[item.field] !== null && data[item.field] !== undefined"
83
- >
84
- <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
85
- <a-avatar
86
- v-if="item.showAvatar"
87
- :size="item.avatar.size"
88
- :icon="item.avatar.icon"
89
- :style="{ background: item.avatar.background }"
90
- />
91
- <span class="label-text">{{ item.label }}:</span>
92
- </div>
93
- <div class="content-wrapper">
94
- {{ data[item.field] }}
95
- </div>
96
- </div>
97
-
98
- <!-- 展开后显示的内容 -->
99
- <template v-if="showAllItems">
100
- <div
101
- v-for="item in hiddenItems"
102
- :key="item.field"
103
- class="description-item"
104
- v-if="data[item.field] !== null && data[item.field] !== undefined"
105
- >
106
- <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
107
- <a-avatar
108
- v-if="item.showAvatar"
109
- :size="item.avatar.size"
110
- :icon="item.avatar.icon"
111
- :style="{ background: item.avatar.background }"
112
- />
113
- <span class="label-text">{{ item.label }}:</span>
114
- </div>
115
- <div class="content-wrapper">
116
- {{ data[item.field] }}
117
- </div>
118
- </div>
119
- </template>
120
- </template>
121
- </div>
122
- </template>
123
- </div>
124
- </div>
125
- </template>
126
-
127
- <script>
128
- import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
129
-
130
- export default {
131
- name: 'XHDescriptions',
132
- data () {
133
- return {
134
- // 隐藏配置 当数据结果 = -1^ 该数据字段会被delete
135
- hiddenConfig: '-1^',
136
- data: null,
137
- config: null,
138
- showAllItems: false // 控制是否显示所有标签
139
- }
140
- },
141
- props: {
142
- queryParamsName: {
143
- type: String,
144
- default: ''
145
- },
146
- parameter: {
147
- type: Object,
148
- default: () => {
149
- return {}
150
- }
151
- }
152
- },
153
- computed: {
154
- // 获取详情按钮应该显示在第几个标签后
155
- detailsAfterIndex () {
156
- return this.config?.detailsConfig?.showAfterIndex || 999
157
- },
158
- // 判断是否有更多标签需要显示
159
- hasMoreItems () {
160
- if (!this.config?.detailsConfig) return false
161
- if (!this.data || !this.config?.items || !Array.isArray(this.config.items)) return false
162
- const hiddenStartIndex = this.detailsAfterIndex || 0
163
- if (hiddenStartIndex >= this.config.items.length) return false
164
- for (let i = hiddenStartIndex; i < this.config.items.length; i++) {
165
- const item = this.config.items[i]
166
- if (item && item.field && this.data[item.field] !== null && this.data[item.field] !== undefined) {
167
- return true
168
- }
169
- }
170
- return false
171
- },
172
- // 获取应该显示的标签
173
- visibleItems () {
174
- if (!this.config?.items) return []
175
- if (!this.config?.detailsConfig) return this.config.items
176
- if (this.showAllItems) return this.config.items.slice(0, this.detailsAfterIndex)
177
- return this.config.items.slice(0, this.detailsAfterIndex)
178
- },
179
- // 获取隐藏的标签(保持原有逻辑)
180
- hiddenItems () {
181
- if (!this.config?.items) return []
182
- if (!this.config?.detailsConfig) return []
183
- return this.config.items.slice(this.detailsAfterIndex)
184
- }
185
- },
186
- created () {
187
- this.getData(this.queryParamsName, {})
188
- },
189
- methods: {
190
- async getData (data, parameterData) {
191
- this.data = null
192
- this.showAllItems = false
193
- getConfigByName(data, 'af-his', res => {
194
- this.config = res
195
- const hiddenConfig = this.config?.hiddenConfig ?? 0 === 1
196
- console.log(this.config)
197
- const parameter = { ...res.parameter, ...this.parameter, ...parameterData }
198
- runLogic(res.logicName, parameter, 'af-his').then(result => {
199
- if (hiddenConfig) {
200
- for (const key in result) {
201
- if (Object.prototype.hasOwnProperty.call(result, key) && result[key] === this.hiddenConfig) {
202
- delete result[key]
203
- }
204
- }
205
- }
206
- this.data = result
207
- })
208
- })
209
- },
210
- toggleDetails () {
211
- this.showAllItems = !this.showAllItems
212
- }
213
- },
214
- watch: {
215
- queryParamsName: {
216
- handler (newValue) {
217
- console.log(newValue)
218
- this.getData(newValue, {})
219
- },
220
- deep: true
221
- },
222
- parameter: {
223
- handler (newValue, oldValue) {
224
- console.log('监听事件触发:', { old: oldValue, new: newValue })
225
- // 当 parameter 变化时重新获取数据
226
- this.getData(this.queryParamsName, {})
227
- },
228
- deep: true // 深度监听对象内部变化
229
- }
230
- }
231
- }
232
- </script>
233
-
234
- <style scoped>
235
- .patient-info-descriptions {
236
- background: #fff;
237
- padding: 12px;
238
- border-radius: 4px;
239
- width: 100%;
240
- }
241
-
242
- .descriptions-container {
243
- position: relative;
244
- width: 100%;
245
- padding-right: 80px; /* 为按钮预留空间 */
246
- }
247
-
248
- /* 自适应布局样式 */
249
- .flex-descriptions {
250
- display: flex;
251
- flex-wrap: wrap;
252
- gap: 8px 24px;
253
- width: 100%;
254
- }
255
-
256
- .description-item {
257
- display: inline-flex;
258
- align-items: center;
259
- padding: 4px 8px;
260
- border-radius: 4px;
261
- transition: background-color 0.3s;
262
- white-space: nowrap;
263
- flex: 0 1 auto;
264
- }
265
-
266
- .description-item:hover {
267
- background-color: rgba(0, 0, 0, 0.02);
268
- }
269
-
270
- /* 共用样式 */
271
- .label-wrapper {
272
- display: flex;
273
- align-items: center;
274
- gap: 8px;
275
- color: rgba(0, 0, 0, 0.65);
276
- font-size: v-bind('config?.style?.fontSize');
277
- white-space: nowrap;
278
- }
279
-
280
- .label-wrapper.with-avatar {
281
- gap: 8px;
282
- }
283
-
284
- .label-text {
285
- white-space: nowrap;
286
- }
287
-
288
- .content-wrapper {
289
- display: inline-flex;
290
- align-items: center;
291
- margin-left: 4px;
292
- font-size: v-bind('config?.style?.fontSize');
293
- color: rgba(0, 0, 0, 0.85);
294
- max-width: 300px;
295
- overflow: hidden;
296
- text-overflow: ellipsis;
297
- white-space: nowrap;
298
- }
299
-
300
- .detail-button-wrapper {
301
- position: absolute;
302
- right: 0;
303
- top: 0;
304
- z-index: 10;
305
- padding: 4px 8px;
306
- white-space: nowrap;
307
- background-color: #fff;
308
- }
309
-
310
- /* Ant Design 描述列表样式覆盖 */
311
- :deep(.ant-descriptions-row) {
312
- display: flex;
313
- flex-direction: row;
314
- align-items: flex-start;
315
- }
316
-
317
- :deep(.ant-descriptions-item) {
318
- padding: 0 !important;
319
- display: flex !important;
320
- align-items: flex-start !important;
321
- flex-direction: row !important;
322
- margin-right: 24px;
323
- width: fit-content !important;
324
- margin-bottom: 16px;
325
- }
326
-
327
- :deep(.ant-descriptions-item-container) {
328
- display: flex !important;
329
- flex-direction: row !important;
330
- align-items: flex-start !important;
331
- position: relative;
332
- gap: 0 !important;
333
- width: 100% !important;
334
- }
335
-
336
- :deep(.ant-descriptions-item-label) {
337
- color: rgba(0, 0, 0, 0.65);
338
- padding: 0 !important;
339
- margin: 0 !important;
340
- font-size: v-bind('config?.style?.fontSize || "14px"');
341
- display: inline-flex !important;
342
- align-items: center !important;
343
- white-space: nowrap !important;
344
- min-width: v-bind('config?.style?.labelWidth || "80px"');
345
- justify-content: flex-start;
346
- padding-right: 2px !important;
347
- }
348
-
349
- :deep(.ant-descriptions-item-content) {
350
- font-size: v-bind('config?.style?.fontSize || "14px"');
351
- display: inline-flex !important;
352
- align-items: center !important;
353
- padding: 0 !important;
354
- margin: 0 !important;
355
- margin-left: 0px !important;
356
- }
357
-
358
- :deep(.ant-descriptions-item-colon) {
359
- position: static !important;
360
- display: inline-flex !important;
361
- align-items: center !important;
362
- margin: 0 !important;
363
- padding: 0 !important;
364
- margin-right: 2px !important;
365
- }
366
-
367
- :deep(.ant-descriptions-item-container:hover) {
368
- background-color: rgba(0, 0, 0, 0.02);
369
- border-radius: 4px;
370
- }
371
-
372
- :deep(.ant-btn-link) {
373
- padding: 0;
374
- height: auto;
375
- line-height: 1;
376
- }
377
-
378
- :deep(.ant-btn-link:hover) {
379
- color: #1890ff;
380
- background: transparent;
381
- }
382
-
383
- /* 响应式调整 */
384
- @media screen and (max-width: 768px) {
385
- .content-wrapper {
386
- max-width: 200px;
387
- }
388
- }
389
-
390
- @media screen and (max-width: 576px) {
391
- .content-wrapper {
392
- max-width: 150px;
393
- }
394
- .flex-descriptions {
395
- gap: 4px 12px;
396
- }
397
- }
398
-
399
- /* 添加虚线样式 */
400
- .with-divider {
401
- position: relative;
402
- margin-bottom: 16px !important;
403
- }
404
-
405
- .with-divider::after {
406
- content: '';
407
- position: absolute;
408
- left: 0;
409
- bottom: -8px;
410
- width: 100%;
411
- height: 0;
412
- border-bottom: 1px dashed rgba(0, 0, 0, 0.15);
413
- }
414
-
415
- /* 对于 Ant Design 描述列表的特殊处理 */
416
- :deep(.ant-descriptions-item.with-divider) {
417
- position: relative;
418
- margin-bottom: 16px !important;
419
- }
420
-
421
- :deep(.ant-descriptions-item.with-divider::after) {
422
- content: '';
423
- position: absolute;
424
- left: 0;
425
- bottom: -8px;
426
- width: 100%;
427
- height: 0;
428
- border-bottom: 1px dashed rgba(0, 0, 0, 0.15);
429
- }
430
- </style>
1
+ <template>
2
+ <div class="patient-info-descriptions">
3
+ <div class="descriptions-container">
4
+ <!-- 详情/收起按钮 -->
5
+ <div v-if="hasMoreItems" class="detail-button-wrapper">
6
+ <a-button
7
+ :type="config?.detailsConfig?.buttonType || 'link'"
8
+ @click="toggleDetails"
9
+ >
10
+ <a-icon :type="showAllItems ? 'up' : 'down'" />
11
+ {{ showAllItems ? '收起' : (config?.detailsConfig?.buttonText || '详情') }}
12
+ </a-button>
13
+ </div>
14
+
15
+ <!-- 当有 layout 配置时使用 a-descriptions -->
16
+ <template v-if="config?.layout">
17
+ <a-descriptions
18
+ :column="config.layout"
19
+ :size="config?.style?.size"
20
+ :bordered="config?.style?.bordered"
21
+ layout="horizontal">
22
+ <template v-if="data">
23
+ <!-- 显示前N个标签 -->
24
+ <a-descriptions-item
25
+ v-for="(item) in visibleItems"
26
+ :key="item.field"
27
+ :colon="item.colon !== false"
28
+ :class="{ 'with-divider': item.isLine }"
29
+ v-if="data[item.field] !== null && data[item.field] !== undefined && (!showAllItems || showAllItems && !hiddenItems.some(i => i.field === item.field))">
30
+ <template #label>
31
+ <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
32
+ <a-avatar
33
+ v-if="item.showAvatar"
34
+ :size="item.avatar.size"
35
+ :icon="item.avatar.icon"
36
+ :style="{ background: item.avatar.background }"
37
+ />
38
+ <span class="label-text">{{ item.label }}</span>
39
+ </div>
40
+ </template>
41
+ <div class="content-wrapper">
42
+ {{ data[item.field] }}
43
+ </div>
44
+ </a-descriptions-item>
45
+
46
+ <!-- 展开后显示剩余标签 -->
47
+ <template v-if="showAllItems">
48
+ <a-descriptions-item
49
+ v-for="item in hiddenItems"
50
+ :key="item.field"
51
+ :colon="item.colon !== false"
52
+ v-if="data[item.field] !== null && data[item.field] !== undefined">
53
+ <template #label>
54
+ <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
55
+ <a-avatar
56
+ v-if="item.showAvatar"
57
+ :size="item.avatar.size"
58
+ :icon="item.avatar.icon"
59
+ :style="{ background: item.avatar.background }"
60
+ />
61
+ <span class="label-text">{{ item.label }}</span>
62
+ </div>
63
+ </template>
64
+ <div class="content-wrapper">
65
+ {{ data[item.field] }}
66
+ </div>
67
+ </a-descriptions-item>
68
+ </template>
69
+ </template>
70
+ </a-descriptions>
71
+ </template>
72
+
73
+ <!-- 当没有 layout 配置时使用自适应布局 -->
74
+ <template v-else>
75
+ <div class="flex-descriptions">
76
+ <template v-if="data">
77
+ <!-- 显示可见的标签 -->
78
+ <div
79
+ v-for="(item) in visibleItems"
80
+ :key="item.field"
81
+ :class="['description-item', { 'with-divider': item.isLine }]"
82
+ v-if="data[item.field] !== null && data[item.field] !== undefined"
83
+ >
84
+ <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
85
+ <a-avatar
86
+ v-if="item.showAvatar"
87
+ :size="item.avatar.size"
88
+ :icon="item.avatar.icon"
89
+ :style="{ background: item.avatar.background }"
90
+ />
91
+ <span class="label-text">{{ item.label }}:</span>
92
+ </div>
93
+ <div class="content-wrapper">
94
+ {{ data[item.field] }}
95
+ </div>
96
+ </div>
97
+
98
+ <!-- 展开后显示的内容 -->
99
+ <template v-if="showAllItems">
100
+ <div
101
+ v-for="item in hiddenItems"
102
+ :key="item.field"
103
+ class="description-item"
104
+ v-if="data[item.field] !== null && data[item.field] !== undefined"
105
+ >
106
+ <div :class="['label-wrapper', { 'with-avatar': item.showAvatar }]">
107
+ <a-avatar
108
+ v-if="item.showAvatar"
109
+ :size="item.avatar.size"
110
+ :icon="item.avatar.icon"
111
+ :style="{ background: item.avatar.background }"
112
+ />
113
+ <span class="label-text">{{ item.label }}:</span>
114
+ </div>
115
+ <div class="content-wrapper">
116
+ {{ data[item.field] }}
117
+ </div>
118
+ </div>
119
+ </template>
120
+ </template>
121
+ </div>
122
+ </template>
123
+ </div>
124
+ </div>
125
+ </template>
126
+
127
+ <script>
128
+ import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
129
+
130
+ export default {
131
+ name: 'XHDescriptions',
132
+ data () {
133
+ return {
134
+ // 隐藏配置 当数据结果 = -1^ 该数据字段会被delete
135
+ hiddenConfig: '-1^',
136
+ data: null,
137
+ config: null,
138
+ showAllItems: false // 控制是否显示所有标签
139
+ }
140
+ },
141
+ props: {
142
+ queryParamsName: {
143
+ type: String,
144
+ default: ''
145
+ },
146
+ parameter: {
147
+ type: Object,
148
+ default: () => {
149
+ return {}
150
+ }
151
+ }
152
+ },
153
+ computed: {
154
+ // 获取详情按钮应该显示在第几个标签后
155
+ detailsAfterIndex () {
156
+ return this.config?.detailsConfig?.showAfterIndex || 999
157
+ },
158
+ // 判断是否有更多标签需要显示
159
+ hasMoreItems () {
160
+ if (!this.config?.detailsConfig) return false
161
+ if (!this.data || !this.config?.items || !Array.isArray(this.config.items)) return false
162
+ const hiddenStartIndex = this.detailsAfterIndex || 0
163
+ if (hiddenStartIndex >= this.config.items.length) return false
164
+ for (let i = hiddenStartIndex; i < this.config.items.length; i++) {
165
+ const item = this.config.items[i]
166
+ if (item && item.field && this.data[item.field] !== null && this.data[item.field] !== undefined) {
167
+ return true
168
+ }
169
+ }
170
+ return false
171
+ },
172
+ // 获取应该显示的标签
173
+ visibleItems () {
174
+ if (!this.config?.items) return []
175
+ if (!this.config?.detailsConfig) return this.config.items
176
+ if (this.showAllItems) return this.config.items.slice(0, this.detailsAfterIndex)
177
+ return this.config.items.slice(0, this.detailsAfterIndex)
178
+ },
179
+ // 获取隐藏的标签(保持原有逻辑)
180
+ hiddenItems () {
181
+ if (!this.config?.items) return []
182
+ if (!this.config?.detailsConfig) return []
183
+ return this.config.items.slice(this.detailsAfterIndex)
184
+ }
185
+ },
186
+ created () {
187
+ this.getData(this.queryParamsName, {})
188
+ },
189
+ methods: {
190
+ async getData (data, parameterData) {
191
+ this.data = null
192
+ this.showAllItems = false
193
+ getConfigByName(data, 'af-his', res => {
194
+ this.config = res
195
+ const hiddenConfig = this.config?.hiddenConfig ?? 0 === 1
196
+ console.log(this.config)
197
+ const parameter = { ...res.parameter, ...this.parameter, ...parameterData }
198
+ runLogic(res.logicName, parameter, 'af-his').then(result => {
199
+ if (hiddenConfig) {
200
+ for (const key in result) {
201
+ if (Object.prototype.hasOwnProperty.call(result, key) && result[key] === this.hiddenConfig) {
202
+ delete result[key]
203
+ }
204
+ }
205
+ }
206
+ this.data = result
207
+ })
208
+ })
209
+ },
210
+ toggleDetails () {
211
+ this.showAllItems = !this.showAllItems
212
+ }
213
+ },
214
+ watch: {
215
+ queryParamsName: {
216
+ handler (newValue) {
217
+ console.log(newValue)
218
+ this.getData(newValue, {})
219
+ },
220
+ deep: true
221
+ },
222
+ parameter: {
223
+ handler (newValue, oldValue) {
224
+ console.log('监听事件触发:', { old: oldValue, new: newValue })
225
+ // 当 parameter 变化时重新获取数据
226
+ this.getData(this.queryParamsName, {})
227
+ },
228
+ deep: true // 深度监听对象内部变化
229
+ }
230
+ }
231
+ }
232
+ </script>
233
+
234
+ <style scoped>
235
+ .patient-info-descriptions {
236
+ background: #fff;
237
+ padding: 12px;
238
+ border-radius: 4px;
239
+ width: 100%;
240
+ }
241
+
242
+ .descriptions-container {
243
+ position: relative;
244
+ width: 100%;
245
+ padding-right: 80px; /* 为按钮预留空间 */
246
+ }
247
+
248
+ /* 自适应布局样式 */
249
+ .flex-descriptions {
250
+ display: flex;
251
+ flex-wrap: wrap;
252
+ gap: 8px 24px;
253
+ width: 100%;
254
+ }
255
+
256
+ .description-item {
257
+ display: inline-flex;
258
+ align-items: center;
259
+ padding: 4px 8px;
260
+ border-radius: 4px;
261
+ transition: background-color 0.3s;
262
+ white-space: nowrap;
263
+ flex: 0 1 auto;
264
+ }
265
+
266
+ .description-item:hover {
267
+ background-color: rgba(0, 0, 0, 0.02);
268
+ }
269
+
270
+ /* 共用样式 */
271
+ .label-wrapper {
272
+ display: flex;
273
+ align-items: center;
274
+ gap: 8px;
275
+ color: rgba(0, 0, 0, 0.65);
276
+ font-size: v-bind('config?.style?.fontSize');
277
+ white-space: nowrap;
278
+ }
279
+
280
+ .label-wrapper.with-avatar {
281
+ gap: 8px;
282
+ }
283
+
284
+ .label-text {
285
+ white-space: nowrap;
286
+ }
287
+
288
+ .content-wrapper {
289
+ display: inline-flex;
290
+ align-items: center;
291
+ margin-left: 4px;
292
+ font-size: v-bind('config?.style?.fontSize');
293
+ color: rgba(0, 0, 0, 0.85);
294
+ max-width: 300px;
295
+ overflow: hidden;
296
+ text-overflow: ellipsis;
297
+ white-space: nowrap;
298
+ }
299
+
300
+ .detail-button-wrapper {
301
+ position: absolute;
302
+ right: 0;
303
+ top: 0;
304
+ z-index: 10;
305
+ padding: 4px 8px;
306
+ white-space: nowrap;
307
+ background-color: #fff;
308
+ }
309
+
310
+ /* Ant Design 描述列表样式覆盖 */
311
+ :deep(.ant-descriptions-row) {
312
+ display: flex;
313
+ flex-direction: row;
314
+ align-items: flex-start;
315
+ }
316
+
317
+ :deep(.ant-descriptions-item) {
318
+ padding: 0 !important;
319
+ display: flex !important;
320
+ align-items: flex-start !important;
321
+ flex-direction: row !important;
322
+ margin-right: 24px;
323
+ width: fit-content !important;
324
+ margin-bottom: 16px;
325
+ }
326
+
327
+ :deep(.ant-descriptions-item-container) {
328
+ display: flex !important;
329
+ flex-direction: row !important;
330
+ align-items: flex-start !important;
331
+ position: relative;
332
+ gap: 0 !important;
333
+ width: 100% !important;
334
+ }
335
+
336
+ :deep(.ant-descriptions-item-label) {
337
+ color: rgba(0, 0, 0, 0.65);
338
+ padding: 0 !important;
339
+ margin: 0 !important;
340
+ font-size: v-bind('config?.style?.fontSize || "14px"');
341
+ display: inline-flex !important;
342
+ align-items: center !important;
343
+ white-space: nowrap !important;
344
+ min-width: v-bind('config?.style?.labelWidth || "80px"');
345
+ justify-content: flex-start;
346
+ padding-right: 2px !important;
347
+ }
348
+
349
+ :deep(.ant-descriptions-item-content) {
350
+ font-size: v-bind('config?.style?.fontSize || "14px"');
351
+ display: inline-flex !important;
352
+ align-items: center !important;
353
+ padding: 0 !important;
354
+ margin: 0 !important;
355
+ margin-left: 0px !important;
356
+ }
357
+
358
+ :deep(.ant-descriptions-item-colon) {
359
+ position: static !important;
360
+ display: inline-flex !important;
361
+ align-items: center !important;
362
+ margin: 0 !important;
363
+ padding: 0 !important;
364
+ margin-right: 2px !important;
365
+ }
366
+
367
+ :deep(.ant-descriptions-item-container:hover) {
368
+ background-color: rgba(0, 0, 0, 0.02);
369
+ border-radius: 4px;
370
+ }
371
+
372
+ :deep(.ant-btn-link) {
373
+ padding: 0;
374
+ height: auto;
375
+ line-height: 1;
376
+ }
377
+
378
+ :deep(.ant-btn-link:hover) {
379
+ color: #1890ff;
380
+ background: transparent;
381
+ }
382
+
383
+ /* 响应式调整 */
384
+ @media screen and (max-width: 768px) {
385
+ .content-wrapper {
386
+ max-width: 200px;
387
+ }
388
+ }
389
+
390
+ @media screen and (max-width: 576px) {
391
+ .content-wrapper {
392
+ max-width: 150px;
393
+ }
394
+ .flex-descriptions {
395
+ gap: 4px 12px;
396
+ }
397
+ }
398
+
399
+ /* 添加虚线样式 */
400
+ .with-divider {
401
+ position: relative;
402
+ margin-bottom: 16px !important;
403
+ }
404
+
405
+ .with-divider::after {
406
+ content: '';
407
+ position: absolute;
408
+ left: 0;
409
+ bottom: -8px;
410
+ width: 100%;
411
+ height: 0;
412
+ border-bottom: 1px dashed rgba(0, 0, 0, 0.15);
413
+ }
414
+
415
+ /* 对于 Ant Design 描述列表的特殊处理 */
416
+ :deep(.ant-descriptions-item.with-divider) {
417
+ position: relative;
418
+ margin-bottom: 16px !important;
419
+ }
420
+
421
+ :deep(.ant-descriptions-item.with-divider::after) {
422
+ content: '';
423
+ position: absolute;
424
+ left: 0;
425
+ bottom: -8px;
426
+ width: 100%;
427
+ height: 0;
428
+ border-bottom: 1px dashed rgba(0, 0, 0, 0.15);
429
+ }
430
+ </style>