vue2-client 1.14.55 → 1.14.56

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 (354) hide show
  1. package/.cursorrules +19 -19
  2. package/.env.gaslink +19 -19
  3. package/.env.his +19 -19
  4. package/.env.liuli +19 -19
  5. package/.env.message +19 -19
  6. package/.env.scada +19 -19
  7. package/.eslintrc.js +90 -90
  8. package/CHANGELOG.md +824 -824
  9. package/Components.md +60 -60
  10. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +45 -45
  11. package/docs/LowCode/lowcode.md +155 -155
  12. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  13. package/docs/index.md +30 -30
  14. package/index.js +31 -31
  15. package/jest-transform-stub.js +8 -8
  16. package/jest.setup.js +7 -7
  17. package/jsconfig.json +19 -19
  18. package/package.json +109 -109
  19. package/public/his/editor/editor.html +51 -51
  20. package/public/his/editor/mock/bind_data.html +779 -779
  21. package/public/his/editor/mock/data_table.html +40 -40
  22. package/public/his/editor/mock/sign.html +75 -75
  23. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  24. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  25. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  26. package/public/his/editor/vender/date97/calendar.js +4 -4
  27. package/public/his/editor/vender/date97/lang/en.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  29. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  30. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  31. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  32. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  33. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  34. package/public/his/editor/vender/diff.js +1627 -1627
  35. package/public/his/editor/vender/editor.js +1 -1
  36. package/public/his/editor/vender/fabric.js +31187 -31187
  37. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  38. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  39. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  40. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  41. package/public/his/editor/vender/mui/mui.min.css +4 -4
  42. package/public/his/editor/vender/mui/mui.min.js +5 -5
  43. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  44. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  45. package/public/his/editor/vender/qrcode.js +7 -7
  46. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  47. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  48. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  49. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  50. package/public/his/editor/vender/validator.js +5094 -5094
  51. package/public/his/editor/vender/weui/weui.css +5659 -5659
  52. package/public/his/editor/vender/weui/weui.min.css +4 -4
  53. package/public/his/editor/vender/weui/weui.min.js +11 -11
  54. package/public/index.html +27 -27
  55. package/src/ReportView.js +19 -19
  56. package/src/assets/img/querySlotDemo.svg +15 -15
  57. package/src/assets/svg/badtwo.svg +1 -1
  58. package/src/assets/svg/goodtwo.svg +1 -1
  59. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  60. package/src/base-client/components/AI/demo.vue +31 -31
  61. package/src/base-client/components/common/AMisRender/index.js +3 -3
  62. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  63. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  64. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  65. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  66. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  67. package/src/base-client/components/common/CitySelect/index.js +3 -3
  68. package/src/base-client/components/common/CitySelect/index.md +109 -109
  69. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  70. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  71. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  72. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  73. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  74. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  75. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  76. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  77. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  78. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  79. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  80. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  81. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  82. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  83. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  84. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  85. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  86. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  87. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  88. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  89. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  90. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  96. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  97. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  98. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  99. package/src/base-client/components/common/Recording/index.js +3 -3
  100. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  101. package/src/base-client/components/common/Tree/index.js +2 -2
  102. package/src/base-client/components/common/Upload/index.js +3 -3
  103. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  104. package/src/base-client/components/common/XAddNativeForm/demo.vue +2 -5
  105. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  106. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  107. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  108. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  109. package/src/base-client/components/common/XAddReport/index.js +3 -3
  110. package/src/base-client/components/common/XAddReport/index.md +56 -56
  111. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  112. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  113. package/src/base-client/components/common/XButtons/XButtons.vue +71 -71
  114. package/src/base-client/components/common/XButtons/index.js +3 -3
  115. package/src/base-client/components/common/XButtons/index.md +61 -61
  116. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  117. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  118. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  119. package/src/base-client/components/common/XConversation/XConversation.vue +261 -45
  120. package/src/base-client/components/common/XDataCard/index.js +3 -3
  121. package/src/base-client/components/common/XDataCard/index.md +1 -1
  122. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  123. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  124. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  125. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  126. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  127. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  128. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  129. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  130. package/src/base-client/components/common/XForm/XFormItem.vue +22 -1
  131. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  132. package/src/base-client/components/common/XForm/index.md +178 -178
  133. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  134. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  135. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  136. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  137. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  138. package/src/base-client/components/common/XFormTable/XFormTable.vue +895 -895
  139. package/src/base-client/components/common/XFormTable/demo.vue +86 -86
  140. package/src/base-client/components/common/XFormTable/index.md +92 -92
  141. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +167 -167
  142. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  143. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  144. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  145. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  146. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  147. package/src/base-client/components/common/XPrint/PrintBill.vue +302 -302
  148. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  149. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  150. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  151. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  152. package/src/base-client/components/common/XPrint/index.vue +97 -97
  153. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  154. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  155. package/src/base-client/components/common/XReport/index.js +3 -3
  156. package/src/base-client/components/common/XReport/index.md +44 -44
  157. package/src/base-client/components/common/XReport/print.js +186 -186
  158. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  159. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  160. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  161. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  162. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  163. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  164. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  165. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  166. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  167. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  168. package/src/base-client/components/common/XStepView/index.js +3 -3
  169. package/src/base-client/components/common/XStepView/index.md +31 -31
  170. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  171. package/src/base-client/components/common/XTab/index.js +3 -3
  172. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  173. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  174. package/src/base-client/components/common/XTable/XTable.vue +1555 -1555
  175. package/src/base-client/components/common/XTable/index.md +255 -255
  176. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  177. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  178. package/src/base-client/components/common/XTree/index.js +3 -3
  179. package/src/base-client/components/common/XTree/index.md +36 -36
  180. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  181. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  182. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  183. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  184. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  185. package/src/base-client/components/index.js +51 -51
  186. package/src/base-client/components/layout/XPageView/XErrorView.vue +11 -11
  187. package/src/base-client/components/layout/XPageView/XPageView.vue +155 -155
  188. package/src/base-client/components/layout/XPageView/index.js +3 -3
  189. package/src/base-client/components/layout/XPageView/index.md +38 -38
  190. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  191. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  192. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  193. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  194. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  195. package/src/base-client/plugins/Config.js +19 -19
  196. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  197. package/src/base-client/plugins/Recording.js +258 -258
  198. package/src/base-client/plugins/index.js +23 -23
  199. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  200. package/src/components/Charts/Bar.vue +62 -62
  201. package/src/components/Charts/ChartCard.vue +134 -134
  202. package/src/components/Charts/Liquid.vue +67 -67
  203. package/src/components/Charts/MiniArea.vue +39 -39
  204. package/src/components/Charts/MiniBar.vue +39 -39
  205. package/src/components/Charts/MiniProgress.vue +75 -75
  206. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  207. package/src/components/Charts/Radar.vue +68 -68
  208. package/src/components/Charts/RankList.vue +77 -77
  209. package/src/components/Charts/TagCloud.vue +113 -113
  210. package/src/components/Charts/TransferBar.vue +64 -64
  211. package/src/components/Charts/Trend.vue +82 -82
  212. package/src/components/Charts/chart.less +12 -12
  213. package/src/components/Charts/smooth.area.less +13 -13
  214. package/src/components/CodeMirror/inedx.vue +118 -118
  215. package/src/components/CodeMirror/setting.js +40 -40
  216. package/src/components/HeightScanner/index.vue +571 -571
  217. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  218. package/src/components/NumberInfo/index.js +3 -3
  219. package/src/components/NumberInfo/index.less +54 -54
  220. package/src/components/NumberInfo/index.md +43 -43
  221. package/src/components/card/ChartCard.vue +79 -79
  222. package/src/components/chart/Bar.vue +60 -60
  223. package/src/components/chart/MiniArea.vue +67 -67
  224. package/src/components/chart/MiniBar.vue +59 -59
  225. package/src/components/chart/MiniProgress.vue +57 -57
  226. package/src/components/chart/Radar.vue +80 -80
  227. package/src/components/chart/RankingList.vue +60 -60
  228. package/src/components/chart/Trend.vue +79 -79
  229. package/src/components/chart/index.less +9 -9
  230. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  231. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  232. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  233. package/src/components/checkbox/index.js +9 -9
  234. package/src/components/exception/ExceptionPage.vue +70 -70
  235. package/src/components/g2Charts/constants.js +202 -202
  236. package/src/components/g2Charts/demo.vue +808 -808
  237. package/src/components/g2Charts/designer.vue +228 -228
  238. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  239. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  240. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  241. package/src/components/g2Charts/index.vue +397 -397
  242. package/src/components/index.js +36 -36
  243. package/src/components/input/IInput.vue +66 -66
  244. package/src/components/menu/SideMenu.vue +75 -75
  245. package/src/components/menu/menu.js +273 -273
  246. package/src/components/setting/Setting.vue +234 -234
  247. package/src/components/tool/AStepItem.vue +60 -60
  248. package/src/config/CreateQueryConfig.js +325 -325
  249. package/src/config/default/antd.config.js +89 -89
  250. package/src/config/default/setting.config.js +55 -55
  251. package/src/font-style/font.css +4 -4
  252. package/src/layouts/CommonLayout.vue +56 -56
  253. package/src/layouts/PageLayout.vue +151 -151
  254. package/src/layouts/SinglePageView.vue +136 -136
  255. package/src/layouts/header/AdminHeader.vue +132 -132
  256. package/src/layouts/header/HeaderNotice.vue +177 -177
  257. package/src/layouts/header/InstitutionDetail.vue +181 -181
  258. package/src/layouts/tabs/TabsHead.vue +189 -189
  259. package/src/layouts/tabs/TabsView.vue +389 -389
  260. package/src/lib.js +1 -1
  261. package/src/main.js +34 -34
  262. package/src/mock/extend/index.js +84 -84
  263. package/src/mock/goods/index.js +108 -108
  264. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  265. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  266. package/src/pages/DefaultExample/index.vue +77 -77
  267. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  268. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  269. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  270. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  271. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  272. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  273. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  274. package/src/pages/DynamicStatistics/index.vue +282 -282
  275. package/src/pages/Example/childIndex.vue +15 -15
  276. package/src/pages/Example/index.vue +30 -30
  277. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  278. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  279. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  280. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  281. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  282. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  283. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  284. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  285. package/src/pages/Recording/index.vue +77 -77
  286. package/src/pages/ServiceReview/index.vue +284 -284
  287. package/src/pages/SubExample/index.vue +26 -26
  288. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  289. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +276 -276
  290. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +975 -975
  291. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +233 -233
  292. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +261 -261
  293. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +248 -248
  294. package/src/pages/XPageViewExample/index.vue +38 -38
  295. package/src/pages/XReportView/index.vue +64 -64
  296. package/src/pages/XTreeOneProExample/index.vue +67 -67
  297. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  298. package/src/pages/login/Login.vue +378 -378
  299. package/src/pages/login/LoginV3.vue +389 -389
  300. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  301. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  302. package/src/pages/report/ReportTable.js +124 -124
  303. package/src/pages/resourceManage/orgListManage.vue +98 -98
  304. package/src/pages/system/dictionary/index.vue +44 -44
  305. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  306. package/src/pages/system/monitor/operLog/index.vue +37 -37
  307. package/src/pages/system/settings/modifyPassword.vue +117 -117
  308. package/src/pages/system/ticket/index.vue +480 -480
  309. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  310. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  311. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  312. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  313. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  314. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  315. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  316. package/src/plugins/EventLogPlugin.js +33 -33
  317. package/src/plugins/FindParentsData.js +17 -17
  318. package/src/router/async/config.async.js +35 -35
  319. package/src/router/async/router.map.js +2 -2
  320. package/src/router/index.js +27 -27
  321. package/src/router.js +19 -19
  322. package/src/services/DataModel.js +30 -30
  323. package/src/services/LodopFuncs.js +137 -137
  324. package/src/services/api/TicketDetailsViewApi.js +46 -46
  325. package/src/services/api/cas.js +79 -79
  326. package/src/services/api/common.js +346 -346
  327. package/src/services/api/entity.js +18 -18
  328. package/src/services/api/index.js +17 -17
  329. package/src/services/api/restTools.js +98 -27
  330. package/src/services/api/workFlow.js +61 -61
  331. package/src/store/modules/account.js +115 -115
  332. package/src/store/modules/index.js +5 -5
  333. package/src/store/modules/lowCode.js +33 -33
  334. package/src/store/modules/setting.js +119 -119
  335. package/src/theme/default/style.less +58 -58
  336. package/src/theme/global.less +159 -159
  337. package/src/utils/authority-utils.js +85 -85
  338. package/src/utils/errorCode.js +6 -6
  339. package/src/utils/formatter.js +74 -74
  340. package/src/utils/htmlToPDF.js +108 -108
  341. package/src/utils/htmlToPDFApi.js +5 -5
  342. package/src/utils/login.js +188 -188
  343. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  344. package/src/utils/lowcode/lowcodeLog.js +29 -29
  345. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  346. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  347. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  348. package/src/utils/map-utils.js +47 -47
  349. package/src/utils/reg.js +95 -95
  350. package/src/utils/runEvalFunction.js +14 -14
  351. package/src/utils/theme-color-replacer-extend.js +92 -92
  352. package/src/utils/util.js +329 -329
  353. package/src/utils/waterMark.js +31 -31
  354. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,895 +1,895 @@
