vue2-client 1.14.15 → 1.14.16

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 (373) 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.scada +19 -19
  6. package/.eslintrc.js +90 -90
  7. package/CHANGELOG.md +824 -824
  8. package/Components.md +60 -60
  9. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +45 -45
  10. package/docs/LowCode/lowcode.md +155 -155
  11. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  12. package/docs/index.md +30 -30
  13. package/index.js +31 -31
  14. package/jest-transform-stub.js +8 -8
  15. package/jest.setup.js +7 -7
  16. package/jsconfig.json +19 -19
  17. package/package.json +1 -1
  18. package/public/his/editor/editor.html +51 -51
  19. package/public/his/editor/mock/bind_data.html +779 -779
  20. package/public/his/editor/mock/data_table.html +40 -40
  21. package/public/his/editor/mock/sign.html +75 -75
  22. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  23. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  24. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  25. package/public/his/editor/vender/date97/calendar.js +4 -4
  26. package/public/his/editor/vender/date97/lang/en.js +13 -13
  27. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  29. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  30. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  31. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  32. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  33. package/public/his/editor/vender/diff.js +1627 -1627
  34. package/public/his/editor/vender/editor.js +1 -1
  35. package/public/his/editor/vender/fabric.js +31187 -31187
  36. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  37. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  38. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  39. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  40. package/public/his/editor/vender/mui/mui.min.css +4 -4
  41. package/public/his/editor/vender/mui/mui.min.js +5 -5
  42. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  43. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  44. package/public/his/editor/vender/qrcode.js +7 -7
  45. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  46. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  47. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  48. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  49. package/public/his/editor/vender/validator.js +5094 -5094
  50. package/public/his/editor/vender/weui/weui.css +5659 -5659
  51. package/public/his/editor/vender/weui/weui.min.css +4 -4
  52. package/public/his/editor/vender/weui/weui.min.js +11 -11
  53. package/public/index.html +27 -27
  54. package/src/ReportView.js +19 -19
  55. package/src/assets/img/querySlotDemo.svg +15 -15
  56. package/src/assets/svg/badtwo.svg +1 -1
  57. package/src/assets/svg/goodtwo.svg +1 -1
  58. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  59. package/src/base-client/components/AI/demo.vue +31 -31
  60. package/src/base-client/components/common/AMisRender/index.js +3 -3
  61. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  62. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +470 -470
  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/FormGroupEdit.vue +1 -0
  78. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  79. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  80. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  81. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  82. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  83. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  84. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  85. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  86. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  87. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  88. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  89. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  90. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  96. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  97. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  98. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  99. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  100. package/src/base-client/components/common/Recording/index.js +3 -3
  101. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  102. package/src/base-client/components/common/Tree/index.js +2 -2
  103. package/src/base-client/components/common/Upload/index.js +3 -3
  104. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  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/XDataCard/index.js +3 -3
  120. package/src/base-client/components/common/XDataCard/index.md +1 -1
  121. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  122. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  123. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  124. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  125. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  126. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  127. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  128. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  129. package/src/base-client/components/common/XForm/XFormItem.vue +0 -9
  130. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  131. package/src/base-client/components/common/XForm/index.md +178 -178
  132. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  133. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  134. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  135. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  136. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  137. package/src/base-client/components/common/XFormTable/XFormTable.vue +4 -0
  138. package/src/base-client/components/common/XFormTable/demo.vue +2 -1
  139. package/src/base-client/components/common/XFormTable/index.md +92 -92
  140. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +167 -167
  141. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  142. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  143. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  144. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  145. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  146. package/src/base-client/components/common/XPrint/PrintBill.vue +302 -302
  147. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  148. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  149. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  150. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  151. package/src/base-client/components/common/XPrint/index.vue +97 -97
  152. package/src/base-client/components/common/XReport/XReport.vue +892 -892
  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/XReport.vue +35 -1
  160. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +6 -1
  161. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  162. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  163. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  164. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  165. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  166. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  167. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  168. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  169. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  170. package/src/base-client/components/common/XStepView/index.js +3 -3
  171. package/src/base-client/components/common/XStepView/index.md +31 -31
  172. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  173. package/src/base-client/components/common/XTab/index.js +3 -3
  174. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  175. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  176. package/src/base-client/components/common/XTable/XTable.vue +5 -0
  177. package/src/base-client/components/common/XTable/XTableWrapper.vue +5 -0
  178. package/src/base-client/components/common/XTable/index.md +255 -255
  179. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  180. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  181. package/src/base-client/components/common/XTree/index.js +3 -3
  182. package/src/base-client/components/common/XTree/index.md +36 -36
  183. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  184. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  185. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  186. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  187. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +1 -0
  188. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  189. package/src/base-client/components/his/XList/XList.vue +14 -5
  190. package/src/base-client/components/his/XSidebar/XSidebar.vue +3 -3
  191. package/src/base-client/components/index.js +51 -51
  192. package/src/base-client/components/layout/XPageView/XErrorView.vue +11 -11
  193. package/src/base-client/components/layout/XPageView/XPageView.vue +155 -155
  194. package/src/base-client/components/layout/XPageView/index.js +3 -3
  195. package/src/base-client/components/layout/XPageView/index.md +38 -38
  196. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  197. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  198. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  199. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  200. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  201. package/src/base-client/plugins/Config.js +19 -19
  202. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  203. package/src/base-client/plugins/Recording.js +258 -258
  204. package/src/base-client/plugins/index.js +23 -23
  205. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  206. package/src/components/Charts/Bar.vue +62 -62
  207. package/src/components/Charts/ChartCard.vue +134 -134
  208. package/src/components/Charts/Liquid.vue +67 -67
  209. package/src/components/Charts/MiniArea.vue +39 -39
  210. package/src/components/Charts/MiniBar.vue +39 -39
  211. package/src/components/Charts/MiniProgress.vue +75 -75
  212. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  213. package/src/components/Charts/Radar.vue +68 -68
  214. package/src/components/Charts/RankList.vue +77 -77
  215. package/src/components/Charts/TagCloud.vue +113 -113
  216. package/src/components/Charts/TransferBar.vue +64 -64
  217. package/src/components/Charts/Trend.vue +82 -82
  218. package/src/components/Charts/chart.less +12 -12
  219. package/src/components/Charts/smooth.area.less +13 -13
  220. package/src/components/CodeMirror/inedx.vue +118 -118
  221. package/src/components/CodeMirror/setting.js +40 -40
  222. package/src/components/HeightScanner/index.vue +571 -571
  223. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  224. package/src/components/NumberInfo/index.js +3 -3
  225. package/src/components/NumberInfo/index.less +54 -54
  226. package/src/components/NumberInfo/index.md +43 -43
  227. package/src/components/STable/index.js +12 -0
  228. package/src/components/card/ChartCard.vue +79 -79
  229. package/src/components/chart/Bar.vue +60 -60
  230. package/src/components/chart/MiniArea.vue +67 -67
  231. package/src/components/chart/MiniBar.vue +59 -59
  232. package/src/components/chart/MiniProgress.vue +57 -57
  233. package/src/components/chart/Radar.vue +80 -80
  234. package/src/components/chart/RankingList.vue +60 -60
  235. package/src/components/chart/Trend.vue +79 -79
  236. package/src/components/chart/index.less +9 -9
  237. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  238. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  239. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  240. package/src/components/checkbox/index.js +9 -9
  241. package/src/components/exception/ExceptionPage.vue +70 -70
  242. package/src/components/g2Charts/constants.js +202 -202
  243. package/src/components/g2Charts/demo.vue +808 -808
  244. package/src/components/g2Charts/designer.vue +228 -228
  245. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  246. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  247. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  248. package/src/components/g2Charts/index.vue +397 -397
  249. package/src/components/index.js +36 -36
  250. package/src/components/input/IInput.vue +66 -66
  251. package/src/components/menu/SideMenu.vue +75 -75
  252. package/src/components/menu/menu.js +273 -273
  253. package/src/components/setting/Setting.vue +234 -234
  254. package/src/components/tool/AStepItem.vue +60 -60
  255. package/src/config/CreateQueryConfig.js +325 -325
  256. package/src/config/default/antd.config.js +89 -89
  257. package/src/config/default/setting.config.js +55 -55
  258. package/src/font-style/font.css +4 -4
  259. package/src/layouts/CommonLayout.vue +56 -56
  260. package/src/layouts/PageLayout.vue +151 -151
  261. package/src/layouts/SinglePageView.vue +136 -136
  262. package/src/layouts/header/AdminHeader.vue +132 -132
  263. package/src/layouts/header/HeaderNotice.vue +177 -177
  264. package/src/layouts/header/InstitutionDetail.vue +181 -181
  265. package/src/layouts/tabs/TabsHead.vue +189 -189
  266. package/src/layouts/tabs/TabsView.vue +389 -389
  267. package/src/lib.js +1 -1
  268. package/src/main.js +34 -34
  269. package/src/mock/extend/index.js +84 -84
  270. package/src/mock/goods/index.js +108 -108
  271. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  272. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  273. package/src/pages/DefaultExample/index.vue +77 -77
  274. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  275. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  276. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  277. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  278. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  279. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  280. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  281. package/src/pages/DynamicStatistics/index.vue +282 -282
  282. package/src/pages/Example/childIndex.vue +15 -15
  283. package/src/pages/Example/index.vue +30 -30
  284. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  285. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  286. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  287. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  288. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  289. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  290. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  291. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  292. package/src/pages/Recording/index.vue +77 -77
  293. package/src/pages/ServiceReview/index.vue +284 -284
  294. package/src/pages/SubExample/index.vue +26 -26
  295. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +131 -131
  296. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  297. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +302 -302
  298. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +276 -276
  299. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +997 -997
  300. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +222 -222
  301. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +233 -233
  302. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +261 -261
  303. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +248 -248
  304. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +73 -73
  305. package/src/pages/XPageViewExample/index.vue +38 -38
  306. package/src/pages/XReportView/index.vue +64 -64
  307. package/src/pages/XTreeOneProExample/index.vue +67 -67
  308. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  309. package/src/pages/login/Login.vue +378 -378
  310. package/src/pages/login/LoginV3.vue +389 -389
  311. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  312. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  313. package/src/pages/report/ReportTable.js +124 -124
  314. package/src/pages/resourceManage/orgListManage.vue +98 -98
  315. package/src/pages/system/dictionary/index.vue +44 -44
  316. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  317. package/src/pages/system/monitor/operLog/index.vue +37 -37
  318. package/src/pages/system/settings/modifyPassword.vue +117 -117
  319. package/src/pages/system/ticket/index.vue +480 -480
  320. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  321. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  322. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +76 -76
  323. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +74 -74
  324. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  325. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  326. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +74 -74
  327. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  328. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +74 -74
  329. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  330. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +86 -86
  331. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +73 -73
  332. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  333. package/src/pages/userInfoDetailManage/index.vue +2 -2
  334. package/src/plugins/EventLogPlugin.js +33 -33
  335. package/src/plugins/FindParentsData.js +17 -17
  336. package/src/router/async/config.async.js +35 -35
  337. package/src/router/async/router.map.js +2 -2
  338. package/src/router/index.js +27 -27
  339. package/src/router.js +19 -19
  340. package/src/services/DataModel.js +30 -30
  341. package/src/services/LodopFuncs.js +137 -137
  342. package/src/services/api/TicketDetailsViewApi.js +46 -46
  343. package/src/services/api/cas.js +79 -79
  344. package/src/services/api/common.js +346 -346
  345. package/src/services/api/entity.js +18 -18
  346. package/src/services/api/index.js +17 -17
  347. package/src/services/api/restTools.js +145 -145
  348. package/src/services/api/workFlow.js +63 -63
  349. package/src/store/modules/account.js +115 -115
  350. package/src/store/modules/index.js +5 -5
  351. package/src/store/modules/lowCode.js +33 -33
  352. package/src/store/modules/setting.js +119 -119
  353. package/src/theme/default/style.less +58 -58
  354. package/src/theme/global.less +159 -159
  355. package/src/utils/authority-utils.js +85 -85
  356. package/src/utils/errorCode.js +6 -6
  357. package/src/utils/formatter.js +74 -74
  358. package/src/utils/htmlToPDF.js +108 -108
  359. package/src/utils/htmlToPDFApi.js +5 -5
  360. package/src/utils/login.js +188 -188
  361. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  362. package/src/utils/lowcode/lowcodeLog.js +29 -29
  363. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  364. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  365. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  366. package/src/utils/map-utils.js +47 -47
  367. package/src/utils/reg.js +95 -95
  368. package/src/utils/routerUtil.js +1 -6
  369. package/src/utils/runEvalFunction.js +14 -14
  370. package/src/utils/theme-color-replacer-extend.js +92 -92
  371. package/src/utils/util.js +329 -329
  372. package/src/utils/waterMark.js +31 -31
  373. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,669 +1,669 @@
