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,723 +1,723 @@
1
- <template>
2
- <a-row id="has_row" type="flex" :gutter="gutter" :style="isWidget ? {margin: '0px'} : {'margin-bottom': '.5rem'}">
3
- <template v-for="(cell, cellIndex) in columns">
4
- <a-col
5
- name="trGroup"
6
- v-if="Array.isArray(cell) || !cell.dontShowRow"
7
- :key="cellIndex"
8
- :ref="`trGroup_${ cell.slotRef || cellIndex}`"
9
- @hook:mounted="(h)=>applyAllStyles(cell,cellIndex)"
10
- :span="calculateColSpan(cell)">
11
- <div id="report_widget" v-if="isWidget">
12
- <!-- 插槽渲染 -->
13
- <template v-if="Array.isArray(cell)">
14
- <!-- 处理 cell 是数组的情况 -->
15
- <div v-for="(item, index) in cell" :key="index">
16
- <x-report-tr-group
17
- :env="env"
18
- :key="index"
19
- :columns="recalculateItem(item)"
20
- :config-data="configData"
21
- :config="config"
22
- :display="true">
23
- </x-report-tr-group>
24
- </div>
25
- </template>
26
- <template v-else-if="cell.type === 'slot'">
27
- <template
28
- v-if="['x-form-table','x-add-native-form','x-tree-pro', 'x-his-editor', 'x-tab', 'x-form-group', 'x-report', 'x-buttons', 'x-label-select', 'x-conversation', 'x-check-list', 'x-cardSet', 'x-collapse','x-h-descriptions', 'x-sidebar', 'x-list','x-input','x-time-line', 'x-radio','x-calendar', 'x-time-select' ,'x-checkbox', 'x-title', 'x-select', 'x-tree-rows', 'x-three-test-orders', 'x-shift-schedule','x-charge','x-questionnaire'].includes(cell.slotType)">
29
- <component
30
- :is="getComponentName(cell.slotConfig, cell.serviceName, cell.slotType)"
31
- :key="cellIndex"
32
- :ref="`dynamicComponent_${ cell.slotRef || cellIndex}`"
33
- :serviceName="cell.serviceName"
34
- :serverName="cell.serviceName"
35
- v-on="getEventHandlers(cell)"
36
- @hook:mounted="(h)=>onComponentMounted(h,cell,cellIndex)"
37
- @beforeDataChange="beforeDataChange"
38
- @rowClick="handleRowClick"
39
- @onExpand="onExpand"
40
- :queryParamsName="cell.slotConfig"
41
- :configName="cell.slotConfig"
42
- :countVisible="false"
43
- :env="env"
44
- />
45
- </template>
46
- </template>
47
- </div>
48
- <a-card v-else class="flexItem" :bordered="false">
49
- <!-- 插槽渲染 -->
50
- <template v-if="Array.isArray(cell)">
51
- <!-- 处理 cell 是数组的情况 -->
52
- <div v-for="(item, index) in cell" :key="index">
53
- <x-report-tr-group
54
- :server-name="serverName"
55
- :env="env"
56
- :key="index"
57
- :columns="recalculateItem(item)"
58
- :config-data="configData"
59
- :config="config"
60
- :display="true">
61
- </x-report-tr-group>
62
- </div>
63
- </template>
64
- <template v-else-if="cell.type === 'slot'">
65
- <template
66
- v-if="['x-form-table','x-add-native-form','x-tree-pro', 'x-his-editor', 'x-tab', 'x-form-group', 'x-report', 'x-buttons', 'x-label-select', 'x-conversation', 'x-check-list', 'x-cardSet', 'x-collapse', 'x-h-descriptions', 'x-sidebar', 'x-list','x-input','x-time-line', 'x-radio','x-calendar', 'x-time-select','x-checkbox', 'x-title', 'x-select', 'x-tree-rows', 'x-three-test-orders', 'x-shift-schedule','x-charge','x-questionnaire'].includes(cell.slotType)">
67
- <component
68
- :is="getComponentName(cell.slotConfig, cell.serviceName, cell.slotType)"
69
- :key="cellIndex"
70
- :ref="`dynamicComponent_${ cell.slotRef || cellIndex}`"
71
- :serviceName="cell.serviceName"
72
- :serverName="cell.serviceName"
73
- v-on="getEventHandlers(cell)"
74
- @hook:mounted="(h)=>onComponentMounted(h,cell,cellIndex)"
75
- @beforeDataChange="beforeDataChange"
76
- @rowClick="handleRowClick"
77
- @onExpand="onExpand"
78
- :queryParamsName="cell.slotConfig"
79
- :configName="cell.slotConfig"
80
- :countVisible="false"
81
- :env="env"
82
- />
83
- </template>
84
- </template>
85
- </a-card>
86
- </a-col>
87
- </template>
88
- </a-row>
89
- </template>
90
-
91
- <script>
92
- import Upload from '@vue2-client/base-client/components/common/Upload'
93
- import { getRealKeyData } from '@vue2-client/utils/util'
94
- import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
95
- import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
96
- import { getMicroData, getWindow, isMicroAppEnv, microDispatch } from '@vue2-client/utils/microAppUtils'
97
-
98
- export default {
99
- name: 'XReportTrGroup',
100
- components: {
101
- Upload,
102
- XFormTable: () => import('@vue2-client/base-client/components/common/XFormTable/XFormTable.vue'),
103
- XAddNativeForm: () => import('@vue2-client/base-client/components/common/XAddNativeForm/XAddNativeForm.vue'),
104
- XFormGroup: () => import('@vue2-client/base-client/components/common/XFormGroup/XFormGroup.vue'),
105
- XTreePro: () => import('@vue2-client/base-client/components/common/XTree/XTreePro.vue'),
106
- XHisEditor: () => import('@vue2-client/base-client/components/his/XHisEditor/XHisEditor.vue'),
107
- XTab: () => import('@vue2-client/base-client/components/common/XTab/XTab.vue'),
108
- XReport: () => import('@vue2-client/base-client/components/common/XReport/XReport.vue'),
109
- XButtons: () => import('@vue2-client/base-client/components/common/XButtons/XButtons.vue'),
110
- XLabelSelect: () => import('@vue2-client/base-client/components/common/XLabelSelect/XLabelSelect.vue'),
111
- XConversation: () => import('@vue2-client/base-client/components/common/XConversation/XConversation.vue'),
112
- XCheckList: () => import('@vue2-client/base-client/components/common/XCheckList/XCheckList.vue'),
113
- XCardSet: () => import('@vue2-client/base-client/components/common/XCardSet/XCardSet.vue'),
114
- XCollapse: () => import('@vue2-client/base-client/components/common/XCollapse/XCollapse.vue'),
115
- XHDescriptions: () => import('@vue2-client/base-client/components/his/XHDescriptions/XHDescriptions.vue'),
116
- XSidebar: () => import('@vue2-client/base-client/components/his/XSidebar/XSidebar.vue'),
117
- XList: () => import('@vue2-client/base-client/components/his/XList/XList.vue'),
118
- XInput: () => import('@vue2-client/base-client/components/common/XInput/XInput.vue'),
119
- XTimeLine: () => import('@vue2-client/base-client/components/common/XTimeline/XTimeline.vue'),
120
- XRadio: () => import('@vue2-client/base-client/components/his/XRadio/XRadio.vue'),
121
- XCalendar: () => import('@vue2-client/base-client/components/common/XCalendar/XCalendar.vue'),
122
- XTimeSelect: () => import('@vue2-client/base-client/components/his/XTimeSelect/XTimeSelect.vue'),
123
- XCheckbox: () => import('@vue2-client/base-client/components/his/XCheckbox/XCheckbox.vue'),
124
- XTitle: () => import('@vue2-client/base-client/components/his/XTitle/XTitle.vue'),
125
- XSelect: () => import('@vue2-client/base-client/components/his/XSelect/XSelect.vue'),
126
- XTreeRows: () => import('@vue2-client/base-client/components/his/XTreeRows/XTreeRows.vue'),
127
- XThreeTestOrders: () => import('@vue2-client/base-client/components/his/threeTestOrders/threeTestOrders.vue'),
128
- XShiftSchedule: () => import('@vue2-client/base-client/components/his/XShiftSchedule/XShiftSchedule.vue'),
129
- XCharge: () => import('@vue2-client/base-client/components/his/XCharge/XCharge.vue'),
130
- XQuestionnaire: () => import('@vue2-client/base-client/components/his/XQuestionnaire/XQuestionnaire.vue')
131
- },
132
- props: {
133
- // 每一行的配置
134
- columns: {
135
- type: Array,
136
- required: true
137
- },
138
- showImgInCell: {
139
- type: Boolean,
140
- default: false
141
- },
142
- config: {
143
- type: Object,
144
- default: function () {
145
- return {}
146
- }
147
- },
148
- // 命名空间
149
- serverName: {
150
- type: String,
151
- default: 'af-system'
152
- },
153
- // 环境
154
- env: {
155
- type: String,
156
- default: 'prod'
157
- },
158
- // 原始配置
159
- configData: {
160
- type: Object,
161
- required: true
162
- },
163
- // 是否为展示行
164
- display: {
165
- type: Boolean,
166
- default: false
167
- },
168
- },
169
- computed: {
170
- allSlotSum () {
171
- // 计算总共有多少个Slot
172
- let sum = 0
173
- this.columns.forEach((item) => {
174
- console.log('item', item)
175
- if (Array.isArray(item)) {
176
- item.forEach((cell) => {
177
- if (cell.type === 'slot') {
178
- sum++
179
- }
180
- })
181
- } else if (item.type && item.type === 'slot') {
182
- sum++
183
- }
184
- })
185
- console.log(`=总共有 ${sum} 个插槽栅格`)
186
- return sum
187
- }
188
- },
189
- data () {
190
- return {
191
- gutter: [8, { xs: 8, sm: 16, md: 24, lg: 32 }], // 设置水槽大小
192
- maxColSpan: 12,
193
- uploadParams: {
194
- type: 'image',
195
- accept: ['*'],
196
- resUploadStock: 1,
197
- pathKey: 'cs'
198
- },
199
- mixinData: {},
200
- flexItemBodyState: {},
201
- // 已经渲染得插槽得数量
202
- slotRendered: 0,
203
- // tableConfig: {}
204
- }
205
- },
206
- watch: {
207
- columns: {
208
- deep: true,
209
- immediate: true,
210
- handler (newVal) {
211
- console.log('columns变化:', JSON.parse(JSON.stringify(newVal)))
212
- // 使用nextTick确保DOM更新
213
- this.$nextTick(() => {
214
- this.$forceUpdate()
215
- })
216
- }
217
- }
218
- },
219
- inject: ['openDialog', 'emitEvent', 'registerComponent', 'setColSpanByName', 'setGlobalData', 'getGlobalData', 'getComponentByName', 'runLogic', 'getMixinData', 'getSelectedId', 'isInAModal', 'getConfigByName', 'getSelectedData', 'getOutEnv', 'currUser', 'isWidget', 'findComponentByName', 'closeAddReport'],
220
- methods: {
221
- getWindow,
222
- isMicroAppEnv,
223
- microDispatch,
224
- getMicroData,
225
- getRealKeyData,
226
- handleRowClick (record) {
227
- this.$emit('rowClick', record)
228
- },
229
- beforeDataChange (record) {
230
- this.$emit('beforeDataChange', record)
231
- },
232
- onExpand (expanded, record) {
233
- this.$emit('expand', expanded, record)
234
- },
235
- listClick (data) {
236
- this.$emit('listClick', data)
237
- },
238
- calculateColSpan (cell) {
239
- return Array.isArray(cell)
240
- ? cell[0][0]?.colSpan * 2
241
- : (cell?.colSpan ?? cell?.def?.colSpan ?? 1) * 2
242
- },
243
- applyAllStyles (cell, cellIndex) {
244
- // 应用组件样式
245
- const component = this.$refs[`trGroup_${ cell.slotRef || cellIndex}`][0]
246
- // 确保组件已经完全挂载
247
- this.$nextTick(() => {
248
- this.applyComponentStyles(component, cell, cellIndex)
249
- })
250
- },
251
- onComponentMounted (h, cell, cellIndex) {
252
- this.slotRendered += 1
253
- if (this.slotRendered >= this.allSlotSum) {
254
- this.$emit('slotRendered')
255
- }
256
- if (this.getMixinData && this.getMixinData()) {
257
- this.mixinData = this.getMixinData()
258
- }
259
- if (cell.slotRef) {
260
- this.registerComponent(cell.slotRef, this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0])
261
- }
262
- // 传递给祖先组件
263
- console.log(`插槽组件已经初始化 slotType ${cell.slotType},ref= dynamicComponent_${cell.slotRef || cellIndex} , serviceName = ${cell.serviceName}`)
264
- const shouldInit = cell.shouldInit == null ? true : cell.shouldInit
265
- if (shouldInit) {
266
- if (cell.slotType === 'x-add-native-form') {
267
- // 简易表单需要主动调用初始化方法
268
- getConfigByName(cell.slotConfig, cell.serviceName, async (res) => {
269
- // 如果配置了 表单初始化logic
270
- // 调用 logic 获取参数
271
- let param = { ...this.mixinData }
272
- let selectedId
273
- if (res.paramLogicName) {
274
- if (!!this.getSelectedId) {
275
- selectedId = this.getSelectedId()
276
- if (typeof selectedId !== 'object') {
277
- selectedId = { selectedId: selectedId }
278
- }
279
- }
280
- param = Object.assign(param, await runLogic(res.paramLogicName, selectedId, cell.serviceName))
281
- }
282
- console.info('给表单赋值', res)
283
- this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
284
- serviceName: cell.serviceName,
285
- configName: cell.slotConfig,
286
- formItems: res.formJson,
287
- showSubmitBtn: !this.isInAModal,
288
- businessType: param.businessType || '新增',
289
- layout: res.xAddFormLayout,
290
- primaryKey: res.primaryKey,
291
- ...res,
292
- fixedAddForm: param,
293
- modifyModelData: {
294
- files: param.files,
295
- images: param.images
296
- }
297
- })
298
- }, this.env === 'dev')
299
- } else if (cell.slotType === 'x-form-group') {
300
- // 简易表单需要主动调用初始化方法
301
- getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
302
- // 如果配置了 表单初始化logic
303
- // 调用 logic 获取参数
304
- const param = { ...this.mixinData }
305
- this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
306
- ...res,
307
- serviceName: cell.serviceName,
308
- showSubmitBtn: !this.isInAModal,
309
- businessType: param.businessType || '新增',
310
- modifyModelData: param,
311
- showLeftTab: true,
312
- })
313
- }, this.env === 'dev')
314
- } else if (cell.slotType === 'x-label-select') {
315
- // 按钮组需要主动调用初始化方法
316
- getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
317
- this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
318
- ...res,
319
- serviceName: cell.serviceName,
320
- })
321
- }, this.env === 'dev')
322
- }
323
- }
324
- if (cell.slotType === 'x-report') {
325
- const param = { ...this.mixinData }
326
- this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init(param)
327
- }
328
- if (cell.slotType === 'x-conversation') {
329
- getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
330
- this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
331
- serviceName: cell.serviceName,
332
- ...res,
333
- })
334
- }, this.env === 'dev')
335
- }
336
- if (cell.slotType === 'x-check-list') {
337
- getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
338
- this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
339
- serviceName: cell.serviceName,
340
- ...res,
341
- })
342
- }, this.env === 'dev')
343
- }
344
- },
345
- recalculateItem (item) {
346
- const totalColSpan = item.reduce((sum, cell) => {
347
- // 保留手动设置的colSpan
348
- return sum + (cell._isManualColSpan ? 0 : (cell.colSpan || 1))
349
- }, 0)
350
- return item.map(cell => {
351
- // 跳过已手动设置的单元格
352
- if (cell._isManualColSpan) return cell
353
- const newColSpan = Math.round((cell.colSpan || 1) / totalColSpan * 12)
354
- return {
355
- ...cell,
356
- colSpan: newColSpan,
357
- // 标记自动计算的单元格
358
- _isAutoCalculated: true
359
- }
360
- })
361
- },
362
-
363
- getEventHandlers (cell) {
364
- const handlers = {}
365
- if (!cell?.events || cell?.events?.length === 0) {
366
- return handlers
367
- }
368
- cell.events.forEach(event => {
369
- handlers[event.type] = async (...args) => {
370
- console.info('Event handled:', event.type, args)
371
- let func = event.customFunction
372
- if (func && func.startsWith('function')) {
373
- func = func.replace('function', 'async function')
374
- }
375
- const result = await executeStrFunctionByContext(this, func, args)
376
- if (result instanceof Promise) {
377
- result.then((res) => {
378
- if (!res) return
379
- let messageType = 'success'
380
- // 如果传递了组件名字 自动调用刷新
381
- if (res?.name) {
382
- const waitRefreshRef = this.getComponentByName(res.name)
383
- if (waitRefreshRef) {
384
- waitRefreshRef.refresh()
385
- } else {
386
- console.warn(`未找到组件${res.name}无法刷新`)
387
- }
388
- }
389
- // 如果传递消息类型 自动调用消息
390
- if (res?.messageType) {
391
- messageType = res.messageType
392
- }
393
- // 如果传递了提示信息自动调用提示
394
- if (res?.message) {
395
- this.$message[messageType](res?.message)
396
- }
397
- })
398
- }
399
- }
400
- })
401
- return handlers
402
- },
403
- getComponentName (queryParamsName, serviceName, componentName) {
404
- return componentName
405
- },
406
- // 判断单元格样式
407
- determineCellStyle (cell, color = '#000', borderWidth = '1px') {
408
- // 如果声明了borderColor
409
- if (this.config.style.borderColor) {
410
- color = this.config.style.borderColor
411
- }
412
- let result = {}
413
- // 如果表格也声明了样式,用表格样式将样式覆盖
414
- if (cell.style) {
415
- if (cell.noBorder) {
416
- result = { ...cell.style }
417
- } else {
418
- if (this.noTopBorder) {
419
- result = { ...cell.style }
420
- } else {
421
- result = { ...cell.style }
422
- }
423
- }
424
- return result
425
- }
426
- return result
427
- },
428
- // 把用户定义的组件,传递到整个杉格中,方便调用
429
- passComponentNamesToAncestor (refs) {
430
- console.log('组件的keys', Object.entries(refs), refs)
431
- // 遍历所有 refs
432
- Object.entries(refs).forEach(([refKey, refValue]) => {
433
- // 检查 ref 是否以 dynamicComponent_ 开头
434
- if (refKey.startsWith('dynamicComponent_')) {
435
- console.log('组件名存在')
436
- const componentRef = refValue[0]
437
- if (componentRef) {
438
- // 去掉前缀并获取组件名字
439
- const index = refKey.replace('dynamicComponent_', '') // 去掉前缀
440
- console.log('注册组件', index)
441
- // 传递给祖先组件
442
- this.registerComponent(index, componentRef)
443
- }
444
- }
445
- })
446
- },
447
- // 获取组件样式配置
448
- async getComponentStyleConfig (componentType) {
449
- try {
450
- // 从配置中获取样式定义
451
- const styleConfig = this.$appdata.getStylesByKey(componentType)
452
- return styleConfig || {}
453
- } catch (error) {
454
- console.error('获取组件样式配置失败:', error)
455
- return {}
456
- }
457
- },
458
-
459
- // 解析组件样式配置
460
- async parseComponentStyles (cell) {
461
- if (!cell.class) return { rootStyles: {}, childStyles: {} }
462
-
463
- const styleConfig = await this.getComponentStyleConfig(cell.slotType)
464
- if (!styleConfig) return { rootStyles: {}, childStyles: {} }
465
-
466
- const rootStyles = {}
467
- const childStyles = new Map()
468
-
469
- // 处理每个class配置
470
- cell.class.split(' ').forEach(className => {
471
- const classConfig = styleConfig[className]
472
- if (!classConfig) return
473
-
474
- // 处理根节点样式
475
- Object.entries(classConfig).forEach(([key, value]) => {
476
- if (!key.startsWith('*') && typeof key !== 'object') {
477
- rootStyles[key] = value
478
- }
479
- })
480
-
481
- // 处理子节点样式
482
- this.parseNestedStyles(classConfig, childStyles)
483
- })
484
-
485
- console.warn('样式配置', rootStyles, childStyles)
486
- return {
487
- rootStyles,
488
- childStyles
489
- }
490
- },
491
-
492
- // 递归解析嵌套的样式配置
493
- parseNestedStyles (config, styleMap, parentKey = '') {
494
- Object.entries(config).forEach(([key, value]) => {
495
- if (!key.startsWith('*')) return
496
-
497
- const className = key.replace('*', '.')
498
-
499
- // 如果值是对象,检查是否包含样式和子节点
500
- if (typeof value === 'object') {
501
- const { style = {}, children = {} } = this.separateStyleAndChildren(value)
502
-
503
- // 创建或获取当前节点的样式配置
504
- if (!styleMap.has(className)) {
505
- styleMap.set(className, {
506
- styles: {},
507
- children: new Map()
508
- })
509
- }
510
-
511
- const nodeData = styleMap.get(className)
512
-
513
- // 合并样式
514
- Object.assign(nodeData.styles, style)
515
-
516
- // 递归处理子节点
517
- this.parseNestedStyles(children, nodeData.children, className)
518
- }
519
- })
520
- },
521
-
522
- // 分离样式属性和子节点配置
523
- separateStyleAndChildren (obj) {
524
- const style = {}
525
- const children = {}
526
-
527
- Object.entries(obj).forEach(([key, value]) => {
528
- if (key.startsWith('*')) {
529
- // 子节点配置
530
- children[key] = value
531
- } else {
532
- // 样式属性
533
- style[key] = value
534
- }
535
- })
536
-
537
- return { style, children }
538
- },
539
-
540
- // 应用组件样式
541
- async applyComponentStyles (component, cell, cellIndex) {
542
- if (!component || !component.$el) return
543
-
544
- const { rootStyles, childStyles } = await this.parseComponentStyles(cell)
545
-
546
- // 应用根节点样式
547
- if (Object.keys(rootStyles).length > 0) {
548
- Object.entries(rootStyles).forEach(([property, value]) => {
549
- component.$el.style.setProperty(property, value, 'important')
550
- })
551
- }
552
-
553
- // 如果没有子节点样式,直接返回
554
- if (childStyles.size === 0) return
555
-
556
- let retryCount = 0
557
- const maxRetries = 5
558
- const retryInterval = 100 // 100ms
559
-
560
- const applyStyles = () => {
561
- this.applyChildStylesOptimized(component.$el, childStyles)
562
- }
563
-
564
- // 首次应用样式
565
- applyStyles()
566
-
567
- // 创建重试机制
568
- const retryApplyStyles = () => {
569
- if (retryCount >= maxRetries) return
570
-
571
- setTimeout(() => {
572
- applyStyles()
573
- retryCount++
574
- retryApplyStyles()
575
- }, retryInterval)
576
- }
577
-
578
- // 开始重试
579
- retryApplyStyles()
580
-
581
- // 创建 MutationObserver 用于动态内容
582
- const observer = new MutationObserver((mutations) => {
583
- // 检查是否有新增节点
584
- const hasNewNodes = mutations.some(mutation =>
585
- mutation.type === 'childList' && mutation.addedNodes.length > 0
586
- )
587
-
588
- if (hasNewNodes) {
589
- applyStyles()
590
- }
591
- })
592
-
593
- // 配置 observer
594
- observer.observe(component.$el, {
595
- childList: true,
596
- subtree: true,
597
- attributes: false
598
- })
599
-
600
- // 3秒后停止观察
601
- // setTimeout(() => {
602
- // observer.disconnect()
603
- // }, 3000)
604
-
605
- // 组件销毁时清理
606
- this.$once('hook:beforeDestroy', () => {
607
- observer.disconnect()
608
- })
609
- },
610
-
611
- // 优化后的子节点样式应用方法
612
- applyChildStylesOptimized (rootElement, styleMap, parentSelector = '') {
613
- if (!rootElement) return
614
-
615
- // 处理样式映射
616
- for (const [selector, data] of styleMap.entries()) {
617
- const currentSelector = parentSelector ? `${parentSelector} ${selector}` : selector
618
-
619
- try {
620
- // 查找匹配的元素
621
- const elements = Array.from(rootElement.querySelectorAll(currentSelector))
622
-
623
- if (!elements.length) continue
624
-
625
- // 应用当前层级样式
626
- if (data.styles) {
627
- elements.forEach(element => {
628
- if (!element) return
629
-
630
- // 应用每个样式属性
631
- Object.entries(data.styles).forEach(([property, value]) => {
632
- try {
633
- element.style.setProperty(property, value, 'important')
634
- } catch (err) {
635
- console.warn(`设置样式失败: ${property}=${value}`, err)
636
- }
637
- })
638
- })
639
- }
640
-
641
- // 处理子层级
642
- if (data.children && data.children.size > 0) {
643
- elements.forEach(element => {
644
- if (element) {
645
- this.applyChildStylesOptimized(element, data.children, currentSelector)
646
- }
647
- })
648
- }
649
- } catch (err) {
650
- console.warn(`处理选择器失败: ${currentSelector}`, err)
651
- continue
652
- }
653
- }
654
- }
655
- },
656
- beforeMount () {
657
- if (this.useOssForImg) {
658
- this.uploadParams.resUploadMode = 'oss'
659
- }
660
- },
661
- mounted () {
662
- },
663
- }
664
-
665
- </script>
666
-
667
- <style scoped lang="less">
668
- .inputsDiv {
669
- display: flex;
670
- justify-content: space-between;
671
-
672
- .inputsDivItem {
673
- display: flex;
674
- align-items: center;
675
- padding: 0 4px;
676
- white-space: nowrap;
677
-
678
- .inputsDivItemLabel {
679
- padding: 0 4px;
680
- }
681
- }
682
- }
683
-
684
- .tdNoBorder {
685
- border-left: 1px solid #000;
686
- border-right: 1px solid #000;
687
- padding: 8px;
688
- }
689
-
690
- .tdWithBorder {
691
- border: 1px solid #000;
692
- padding: 8px;
693
- }
694
-
695
- .tdWithNoTopBorder {
696
- border-top-style: none;
697
- border-left: 1px solid #000;
698
- border-right: 1px solid #000;
699
- border-bottom: 1px solid #000;
700
- padding: 8px;
701
- }
702
-
703
- .grid-content {
704
- border-radius: 4px;
705
- min-height: 36px;
706
- text-align: center;
707
- color: #fff;
708
- background-color: #606266;
709
- }
710
-
711
- .bg-purple {
712
- background: #9254de;
713
- }
714
-
715
- .bg-purple-light {
716
- background: #b37feb;
717
- }
718
-
719
- .flexItem {
720
- border-radius: 8px;
721
- height: 100%;
722
- }
723
- </style>
1
+ <template>
2
+ <a-row id="has_row" type="flex" :gutter="gutter" :style="isWidget ? {margin: '0px'} : {'margin-bottom': '.5rem'}">
3
+ <template v-for="(cell, cellIndex) in columns">
4
+ <a-col
5
+ name="trGroup"
6
+ v-if="Array.isArray(cell) || !cell.dontShowRow"
7
+ :key="cellIndex"
8
+ :ref="`trGroup_${ cell.slotRef || cellIndex}`"
9
+ @hook:mounted="(h)=>applyAllStyles(cell,cellIndex)"
10
+ :span="calculateColSpan(cell)">
11
+ <div id="report_widget" v-if="isWidget">
12
+ <!-- 插槽渲染 -->
13
+ <template v-if="Array.isArray(cell)">
14
+ <!-- 处理 cell 是数组的情况 -->
15
+ <div v-for="(item, index) in cell" :key="index">
16
+ <x-report-tr-group
17
+ :env="env"
18
+ :key="index"
19
+ :columns="recalculateItem(item)"
20
+ :config-data="configData"
21
+ :config="config"
22
+ :display="true">
23
+ </x-report-tr-group>
24
+ </div>
25
+ </template>
26
+ <template v-else-if="cell.type === 'slot'">
27
+ <template
28
+ v-if="['x-form-table','x-add-native-form','x-tree-pro', 'x-his-editor', 'x-tab', 'x-form-group', 'x-report', 'x-buttons', 'x-label-select', 'x-conversation', 'x-check-list', 'x-cardSet', 'x-collapse','x-h-descriptions', 'x-sidebar', 'x-list','x-input','x-time-line', 'x-radio','x-calendar', 'x-time-select' ,'x-checkbox', 'x-title', 'x-select', 'x-tree-rows', 'x-three-test-orders', 'x-shift-schedule','x-charge','x-questionnaire'].includes(cell.slotType)">
29
+ <component
30
+ :is="getComponentName(cell.slotConfig, cell.serviceName, cell.slotType)"
31
+ :key="cellIndex"
32
+ :ref="`dynamicComponent_${ cell.slotRef || cellIndex}`"
33
+ :serviceName="cell.serviceName"
34
+ :serverName="cell.serviceName"
35
+ v-on="getEventHandlers(cell)"
36
+ @hook:mounted="(h)=>onComponentMounted(h,cell,cellIndex)"
37
+ @beforeDataChange="beforeDataChange"
38
+ @rowClick="handleRowClick"
39
+ @onExpand="onExpand"
40
+ :queryParamsName="cell.slotConfig"
41
+ :configName="cell.slotConfig"
42
+ :countVisible="false"
43
+ :env="env"
44
+ />
45
+ </template>
46
+ </template>
47
+ </div>
48
+ <a-card v-else class="flexItem" :bordered="false">
49
+ <!-- 插槽渲染 -->
50
+ <template v-if="Array.isArray(cell)">
51
+ <!-- 处理 cell 是数组的情况 -->
52
+ <div v-for="(item, index) in cell" :key="index">
53
+ <x-report-tr-group
54
+ :server-name="serverName"
55
+ :env="env"
56
+ :key="index"
57
+ :columns="recalculateItem(item)"
58
+ :config-data="configData"
59
+ :config="config"
60
+ :display="true">
61
+ </x-report-tr-group>
62
+ </div>
63
+ </template>
64
+ <template v-else-if="cell.type === 'slot'">
65
+ <template
66
+ v-if="['x-form-table','x-add-native-form','x-tree-pro', 'x-his-editor', 'x-tab', 'x-form-group', 'x-report', 'x-buttons', 'x-label-select', 'x-conversation', 'x-check-list', 'x-cardSet', 'x-collapse', 'x-h-descriptions', 'x-sidebar', 'x-list','x-input','x-time-line', 'x-radio','x-calendar', 'x-time-select','x-checkbox', 'x-title', 'x-select', 'x-tree-rows', 'x-three-test-orders', 'x-shift-schedule','x-charge','x-questionnaire'].includes(cell.slotType)">
67
+ <component
68
+ :is="getComponentName(cell.slotConfig, cell.serviceName, cell.slotType)"
69
+ :key="cellIndex"
70
+ :ref="`dynamicComponent_${ cell.slotRef || cellIndex}`"
71
+ :serviceName="cell.serviceName"
72
+ :serverName="cell.serviceName"
73
+ v-on="getEventHandlers(cell)"
74
+ @hook:mounted="(h)=>onComponentMounted(h,cell,cellIndex)"
75
+ @beforeDataChange="beforeDataChange"
76
+ @rowClick="handleRowClick"
77
+ @onExpand="onExpand"
78
+ :queryParamsName="cell.slotConfig"
79
+ :configName="cell.slotConfig"
80
+ :countVisible="false"
81
+ :env="env"
82
+ />
83
+ </template>
84
+ </template>
85
+ </a-card>
86
+ </a-col>
87
+ </template>
88
+ </a-row>
89
+ </template>
90
+
91
+ <script>
92
+ import Upload from '@vue2-client/base-client/components/common/Upload'
93
+ import { getRealKeyData } from '@vue2-client/utils/util'
94
+ import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
95
+ import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
96
+ import { getMicroData, getWindow, isMicroAppEnv, microDispatch } from '@vue2-client/utils/microAppUtils'
97
+
98
+ export default {
99
+ name: 'XReportTrGroup',
100
+ components: {
101
+ Upload,
102
+ XFormTable: () => import('@vue2-client/base-client/components/common/XFormTable/XFormTable.vue'),
103
+ XAddNativeForm: () => import('@vue2-client/base-client/components/common/XAddNativeForm/XAddNativeForm.vue'),
104
+ XFormGroup: () => import('@vue2-client/base-client/components/common/XFormGroup/XFormGroup.vue'),
105
+ XTreePro: () => import('@vue2-client/base-client/components/common/XTree/XTreePro.vue'),
106
+ XHisEditor: () => import('@vue2-client/base-client/components/his/XHisEditor/XHisEditor.vue'),
107
+ XTab: () => import('@vue2-client/base-client/components/common/XTab/XTab.vue'),
108
+ XReport: () => import('@vue2-client/base-client/components/common/XReport/XReport.vue'),
109
+ XButtons: () => import('@vue2-client/base-client/components/common/XButtons/XButtons.vue'),
110
+ XLabelSelect: () => import('@vue2-client/base-client/components/common/XLabelSelect/XLabelSelect.vue'),
111
+ XConversation: () => import('@vue2-client/base-client/components/common/XConversation/XConversation.vue'),
112
+ XCheckList: () => import('@vue2-client/base-client/components/common/XCheckList/XCheckList.vue'),
113
+ XCardSet: () => import('@vue2-client/base-client/components/common/XCardSet/XCardSet.vue'),
114
+ XCollapse: () => import('@vue2-client/base-client/components/common/XCollapse/XCollapse.vue'),
115
+ XHDescriptions: () => import('@vue2-client/base-client/components/his/XHDescriptions/XHDescriptions.vue'),
116
+ XSidebar: () => import('@vue2-client/base-client/components/his/XSidebar/XSidebar.vue'),
117
+ XList: () => import('@vue2-client/base-client/components/his/XList/XList.vue'),
118
+ XInput: () => import('@vue2-client/base-client/components/common/XInput/XInput.vue'),
119
+ XTimeLine: () => import('@vue2-client/base-client/components/common/XTimeline/XTimeline.vue'),
120
+ XRadio: () => import('@vue2-client/base-client/components/his/XRadio/XRadio.vue'),
121
+ XCalendar: () => import('@vue2-client/base-client/components/common/XCalendar/XCalendar.vue'),
122
+ XTimeSelect: () => import('@vue2-client/base-client/components/his/XTimeSelect/XTimeSelect.vue'),
123
+ XCheckbox: () => import('@vue2-client/base-client/components/his/XCheckbox/XCheckbox.vue'),
124
+ XTitle: () => import('@vue2-client/base-client/components/his/XTitle/XTitle.vue'),
125
+ XSelect: () => import('@vue2-client/base-client/components/his/XSelect/XSelect.vue'),
126
+ XTreeRows: () => import('@vue2-client/base-client/components/his/XTreeRows/XTreeRows.vue'),
127
+ XThreeTestOrders: () => import('@vue2-client/base-client/components/his/threeTestOrders/threeTestOrders.vue'),
128
+ XShiftSchedule: () => import('@vue2-client/base-client/components/his/XShiftSchedule/XShiftSchedule.vue'),
129
+ XCharge: () => import('@vue2-client/base-client/components/his/XCharge/XCharge.vue'),
130
+ XQuestionnaire: () => import('@vue2-client/base-client/components/his/XQuestionnaire/XQuestionnaire.vue')
131
+ },
132
+ props: {
133
+ // 每一行的配置
134
+ columns: {
135
+ type: Array,
136
+ required: true
137
+ },
138
+ showImgInCell: {
139
+ type: Boolean,
140
+ default: false
141
+ },
142
+ config: {
143
+ type: Object,
144
+ default: function () {
145
+ return {}
146
+ }
147
+ },
148
+ // 命名空间
149
+ serverName: {
150
+ type: String,
151
+ default: 'af-system'
152
+ },
153
+ // 环境
154
+ env: {
155
+ type: String,
156
+ default: 'prod'
157
+ },
158
+ // 原始配置
159
+ configData: {
160
+ type: Object,
161
+ required: true
162
+ },
163
+ // 是否为展示行
164
+ display: {
165
+ type: Boolean,
166
+ default: false
167
+ },
168
+ },
169
+ computed: {
170
+ allSlotSum () {
171
+ // 计算总共有多少个Slot
172
+ let sum = 0
173
+ this.columns.forEach((item) => {
174
+ console.log('item', item)
175
+ if (Array.isArray(item)) {
176
+ item.forEach((cell) => {
177
+ if (cell.type === 'slot') {
178
+ sum++
179
+ }
180
+ })
181
+ } else if (item.type && item.type === 'slot') {
182
+ sum++
183
+ }
184
+ })
185
+ console.log(`=总共有 ${sum} 个插槽栅格`)
186
+ return sum
187
+ }
188
+ },
189
+ data () {
190
+ return {
191
+ gutter: [8, { xs: 8, sm: 16, md: 24, lg: 32 }], // 设置水槽大小
192
+ maxColSpan: 12,
193
+ uploadParams: {
194
+ type: 'image',
195
+ accept: ['*'],
196
+ resUploadStock: 1,
197
+ pathKey: 'cs'
198
+ },
199
+ mixinData: {},
200
+ flexItemBodyState: {},
201
+ // 已经渲染得插槽得数量
202
+ slotRendered: 0,
203
+ // tableConfig: {}
204
+ }
205
+ },
206
+ watch: {
207
+ columns: {
208
+ deep: true,
209
+ immediate: true,
210
+ handler (newVal) {
211
+ console.log('columns变化:', JSON.parse(JSON.stringify(newVal)))
212
+ // 使用nextTick确保DOM更新
213
+ this.$nextTick(() => {
214
+ this.$forceUpdate()
215
+ })
216
+ }
217
+ }
218
+ },
219
+ inject: ['openDialog', 'emitEvent', 'registerComponent', 'setColSpanByName', 'setGlobalData', 'getGlobalData', 'getComponentByName', 'runLogic', 'getMixinData', 'getSelectedId', 'isInAModal', 'getConfigByName', 'getSelectedData', 'getOutEnv', 'currUser', 'isWidget', 'findComponentByName', 'closeAddReport'],
220
+ methods: {
221
+ getWindow,
222
+ isMicroAppEnv,
223
+ microDispatch,
224
+ getMicroData,
225
+ getRealKeyData,
226
+ handleRowClick (record) {
227
+ this.$emit('rowClick', record)
228
+ },
229
+ beforeDataChange (record) {
230
+ this.$emit('beforeDataChange', record)
231
+ },
232
+ onExpand (expanded, record) {
233
+ this.$emit('expand', expanded, record)
234
+ },
235
+ listClick (data) {
236
+ this.$emit('listClick', data)
237
+ },
238
+ calculateColSpan (cell) {
239
+ return Array.isArray(cell)
240
+ ? cell[0][0]?.colSpan * 2
241
+ : (cell?.colSpan ?? cell?.def?.colSpan ?? 1) * 2
242
+ },
243
+ applyAllStyles (cell, cellIndex) {
244
+ // 应用组件样式
245
+ const component = this.$refs[`trGroup_${ cell.slotRef || cellIndex}`][0]
246
+ // 确保组件已经完全挂载
247
+ this.$nextTick(() => {
248
+ this.applyComponentStyles(component, cell, cellIndex)
249
+ })
250
+ },
251
+ onComponentMounted (h, cell, cellIndex) {
252
+ this.slotRendered += 1
253
+ if (this.slotRendered >= this.allSlotSum) {
254
+ this.$emit('slotRendered')
255
+ }
256
+ if (this.getMixinData && this.getMixinData()) {
257
+ this.mixinData = this.getMixinData()
258
+ }
259
+ if (cell.slotRef) {
260
+ this.registerComponent(cell.slotRef, this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0])
261
+ }
262
+ // 传递给祖先组件
263
+ console.log(`插槽组件已经初始化 slotType ${cell.slotType},ref= dynamicComponent_${cell.slotRef || cellIndex} , serviceName = ${cell.serviceName}`)
264
+ const shouldInit = cell.shouldInit == null ? true : cell.shouldInit
265
+ if (shouldInit) {
266
+ if (cell.slotType === 'x-add-native-form') {
267
+ // 简易表单需要主动调用初始化方法
268
+ getConfigByName(cell.slotConfig, cell.serviceName, async (res) => {
269
+ // 如果配置了 表单初始化logic
270
+ // 调用 logic 获取参数
271
+ let param = { ...this.mixinData }
272
+ let selectedId
273
+ if (res.paramLogicName) {
274
+ if (!!this.getSelectedId) {
275
+ selectedId = this.getSelectedId()
276
+ if (typeof selectedId !== 'object') {
277
+ selectedId = { selectedId: selectedId }
278
+ }
279
+ }
280
+ param = Object.assign(param, await runLogic(res.paramLogicName, selectedId, cell.serviceName))
281
+ }
282
+ console.info('给表单赋值', res)
283
+ this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
284
+ serviceName: cell.serviceName,
285
+ configName: cell.slotConfig,
286
+ formItems: res.formJson,
287
+ showSubmitBtn: !this.isInAModal,
288
+ businessType: param.businessType || '新增',
289
+ layout: res.xAddFormLayout,
290
+ primaryKey: res.primaryKey,
291
+ ...res,
292
+ fixedAddForm: param,
293
+ modifyModelData: {
294
+ files: param.files,
295
+ images: param.images
296
+ }
297
+ })
298
+ }, this.env === 'dev')
299
+ } else if (cell.slotType === 'x-form-group') {
300
+ // 简易表单需要主动调用初始化方法
301
+ getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
302
+ // 如果配置了 表单初始化logic
303
+ // 调用 logic 获取参数
304
+ const param = { ...this.mixinData }
305
+ this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
306
+ ...res,
307
+ serviceName: cell.serviceName,
308
+ showSubmitBtn: !this.isInAModal,
309
+ businessType: param.businessType || '新增',
310
+ modifyModelData: param,
311
+ showLeftTab: true,
312
+ })
313
+ }, this.env === 'dev')
314
+ } else if (cell.slotType === 'x-label-select') {
315
+ // 按钮组需要主动调用初始化方法
316
+ getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
317
+ this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
318
+ ...res,
319
+ serviceName: cell.serviceName,
320
+ })
321
+ }, this.env === 'dev')
322
+ }
323
+ }
324
+ if (cell.slotType === 'x-report') {
325
+ const param = { ...this.mixinData }
326
+ this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init(param)
327
+ }
328
+ if (cell.slotType === 'x-conversation') {
329
+ getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
330
+ this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
331
+ serviceName: cell.serviceName,
332
+ ...res,
333
+ })
334
+ }, this.env === 'dev')
335
+ }
336
+ if (cell.slotType === 'x-check-list') {
337
+ getConfigByName(cell.slotConfig, cell.serviceName, (res) => {
338
+ this.$refs[`dynamicComponent_${cell.slotRef || cellIndex}`][0].init({
339
+ serviceName: cell.serviceName,
340
+ ...res,
341
+ })
342
+ }, this.env === 'dev')
343
+ }
344
+ },
345
+ recalculateItem (item) {
346
+ const totalColSpan = item.reduce((sum, cell) => {
347
+ // 保留手动设置的colSpan
348
+ return sum + (cell._isManualColSpan ? 0 : (cell.colSpan || 1))
349
+ }, 0)
350
+ return item.map(cell => {
351
+ // 跳过已手动设置的单元格
352
+ if (cell._isManualColSpan) return cell
353
+ const newColSpan = Math.round((cell.colSpan || 1) / totalColSpan * 12)
354
+ return {
355
+ ...cell,
356
+ colSpan: newColSpan,
357
+ // 标记自动计算的单元格
358
+ _isAutoCalculated: true
359
+ }
360
+ })
361
+ },
362
+
363
+ getEventHandlers (cell) {
364
+ const handlers = {}
365
+ if (!cell?.events || cell?.events?.length === 0) {
366
+ return handlers
367
+ }
368
+ cell.events.forEach(event => {
369
+ handlers[event.type] = async (...args) => {
370
+ console.info('Event handled:', event.type, args)
371
+ let func = event.customFunction
372
+ if (func && func.startsWith('function')) {
373
+ func = func.replace('function', 'async function')
374
+ }
375
+ const result = await executeStrFunctionByContext(this, func, args)
376
+ if (result instanceof Promise) {
377
+ result.then((res) => {
378
+ if (!res) return
379
+ let messageType = 'success'
380
+ // 如果传递了组件名字 自动调用刷新
381
+ if (res?.name) {
382
+ const waitRefreshRef = this.getComponentByName(res.name)
383
+ if (waitRefreshRef) {
384
+ waitRefreshRef.refresh()
385
+ } else {
386
+ console.warn(`未找到组件${res.name}无法刷新`)
387
+ }
388
+ }
389
+ // 如果传递消息类型 自动调用消息
390
+ if (res?.messageType) {
391
+ messageType = res.messageType
392
+ }
393
+ // 如果传递了提示信息自动调用提示
394
+ if (res?.message) {
395
+ this.$message[messageType](res?.message)
396
+ }
397
+ })
398
+ }
399
+ }
400
+ })
401
+ return handlers
402
+ },
403
+ getComponentName (queryParamsName, serviceName, componentName) {
404
+ return componentName
405
+ },
406
+ // 判断单元格样式
407
+ determineCellStyle (cell, color = '#000', borderWidth = '1px') {
408
+ // 如果声明了borderColor
409
+ if (this.config.style.borderColor) {
410
+ color = this.config.style.borderColor
411
+ }
412
+ let result = {}
413
+ // 如果表格也声明了样式,用表格样式将样式覆盖
414
+ if (cell.style) {
415
+ if (cell.noBorder) {
416
+ result = { ...cell.style }
417
+ } else {
418
+ if (this.noTopBorder) {
419
+ result = { ...cell.style }
420
+ } else {
421
+ result = { ...cell.style }
422
+ }
423
+ }
424
+ return result
425
+ }
426
+ return result
427
+ },
428
+ // 把用户定义的组件,传递到整个杉格中,方便调用
429
+ passComponentNamesToAncestor (refs) {
430
+ console.log('组件的keys', Object.entries(refs), refs)
431
+ // 遍历所有 refs
432
+ Object.entries(refs).forEach(([refKey, refValue]) => {
433
+ // 检查 ref 是否以 dynamicComponent_ 开头
434
+ if (refKey.startsWith('dynamicComponent_')) {
435
+ console.log('组件名存在')
436
+ const componentRef = refValue[0]
437
+ if (componentRef) {
438
+ // 去掉前缀并获取组件名字
439
+ const index = refKey.replace('dynamicComponent_', '') // 去掉前缀
440
+ console.log('注册组件', index)
441
+ // 传递给祖先组件
442
+ this.registerComponent(index, componentRef)
443
+ }
444
+ }
445
+ })
446
+ },
447
+ // 获取组件样式配置
448
+ async getComponentStyleConfig (componentType) {
449
+ try {
450
+ // 从配置中获取样式定义
451
+ const styleConfig = this.$appdata.getStylesByKey(componentType)
452
+ return styleConfig || {}
453
+ } catch (error) {
454
+ console.error('获取组件样式配置失败:', error)
455
+ return {}
456
+ }
457
+ },
458
+
459
+ // 解析组件样式配置
460
+ async parseComponentStyles (cell) {
461
+ if (!cell.class) return { rootStyles: {}, childStyles: {} }
462
+
463
+ const styleConfig = await this.getComponentStyleConfig(cell.slotType)
464
+ if (!styleConfig) return { rootStyles: {}, childStyles: {} }
465
+
466
+ const rootStyles = {}
467
+ const childStyles = new Map()
468
+
469
+ // 处理每个class配置
470
+ cell.class.split(' ').forEach(className => {
471
+ const classConfig = styleConfig[className]
472
+ if (!classConfig) return
473
+
474
+ // 处理根节点样式
475
+ Object.entries(classConfig).forEach(([key, value]) => {
476
+ if (!key.startsWith('*') && typeof key !== 'object') {
477
+ rootStyles[key] = value
478
+ }
479
+ })
480
+
481
+ // 处理子节点样式
482
+ this.parseNestedStyles(classConfig, childStyles)
483
+ })
484
+
485
+ console.warn('样式配置', rootStyles, childStyles)
486
+ return {
487
+ rootStyles,
488
+ childStyles
489
+ }
490
+ },
491
+
492
+ // 递归解析嵌套的样式配置
493
+ parseNestedStyles (config, styleMap, parentKey = '') {
494
+ Object.entries(config).forEach(([key, value]) => {
495
+ if (!key.startsWith('*')) return
496
+
497
+ const className = key.replace('*', '.')
498
+
499
+ // 如果值是对象,检查是否包含样式和子节点
500
+ if (typeof value === 'object') {
501
+ const { style = {}, children = {} } = this.separateStyleAndChildren(value)
502
+
503
+ // 创建或获取当前节点的样式配置
504
+ if (!styleMap.has(className)) {
505
+ styleMap.set(className, {
506
+ styles: {},
507
+ children: new Map()
508
+ })
509
+ }
510
+
511
+ const nodeData = styleMap.get(className)
512
+
513
+ // 合并样式
514
+ Object.assign(nodeData.styles, style)
515
+
516
+ // 递归处理子节点
517
+ this.parseNestedStyles(children, nodeData.children, className)
518
+ }
519
+ })
520
+ },
521
+
522
+ // 分离样式属性和子节点配置
523
+ separateStyleAndChildren (obj) {
524
+ const style = {}
525
+ const children = {}
526
+
527
+ Object.entries(obj).forEach(([key, value]) => {
528
+ if (key.startsWith('*')) {
529
+ // 子节点配置
530
+ children[key] = value
531
+ } else {
532
+ // 样式属性
533
+ style[key] = value
534
+ }
535
+ })
536
+
537
+ return { style, children }
538
+ },
539
+
540
+ // 应用组件样式
541
+ async applyComponentStyles (component, cell, cellIndex) {
542
+ if (!component || !component.$el) return
543
+
544
+ const { rootStyles, childStyles } = await this.parseComponentStyles(cell)
545
+
546
+ // 应用根节点样式
547
+ if (Object.keys(rootStyles).length > 0) {
548
+ Object.entries(rootStyles).forEach(([property, value]) => {
549
+ component.$el.style.setProperty(property, value, 'important')
550
+ })
551
+ }
552
+
553
+ // 如果没有子节点样式,直接返回
554
+ if (childStyles.size === 0) return
555
+
556
+ let retryCount = 0
557
+ const maxRetries = 5
558
+ const retryInterval = 100 // 100ms
559
+
560
+ const applyStyles = () => {
561
+ this.applyChildStylesOptimized(component.$el, childStyles)
562
+ }
563
+
564
+ // 首次应用样式
565
+ applyStyles()
566
+
567
+ // 创建重试机制
568
+ const retryApplyStyles = () => {
569
+ if (retryCount >= maxRetries) return
570
+
571
+ setTimeout(() => {
572
+ applyStyles()
573
+ retryCount++
574
+ retryApplyStyles()
575
+ }, retryInterval)
576
+ }
577
+
578
+ // 开始重试
579
+ retryApplyStyles()
580
+
581
+ // 创建 MutationObserver 用于动态内容
582
+ const observer = new MutationObserver((mutations) => {
583
+ // 检查是否有新增节点
584
+ const hasNewNodes = mutations.some(mutation =>
585
+ mutation.type === 'childList' && mutation.addedNodes.length > 0
586
+ )
587
+
588
+ if (hasNewNodes) {
589
+ applyStyles()
590
+ }
591
+ })
592
+
593
+ // 配置 observer
594
+ observer.observe(component.$el, {
595
+ childList: true,
596
+ subtree: true,
597
+ attributes: false
598
+ })
599
+
600
+ // 3秒后停止观察
601
+ // setTimeout(() => {
602
+ // observer.disconnect()
603
+ // }, 3000)
604
+
605
+ // 组件销毁时清理
606
+ this.$once('hook:beforeDestroy', () => {
607
+ observer.disconnect()
608
+ })
609
+ },
610
+
611
+ // 优化后的子节点样式应用方法
612
+ applyChildStylesOptimized (rootElement, styleMap, parentSelector = '') {
613
+ if (!rootElement) return
614
+
615
+ // 处理样式映射
616
+ for (const [selector, data] of styleMap.entries()) {
617
+ const currentSelector = parentSelector ? `${parentSelector} ${selector}` : selector
618
+
619
+ try {
620
+ // 查找匹配的元素
621
+ const elements = Array.from(rootElement.querySelectorAll(currentSelector))
622
+
623
+ if (!elements.length) continue
624
+
625
+ // 应用当前层级样式
626
+ if (data.styles) {
627
+ elements.forEach(element => {
628
+ if (!element) return
629
+
630
+ // 应用每个样式属性
631
+ Object.entries(data.styles).forEach(([property, value]) => {
632
+ try {
633
+ element.style.setProperty(property, value, 'important')
634
+ } catch (err) {
635
+ console.warn(`设置样式失败: ${property}=${value}`, err)
636
+ }
637
+ })
638
+ })
639
+ }
640
+
641
+ // 处理子层级
642
+ if (data.children && data.children.size > 0) {
643
+ elements.forEach(element => {
644
+ if (element) {
645
+ this.applyChildStylesOptimized(element, data.children, currentSelector)
646
+ }
647
+ })
648
+ }
649
+ } catch (err) {
650
+ console.warn(`处理选择器失败: ${currentSelector}`, err)
651
+ continue
652
+ }
653
+ }
654
+ }
655
+ },
656
+ beforeMount () {
657
+ if (this.useOssForImg) {
658
+ this.uploadParams.resUploadMode = 'oss'
659
+ }
660
+ },
661
+ mounted () {
662
+ },
663
+ }
664
+
665
+ </script>
666
+
667
+ <style scoped lang="less">
668
+ .inputsDiv {
669
+ display: flex;
670
+ justify-content: space-between;
671
+
672
+ .inputsDivItem {
673
+ display: flex;
674
+ align-items: center;
675
+ padding: 0 4px;
676
+ white-space: nowrap;
677
+
678
+ .inputsDivItemLabel {
679
+ padding: 0 4px;
680
+ }
681
+ }
682
+ }
683
+
684
+ .tdNoBorder {
685
+ border-left: 1px solid #000;
686
+ border-right: 1px solid #000;
687
+ padding: 8px;
688
+ }
689
+
690
+ .tdWithBorder {
691
+ border: 1px solid #000;
692
+ padding: 8px;
693
+ }
694
+
695
+ .tdWithNoTopBorder {
696
+ border-top-style: none;
697
+ border-left: 1px solid #000;
698
+ border-right: 1px solid #000;
699
+ border-bottom: 1px solid #000;
700
+ padding: 8px;
701
+ }
702
+
703
+ .grid-content {
704
+ border-radius: 4px;
705
+ min-height: 36px;
706
+ text-align: center;
707
+ color: #fff;
708
+ background-color: #606266;
709
+ }
710
+
711
+ .bg-purple {
712
+ background: #9254de;
713
+ }
714
+
715
+ .bg-purple-light {
716
+ background: #b37feb;
717
+ }
718
+
719
+ .flexItem {
720
+ border-radius: 8px;
721
+ height: 100%;
722
+ }
723
+ </style>