1
- <template>
2
- <a-row type="flex" :gutter="{ xs: 8, sm: 10, md: 12, lg: 16 }">
3
- <a-col
4
- :xs="14"
5
- :sm="14"
6
- :md="12"
7
- :lg="9"
8
- :xl="6"
9
- :xxl="5"
10
- v-if="xTreeConfigName"
11
- :style="{ maxWidth: '400px'}">
12
- <x-tree-pro
13
- :config-name="xTreeConfigName"
14
- :env="env"
15
- @action="action"
16
- @btnFuncClick="treeBtnFuncClick"
17
- @treeOnChecked="treeOnChecked"
18
- ref="xtree"
19
- ></x-tree-pro>
20
- </a-col>
21
- <a-col
22
- :xs="xTreeConfigName ? 10 : 24"
23
- :sm="xTreeConfigName ? 10 : 24"
24
- :md="xTreeConfigName ? 12 : 24"
25
- :lg="xTreeConfigName ? 15 : 24"
26
- :xl="xTreeConfigName ? 18 : 24"
27
- :xxl="xTreeConfigName ? 19 : 24">
28
- <a-skeleton :loading="loading" :paragraph="{ rows: 4 }"/>
29
- <a-row style="height: 12px" v-if="xTreeConfigName"></a-row>
30
- <div v-show="!loading">
31
- <template v-if="!loadError">
32
- <x-add-form
33
- ref="xAddForm"
34
- @onLocalSubmit="onLocalSubmit"
35
- @x-form-item-emit-func="emitFunc"
36
- @afterSubmit="onAddOrEditSubmitAfterSubmit"
37
- >
38
- <template slot="groupFormItems" slot-scope="{form, model, rules, modifyModelData}">
39
- <slot
40
- name="groupFormItems"
41
- :form="form"
42
- :model="model"
43
- :rules="rules"
44
- :modifyModelData="modifyModelData"></slot>
45
- </template>
46
- </x-add-form>
47
- <x-add-report
48
- v-if="moveType"
49
- ref="xAddReport"
50
- >
51
- </x-add-report>
52
- <div v-if="crudTitle" class="crud_title">
53
- {{ crudTitle }}
54
- </div>
55
- <x-form
56
- ref="xForm"
57
- @toggleAdvanced="toggleAdvanced"
58
- @onSubmit="onSearchSubmit">
59
- <slot name="formBtnExpand"></slot>
60
- </x-form>
61
- <x-table
62
- ref="xTable"
63
- :fixedQueryForm="fixedQueryForm"
64
- :queryParamsName="queryParamsName"
65
- :query-params-json="queryParamsJson"
66
- :show-pagination="showPagination"
67
- :customDelete="customDelete"
68
- :extraHeight="extraHeight"
69
- :serviceName="serviceName"
70
- :pageMaxSize="realQueryConfig.queryPagesSize"
71
- :externalSelectedRowKeys="externalSelectedRowKeys"
72
- @add="add"
73
- @move="move"
74
- @edit="edit"
75
- @del="del"
76
- @rowChoose="rowChoose"
77
- @customEvent="customEvent"
78
- @afterDelete="afterDelete"
79
- @action="action"
80
- @selectRow="selectRow"
81
- @afterQuery="afterQuery"
82
- @columnClick="columnClick"
83
- @gotoUserDetail="gotoUserDetail"
84
- @editButtonStateDataClick="editButtonStateDataClick"
85
- @importExcelOk="importExcelOk"
86
- @rowClick="handleRowClick"
87
- @beforeDataChange="beforeDataChange"
88
- @expand="onExpand">
89
- <template slot="leftButton" slot-scope="{selectedRowKeys, selectedRows}">
90
- <slot name="leftButton" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
91
- </template>
92
- <template slot="button" slot-scope="{selectedRowKeys, selectedRows}">
93
- <slot name="button" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
94
- </template>
95
- <template slot="rightBtnExpand" slot-scope="{selectedRowKeys, selectedRows}">
96
- <slot name="rightBtnExpand" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
97
- <a-tooltip title="收起查询条件" placement="bottom">
98
- <a-button @click="toggleIsFormShow">
99
- <a-icon :style="iconStyle" :type="toggleIsFormIcon"/>
100
- </a-button>
101
- </a-tooltip>
102
- </template>
103
- <!-- 底部插槽 -->
104
- <template slot="footer" slot-scope="{selectedRowKeys, selectedRows}">
105
- <slot name="footer" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
106
- </template>
107
- <!-- excel导入说明插槽 -->
108
- <template #importExcelSlot>
109
- <slot name="importExcelSlot"></slot>
110
- </template>
111
- </x-table>
112
- </template>
113
- <template v-else>
114
- <a-empty>
115
- <span slot="description"> 页面配置不存在,请联系系统管理员</span>
116
- </a-empty>
117
- </template>
118
- </div>
119
- </a-col>
120
- <UserInfoDetailManage ref="userInfo" @close="refresh(false)"/>
121
- </a-row>
122
- </template>
123
- <script>
124
- import XForm from '@vue2-client/base-client/components/common/XForm'
125
- import XAddForm from '@vue2-client/base-client/components/common/XAddForm'
126
- import XAddReport from '@vue2-client/base-client/components/common/XAddReport'
127
- import XTable from '@vue2-client/base-client/components/common/XTable'
128
- import XTree from '@vue2-client/base-client/components/common/XTree'
129
- import XImportExcel from '@vue2-client/base-client/components/common/XImportExcel'
130
- import {
131
- getConfigByName,
132
- getConfigByLogic,
133
- parseConfig, runLogic, getConfigByNameAsync,
134
- } from '@vue2-client/services/api/common'
135
- import { mapState } from 'vuex'
136
- import XTreePro from '@vue2-client/base-client/components/common/XTree/XTreePro.vue'
137
- import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
138
- import { getRealKeyData } from '@vue2-client/utils/util'
139
- import * as util from '@vue2-client/utils/util'
140
- import UserInfoDetailManage from '@vue2-client/pages/userInfoDetailManage/index.vue'
141
-
142
- export default {
143
- name: 'XFormTable',
144
- components: {
145
- UserInfoDetailManage,
146
- XTreePro,
147
- XTable,
148
- XForm,
149
- XTree,
150
- XAddForm,
151
- XAddReport,
152
- XImportExcel
153
- },
154
- provide () {
155
- return {
156
- getSelf: () => this,
157
- emitEvent: this.emitEvent.bind(this)
158
- }
159
- },
160
- inject: {
161
- getSelectedId: {
162
- default: () => () => {
163
- console.warn('getSelectedId is not provided.')
164
- return null
165
- },
166
- },
167
- setGlobalData: {
168
- default: () => () => {
169
- console.warn('setGlobalData is not provided.')
170
- return null
171
- },
172
- },
173
- getGlobalData: {
174
- default: () => () => {
175
- console.warn('getGlobalData is not provided.')
176
- return null
177
- },
178
- },
179
- getSelectedData: {
180
- default: () => () => {
181
- console.warn('getSelectedData is not provided.')
182
- return null
183
- },
184
- },
185
- getMixinData: {
186
- default: () => () => {
187
- console.warn('getMixinData is not provided.')
188
- return {}
189
- },
190
- },
191
- getOutEnv: {
192
- default: () => () => {
193
- console.warn('getOutEnv is not provided.')
194
- return {}
195
- },
196
- },
197
- currUser: {
198
- default: () => {
199
- console.warn('currUser is not provided.')
200
- return { id: null, name: 'Guest' }
201
- },
202
- },
203
- },
204
- data () {
205
- return {
206
- // 加载状态
207
- loading: false,
208
- // 图标样式
209
- iconStyle: {
210
- position: 'relative',
211
- top: '1px'
212
- },
213
- loadError: false,
214
- moveType: false,
215
- // 添加按钮对应的配置名
216
- moveconfig: '',
217
- // 实际查询配置内容
218
- realQueryConfig: {},
219
- toggleIsFormIcon: 'vertical-align-top',
220
- table_selectedRowKeys: [],
221
- table_selectedRows: [],
222
- // 数据只有一页时是否展示分页,true:展示,auto:隐藏
223
- showPagination: true,
224
- isMounted: false
225
- }
226
- },
227
- computed: {
228
- ...mapState('setting', ['isMobile'])
229
- },
230
- props: {
231
- // 业务名称
232
- title: {
233
- type: String,
234
- default: ''
235
- },
236
- // 外部传入的选中行keys
237
- externalSelectedRowKeys: {
238
- type: Array,
239
- default: () => []
240
- },
241
- // 卡片标题
242
- crudTitle: {
243
- type: String,
244
- default: null
245
- },
246
- // 查询配置文件名
247
- queryParamsName: {
248
- type: String,
249
- default: null
250
- },
251
- // 配置所属命名空间
252
- serviceName: {
253
- type: String,
254
- default: process.env.VUE_APP_SYSTEM_NAME
255
- },
256
- // 查询配置文件Json,用于查询配置生成器的预览
257
- queryParamsJson: {
258
- type: Object,
259
- default: null
260
- },
261
- // xTree 配置
262
- xTreeConfigName: {
263
- type: String,
264
- default: null
265
- },
266
- // 业务逻辑名称, 通过logic获取表单表格配置
267
- logicName: {
268
- type: String,
269
- default: null
270
- },
271
- // 执行logic传递的参数
272
- logicParam: {
273
- type: Object,
274
- default: () => {
275
- }
276
- },
277
- // 固定新增表单
278
- fixedAddForm: {
279
- type: Object,
280
- default: () => {
281
- return {}
282
- }
283
- },
284
- // 固定查询表单
285
- fixedQueryForm: {
286
- type: Object,
287
- default: () => {
288
- return {}
289
- }
290
- },
291
- // 预览模式
292
- viewMode: {
293
- type: Boolean,
294
- default: () => {
295
- return false
296
- }
297
- },
298
- // 本地编辑模式
299
- localEditMode: {
300
- type: Boolean,
301
- default: () => {
302
- return false
303
- }
304
- },
305
- // 行选择模式
306
- rowSelectMode: {
307
- type: Boolean,
308
- default: () => {
309
- return false
310
- }
311
- },
312
- // 行选择模式-允许选中行数量,0:任意数量行,大于0:指定值数量的行
313
- allowSelectRowNum: {
314
- type: Number,
315
- default: () => {
316
- return 0
317
- }
318
- },
319
- // 环境
320
- env: {
321
- type: String,
322
- default: () => {
323
- return 'prod'
324
- }
325
- },
326
- // 调用logic获取数据源的追加参数
327
- getDataParams: {
328
- type: Object,
329
- default: undefined
330
- },
331
- // 可以控制组件中导出等按钮的隐藏
332
- buttonState: {
333
- type: Object,
334
- default: undefined
335
- },
336
- // 是否自定义新增按钮的功能
337
- customAdd: {
338
- type: Boolean,
339
- default: false
340
- },
341
- reportQueryName: {
342
- type: String,
343
- default: undefined,
344
- },
345
- // 是否自定义删除按钮的功能
346
- customDelete: {
347
- type: Boolean,
348
- default: false
349
- },
350
- // 是否自定义修改按钮的功能
351
- customEdit: {
352
- type: Boolean,
353
- default: false
354
- },
355
- // 是否自定义增加按钮
356
- customMove: {
357
- type: Boolean,
358
- default: false
359
- },
360
- // 自适应底部边距
361
- extraHeight: {
362
- type: Number,
363
- default: 80
364
- }
365
- },
366
- watch: {
367
- logicParam: {
368
- handler () {
369
- this.initConfig()
370
- },
371
- deep: true
372
- },
373
- queryParamsJson: {
374
- handler () {
375
- this.initConfig()
376
- },
377
- deep: true
378
- },
379
- queryParamsName: {
380
- handler () {
381
- this.initConfig()
382
- }
383
- },
384
- serviceName: {
385
- handler () {
386
- this.initConfig()
387
- }
388
- }
389
- },
390
- methods: {
391
- runLogic,
392
- getRealKeyData,
393
- getConfigByNameAsync,
394
- getConfigByName,
395
- customEvent (func, data) {
396
- this.$emit(func, data)
397
- },
398
- columnClick (key, value, record) {
399
- this.$emit('columnClick', key, value, record)
400
- },
401
- gotoUserDetail (key, value, record) {
402
- this.$refs.userInfo.init(getRealKeyData(record))
403
- },
404
- // 获取主表的数据内容,去掉主表别名
405
- getPrimaryData (rows) {
406
- const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
407
- const prefix = `${alias}_` // 构建前缀
408
- const result = []
409
-
410
- // 遍历 rows 的每一项,提取符合条件的数据
411
- rows.forEach(row => {
412
- const itemResult = {}
413
- Object.keys(row).forEach(key => {
414
- if (key.startsWith(prefix)) {
415
- const newKey = key.slice(prefix.length) // 去掉前缀
416
- itemResult[newKey] = row[key] // 添加到结果对象中
417
- }
418
- })
419
- result.push(itemResult) // 将处理后的项添加到结果数组中
420
- })
421
-
422
- return result // 返回去掉前缀后的对象数组
423
- },
424
-
425
- // 给数据区域添加主表数据,给的数据没有主表别名,放着时添加主表别名
426
- pushPrimaryData (rows) {
427
- const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
428
- const prefix = `${alias}_` // 构建前缀
429
- const result = rows.map(row => {
430
- const itemResult = {}
431
- Object.keys(row).forEach(key => {
432
- itemResult[prefix + key] = row[key] // 复制原始数据
433
- })
434
- return itemResult // 返回添加了主表别名的数据
435
- })
436
- // 把结果添加到数据区
437
- this.getTableData().push(...result)
438
- },
439
-
440
- // 设置固定查询条件,主表别名自动带
441
- setFixedQueryForm (data) {
442
- const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
443
- const prefixedData = {}
444
-
445
- // 为每个键添加主表别名
446
- Object.keys(data).forEach(key => {
447
- prefixedData[`${alias}_${key}`] = data[key]
448
- })
449
-
450
- Object.assign(this.fixedQueryForm, prefixedData)
451
- },
452
-
453
- importExcelOk (data) {
454
- this.$emit('importExcelOk', data)
455
- },
456
- initConfig () {
457
- this.loading = true
458
- this.loadError = false
459
- if (this.queryParamsName) {
460
- this.getConfig()
461
- } else if (this.queryParamsJson) {
462
- this.getConfigBySource()
463
- } else if (this.logicName && this.logicParam) {
464
- this.getColumnJsonByLogic()
465
- } else {
466
- this.loading = false
467
- this.loadError = true
468
- }
469
- },
470
-
471
- getConfig () {
472
- getConfigByName(this.queryParamsName, this.serviceName, (res) => {
473
- if (!res) {
474
- this.loading = false
475
- this.loadError = true
476
- return
477
- }
478
- this.updateComponents(res)
479
- }, this.env === 'dev')
480
- },
481
- getConfigBySource () {
482
- parseConfig(this.queryParamsJson, 'CRUD_FORM', this.serviceName, this.env === 'dev').then(res => {
483
- if (!res) {
484
- this.loading = false
485
- this.loadError = true
486
- return
487
- }
488
- this.updateComponents(res, true)
489
- })
490
- },
491
- getColumnJsonByLogic () {
492
- getConfigByLogic(this.logicName, this.logicParam, this.serviceName, (res) => {
493
- if (!res) {
494
- this.loading = false
495
- this.loadError = true
496
- return
497
- }
498
- this.updateComponents(res, true)
499
- }, this.env === 'dev')
500
- },
501
-
502
- /**
503
- * 更新子组件
504
- * @param res 参数
505
- * @param setQueryParams 是否设置queryParams参数
506
- */
507
- updateComponents (res, setQueryParams) {
508
- this.realQueryConfig = res
509
- if (this.$refs.xTable && this.$refs.xForm && this.$refs.xAddForm) {
510
- // 设置添加按钮对应的配置名
511
- this.moveconfig = res.moveconfig
512
- this.showPagination = res.showPagination === null ? true : res.showPagination
513
- // 是否展示排序按钮控制
514
- if (res.showSortIcon !== null && !res.showSortIcon) {
515
- res.columnJson.forEach(item => {
516
- item.sorter = false
517
- })
518
- }
519
- const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
520
- const initTable = () => {
521
- // 初始化 xTable 子组件
522
- this.$refs.xTable.init({
523
- formItems: res.formJson,
524
- queryParams: setQueryParams ? res : null,
525
- tableColumns: res.columnJson,
526
- buttonState: Object.assign(res.buttonState, this.buttonState),
527
- title: this.title || res.title,
528
- viewMode: this.viewMode,
529
- localEditMode: localEditMode,
530
- rowSelectMode: this.rowSelectMode,
531
- allowSelectRowNum: this.allowSelectRowNum,
532
- tableSummaryMap: res.tableSummaryMap,
533
- serviceName: this.serviceName,
534
- env: this.env,
535
- form: this.$refs.xForm.form,
536
- summaryUpdate: true,
537
- ...res
538
- })
539
- if (this.realQueryConfig?.funcData?.pageMounted) {
540
- executeStrFunctionByContext(this, this.realQueryConfig.funcData.pageMounted, [util, runLogic, getConfigByNameAsync])
541
- }
542
- this.$emit('afterTableInit')
543
- }
544
- // 初始化 xForm 子组件
545
- if (!localEditMode && !this.rowSelectMode) {
546
- this.$refs.xForm.init({
547
- queryParamsName: this.queryParamsName || 'localConfig',
548
- formItems: res.formJson,
549
- serviceName: this.serviceName,
550
- getDataParams: this.getDataParams,
551
- simpleMode: res.simpleMode,
552
- funcData: res.funcData,
553
- env: this.env
554
- })
555
- } else {
556
- // TODO 此处应删除
557
- initTable()
558
- }
559
- // 初始化 xTable 子组件
560
- // 等待 x-from-item 的 mounted 完成
561
- this.$refs.xForm.$on('itemsMounted', initTable)
562
- }
563
- this.loading = false
564
- },
565
- // 自定义按钮
566
- editButtonStateDataClick (functionName, rows) {
567
- console.log('functionName', functionName)
568
- console.log('rows', rows)
569
- this.$emit(functionName, rows)
570
- },
571
-
572
- /**
573
- * 提交查询表单事件
574
- * @param res 参数
575
- */
576
- onSearchSubmit (res) {
577
- if (res.valid) {
578
- // 表单赋值
579
- this.$refs.xTable.setQueryForm(res.form)
580
- this.$refs.xTable.summaryUpdate = true
581
- // commit
582
- this.$emit('afterSearchSubmit', res)
583
- } else {
584
- return false
585
- }
586
- },
587
- active (props) {
588
- let num = false
589
- for (const key in props) {
590
- // eslint-disable-next-line no-prototype-builtins
591
- if (this.$props.hasOwnProperty(key)) {
592
- if (this.$props[key] instanceof Object) {
593
- this.$props[key] = JSON.parse(props[key])
594
- } else {
595
- this.$props[key] = props[key]
596
- }
597
- num = true
598
- }
599
- }
600
- if (num) {
601
- this.initConfig()
602
- }
603
- },
604
- /**
605
- * 提交新增/修改表单后事件
606
- */
607
- onAddOrEditSubmitAfterSubmit (res) {
608
- this.refreshTable(res.businessType === '新增')
609
- // commit
610
- this.$emit('afterSubmit', res)
611
- },
612
- /**
613
- * 表格查询后事件
614
- * @param res 参数
615
- * @param conditionParams 查询条件
616
- */
617
- afterQuery (res, conditionParams) {
618
- this.$emit('afterQuery', res, conditionParams)
619
- },
620
- /**
621
- * 详情按钮事件
622
- * @param record 本条数据
623
- * @param id 数据标识
624
- * @param actionType 操作类型
625
- * @param fun 向上级传递的事件
626
- */
627
- action (record, id, actionType, fun = 'action', index) {
628
- this.$emit('innerXFormTableEmit', fun, record, id, actionType, index)
629
- this.$emit(fun, record, id, actionType, index)
630
- },
631
- treeOnChecked (checkedKeys, deepNodes, deepKeys) {
632
- this.$emit('treeOnChecked', checkedKeys, deepNodes, deepKeys)
633
- },
634
- treeBtnFuncClick (index, func) {
635
- this.$emit('treeBtnFuncClick', index, func)
636
- },
637
- /**
638
- * 新增按钮事件
639
- */
640
- add () {
641
- if (this.customAdd) {
642
- this.$emit('add')
643
- } else {
644
- if (this.$listeners.curdAddBefore) {
645
- this.$emit('curdAddBefore', this.addFormInit)
646
- } else {
647
- this.addFormInit()
648
- }
649
- }
650
- },
651
- addFormInit () {
652
- const res = this.realQueryConfig
653
- const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
654
- this.$refs.xAddForm.init({
655
- businessType: '新增',
656
- title: this.title || res.title,
657
- isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
658
- configName: this.queryParamsName,
659
- configContent: this.queryParamsJson,
660
- formItems: res.formJson,
661
- viewMode: this.viewMode,
662
- localEditMode: localEditMode,
663
- isKeyHandle: !Boolean(localEditMode),
664
- serviceName: this.serviceName,
665
- fixedAddForm: this.fixedAddForm,
666
- getDataParams: this.getDataParams,
667
- layout: res.xAddFormLayout || 'horizontal',
668
- xAddFormLayoutWidth: res.xAddFormLayoutWidth,
669
- formItemLayout: res.formItemLayout || {},
670
- env: this.env
671
- })
672
- },
673
- /**
674
- * 添加按钮事件
675
- */
676
- move () {
677
- this.moveType = true
678
- this.$nextTick(
679
- () => {
680
- this.$refs.xAddReport.init({
681
- configName: this.moveconfig,
682
- selectedId: this.fixedAddForm.selected_id
683
- })
684
- }
685
- )
686
- },
687
- /**
688
- * 修改按钮事件
689
- * @param modifyModelData 修改表单数据
690
- */
691
- edit (modifyModelData) {
692
- if (this.customEdit) {
693
- this.$emit('edit')
694
- } else {
695
- const res = this.realQueryConfig
696
- const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
697
- this.$refs.xAddForm.init({
698
- businessType: '修改',
699
- title: this.title || res.title,
700
- isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
701
- configName: this.queryParamsName,
702
- configContent: this.queryParamsJson,
703
- formItems: res.formJson,
704
- viewMode: this.viewMode,
705
- localEditMode: localEditMode,
706
- isKeyHandle: !Boolean(localEditMode),
707
- serviceName: this.serviceName,
708
- fixedAddForm: this.fixedAddForm,
709
- getDataParams: this.getDataParams,
710
- modifyModelData: modifyModelData,
711
- layout: res.xAddFormLayout || 'horizontal',
712
- env: this.env
713
- })
714
- }
715
- },
716
- /**
717
- * 删除按钮事件
718
- */
719
- del (keys, callback) {
720
- if (this.customDelete) {
721
- this.$emit('del', keys, callback)
722
- }
723
- },
724
- /**
725
- * 删除后事件
726
- * @param res
727
- */
728
- afterDelete (res) {
729
- this.$emit('afterDelete', res)
730
- },
731
- /**
732
- * 行选择事件
733
- * @param row 选中行
734
- */
735
- rowChoose (row) {
736
- this.$emit('rowChoose', row)
737
- },
738
- /**
739
- * 本地编辑模式下校验表格并同步本地数据
740
- * @param currRow 当前行
741
- * @param defaultAppendRowData 默认追加的行数据
742
- */
743
- validateTableAndSyncData (currRow, defaultAppendRowData) {
744
- this.$refs.xTable.validateTableAndSyncData(currRow, defaultAppendRowData)
745
- },
746
- /**
747
- * 更多条件是否展示
748
- */
749
- toggleAdvanced () {
750
- this.$refs.xTable.setScrollYHeight({})
751
- },
752
- /**
753
- * 查询表单部分显示/隐藏切换
754
- */
755
- toggleIsFormShow () {
756
- this.toggleIsFormIcon = this.toggleIsFormIcon === 'vertical-align-top' ? 'vertical-align-bottom' : 'vertical-align-top'
757
- this.$refs.xForm.toggleVisible()
758
- this.$refs.xTable.setScrollYHeight({})
759
- },
760
- /**
761
- * 选择列事件
762
- * @param selectedRowKeys 选中列Key集合
763
- * @param selectedRows 选中列
764
- */
765
- selectRow (selectedRowKeys, selectedRows) {
766
- this.table_selectedRowKeys = selectedRowKeys
767
- this.table_selectedRows = selectedRows
768
- this.$emit('selectRow', selectedRowKeys, selectedRows)
769
- },
770
- /**
771
- * 清除勾选数据
772
- */
773
- clearRowKeys () {
774
- this.$refs.xTable.clearRowKeys()
775
- },
776
- /**
777
- * 刷新表格
778
- * @param toFirstPage 是否到第一页
779
- */
780
- refreshTable (toFirstPage = true) {
781
- this.$refs.xTable.refresh(toFirstPage)
782
- },
783
- /**
784
- * 刷新表格
785
- * @param toFirstPage 是否到第一页
786
- */
787
- refresh (toFirstPage = true) {
788
- this.$refs.xTable.refresh(toFirstPage)
789
- },
790
- /**
791
- * 获取表格数据
792
- */
793
- getTableData () {
794
- return this.$refs.xTable.getTableData()
795
- },
796
- // 在行编辑等情况下,让界面生效
797
- update () {
798
- this.getTableData().push(...[])
799
- },
800
-
801
- /**
802
- * 设置表格数据
803
- */
804
- setTableData (data) {
805
- this.$refs.xTable.setTableData(data)
806
- },
807
- /**
808
- * 表单本地提交
809
- */
810
- onLocalSubmit (res, callback) {
811
- const form = res.realForm
812
- if (res.businessType === '新增') {
813
- this.$refs.xTable.appendLocalData(form)
814
- } else {
815
- this.$refs.xTable.modifyLocalData(form['序号'], form)
816
- }
817
- this.$message.success(res.businessType + '成功!')
818
- this.onAddOrEditSubmitAfterSubmit(res, callback)
819
- if (callback) {
820
- callback()
821
- }
822
- },
823
- emitFunc (func, data, value) {
824
- this.$emit(func, data, value)
825
- this.$emit('getEmitFuncData', func, data, value)
826
- },
827
- // 直接转发事件的函数
828
- emitEvent (event, ...args) {
829
- this.$emit(event, ...args)
830
- },
831
- // 添加处理 rowClick 的方法
832
- handleRowClick (record) {
833
- this.$emit('rowClick', record)
834
- },
835
- beforeDataChange (record) {
836
- this.$emit('beforeDataChange', record)
837
- },
838
- onExpand (expanded, record) {
839
- this.$emit('expand', expanded, record)
840
- }
841
- },
842
- action: {
843
- /**
844
- * 实现doAction方法
845
- */
846
- doAction (actionType, args, data) {
847
- switch (actionType) {
848
- case 'refreshTable':
849
- for (const item in args) {
850
- console.log('item', item)
851
- }
852
- break
853
- default:
854
- break
855
- }
856
- }
857
- },
858
- mounted () {
859
- if (!this.isMounted) {
860
- // 防止多次调用
861
- // 不知道为啥他会执行两次 mounted 暂时处理方式
862
- this.initConfig()
863
- this.isMounted = true
864
- }
865
- if (this.getSelectedData && typeof this.getSelectedData === 'function') {
866
- const selectedId = this.getSelectedData()
867
- if (!selectedId) {
868
- return
869
- }
870
- if (typeof selectedId === 'object') {
871
- const data = JSON.parse(JSON.stringify(selectedId))
872
- if (data.selectedId) {
873
- data.selected_id = data.selectedId
874
- delete data.selectedId
875
- }
876
- Object.assign(this.fixedAddForm, data)
877
- Object.assign(this.fixedQueryForm, data)
878
- } else {
879
- Object.assign(this.fixedAddForm, { selected_id: selectedId })
880
- Object.assign(this.fixedQueryForm, { selected_id: selectedId })
881
- }
882
- }
883
- }
884
- }
885
- </script>
886
- <style lang="less" scoped>
887
- .crud_title {
888
- height: 32px;
889
- font-size: 16px;
890
- font-weight: 500;
891
- color: #000000d9;
892
- line-height: 32px;
893
- margin-bottom: 12px;
894
- }
895
- </style>
1
+ <template>
2
+ <a-row type="flex" :gutter="{ xs: 8, sm: 10, md: 12, lg: 16 }">
3
+ <a-col
4
+ :xs="14"
5
+ :sm="14"
6
+ :md="12"
7
+ :lg="9"
8
+ :xl="6"
9
+ :xxl="5"
10
+ v-if="xTreeConfigName"
11
+ :style="{ maxWidth: '400px'}">
12
+ <x-tree-pro
13
+ :config-name="xTreeConfigName"
14
+ :env="env"
15
+ @action="action"
16
+ @btnFuncClick="treeBtnFuncClick"
17
+ @treeOnChecked="treeOnChecked"
18
+ ref="xtree"
19
+ ></x-tree-pro>
20
+ </a-col>
21
+ <a-col
22
+ :xs="xTreeConfigName ? 10 : 24"
23
+ :sm="xTreeConfigName ? 10 : 24"
24
+ :md="xTreeConfigName ? 12 : 24"
25
+ :lg="xTreeConfigName ? 15 : 24"
26
+ :xl="xTreeConfigName ? 18 : 24"
27
+ :xxl="xTreeConfigName ? 19 : 24">
28
+ <a-skeleton :loading="loading" :paragraph="{ rows: 4 }"/>
29
+ <a-row style="height: 12px" v-if="xTreeConfigName"></a-row>
30
+ <div v-show="!loading">
31
+ <template v-if="!loadError">
32
+ <x-add-form
33
+ ref="xAddForm"
34
+ @onLocalSubmit="onLocalSubmit"
35
+ @x-form-item-emit-func="emitFunc"
36
+ @afterSubmit="onAddOrEditSubmitAfterSubmit"
37
+ >
38
+ <template slot="groupFormItems" slot-scope="{form, model, rules, modifyModelData}">
39
+ <slot
40
+ name="groupFormItems"
41
+ :form="form"
42
+ :model="model"
43
+ :rules="rules"
44
+ :modifyModelData="modifyModelData"></slot>
45
+ </template>
46
+ </x-add-form>
47
+ <x-add-report
48
+ v-if="moveType"
49
+ ref="xAddReport"
50
+ >
51
+ </x-add-report>
52
+ <div v-if="crudTitle" class="crud_title">
53
+ {{ crudTitle }}
54
+ </div>
55
+ <x-form
56
+ ref="xForm"
57
+ @toggleAdvanced="toggleAdvanced"
58
+ @onSubmit="onSearchSubmit">
59
+ <slot name="formBtnExpand"></slot>
60
+ </x-form>
61
+ <x-table
62
+ ref="xTable"
63
+ :fixedQueryForm="fixedQueryForm"
64
+ :queryParamsName="queryParamsName"
65
+ :query-params-json="queryParamsJson"
66
+ :show-pagination="showPagination"
67
+ :customDelete="customDelete"
68
+ :extraHeight="extraHeight"
69
+ :serviceName="serviceName"
70
+ :pageMaxSize="realQueryConfig.queryPagesSize"
71
+ :externalSelectedRowKeys="externalSelectedRowKeys"
72
+ @add="add"
73
+ @move="move"
74
+ @edit="edit"
75
+ @del="del"
76
+ @rowChoose="rowChoose"
77
+ @customEvent="customEvent"
78
+ @afterDelete="afterDelete"
79
+ @action="action"
80
+ @selectRow="selectRow"
81
+ @afterQuery="afterQuery"
82
+ @columnClick="columnClick"
83
+ @gotoUserDetail="gotoUserDetail"
84
+ @editButtonStateDataClick="editButtonStateDataClick"
85
+ @importExcelOk="importExcelOk"
86
+ @rowClick="handleRowClick"
87
+ @beforeDataChange="beforeDataChange"
88
+ @expand="onExpand">
89
+ <template slot="leftButton" slot-scope="{selectedRowKeys, selectedRows}">
90
+ <slot name="leftButton" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
91
+ </template>
92
+ <template slot="button" slot-scope="{selectedRowKeys, selectedRows}">
93
+ <slot name="button" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
94
+ </template>
95
+ <template slot="rightBtnExpand" slot-scope="{selectedRowKeys, selectedRows}">
96
+ <slot name="rightBtnExpand" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
97
+ <a-tooltip title="收起查询条件" placement="bottom">
98
+ <a-button @click="toggleIsFormShow">
99
+ <a-icon :style="iconStyle" :type="toggleIsFormIcon"/>
100
+ </a-button>
101
+ </a-tooltip>
102
+ </template>
103
+ <!-- 底部插槽 -->
104
+ <template slot="footer" slot-scope="{selectedRowKeys, selectedRows}">
105
+ <slot name="footer" :selectedRowKeys="selectedRowKeys" :selectedRows="selectedRows"></slot>
106
+ </template>
107
+ <!-- excel导入说明插槽 -->
108
+ <template #importExcelSlot>
109
+ <slot name="importExcelSlot"></slot>
110
+ </template>
111
+ </x-table>
112
+ </template>
113
+ <template v-else>
114
+ <a-empty>
115
+ <span slot="description"> 页面配置不存在,请联系系统管理员</span>
116
+ </a-empty>
117
+ </template>
118
+ </div>
119
+ </a-col>
120
+ <UserInfoDetailManage ref="userInfo" @close="refresh(false)"/>
121
+ </a-row>
122
+ </template>
123
+ <script>
124
+ import XForm from '@vue2-client/base-client/components/common/XForm'
125
+ import XAddForm from '@vue2-client/base-client/components/common/XAddForm'
126
+ import XAddReport from '@vue2-client/base-client/components/common/XAddReport'
127
+ import XTable from '@vue2-client/base-client/components/common/XTable'
128
+ import XTree from '@vue2-client/base-client/components/common/XTree'
129
+ import XImportExcel from '@vue2-client/base-client/components/common/XImportExcel'
130
+ import {
131
+ getConfigByName,
132
+ getConfigByLogic,
133
+ parseConfig, runLogic, getConfigByNameAsync,
134
+ } from '@vue2-client/services/api/common'
135
+ import { mapState } from 'vuex'
136
+ import XTreePro from '@vue2-client/base-client/components/common/XTree/XTreePro.vue'
137
+ import { executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
138
+ import { getRealKeyData } from '@vue2-client/utils/util'
139
+ import * as util from '@vue2-client/utils/util'
140
+ import UserInfoDetailManage from '@vue2-client/pages/userInfoDetailManage/index.vue'
141
+
142
+ export default {
143
+ name: 'XFormTable',
144
+ components: {
145
+ UserInfoDetailManage,
146
+ XTreePro,
147
+ XTable,
148
+ XForm,
149
+ XTree,
150
+ XAddForm,
151
+ XAddReport,
152
+ XImportExcel
153
+ },
154
+ provide () {
155
+ return {
156
+ getSelf: () => this,
157
+ emitEvent: this.emitEvent.bind(this)
158
+ }
159
+ },
160
+ inject: {
161
+ getSelectedId: {
162
+ default: () => () => {
163
+ console.warn('getSelectedId is not provided.')
164
+ return null
165
+ },
166
+ },
167
+ setGlobalData: {
168
+ default: () => () => {
169
+ console.warn('setGlobalData is not provided.')
170
+ return null
171
+ },
172
+ },
173
+ getGlobalData: {
174
+ default: () => () => {
175
+ console.warn('getGlobalData is not provided.')
176
+ return null
177
+ },
178
+ },
179
+ getSelectedData: {
180
+ default: () => () => {
181
+ console.warn('getSelectedData is not provided.')
182
+ return null
183
+ },
184
+ },
185
+ getMixinData: {
186
+ default: () => () => {
187
+ console.warn('getMixinData is not provided.')
188
+ return {}
189
+ },
190
+ },
191
+ getOutEnv: {
192
+ default: () => () => {
193
+ console.warn('getOutEnv is not provided.')
194
+ return {}
195
+ },
196
+ },
197
+ currUser: {
198
+ default: () => {
199
+ console.warn('currUser is not provided.')
200
+ return { id: null, name: 'Guest' }
201
+ },
202
+ },
203
+ },
204
+ data () {
205
+ return {
206
+ // 加载状态
207
+ loading: false,
208
+ // 图标样式
209
+ iconStyle: {
210
+ position: 'relative',
211
+ top: '1px'
212
+ },
213
+ loadError: false,
214
+ moveType: false,
215
+ // 添加按钮对应的配置名
216
+ moveconfig: '',
217
+ // 实际查询配置内容
218
+ realQueryConfig: {},
219
+ toggleIsFormIcon: 'vertical-align-top',
220
+ table_selectedRowKeys: [],
221
+ table_selectedRows: [],
222
+ // 数据只有一页时是否展示分页,true:展示,auto:隐藏
223
+ showPagination: true,
224
+ isMounted: false
225
+ }
226
+ },
227
+ computed: {
228
+ ...mapState('setting', ['isMobile'])
229
+ },
230
+ props: {
231
+ // 业务名称
232
+ title: {
233
+ type: String,
234
+ default: ''
235
+ },
236
+ // 外部传入的选中行keys
237
+ externalSelectedRowKeys: {
238
+ type: Array,
239
+ default: () => []
240
+ },
241
+ // 卡片标题
242
+ crudTitle: {
243
+ type: String,
244
+ default: null
245
+ },
246
+ // 查询配置文件名
247
+ queryParamsName: {
248
+ type: String,
249
+ default: null
250
+ },
251
+ // 配置所属命名空间
252
+ serviceName: {
253
+ type: String,
254
+ default: process.env.VUE_APP_SYSTEM_NAME
255
+ },
256
+ // 查询配置文件Json,用于查询配置生成器的预览
257
+ queryParamsJson: {
258
+ type: Object,
259
+ default: null
260
+ },
261
+ // xTree 配置
262
+ xTreeConfigName: {
263
+ type: String,
264
+ default: null
265
+ },
266
+ // 业务逻辑名称, 通过logic获取表单表格配置
267
+ logicName: {
268
+ type: String,
269
+ default: null
270
+ },
271
+ // 执行logic传递的参数
272
+ logicParam: {
273
+ type: Object,
274
+ default: () => {
275
+ }
276
+ },
277
+ // 固定新增表单
278
+ fixedAddForm: {
279
+ type: Object,
280
+ default: () => {
281
+ return {}
282
+ }
283
+ },
284
+ // 固定查询表单
285
+ fixedQueryForm: {
286
+ type: Object,
287
+ default: () => {
288
+ return {}
289
+ }
290
+ },
291
+ // 预览模式
292
+ viewMode: {
293
+ type: Boolean,
294
+ default: () => {
295
+ return false
296
+ }
297
+ },
298
+ // 本地编辑模式
299
+ localEditMode: {
300
+ type: Boolean,
301
+ default: () => {
302
+ return false
303
+ }
304
+ },
305
+ // 行选择模式
306
+ rowSelectMode: {
307
+ type: Boolean,
308
+ default: () => {
309
+ return false
310
+ }
311
+ },
312
+ // 行选择模式-允许选中行数量,0:任意数量行,大于0:指定值数量的行
313
+ allowSelectRowNum: {
314
+ type: Number,
315
+ default: () => {
316
+ return 0
317
+ }
318
+ },
319
+ // 环境
320
+ env: {
321
+ type: String,
322
+ default: () => {
323
+ return 'prod'
324
+ }
325
+ },
326
+ // 调用logic获取数据源的追加参数
327
+ getDataParams: {
328
+ type: Object,
329
+ default: undefined
330
+ },
331
+ // 可以控制组件中导出等按钮的隐藏
332
+ buttonState: {
333
+ type: Object,
334
+ default: undefined
335
+ },
336
+ // 是否自定义新增按钮的功能
337
+ customAdd: {
338
+ type: Boolean,
339
+ default: false
340
+ },
341
+ reportQueryName: {
342
+ type: String,
343
+ default: undefined,
344
+ },
345
+ // 是否自定义删除按钮的功能
346
+ customDelete: {
347
+ type: Boolean,
348
+ default: false
349
+ },
350
+ // 是否自定义修改按钮的功能
351
+ customEdit: {
352
+ type: Boolean,
353
+ default: false
354
+ },
355
+ // 是否自定义增加按钮
356
+ customMove: {
357
+ type: Boolean,
358
+ default: false
359
+ },
360
+ // 自适应底部边距
361
+ extraHeight: {
362
+ type: Number,
363
+ default: 80
364
+ }
365
+ },
366
+ watch: {
367
+ logicParam: {
368
+ handler () {
369
+ this.initConfig()
370
+ },
371
+ deep: true
372
+ },
373
+ queryParamsJson: {
374
+ handler () {
375
+ this.initConfig()
376
+ },
377
+ deep: true
378
+ },
379
+ queryParamsName: {
380
+ handler () {
381
+ this.initConfig()
382
+ }
383
+ },
384
+ serviceName: {
385
+ handler () {
386
+ this.initConfig()
387
+ }
388
+ }
389
+ },
390
+ methods: {
391
+ runLogic,
392
+ getRealKeyData,
393
+ getConfigByNameAsync,
394
+ getConfigByName,
395
+ customEvent (func, data) {
396
+ this.$emit(func, data)
397
+ },
398
+ columnClick (key, value, record) {
399
+ this.$emit('columnClick', key, value, record)
400
+ },
401
+ gotoUserDetail (key, value, record) {
402
+ this.$refs.userInfo.init(getRealKeyData(record))
403
+ },
404
+ // 获取主表的数据内容,去掉主表别名
405
+ getPrimaryData (rows) {
406
+ const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
407
+ const prefix = `${alias}_` // 构建前缀
408
+ const result = []
409
+
410
+ // 遍历 rows 的每一项,提取符合条件的数据
411
+ rows.forEach(row => {
412
+ const itemResult = {}
413
+ Object.keys(row).forEach(key => {
414
+ if (key.startsWith(prefix)) {
415
+ const newKey = key.slice(prefix.length) // 去掉前缀
416
+ itemResult[newKey] = row[key] // 添加到结果对象中
417
+ }
418
+ })
419
+ result.push(itemResult) // 将处理后的项添加到结果数组中
420
+ })
421
+
422
+ return result // 返回去掉前缀后的对象数组
423
+ },
424
+
425
+ // 给数据区域添加主表数据,给的数据没有主表别名,放着时添加主表别名
426
+ pushPrimaryData (rows) {
427
+ const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
428
+ const prefix = `${alias}_` // 构建前缀
429
+ const result = rows.map(row => {
430
+ const itemResult = {}
431
+ Object.keys(row).forEach(key => {
432
+ itemResult[prefix + key] = row[key] // 复制原始数据
433
+ })
434
+ return itemResult // 返回添加了主表别名的数据
435
+ })
436
+ // 把结果添加到数据区
437
+ this.getTableData().push(...result)
438
+ },
439
+
440
+ // 设置固定查询条件,主表别名自动带
441
+ setFixedQueryForm (data) {
442
+ const alias = this.realQueryConfig.tableAliasName // 获取主表的别名
443
+ const prefixedData = {}
444
+
445
+ // 为每个键添加主表别名
446
+ Object.keys(data).forEach(key => {
447
+ prefixedData[`${alias}_${key}`] = data[key]
448
+ })
449
+
450
+ Object.assign(this.fixedQueryForm, prefixedData)
451
+ },
452
+
453
+ importExcelOk (data) {
454
+ this.$emit('importExcelOk', data)
455
+ },
456
+ initConfig () {
457
+ this.loading = true
458
+ this.loadError = false
459
+ if (this.queryParamsName) {
460
+ this.getConfig()
461
+ } else if (this.queryParamsJson) {
462
+ this.getConfigBySource()
463
+ } else if (this.logicName && this.logicParam) {
464
+ this.getColumnJsonByLogic()
465
+ } else {
466
+ this.loading = false
467
+ this.loadError = true
468
+ }
469
+ },
470
+
471
+ getConfig () {
472
+ getConfigByName(this.queryParamsName, this.serviceName, (res) => {
473
+ if (!res) {
474
+ this.loading = false
475
+ this.loadError = true
476
+ return
477
+ }
478
+ this.updateComponents(res)
479
+ }, this.env === 'dev')
480
+ },
481
+ getConfigBySource () {
482
+ parseConfig(this.queryParamsJson, 'CRUD_FORM', this.serviceName, this.env === 'dev').then(res => {
483
+ if (!res) {
484
+ this.loading = false
485
+ this.loadError = true
486
+ return
487
+ }
488
+ this.updateComponents(res, true)
489
+ })
490
+ },
491
+ getColumnJsonByLogic () {
492
+ getConfigByLogic(this.logicName, this.logicParam, this.serviceName, (res) => {
493
+ if (!res) {
494
+ this.loading = false
495
+ this.loadError = true
496
+ return
497
+ }
498
+ this.updateComponents(res, true)
499
+ }, this.env === 'dev')
500
+ },
501
+
502
+ /**
503
+ * 更新子组件
504
+ * @param res 参数
505
+ * @param setQueryParams 是否设置queryParams参数
506
+ */
507
+ updateComponents (res, setQueryParams) {
508
+ this.realQueryConfig = res
509
+ if (this.$refs.xTable && this.$refs.xForm && this.$refs.xAddForm) {
510
+ // 设置添加按钮对应的配置名
511
+ this.moveconfig = res.moveconfig
512
+ this.showPagination = res.showPagination === null ? true : res.showPagination
513
+ // 是否展示排序按钮控制
514
+ if (res.showSortIcon !== null && !res.showSortIcon) {
515
+ res.columnJson.forEach(item => {
516
+ item.sorter = false
517
+ })
518
+ }
519
+ const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
520
+ const initTable = () => {
521
+ // 初始化 xTable 子组件
522
+ this.$refs.xTable.init({
523
+ formItems: res.formJson,
524
+ queryParams: setQueryParams ? res : null,
525
+ tableColumns: res.columnJson,
526
+ buttonState: Object.assign(res.buttonState, this.buttonState),
527
+ title: this.title || res.title,
528
+ viewMode: this.viewMode,
529
+ localEditMode: localEditMode,
530
+ rowSelectMode: this.rowSelectMode,
531
+ allowSelectRowNum: this.allowSelectRowNum,
532
+ tableSummaryMap: res.tableSummaryMap,
533
+ serviceName: this.serviceName,
534
+ env: this.env,
535
+ form: this.$refs.xForm.form,
536
+ summaryUpdate: true,
537
+ ...res
538
+ })
539
+ if (this.realQueryConfig?.funcData?.pageMounted) {
540
+ executeStrFunctionByContext(this, this.realQueryConfig.funcData.pageMounted, [util, runLogic, getConfigByNameAsync])
541
+ }
542
+ this.$emit('afterTableInit')
543
+ }
544
+ // 初始化 xForm 子组件
545
+ if (!localEditMode && !this.rowSelectMode) {
546
+ this.$refs.xForm.init({
547
+ queryParamsName: this.queryParamsName || 'localConfig',
548
+ formItems: res.formJson,
549
+ serviceName: this.serviceName,
550
+ getDataParams: this.getDataParams,
551
+ simpleMode: res.simpleMode,
552
+ funcData: res.funcData,
553
+ env: this.env
554
+ })
555
+ } else {
556
+ // TODO 此处应删除
557
+ initTable()
558
+ }
559
+ // 初始化 xTable 子组件
560
+ // 等待 x-from-item 的 mounted 完成
561
+ this.$refs.xForm.$on('itemsMounted', initTable)
562
+ }
563
+ this.loading = false
564
+ },
565
+ // 自定义按钮
566
+ editButtonStateDataClick (functionName, rows) {
567
+ console.log('functionName', functionName)
568
+ console.log('rows', rows)
569
+ this.$emit(functionName, rows)
570
+ },
571
+
572
+ /**
573
+ * 提交查询表单事件
574
+ * @param res 参数
575
+ */
576
+ onSearchSubmit (res) {
577
+ if (res.valid) {
578
+ // 表单赋值
579
+ this.$refs.xTable.setQueryForm(res.form)
580
+ this.$refs.xTable.summaryUpdate = true
581
+ // commit
582
+ this.$emit('afterSearchSubmit', res)
583
+ } else {
584
+ return false
585
+ }
586
+ },
587
+ active (props) {
588
+ let num = false
589
+ for (const key in props) {
590
+ // eslint-disable-next-line no-prototype-builtins
591
+ if (this.$props.hasOwnProperty(key)) {
592
+ if (this.$props[key] instanceof Object) {
593
+ this.$props[key] = JSON.parse(props[key])
594
+ } else {
595
+ this.$props[key] = props[key]
596
+ }
597
+ num = true
598
+ }
599
+ }
600
+ if (num) {
601
+ this.initConfig()
602
+ }
603
+ },
604
+ /**
605
+ * 提交新增/修改表单后事件
606
+ */
607
+ onAddOrEditSubmitAfterSubmit (res) {
608
+ this.refreshTable(res.businessType === '新增')
609
+ // commit
610
+ this.$emit('afterSubmit', res)
611
+ },
612
+ /**
613
+ * 表格查询后事件
614
+ * @param res 参数
615
+ * @param conditionParams 查询条件
616
+ */
617
+ afterQuery (res, conditionParams) {
618
+ this.$emit('afterQuery', res, conditionParams)
619
+ },
620
+ /**
621
+ * 详情按钮事件
622
+ * @param record 本条数据
623
+ * @param id 数据标识
624
+ * @param actionType 操作类型
625
+ * @param fun 向上级传递的事件
626
+ */
627
+ action (record, id, actionType, fun = 'action', index) {
628
+ this.$emit('innerXFormTableEmit', fun, record, id, actionType, index)
629
+ this.$emit(fun, record, id, actionType, index)
630
+ },
631
+ treeOnChecked (checkedKeys, deepNodes, deepKeys) {
632
+ this.$emit('treeOnChecked', checkedKeys, deepNodes, deepKeys)
633
+ },
634
+ treeBtnFuncClick (index, func) {
635
+ this.$emit('treeBtnFuncClick', index, func)
636
+ },
637
+ /**
638
+ * 新增按钮事件
639
+ */
640
+ add () {
641
+ if (this.customAdd) {
642
+ this.$emit('add')
643
+ } else {
644
+ if (this.$listeners.curdAddBefore) {
645
+ this.$emit('curdAddBefore', this.addFormInit)
646
+ } else {
647
+ this.addFormInit()
648
+ }
649
+ }
650
+ },
651
+ addFormInit () {
652
+ const res = this.realQueryConfig
653
+ const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
654
+ this.$refs.xAddForm.init({
655
+ businessType: '新增',
656
+ title: this.title || res.title,
657
+ isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
658
+ configName: this.queryParamsName,
659
+ configContent: this.queryParamsJson,
660
+ formItems: res.formJson,
661
+ viewMode: this.viewMode,
662
+ localEditMode: localEditMode,
663
+ isKeyHandle: !Boolean(localEditMode),
664
+ serviceName: this.serviceName,
665
+ fixedAddForm: this.fixedAddForm,
666
+ getDataParams: this.getDataParams,
667
+ layout: res.xAddFormLayout || 'horizontal',
668
+ xAddFormLayoutWidth: res.xAddFormLayoutWidth,
669
+ formItemLayout: res.formItemLayout || {},
670
+ env: this.env
671
+ })
672
+ },
673
+ /**
674
+ * 添加按钮事件
675
+ */
676
+ move () {
677
+ this.moveType = true
678
+ this.$nextTick(
679
+ () => {
680
+ this.$refs.xAddReport.init({
681
+ configName: this.moveconfig,
682
+ selectedId: this.fixedAddForm.selected_id
683
+ })
684
+ }
685
+ )
686
+ },
687
+ /**
688
+ * 修改按钮事件
689
+ * @param modifyModelData 修改表单数据
690
+ */
691
+ edit (modifyModelData) {
692
+ if (this.customEdit) {
693
+ this.$emit('edit')
694
+ } else {
695
+ const res = this.realQueryConfig
696
+ const localEditMode = !this.localEditMode ? res.localEditMode : this.localEditMode
697
+ this.$refs.xAddForm.init({
698
+ businessType: '修改',
699
+ title: this.title || res.title,
700
+ isShow: !res.buttonState || res.buttonState.add || res.buttonState.edit,
701
+ configName: this.queryParamsName,
702
+ configContent: this.queryParamsJson,
703
+ formItems: res.formJson,
704
+ viewMode: this.viewMode,
705
+ localEditMode: localEditMode,
706
+ isKeyHandle: !Boolean(localEditMode),
707
+ serviceName: this.serviceName,
708
+ fixedAddForm: this.fixedAddForm,
709
+ getDataParams: this.getDataParams,
710
+ modifyModelData: modifyModelData,
711
+ layout: res.xAddFormLayout || 'horizontal',
712
+ env: this.env
713
+ })
714
+ }
715
+ },
716
+ /**
717
+ * 删除按钮事件
718
+ */
719
+ del (keys, callback) {
720
+ if (this.customDelete) {
721
+ this.$emit('del', keys, callback)
722
+ }
723
+ },
724
+ /**
725
+ * 删除后事件
726
+ * @param res
727
+ */
728
+ afterDelete (res) {
729
+ this.$emit('afterDelete', res)
730
+ },
731
+ /**
732
+ * 行选择事件
733
+ * @param row 选中行
734
+ */
735
+ rowChoose (row) {
736
+ this.$emit('rowChoose', row)
737
+ },
738
+ /**
739
+ * 本地编辑模式下校验表格并同步本地数据
740
+ * @param currRow 当前行
741
+ * @param defaultAppendRowData 默认追加的行数据
742
+ */
743
+ validateTableAndSyncData (currRow, defaultAppendRowData) {
744
+ this.$refs.xTable.validateTableAndSyncData(currRow, defaultAppendRowData)
745
+ },
746
+ /**
747
+ * 更多条件是否展示
748
+ */
749
+ toggleAdvanced () {
750
+ this.$refs.xTable.setScrollYHeight({})
751
+ },
752
+ /**
753
+ * 查询表单部分显示/隐藏切换
754
+ */
755
+ toggleIsFormShow () {
756
+ this.toggleIsFormIcon = this.toggleIsFormIcon === 'vertical-align-top' ? 'vertical-align-bottom' : 'vertical-align-top'
757
+ this.$refs.xForm.toggleVisible()
758
+ this.$refs.xTable.setScrollYHeight({})
759
+ },
760
+ /**
761
+ * 选择列事件
762
+ * @param selectedRowKeys 选中列Key集合
763
+ * @param selectedRows 选中列
764
+ */
765
+ selectRow (selectedRowKeys, selectedRows) {
766
+ this.table_selectedRowKeys = selectedRowKeys
767
+ this.table_selectedRows = selectedRows
768
+ this.$emit('selectRow', selectedRowKeys, selectedRows)
769
+ },
770
+ /**
771
+ * 清除勾选数据
772
+ */
773
+ clearRowKeys () {
774
+ this.$refs.xTable.clearRowKeys()
775
+ },
776
+ /**
777
+ * 刷新表格
778
+ * @param toFirstPage 是否到第一页
779
+ */
780
+ refreshTable (toFirstPage = true) {
781
+ this.$refs.xTable.refresh(toFirstPage)
782
+ },
783
+ /**
784
+ * 刷新表格
785
+ * @param toFirstPage 是否到第一页
786
+ */
787
+ refresh (toFirstPage = true) {
788
+ this.$refs.xTable.refresh(toFirstPage)
789
+ },
790
+ /**
791
+ * 获取表格数据
792
+ */
793
+ getTableData () {
794
+ return this.$refs.xTable.getTableData()
795
+ },
796
+ // 在行编辑等情况下,让界面生效
797
+ update () {
798
+ this.getTableData().push(...[])
799
+ },
800
+
801
+ /**
802
+ * 设置表格数据
803
+ */
804
+ setTableData (data) {
805
+ this.$refs.xTable.setTableData(data)
806
+ },
807
+ /**
808
+ * 表单本地提交
809
+ */
810
+ onLocalSubmit (res, callback) {
811
+ const form = res.realForm
812
+ if (res.businessType === '新增') {
813
+ this.$refs.xTable.appendLocalData(form)
814
+ } else {
815
+ this.$refs.xTable.modifyLocalData(form['序号'], form)
816
+ }
817
+ this.$message.success(res.businessType + '成功!')
818
+ this.onAddOrEditSubmitAfterSubmit(res, callback)
819
+ if (callback) {
820
+ callback()
821
+ }
822
+ },
823
+ emitFunc (func, data, value) {
824
+ this.$emit(func, data, value)
825
+ this.$emit('getEmitFuncData', func, data, value)
826
+ },
827
+ // 直接转发事件的函数
828
+ emitEvent (event, ...args) {
829
+ this.$emit(event, ...args)
830
+ },
831
+ // 添加处理 rowClick 的方法
832
+ handleRowClick (record) {
833
+ this.$emit('rowClick', record)
834
+ },
835
+ beforeDataChange (record) {
836
+ this.$emit('beforeDataChange', record)
837
+ },
838
+ onExpand (expanded, record) {
839
+ this.$emit('expand', expanded, record)
840
+ }
841
+ },
842
+ action: {
843
+ /**
844
+ * 实现doAction方法
845
+ */
846
+ doAction (actionType, args, data) {
847
+ switch (actionType) {
848
+ case 'refreshTable':
849
+ for (const item in args) {
850
+ console.log('item', item)
851
+ }
852
+ break
853
+ default:
854
+ break
855
+ }
856
+ }
857
+ },
858
+ mounted () {
859
+ if (!this.isMounted) {
860
+ // 防止多次调用
861
+ // 不知道为啥他会执行两次 mounted 暂时处理方式
862
+ this.initConfig()
863
+ this.isMounted = true
864
+ }
865
+ if (this.getSelectedData && typeof this.getSelectedData === 'function') {
866
+ const selectedId = this.getSelectedData()
867
+ if (!selectedId) {
868
+ return
869
+ }
870
+ if (typeof selectedId === 'object') {
871
+ const data = JSON.parse(JSON.stringify(selectedId))
872
+ if (data.selectedId) {
873
+ data.selected_id = data.selectedId
874
+ delete data.selectedId
875
+ }
876
+ Object.assign(this.fixedAddForm, data)
877
+ Object.assign(this.fixedQueryForm, data)
878
+ } else {
879
+ Object.assign(this.fixedAddForm, { selected_id: selectedId })
880
+ Object.assign(this.fixedQueryForm, { selected_id: selectedId })
881
+ }
882
+ }
883
+ }
884
+ }
885
+ </script>
886
+ <style lang="less" scoped>
887
+ .crud_title {
888
+ height: 32px;
889
+ font-size: 16px;
890
+ font-weight: 500;
891
+ color: #000000d9;
892
+ line-height: 32px;
893
+ margin-bottom: 12px;
894
+ }
895
+ </style>