vue2-client 1.10.29 → 1.10.31

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