1
- <template>
2
- <a-drawer
3
- title="查询配置生成"
4
- placement="right"
5
- :width="isMobile ? screenWidth : screenWidth * 0.85"
6
- :visible="visible"
7
- @close="onClose"
8
- >
9
- <a-row :gutter="24">
10
- <a-col :lg="12" :md="12" :sm="24" :xl="18" :xs="24">
11
- <a-form-model
12
- ref="businessCreateForm"
13
- :label-col="labelCol"
14
- :model="form"
15
- :rules="rules"
16
- :wrapper-col="wrapperCol"
17
- >
18
- <a-form-model-item label="查询主表名" prop="tableName">
19
- <a-input v-model="form.tableName" placeholder="查询用的主表+别名,用空格隔开,如:t_userfiles u"/>
20
- </a-form-model-item>
21
- <a-form-model-item label="预设关联表" prop="joinArray">
22
- <a-popover placement="right" title="说明">
23
- <template slot="content">
24
- <p>配置你的查询中可能涉及到的所有关联表</p>
25
- <p>比如你的查询中涉及到了t_userinfo表,就需要加入t_userinfo表的关联,和你写SQL的关联一样</p>
26
- <p>请注意,你关联的<span style="color: #ff0000">除主表外的任何表</span>都需要配置</p>
27
- <a-input-group compact style="width: 400px;">
28
- <a-input placeholder="表别名" readOnly style="width: 20%"/>
29
- <a-input placeholder="关联条件" readOnly style="width: 80%"/>
30
- </a-input-group>
31
- <a-input-group compact style="width: 400px;">
32
- <a-input placeholder="表别名" readOnly style="width: 20%" value="ui"/>
33
- <a-input
34
- placeholder="关联条件"
35
- readOnly
36
- style="width: 80%"
37
- value="t_userinfo ui on i.f_userinfo_id = ui.f_userinfo_id"/>
38
- </a-input-group>
39
- </template>
40
- <a-button type="primary" @click="addJoinItem()">增加</a-button>
41
- </a-popover>
42
- <div v-for="(itemObj, index) in joinArray" :key="index">
43
- <a-input-group compact>
44
- <a-input
45
- v-model="itemObj.key"
46
- placeholder="表别名"
47
- style="width: 20%;position: relative;bottom: 1px;"
48
- @change="changeJoinArray()"/>
49
- <a-input v-model="itemObj.value" placeholder="关联条件" style="width: 80%" @change="changeJoinArray()">
50
- <a-icon slot="addonAfter" type="close" @click="removeJoinItem(index)"/>
51
- </a-input>
52
- </a-input-group>
53
- </div>
54
- </a-form-model-item>
55
- <a-form-model-item label="SQL查询表达式" prop="condition">
56
- <a-input v-model="form.condition.value" placeholder="用作SQL查询的固定条件表达式,如:gb.f_meter_type='物联网表',可选"/>
57
- <template v-if="form.condition.value && Object.keys(form.joinArray).length > 0">
58
- <a-alert message="提示:如果SQL查询表达式中用到了关联表,需要勾选用到的关联表别名" type="success"/>
59
- <a-checkbox-group v-model="form.condition.join" :options="conditionJoinArray"/>
60
- </template>
61
- </a-form-model-item>
62
- <a-form-model-item label="排序方式" prop="orderBy">
63
- <a-input v-model="form.orderBy" placeholder="排序字段,用别名+字段名+排序方式(可选)表示,如:u.id desc"/>
64
- </a-form-model-item>
65
- <a-form-model-item label="数据字段" prop="column">
66
- <a-space>
67
- <a-button type="primary" @click="addColumnItem()">增加</a-button>
68
- <a-button icon="import" @click="$message.warn('从创意库中选择并引用高质量的通用表单项配置,敬请期待')">从创意库引入</a-button>
69
- </a-space>
70
- <a-row :gutter="24">
71
- <a-col :span="6">
72
- <span style="font-weight: bold">
73
- 标签名
74
- </span>
75
- </a-col>
76
- <a-col :span="6">
77
- <span style="font-weight: bold">
78
- 字段名
79
- </span>
80
- </a-col>
81
- <a-col :span="10">
82
- <span style="font-weight: bold">
83
- 数据模式
84
- </span>
85
- </a-col>
86
- <a-col :span="2">
87
- <span style="font-weight: bold">
88
- 操作
89
- </span>
90
- </a-col>
91
- </a-row>
92
- <a-divider style="margin: 6px 0" />
93
- <div
94
- v-for="(columnItem, index) in form.column"
95
- :key="index"
96
- draggable="true"
97
- @dragend="handleDragEnd($event, columnItem)"
98
- @dragenter="handleDragEnter($event, columnItem)"
99
- @dragstart="handleDragStart($event, columnItem)"
100
- @dragover.prevent="handleDragOver($event, columnItem)">
101
- <a-row v-if="ending && dragging && columnItem.key === ending.key && dragging.key !== ending.key" class="dragTipsWarp">
102
- <span class="dragTips">拖到此处放置</span>
103
- </a-row>
104
- <a-row :gutter="24" class="column_item">
105
- <a-col :span="6">
106
- <span style="font-weight: bold">
107
- {{ columnItem.title }}
108
- </span>
109
- </a-col>
110
- <a-col :span="6">
111
- <span style="font-weight: bold">
112
- {{ columnItem.key }}
113
- </span>
114
- </a-col>
115
- <a-col :span="10">
116
- <a-tooltip>
117
- <template slot="title">
118
- 查询表单项
119
- </template>
120
- <a-tag :color="columnItem.dataModeArray.includes('queryForm') ? 'blue' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="file-search" /></a-tag>
121
- </a-tooltip>
122
- <a-tooltip>
123
- <template slot="title">
124
- 表格列
125
- </template>
126
- <a-tag :color="columnItem.dataModeArray.includes('table') ? 'orange' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="table" /></a-tag>
127
- </a-tooltip>
128
- <a-tooltip>
129
- <template slot="title">
130
- 新增/修改表单项
131
- </template>
132
- <a-tag :color="columnItem.dataModeArray.includes('addOrEditForm') ? 'green' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="form" /></a-tag>
133
- </a-tooltip>
134
- <a-tooltip>
135
- <template slot="title">
136
- SQL查询项
137
- </template>
138
- <a-tag :color="columnItem.dataModeArray.includes('sqlQueryItem') ? 'cyan' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="bars" /></a-tag>
139
- </a-tooltip>
140
- <a-tooltip>
141
- <template slot="title">
142
- SQL查询表达式
143
- </template>
144
- <a-tag :color="columnItem.dataModeArray.includes('sqlQueryCondition') ? 'purple' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="search" /></a-tag>
145
- </a-tooltip>
146
- <a-tooltip>
147
- <template slot="title">
148
- Excel导入项
149
- </template>
150
- <a-tag :color="columnItem.dataModeArray.includes('excelImportItem') ? '#107C41' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="file-excel" /></a-tag>
151
- </a-tooltip>
152
- <a-tooltip>
153
- <template slot="title">
154
- 数据组
155
- </template>
156
- <a-tag :color="columnItem.dataModeArray.includes('group') ? '#82A0D8' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="crown" /></a-tag>
157
- </a-tooltip>
158
- </a-col>
159
- <a-col :span="1">
160
- <a-icon type="edit" @click="editColumnItem(columnItem.key,index)"/>
161
- </a-col>
162
- <a-col :span="1">
163
- <a-icon type="close" @click="removeColumnItem(columnItem.key,index)"/>
164
- </a-col>
165
- </a-row>
166
- </div>
167
- </a-form-model-item>
168
- <a-form-model-item label="操作按钮配置" prop="buttonState">
169
- <a-checkbox-group v-model="buttonStateData" :options="buttonStateArray"/>
170
- </a-form-model-item>
171
- <a-form-model-item label="接口插槽" prop="apiSlot">
172
- <a-popover placement="right" title="说明">
173
- <template slot="content">
174
- <p>通过插槽,你可以轻松扩展查询配置的默认业务,配置的插槽会根据类型在默认业务的前后执行,类似于切面</p>
175
- <p><span style="color: #FF0000">注意:插槽不应改变默认的业务行为</span></p>
176
- <p>如果配置了业务执行前插槽,<br/>执行默认业务前会先执行设置的插槽logic,传给插槽的参数为data本身</p>
177
- <p>如果配置了业务执行后插槽,<br/>执行默认业务后会执行设置的插槽logic,传给插槽的参数为默认业务的返回值</p>
178
- <img src="@vue2-client/assets/img/querySlotDemo.svg" style="zoom:0.5">
179
- </template>
180
- <a-button type="primary" @click="addApiSlot()">增加</a-button>
181
- </a-popover>
182
- <div
183
- v-for="(columnItem, index) in form.apiSlotView"
184
- :key="index"
185
- >
186
- <a-input v-model="columnItem.slotName" placeholder="插槽logic名称">
187
- <a-select slot="addonBefore" v-model="columnItem.slotType" style="width: 10rem" placeholder="选择插槽类型">
188
- <a-select-option
189
- v-for="item in apiSlotData"
190
- :key="item.value"
191
- :value="item.value">
192
- {{ item.label }}
193
- </a-select-option>
194
- </a-select>
195
- <a-icon slot="addonAfter" type="close" @click="removeApiSlotItem(index)"/>
196
- </a-input>
197
- </div>
198
- </a-form-model-item>
199
- </a-form-model>
200
- <create-query-item ref="queryItem" @getColumn="getColumn" @itemHandle="itemHandle"/>
201
- <a-button type="primary" @click="view">操作</a-button>
202
- </a-col>
203
- <a-col :lg="12" :md="12" :sm="24" :xl="6" :xs="24">
204
- <a-card :bordered="false" size="small" style="overflow: auto" title="预览">
205
- <json-viewer
206
- :copyable="{copyText: '复制', copiedText: '已复制'}"
207
- :expand-depth="parseInt('100')"
208
- :value="result"
209
- style="overflow: auto;max-height: 440px"></json-viewer>
210
- </a-card>
211
- </a-col>
212
- </a-row>
213
- <a-modal
214
- :centered="true"
215
- :destroyOnClose="true"
216
- :visible="modelVisible"
217
- :width="isMobile ? screenWidth : screenWidth * 0.8"
218
- :zIndex="1001"
219
- title="效果预览"
220
- @cancel="onModelClose">
221
- <template slot="footer">
222
- <a-button key="close" @click="onModelClose">
223
- 返回
224
- </a-button>
225
- <a-button key="submit" type="primary" @click="submit">
226
- 保存
227
- </a-button>
228
- </template>
229
- <x-form-table
230
- :queryParamsJson="result"
231
- :view-mode="true"
232
- :service-name="serviceName">
233
- </x-form-table>
234
- </a-modal>
235
- </a-drawer>
236
- </template>
237
-
238
- <script>
239
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
240
- import JsonViewer from 'vue-json-viewer'
241
- import FileSaver from 'file-saver'
242
- import { mapState } from 'vuex'
243
- import CreateQueryItem from '@vue2-client/base-client/components/common/CreateQuery/CreateQueryItem'
244
-
245
- export default {
246
- name: 'CreateQuery',
247
- components: {
248
- CreateQueryItem,
249
- JsonViewer,
250
- XFormTable
251
- },
252
- data () {
253
- return {
254
- // 页面宽度
255
- screenWidth: document.documentElement.clientWidth,
256
- // 效果预览模态框是否展示
257
- modelVisible: false,
258
- // 操作按钮状态集合
259
- buttonStateArray: [
260
- { label: '新增', value: 'add' },
261
- { label: '修改', value: 'edit' },
262
- { label: '删除', value: 'delete' },
263
- { label: '导入', value: 'import' },
264
- { label: '导出', value: 'export' }
265
- ],
266
- // 操作按钮状态集合值
267
- buttonStateData: ['add', 'edit', 'delete', 'import', 'export'],
268
- labelCol: { span: 3 },
269
- wrapperCol: { span: 18 },
270
- form: {
271
- tableName: '',
272
- joinArray: {},
273
- condition: {},
274
- orderBy: '',
275
- column: [],
276
- apiSlotView: [],
277
- apiSlot: {},
278
- },
279
- result: {},
280
- itemMap: {},
281
- selectIndex: null,
282
- selectType: undefined,
283
- joinArray: [],
284
- rules: {
285
- tableName: [{ required: true, message: '请输入查询表名', trigger: 'blur' }],
286
- orderBy: [{ required: true, message: '请输入排序方式', trigger: 'blur' }]
287
- },
288
- ending: null,
289
- dragging: null,
290
- // 操作按钮状态集合
291
- apiSlotData: [
292
- { label: '查询前插槽', value: 'queryBefore' },
293
- { label: '查询后插槽', value: 'queryAfter' },
294
- { label: '删除前插槽', value: 'delBefore' },
295
- { label: '删除后插槽', value: 'delAfter' },
296
- { label: '获取行信息前插槽', value: 'editQueryBefore' },
297
- { label: '获取行信息后插槽', value: 'editQueryAfter' },
298
- { label: '新增/修改保存前插槽', value: 'addOrEditSaveBefore' },
299
- { label: '新增/修改保存后插槽', value: 'addOrEditSaveAfter' },
300
- ]
301
- }
302
- },
303
- mounted () {
304
- this.initView()
305
- },
306
- computed: {
307
- ...mapState('setting', ['isMobile']),
308
- conditionJoinArray: function () {
309
- const result = []
310
- for (const item in this.form.joinArray) {
311
- if (item !== '') {
312
- result.push({
313
- label: item,
314
- value: item
315
- })
316
- }
317
- }
318
- if (result.length === 0) {
319
- result.push({
320
- label: '-',
321
- value: '-'
322
- })
323
- }
324
- return result
325
- },
326
- buttonState: function () {
327
- const result = {
328
- add: false,
329
- edit: false,
330
- delete: false,
331
- export: false
332
- }
333
- for (const item of this.buttonStateData) {
334
- result[item] = true
335
- }
336
- return result
337
- }
338
- },
339
- props: {
340
- visible: {
341
- type: Boolean,
342
- default: false
343
- },
344
- toEditJson: {
345
- type: Object,
346
- default: () => {}
347
- },
348
- saveExportJson: {
349
- type: Boolean,
350
- default: false
351
- },
352
- serviceName: {
353
- type: String,
354
- default: undefined
355
- }
356
- },
357
- watch: {
358
- visible (rel) {
359
- if (rel) {
360
- this.initView()
361
- }
362
- if (rel && this.toEditJson) {
363
- // 处理预设关联表
364
- if (this.joinArray.length === 0) {
365
- for (const key in this.toEditJson.joinArray) {
366
- this.joinArray.push({
367
- key: key,
368
- value: this.toEditJson.joinArray[key]
369
- })
370
- }
371
- }
372
- // apiSlot obj to arr
373
- if (this.toEditJson.apiSlot) {
374
- this.toEditJson.apiSlotView = []
375
- for (const key of Object.keys(this.toEditJson.apiSlot)) {
376
- this.toEditJson.apiSlotView.push({ slotType: key, slotName: this.toEditJson.apiSlot[key] })
377
- }
378
- }
379
- // 处理具体表单项
380
- this.form = Object.assign(
381
- {
382
- tableName: '',
383
- joinArray: {},
384
- condition: {},
385
- orderBy: '',
386
- apiSlotView: [],
387
- apiSlot: {},
388
- column: []
389
- }, this.toEditJson
390
- )
391
- for (const columnItem of this.form.column) {
392
- if (!(columnItem.dataMode || columnItem.dataModeArray)) {
393
- columnItem.dataModeArray = ['queryForm', 'table', 'addOrEditForm', 'sqlQueryItem', 'sqlQueryCondition']
394
- }
395
- delete columnItem.dataMode
396
- // 插槽兼容处理
397
- if (columnItem.slot) {
398
- if (columnItem.slot.value && columnItem.slot.type === 'ellipsis') {
399
- columnItem.slotValue = columnItem.slot.value
400
- } else if (columnItem.slot.keyMap && columnItem.slot.type === 'badge') {
401
- columnItem.slotKeyMap = columnItem.slot.keyMap
402
- } else if (columnItem.slot.actionText && columnItem.slot.type === 'action') {
403
- columnItem.actionText = columnItem.slot.actionText
404
- }
405
- }
406
- // 必选项兼容处理
407
- if (columnItem.rule && columnItem.rule.required && columnItem.rule.required !== 'false') {
408
- columnItem.rule.required = columnItem.rule.required.toString()
409
- } else {
410
- if (!columnItem.rule) {
411
- columnItem.rule = {}
412
- }
413
- columnItem.rule.required = 'false'
414
- }
415
- // 数据源加载方式兼容处理
416
- if (columnItem.lazyLoad && columnItem.lazyLoad !== 'false') {
417
- columnItem.lazyLoad = columnItem.lazyLoad.toString()
418
- } else {
419
- columnItem.lazyLoad = 'false'
420
- }
421
- // 下拉框数据源兼容处理
422
- if ((columnItem.formType === 'select' || columnItem.formType === 'treeSelect') && columnItem.selectKey) {
423
- // 数据源为logic
424
- if (columnItem.selectKey.toString().startsWith('logic@')) {
425
- columnItem.selectType = 'logic'
426
- } else if (columnItem.selectKey instanceof Array || this.isJSON(columnItem.selectKey)) {
427
- // 数据源为固定json集合
428
- if (columnItem.selectKey instanceof Array) {
429
- columnItem.selectKey = JSON.stringify(columnItem.selectKey)
430
- }
431
- columnItem.selectType = 'fixArray'
432
- } else {
433
- columnItem.selectType = 'key'
434
- }
435
- }
436
- this.itemMap[columnItem.key] = Object.assign({
437
- key: '',
438
- title: '',
439
- slot: {},
440
- rule: {
441
- required: 'false'
442
- },
443
- dataModeArray: []
444
- }, columnItem)
445
- }
446
- // 处理操作按钮配置
447
- if (this.toEditJson.buttonState) {
448
- this.buttonStateData = []
449
- for (const buttonStateKey of Object.keys(this.toEditJson.buttonState)) {
450
- if (this.toEditJson.buttonState[buttonStateKey]) {
451
- this.buttonStateData.push(buttonStateKey)
452
- }
453
- }
454
- } else {
455
- this.buttonStateData = ['add', 'edit', 'delete', 'import', 'export']
456
- }
457
- }
458
- }
459
- },
460
- methods: {
461
- // 新增接口插槽
462
- addApiSlot () {
463
- if (this.form.apiSlotView.length < this.apiSlotData.length) {
464
- this.form.apiSlotView.push({})
465
- }
466
- },
467
- // 删除接口插槽
468
- removeApiSlotItem (index) {
469
- this.form.apiSlotView.splice(index, 1)
470
- },
471
- // 初始化组件
472
- initView () {
473
- this.joinArray = []
474
- this.result = {}
475
- },
476
- onClose () {
477
- this.$emit('close')
478
- this.$emit('update:visible', false)
479
- },
480
- onModelClose () {
481
- this.modelVisible = false
482
- },
483
- addJoinItem () {
484
- this.joinArray.push({
485
- key: '',
486
- value: ''
487
- })
488
- this.changeJoinArray()
489
- },
490
- removeJoinItem (index) {
491
- this.joinArray.splice(index, 1)
492
- this.changeJoinArray()
493
- },
494
- itemHandle (item, type) {
495
- this.itemMap[item.key] = item
496
- if (this.type === '新增') {
497
- this.form.column.push(item)
498
- } else {
499
- this.$set(this.form.column, this.selectIndex, item)
500
- }
501
- this.$message.success(`${type}成功`)
502
- this.$refs.queryItem.flashModal(false)
503
- },
504
- getColumn (callback) {
505
- callback(JSON.parse(JSON.stringify(this.form.column)))
506
- },
507
- addColumnItem () {
508
- this.type = '新增'
509
- this.$refs.queryItem.addColumnItemExecute()
510
- },
511
- editColumnItem (key, index) {
512
- this.type = '修改'
513
- if (this.itemMap[key]) {
514
- this.$refs.queryItem.editColumnItemExecute(this.itemMap[key])
515
- this.selectIndex = index
516
- } else {
517
- this.$message.warn('编辑失败')
518
- }
519
- },
520
- removeColumnItem (key, index) {
521
- const _this = this
522
- this.$confirm({
523
- title: '您确定要删除该数据项?',
524
- content: '删除的数据项无法恢复',
525
- okText: '确定',
526
- okType: 'danger',
527
- cancelText: '取消',
528
- onOk () {
529
- delete _this.itemMap[key]
530
- _this.form.column.splice(index, 1)
531
- }
532
- })
533
- },
534
- upColumnItem (key, index) {
535
- const newIndex = index - 1
536
- const itemA = this.form.column[newIndex]
537
- const itemB = this.form.column[index]
538
- this.form.column.splice(index, 1, itemA)
539
- this.form.column.splice(newIndex, 1, itemB)
540
- },
541
- downColumnItem (key, index) {
542
- const newIndex = index + 1
543
- const itemA = this.form.column[newIndex]
544
- const itemB = this.form.column[index]
545
- this.form.column.splice(index, 1, itemA)
546
- this.form.column.splice(newIndex, 1, itemB)
547
- },
548
- changeJoinArray () {
549
- const joinArrayObject = {}
550
- for (const item of this.joinArray) {
551
- joinArrayObject[item.key] = item.value
552
- }
553
- this.form.joinArray = joinArrayObject
554
- },
555
- exportJson () {
556
- const data = JSON.stringify(this.result, null, 2)
557
- const blob = new Blob([data], { type: 'application/json' })
558
- FileSaver.saveAs(blob, `Query.json`)
559
- this.$message.success('导出到本地成功,请复制内容到琉璃配置中心中')
560
- },
561
- viewHandle (then) {
562
- if (this.form.column.length === 0) {
563
- this.$message.error('你没有增加任何数据字段')
564
- return
565
- }
566
- this.result = JSON.parse(JSON.stringify(this.form))
567
- if (this.result.condition && (!this.result.condition.value || this.result.condition.value === '')) {
568
- delete this.result.condition
569
- }
570
- for (const item of this.result.column) {
571
- if (item.selectType === 'fixArray') {
572
- if (typeof item.selectKey === 'string') {
573
- item.selectKey = JSON.parse(item.selectKey)
574
- }
575
- }
576
- if (item.dataModeArray.length === 5) {
577
- delete item.dataModeArray
578
- }
579
- }
580
- // 查询插槽array to object
581
- delete this.result.apiSlotView
582
- this.result.apiSlot = {}
583
- for (let i = 0; i < this.form.apiSlotView.length; i++) {
584
- this.result.apiSlot[this.form.apiSlotView[i].slotType] = this.form.apiSlotView[i].slotName
585
- }
586
- this.result.buttonState = this.buttonState
587
- then()
588
- },
589
- view () {
590
- this.$refs.businessCreateForm.validate(valid => {
591
- if (valid) {
592
- this.viewHandle(() => {
593
- this.modelVisible = true
594
- })
595
- }
596
- })
597
- },
598
- submit () {
599
- this.onModelClose()
600
- this.$refs.businessCreateForm.validate(valid => {
601
- if (valid) {
602
- this.viewHandle(() => {
603
- if (this.saveExportJson) {
604
- this.exportJson()
605
- } else {
606
- this.$emit('saveQueryParams', this.result)
607
- }
608
- })
609
- }
610
- })
611
- },
612
- // 判断是否为json字符串
613
- isJSON (str) {
614
- if (typeof str == 'string') {
615
- try {
616
- const obj = JSON.parse(str)
617
- return !!(typeof obj == 'object' && obj)
618
- } catch (e) {
619
- return false
620
- }
621
- }
622
- },
623
- // 拖拽事件
624
- handleDragStart (e, item) {
625
- this.dragging = item
626
- },
627
- handleDragEnd (e, item) {
628
- if (this.ending.key === this.dragging.key) {
629
- return
630
- }
631
- const newItems = [...this.form.column]
632
- const src = newItems.indexOf(this.dragging)
633
- const dst = newItems.indexOf(this.ending)
634
- // newItems.splice(src, 1, ...newItems.splice(dst, 1, newItems[src])) 替换位置
635
- // 挪移位置
636
- newItems.splice(src, 1)
637
- newItems.splice(dst, 0, this.dragging)
638
- this.form.column = newItems
639
- this.$nextTick(() => {
640
- this.dragging = null
641
- this.ending = null
642
- })
643
- },
644
- handleDragOver (e) {
645
- // 首先把div变成可以放置的元素,即重写dragenter/dragover
646
- // e.dataTransfer.dropEffect="move";//在dragenter中针对放置目标来设置!
647
- e.dataTransfer.dropEffect = 'move'
648
- },
649
- handleDragEnter (e, item) {
650
- // 为需要移动的元素设置dragstart事件
651
- e.dataTransfer.effectAllowed = 'move'
652
- this.ending = item
653
- }
654
- }
655
- }
656
- </script>
657
- <style lang="less" scoped>
658
- .column_item:hover {
659
- background-color:rgba(64, 169, 255,0.25);
660
- }
661
- .dragTips{
662
- display:block;
663
- text-align: center;
664
- border:1px dashed rgba(64, 169, 255,0.55);
665
- }
666
- .dragTipsWarp{
667
- padding: .5rem 2rem;
668
- }
669
- </style>
1
+ <template>
2
+ <a-drawer
3
+ title="查询配置生成"
4
+ placement="right"
5
+ :width="isMobile ? screenWidth : screenWidth * 0.85"
6
+ :visible="visible"
7
+ @close="onClose"
8
+ >
9
+ <a-row :gutter="24">
10
+ <a-col :lg="12" :md="12" :sm="24" :xl="18" :xs="24">
11
+ <a-form-model
12
+ ref="businessCreateForm"
13
+ :label-col="labelCol"
14
+ :model="form"
15
+ :rules="rules"
16
+ :wrapper-col="wrapperCol"
17
+ >
18
+ <a-form-model-item label="查询主表名" prop="tableName">
19
+ <a-input v-model="form.tableName" placeholder="查询用的主表+别名,用空格隔开,如:t_userfiles u"/>
20
+ </a-form-model-item>
21
+ <a-form-model-item label="预设关联表" prop="joinArray">
22
+ <a-popover placement="right" title="说明">
23
+ <template slot="content">
24
+ <p>配置你的查询中可能涉及到的所有关联表</p>
25
+ <p>比如你的查询中涉及到了t_userinfo表,就需要加入t_userinfo表的关联,和你写SQL的关联一样</p>
26
+ <p>请注意,你关联的<span style="color: #ff0000">除主表外的任何表</span>都需要配置</p>
27
+ <a-input-group compact style="width: 400px;">
28
+ <a-input placeholder="表别名" readOnly style="width: 20%"/>
29
+ <a-input placeholder="关联条件" readOnly style="width: 80%"/>
30
+ </a-input-group>
31
+ <a-input-group compact style="width: 400px;">
32
+ <a-input placeholder="表别名" readOnly style="width: 20%" value="ui"/>
33
+ <a-input
34
+ placeholder="关联条件"
35
+ readOnly
36
+ style="width: 80%"
37
+ value="t_userinfo ui on i.f_userinfo_id = ui.f_userinfo_id"/>
38
+ </a-input-group>
39
+ </template>
40
+ <a-button type="primary" @click="addJoinItem()">增加</a-button>
41
+ </a-popover>
42
+ <div v-for="(itemObj, index) in joinArray" :key="index">
43
+ <a-input-group compact>
44
+ <a-input
45
+ v-model="itemObj.key"
46
+ placeholder="表别名"
47
+ style="width: 20%;position: relative;bottom: 1px;"
48
+ @change="changeJoinArray()"/>
49
+ <a-input v-model="itemObj.value" placeholder="关联条件" style="width: 80%" @change="changeJoinArray()">
50
+ <a-icon slot="addonAfter" type="close" @click="removeJoinItem(index)"/>
51
+ </a-input>
52
+ </a-input-group>
53
+ </div>
54
+ </a-form-model-item>
55
+ <a-form-model-item label="SQL查询表达式" prop="condition">
56
+ <a-input v-model="form.condition.value" placeholder="用作SQL查询的固定条件表达式,如:gb.f_meter_type='物联网表',可选"/>
57
+ <template v-if="form.condition.value && Object.keys(form.joinArray).length > 0">
58
+ <a-alert message="提示:如果SQL查询表达式中用到了关联表,需要勾选用到的关联表别名" type="success"/>
59
+ <a-checkbox-group v-model="form.condition.join" :options="conditionJoinArray"/>
60
+ </template>
61
+ </a-form-model-item>
62
+ <a-form-model-item label="排序方式" prop="orderBy">
63
+ <a-input v-model="form.orderBy" placeholder="排序字段,用别名+字段名+排序方式(可选)表示,如:u.id desc"/>
64
+ </a-form-model-item>
65
+ <a-form-model-item label="数据字段" prop="column">
66
+ <a-space>
67
+ <a-button type="primary" @click="addColumnItem()">增加</a-button>
68
+ <a-button icon="import" @click="$message.warn('从创意库中选择并引用高质量的通用表单项配置,敬请期待')">从创意库引入</a-button>
69
+ </a-space>
70
+ <a-row :gutter="24">
71
+ <a-col :span="6">
72
+ <span style="font-weight: bold">
73
+ 标签名
74
+ </span>
75
+ </a-col>
76
+ <a-col :span="6">
77
+ <span style="font-weight: bold">
78
+ 字段名
79
+ </span>
80
+ </a-col>
81
+ <a-col :span="10">
82
+ <span style="font-weight: bold">
83
+ 数据模式
84
+ </span>
85
+ </a-col>
86
+ <a-col :span="2">
87
+ <span style="font-weight: bold">
88
+ 操作
89
+ </span>
90
+ </a-col>
91
+ </a-row>
92
+ <a-divider style="margin: 6px 0" />
93
+ <div
94
+ v-for="(columnItem, index) in form.column"
95
+ :key="index"
96
+ draggable="true"
97
+ @dragend="handleDragEnd($event, columnItem)"
98
+ @dragenter="handleDragEnter($event, columnItem)"
99
+ @dragstart="handleDragStart($event, columnItem)"
100
+ @dragover.prevent="handleDragOver($event, columnItem)">
101
+ <a-row v-if="ending && dragging && columnItem.key === ending.key && dragging.key !== ending.key" class="dragTipsWarp">
102
+ <span class="dragTips">拖到此处放置</span>
103
+ </a-row>
104
+ <a-row :gutter="24" class="column_item">
105
+ <a-col :span="6">
106
+ <span style="font-weight: bold">
107
+ {{ columnItem.title }}
108
+ </span>
109
+ </a-col>
110
+ <a-col :span="6">
111
+ <span style="font-weight: bold">
112
+ {{ columnItem.key }}
113
+ </span>
114
+ </a-col>
115
+ <a-col :span="10">
116
+ <a-tooltip>
117
+ <template slot="title">
118
+ 查询表单项
119
+ </template>
120
+ <a-tag :color="columnItem.dataModeArray.includes('queryForm') ? 'blue' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="file-search" /></a-tag>
121
+ </a-tooltip>
122
+ <a-tooltip>
123
+ <template slot="title">
124
+ 表格列
125
+ </template>
126
+ <a-tag :color="columnItem.dataModeArray.includes('table') ? 'orange' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="table" /></a-tag>
127
+ </a-tooltip>
128
+ <a-tooltip>
129
+ <template slot="title">
130
+ 新增/修改表单项
131
+ </template>
132
+ <a-tag :color="columnItem.dataModeArray.includes('addOrEditForm') ? 'green' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="form" /></a-tag>
133
+ </a-tooltip>
134
+ <a-tooltip>
135
+ <template slot="title">
136
+ SQL查询项
137
+ </template>
138
+ <a-tag :color="columnItem.dataModeArray.includes('sqlQueryItem') ? 'cyan' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="bars" /></a-tag>
139
+ </a-tooltip>
140
+ <a-tooltip>
141
+ <template slot="title">
142
+ SQL查询表达式
143
+ </template>
144
+ <a-tag :color="columnItem.dataModeArray.includes('sqlQueryCondition') ? 'purple' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="search" /></a-tag>
145
+ </a-tooltip>
146
+ <a-tooltip>
147
+ <template slot="title">
148
+ Excel导入项
149
+ </template>
150
+ <a-tag :color="columnItem.dataModeArray.includes('excelImportItem') ? '#107C41' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="file-excel" /></a-tag>
151
+ </a-tooltip>
152
+ <a-tooltip>
153
+ <template slot="title">
154
+ 数据组
155
+ </template>
156
+ <a-tag :color="columnItem.dataModeArray.includes('group') ? '#82A0D8' : 'rgba(0, 0, 0, 0.25)'"><a-icon type="crown" /></a-tag>
157
+ </a-tooltip>
158
+ </a-col>
159
+ <a-col :span="1">
160
+ <a-icon type="edit" @click="editColumnItem(columnItem.key,index)"/>
161
+ </a-col>
162
+ <a-col :span="1">
163
+ <a-icon type="close" @click="removeColumnItem(columnItem.key,index)"/>
164
+ </a-col>
165
+ </a-row>
166
+ </div>
167
+ </a-form-model-item>
168
+ <a-form-model-item label="操作按钮配置" prop="buttonState">
169
+ <a-checkbox-group v-model="buttonStateData" :options="buttonStateArray"/>
170
+ </a-form-model-item>
171
+ <a-form-model-item label="接口插槽" prop="apiSlot">
172
+ <a-popover placement="right" title="说明">
173
+ <template slot="content">
174
+ <p>通过插槽,你可以轻松扩展查询配置的默认业务,配置的插槽会根据类型在默认业务的前后执行,类似于切面</p>
175
+ <p><span style="color: #FF0000">注意:插槽不应改变默认的业务行为</span></p>
176
+ <p>如果配置了业务执行前插槽,<br/>执行默认业务前会先执行设置的插槽logic,传给插槽的参数为data本身</p>
177
+ <p>如果配置了业务执行后插槽,<br/>执行默认业务后会执行设置的插槽logic,传给插槽的参数为默认业务的返回值</p>
178
+ <img src="@vue2-client/assets/img/querySlotDemo.svg" style="zoom:0.5">
179
+ </template>
180
+ <a-button type="primary" @click="addApiSlot()">增加</a-button>
181
+ </a-popover>
182
+ <div
183
+ v-for="(columnItem, index) in form.apiSlotView"
184
+ :key="index"
185
+ >
186
+ <a-input v-model="columnItem.slotName" placeholder="插槽logic名称">
187
+ <a-select slot="addonBefore" v-model="columnItem.slotType" style="width: 10rem" placeholder="选择插槽类型">
188
+ <a-select-option
189
+ v-for="item in apiSlotData"
190
+ :key="item.value"
191
+ :value="item.value">
192
+ {{ item.label }}
193
+ </a-select-option>
194
+ </a-select>
195
+ <a-icon slot="addonAfter" type="close" @click="removeApiSlotItem(index)"/>
196
+ </a-input>
197
+ </div>
198
+ </a-form-model-item>
199
+ </a-form-model>
200
+ <create-query-item ref="queryItem" @getColumn="getColumn" @itemHandle="itemHandle"/>
201
+ <a-button type="primary" @click="view">操作</a-button>
202
+ </a-col>
203
+ <a-col :lg="12" :md="12" :sm="24" :xl="6" :xs="24">
204
+ <a-card :bordered="false" size="small" style="overflow: auto" title="预览">
205
+ <json-viewer
206
+ :copyable="{copyText: '复制', copiedText: '已复制'}"
207
+ :expand-depth="parseInt('100')"
208
+ :value="result"
209
+ style="overflow: auto;max-height: 440px"></json-viewer>
210
+ </a-card>
211
+ </a-col>
212
+ </a-row>
213
+ <a-modal
214
+ :centered="true"
215
+ :destroyOnClose="true"
216
+ :visible="modelVisible"
217
+ :width="isMobile ? screenWidth : screenWidth * 0.8"
218
+ :zIndex="1001"
219
+ title="效果预览"
220
+ @cancel="onModelClose">
221
+ <template slot="footer">
222
+ <a-button key="close" @click="onModelClose">
223
+ 返回
224
+ </a-button>
225
+ <a-button key="submit" type="primary" @click="submit">
226
+ 保存
227
+ </a-button>
228
+ </template>
229
+ <x-form-table
230
+ :queryParamsJson="result"
231
+ :view-mode="true"
232
+ :service-name="serviceName">
233
+ </x-form-table>
234
+ </a-modal>
235
+ </a-drawer>
236
+ </template>
237
+
238
+ <script>
239
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
240
+ import JsonViewer from 'vue-json-viewer'
241
+ import FileSaver from 'file-saver'
242
+ import { mapState } from 'vuex'
243
+ import CreateQueryItem from '@vue2-client/base-client/components/common/CreateQuery/CreateQueryItem'
244
+
245
+ export default {
246
+ name: 'CreateQuery',
247
+ components: {
248
+ CreateQueryItem,
249
+ JsonViewer,
250
+ XFormTable
251
+ },
252
+ data () {
253
+ return {
254
+ // 页面宽度
255
+ screenWidth: document.documentElement.clientWidth,
256
+ // 效果预览模态框是否展示
257
+ modelVisible: false,
258
+ // 操作按钮状态集合
259
+ buttonStateArray: [
260
+ { label: '新增', value: 'add' },
261
+ { label: '修改', value: 'edit' },
262
+ { label: '删除', value: 'delete' },
263
+ { label: '导入', value: 'import' },
264
+ { label: '导出', value: 'export' }
265
+ ],
266
+ // 操作按钮状态集合值
267
+ buttonStateData: ['add', 'edit', 'delete', 'import', 'export'],
268
+ labelCol: { span: 3 },
269
+ wrapperCol: { span: 18 },
270
+ form: {
271
+ tableName: '',
272
+ joinArray: {},
273
+ condition: {},
274
+ orderBy: '',
275
+ column: [],
276
+ apiSlotView: [],
277
+ apiSlot: {},
278
+ },
279
+ result: {},
280
+ itemMap: {},
281
+ selectIndex: null,
282
+ selectType: undefined,
283
+ joinArray: [],
284
+ rules: {
285
+ tableName: [{ required: true, message: '请输入查询表名', trigger: 'blur' }],
286
+ orderBy: [{ required: true, message: '请输入排序方式', trigger: 'blur' }]
287
+ },
288
+ ending: null,
289
+ dragging: null,
290
+ // 操作按钮状态集合
291
+ apiSlotData: [
292
+ { label: '查询前插槽', value: 'queryBefore' },
293
+ { label: '查询后插槽', value: 'queryAfter' },
294
+ { label: '删除前插槽', value: 'delBefore' },
295
+ { label: '删除后插槽', value: 'delAfter' },
296
+ { label: '获取行信息前插槽', value: 'editQueryBefore' },
297
+ { label: '获取行信息后插槽', value: 'editQueryAfter' },
298
+ { label: '新增/修改保存前插槽', value: 'addOrEditSaveBefore' },
299
+ { label: '新增/修改保存后插槽', value: 'addOrEditSaveAfter' },
300
+ ]
301
+ }
302
+ },
303
+ mounted () {
304
+ this.initView()
305
+ },
306
+ computed: {
307
+ ...mapState('setting', ['isMobile']),
308
+ conditionJoinArray: function () {
309
+ const result = []
310
+ for (const item in this.form.joinArray) {
311
+ if (item !== '') {
312
+ result.push({
313
+ label: item,
314
+ value: item
315
+ })
316
+ }
317
+ }
318
+ if (result.length === 0) {
319
+ result.push({
320
+ label: '-',
321
+ value: '-'
322
+ })
323
+ }
324
+ return result
325
+ },
326
+ buttonState: function () {
327
+ const result = {
328
+ add: false,
329
+ edit: false,
330
+ delete: false,
331
+ export: false
332
+ }
333
+ for (const item of this.buttonStateData) {
334
+ result[item] = true
335
+ }
336
+ return result
337
+ }
338
+ },
339
+ props: {
340
+ visible: {
341
+ type: Boolean,
342
+ default: false
343
+ },
344
+ toEditJson: {
345
+ type: Object,
346
+ default: () => {}
347
+ },
348
+ saveExportJson: {
349
+ type: Boolean,
350
+ default: false
351
+ },
352
+ serviceName: {
353
+ type: String,
354
+ default: undefined
355
+ }
356
+ },
357
+ watch: {
358
+ visible (rel) {
359
+ if (rel) {
360
+ this.initView()
361
+ }
362
+ if (rel && this.toEditJson) {
363
+ // 处理预设关联表
364
+ if (this.joinArray.length === 0) {
365
+ for (const key in this.toEditJson.joinArray) {
366
+ this.joinArray.push({
367
+ key: key,
368
+ value: this.toEditJson.joinArray[key]
369
+ })
370
+ }
371
+ }
372
+ // apiSlot obj to arr
373
+ if (this.toEditJson.apiSlot) {
374
+ this.toEditJson.apiSlotView = []
375
+ for (const key of Object.keys(this.toEditJson.apiSlot)) {
376
+ this.toEditJson.apiSlotView.push({ slotType: key, slotName: this.toEditJson.apiSlot[key] })
377
+ }
378
+ }
379
+ // 处理具体表单项
380
+ this.form = Object.assign(
381
+ {
382
+ tableName: '',
383
+ joinArray: {},
384
+ condition: {},
385
+ orderBy: '',
386
+ apiSlotView: [],
387
+ apiSlot: {},
388
+ column: []
389
+ }, this.toEditJson
390
+ )
391
+ for (const columnItem of this.form.column) {
392
+ if (!(columnItem.dataMode || columnItem.dataModeArray)) {
393
+ columnItem.dataModeArray = ['queryForm', 'table', 'addOrEditForm', 'sqlQueryItem', 'sqlQueryCondition']
394
+ }
395
+ delete columnItem.dataMode
396
+ // 插槽兼容处理
397
+ if (columnItem.slot) {
398
+ if (columnItem.slot.value && columnItem.slot.type === 'ellipsis') {
399
+ columnItem.slotValue = columnItem.slot.value
400
+ } else if (columnItem.slot.keyMap && columnItem.slot.type === 'badge') {
401
+ columnItem.slotKeyMap = columnItem.slot.keyMap
402
+ } else if (columnItem.slot.actionText && columnItem.slot.type === 'action') {
403
+ columnItem.actionText = columnItem.slot.actionText
404
+ }
405
+ }
406
+ // 必选项兼容处理
407
+ if (columnItem.rule && columnItem.rule.required && columnItem.rule.required !== 'false') {
408
+ columnItem.rule.required = columnItem.rule.required.toString()
409
+ } else {
410
+ if (!columnItem.rule) {
411
+ columnItem.rule = {}
412
+ }
413
+ columnItem.rule.required = 'false'
414
+ }
415
+ // 数据源加载方式兼容处理
416
+ if (columnItem.lazyLoad && columnItem.lazyLoad !== 'false') {
417
+ columnItem.lazyLoad = columnItem.lazyLoad.toString()
418
+ } else {
419
+ columnItem.lazyLoad = 'false'
420
+ }
421
+ // 下拉框数据源兼容处理
422
+ if ((columnItem.formType === 'select' || columnItem.formType === 'treeSelect') && columnItem.selectKey) {
423
+ // 数据源为logic
424
+ if (columnItem.selectKey.toString().startsWith('logic@')) {
425
+ columnItem.selectType = 'logic'
426
+ } else if (columnItem.selectKey instanceof Array || this.isJSON(columnItem.selectKey)) {
427
+ // 数据源为固定json集合
428
+ if (columnItem.selectKey instanceof Array) {
429
+ columnItem.selectKey = JSON.stringify(columnItem.selectKey)
430
+ }
431
+ columnItem.selectType = 'fixArray'
432
+ } else {
433
+ columnItem.selectType = 'key'
434
+ }
435
+ }
436
+ this.itemMap[columnItem.key] = Object.assign({
437
+ key: '',
438
+ title: '',
439
+ slot: {},
440
+ rule: {
441
+ required: 'false'
442
+ },
443
+ dataModeArray: []
444
+ }, columnItem)
445
+ }
446
+ // 处理操作按钮配置
447
+ if (this.toEditJson.buttonState) {
448
+ this.buttonStateData = []
449
+ for (const buttonStateKey of Object.keys(this.toEditJson.buttonState)) {
450
+ if (this.toEditJson.buttonState[buttonStateKey]) {
451
+ this.buttonStateData.push(buttonStateKey)
452
+ }
453
+ }
454
+ } else {
455
+ this.buttonStateData = ['add', 'edit', 'delete', 'import', 'export']
456
+ }
457
+ }
458
+ }
459
+ },
460
+ methods: {
461
+ // 新增接口插槽
462
+ addApiSlot () {
463
+ if (this.form.apiSlotView.length < this.apiSlotData.length) {
464
+ this.form.apiSlotView.push({})
465
+ }
466
+ },
467
+ // 删除接口插槽
468
+ removeApiSlotItem (index) {
469
+ this.form.apiSlotView.splice(index, 1)
470
+ },
471
+ // 初始化组件
472
+ initView () {
473
+ this.joinArray = []
474
+ this.result = {}
475
+ },
476
+ onClose () {
477
+ this.$emit('close')
478
+ this.$emit('update:visible', false)
479
+ },
480
+ onModelClose () {
481
+ this.modelVisible = false
482
+ },
483
+ addJoinItem () {
484
+ this.joinArray.push({
485
+ key: '',
486
+ value: ''
487
+ })
488
+ this.changeJoinArray()
489
+ },
490
+ removeJoinItem (index) {
491
+ this.joinArray.splice(index, 1)
492
+ this.changeJoinArray()
493
+ },
494
+ itemHandle (item, type) {
495
+ this.itemMap[item.key] = item
496
+ if (this.type === '新增') {
497
+ this.form.column.push(item)
498
+ } else {
499
+ this.$set(this.form.column, this.selectIndex, item)
500
+ }
501
+ this.$message.success(`${type}成功`)
502
+ this.$refs.queryItem.flashModal(false)
503
+ },
504
+ getColumn (callback) {
505
+ callback(JSON.parse(JSON.stringify(this.form.column)))
506
+ },
507
+ addColumnItem () {
508
+ this.type = '新增'
509
+ this.$refs.queryItem.addColumnItemExecute()
510
+ },
511
+ editColumnItem (key, index) {
512
+ this.type = '修改'
513
+ if (this.itemMap[key]) {
514
+ this.$refs.queryItem.editColumnItemExecute(this.itemMap[key])
515
+ this.selectIndex = index
516
+ } else {
517
+ this.$message.warn('编辑失败')
518
+ }
519
+ },
520
+ removeColumnItem (key, index) {
521
+ const _this = this
522
+ this.$confirm({
523
+ title: '您确定要删除该数据项?',
524
+ content: '删除的数据项无法恢复',
525
+ okText: '确定',
526
+ okType: 'danger',
527
+ cancelText: '取消',
528
+ onOk () {
529
+ delete _this.itemMap[key]
530
+ _this.form.column.splice(index, 1)
531
+ }
532
+ })
533
+ },
534
+ upColumnItem (key, index) {
535
+ const newIndex = index - 1
536
+ const itemA = this.form.column[newIndex]
537
+ const itemB = this.form.column[index]
538
+ this.form.column.splice(index, 1, itemA)
539
+ this.form.column.splice(newIndex, 1, itemB)
540
+ },
541
+ downColumnItem (key, index) {
542
+ const newIndex = index + 1
543
+ const itemA = this.form.column[newIndex]
544
+ const itemB = this.form.column[index]
545
+ this.form.column.splice(index, 1, itemA)
546
+ this.form.column.splice(newIndex, 1, itemB)
547
+ },
548
+ changeJoinArray () {
549
+ const joinArrayObject = {}
550
+ for (const item of this.joinArray) {
551
+ joinArrayObject[item.key] = item.value
552
+ }
553
+ this.form.joinArray = joinArrayObject
554
+ },
555
+ exportJson () {
556
+ const data = JSON.stringify(this.result, null, 2)
557
+ const blob = new Blob([data], { type: 'application/json' })
558
+ FileSaver.saveAs(blob, `Query.json`)
559
+ this.$message.success('导出到本地成功,请复制内容到琉璃配置中心中')
560
+ },
561
+ viewHandle (then) {
562
+ if (this.form.column.length === 0) {
563
+ this.$message.error('你没有增加任何数据字段')
564
+ return
565
+ }
566
+ this.result = JSON.parse(JSON.stringify(this.form))
567
+ if (this.result.condition && (!this.result.condition.value || this.result.condition.value === '')) {
568
+ delete this.result.condition
569
+ }
570
+ for (const item of this.result.column) {
571
+ if (item.selectType === 'fixArray') {
572
+ if (typeof item.selectKey === 'string') {
573
+ item.selectKey = JSON.parse(item.selectKey)
574
+ }
575
+ }
576
+ if (item.dataModeArray.length === 5) {
577
+ delete item.dataModeArray
578
+ }
579
+ }
580
+ // 查询插槽array to object
581
+ delete this.result.apiSlotView
582
+ this.result.apiSlot = {}
583
+ for (let i = 0; i < this.form.apiSlotView.length; i++) {
584
+ this.result.apiSlot[this.form.apiSlotView[i].slotType] = this.form.apiSlotView[i].slotName
585
+ }
586
+ this.result.buttonState = this.buttonState
587
+ then()
588
+ },
589
+ view () {
590
+ this.$refs.businessCreateForm.validate(valid => {
591
+ if (valid) {
592
+ this.viewHandle(() => {
593
+ this.modelVisible = true
594
+ })
595
+ }
596
+ })
597
+ },
598
+ submit () {
599
+ this.onModelClose()
600
+ this.$refs.businessCreateForm.validate(valid => {
601
+ if (valid) {
602
+ this.viewHandle(() => {
603
+ if (this.saveExportJson) {
604
+ this.exportJson()
605
+ } else {
606
+ this.$emit('saveQueryParams', this.result)
607
+ }
608
+ })
609
+ }
610
+ })
611
+ },
612
+ // 判断是否为json字符串
613
+ isJSON (str) {
614
+ if (typeof str == 'string') {
615
+ try {
616
+ const obj = JSON.parse(str)
617
+ return !!(typeof obj == 'object' && obj)
618
+ } catch (e) {
619
+ return false
620
+ }
621
+ }
622
+ },
623
+ // 拖拽事件
624
+ handleDragStart (e, item) {
625
+ this.dragging = item
626
+ },
627
+ handleDragEnd (e, item) {
628
+ if (this.ending.key === this.dragging.key) {
629
+ return
630
+ }
631
+ const newItems = [...this.form.column]
632
+ const src = newItems.indexOf(this.dragging)
633
+ const dst = newItems.indexOf(this.ending)
634
+ // newItems.splice(src, 1, ...newItems.splice(dst, 1, newItems[src])) 替换位置
635
+ // 挪移位置
636
+ newItems.splice(src, 1)
637
+ newItems.splice(dst, 0, this.dragging)
638
+ this.form.column = newItems
639
+ this.$nextTick(() => {
640
+ this.dragging = null
641
+ this.ending = null
642
+ })
643
+ },
644
+ handleDragOver (e) {
645
+ // 首先把div变成可以放置的元素,即重写dragenter/dragover
646
+ // e.dataTransfer.dropEffect="move";//在dragenter中针对放置目标来设置!
647
+ e.dataTransfer.dropEffect = 'move'
648
+ },
649
+ handleDragEnter (e, item) {
650
+ // 为需要移动的元素设置dragstart事件
651
+ e.dataTransfer.effectAllowed = 'move'
652
+ this.ending = item
653
+ }
654
+ }
655
+ }
656
+ </script>
657
+ <style lang="less" scoped>
658
+ .column_item:hover {
659
+ background-color:rgba(64, 169, 255,0.25);
660
+ }
661
+ .dragTips{
662
+ display:block;
663
+ text-align: center;
664
+ border:1px dashed rgba(64, 169, 255,0.55);
665
+ }
666
+ .dragTipsWarp{
667
+ padding: .5rem 2rem;
668
+ }
669
+ </style>