vue2-client 1.15.34 → 1.15.35

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 (691) hide show
  1. package/.cursorrules +19 -19
  2. package/.editorconfig +9 -9
  3. package/.env +20 -20
  4. package/.env.apply +19 -19
  5. package/.env.development +1 -1
  6. package/.env.gaslink +19 -19
  7. package/.env.his +19 -19
  8. package/.env.iot +19 -19
  9. package/.env.liuli +20 -20
  10. package/.env.message +19 -19
  11. package/.env.revenue +19 -19
  12. package/.env.runtime +19 -19
  13. package/.env.scada +19 -19
  14. package/.eslintrc.js +90 -90
  15. package/.eslintrc.json +5 -5
  16. package/CHANGELOG.md +824 -824
  17. package/CLAUDE.md +89 -89
  18. package/Components.md +60 -60
  19. package/README.md +65 -65
  20. package/babel.config.js +21 -21
  21. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +45 -45
  22. package/docs/LowCode/lowcode.md +155 -155
  23. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  24. package/docs/index.md +30 -30
  25. package/docs/notice.md +22 -22
  26. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +177 -177
  27. package/index.js +31 -31
  28. package/jest-transform-stub.js +8 -8
  29. package/jest.config.js +22 -22
  30. package/jest.setup.js +7 -7
  31. package/jsconfig.json +19 -19
  32. package/package.json +110 -110
  33. package/public/his/editor/editor.html +51 -51
  34. package/public/his/editor/mock/bind_data.html +779 -779
  35. package/public/his/editor/mock/data_table.html +40 -40
  36. package/public/his/editor/mock/sign.html +75 -75
  37. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  38. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  39. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  40. package/public/his/editor/vender/date97/calendar.js +4 -4
  41. package/public/his/editor/vender/date97/lang/en.js +13 -13
  42. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  43. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  44. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  45. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  46. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  47. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  48. package/public/his/editor/vender/diff.js +1627 -1627
  49. package/public/his/editor/vender/editor.js +1 -1
  50. package/public/his/editor/vender/fabric.js +31187 -31187
  51. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  52. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  53. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  54. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  55. package/public/his/editor/vender/mui/mui.min.css +4 -4
  56. package/public/his/editor/vender/mui/mui.min.js +5 -5
  57. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  58. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  59. package/public/his/editor/vender/qrcode.js +7 -7
  60. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  61. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  62. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  63. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  64. package/public/his/editor/vender/validator.js +5094 -5094
  65. package/public/his/editor/vender/weui/weui.css +5659 -5659
  66. package/public/his/editor/vender/weui/weui.min.css +4 -4
  67. package/public/his/editor/vender/weui/weui.min.js +11 -11
  68. package/public/index.html +27 -27
  69. package/src/App.vue +196 -196
  70. package/src/ReportView.js +13 -13
  71. package/src/assets/img/querySlotDemo.svg +15 -15
  72. package/src/assets/svg/badtwo.svg +1 -1
  73. package/src/assets/svg/goodtwo.svg +1 -1
  74. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  75. package/src/base-client/components/AI/demo.vue +31 -31
  76. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +532 -532
  77. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  78. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  79. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  80. package/src/base-client/components/common/AddressSearchCombobox/index.js +3 -3
  81. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  82. package/src/base-client/components/common/AmapMarker/index.js +3 -3
  83. package/src/base-client/components/common/CitySelect/CitySelect.vue +365 -365
  84. package/src/base-client/components/common/CitySelect/index.js +3 -3
  85. package/src/base-client/components/common/CitySelect/index.md +109 -109
  86. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  87. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  88. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  89. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  90. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  91. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  92. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  93. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  94. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +146 -146
  95. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  96. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  97. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  98. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  99. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  100. package/src/base-client/components/common/JSONToTree/index.js +3 -3
  101. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  102. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  103. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  104. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  105. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  106. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  107. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  108. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  109. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  110. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  111. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  112. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  113. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  114. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  115. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  116. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  117. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  118. package/src/base-client/components/common/Recording/index.js +3 -3
  119. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  120. package/src/base-client/components/common/Tree/index.js +2 -2
  121. package/src/base-client/components/common/Upload/Upload.vue +323 -323
  122. package/src/base-client/components/common/Upload/index.js +3 -3
  123. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  124. package/src/base-client/components/common/XAddForm/index.js +3 -3
  125. package/src/base-client/components/common/XAddForm/index.md +61 -61
  126. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +1169 -1169
  127. package/src/base-client/components/common/XAddNativeForm/demo.vue +40 -40
  128. package/src/base-client/components/common/XAddNativeForm/index.js +3 -3
  129. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  130. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  131. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  132. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  133. package/src/base-client/components/common/XAddReport/XAddReport.vue +212 -212
  134. package/src/base-client/components/common/XAddReport/index.js +3 -3
  135. package/src/base-client/components/common/XAddReport/index.md +56 -56
  136. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  137. package/src/base-client/components/common/XBadge/index.js +3 -3
  138. package/src/base-client/components/common/XBadge/index.md +39 -39
  139. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  140. package/src/base-client/components/common/XButtons/XButtons.vue +71 -71
  141. package/src/base-client/components/common/XButtons/index.js +3 -3
  142. package/src/base-client/components/common/XButtons/index.md +61 -61
  143. package/src/base-client/components/common/XCalendar/XCalendar.vue +369 -369
  144. package/src/base-client/components/common/XCalendar/index.md +284 -284
  145. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  146. package/src/base-client/components/common/XCard/index.js +3 -3
  147. package/src/base-client/components/common/XCard/index.md +43 -43
  148. package/src/base-client/components/common/XCardSet/XCardSet.vue +300 -300
  149. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  150. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  151. package/src/base-client/components/common/XCollapse/XCollapse.vue +253 -253
  152. package/src/base-client/components/common/XConversation/XConversation.vue +576 -576
  153. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  154. package/src/base-client/components/common/XDataCard/XDataCard.vue +629 -629
  155. package/src/base-client/components/common/XDataCard/index.js +3 -3
  156. package/src/base-client/components/common/XDataCard/index.md +1 -1
  157. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  158. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  159. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  160. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  161. package/src/base-client/components/common/XDatePicker/index.vue +276 -276
  162. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +174 -174
  163. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +314 -314
  164. package/src/base-client/components/common/XDescriptions/demo.vue +51 -51
  165. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  166. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  167. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  168. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  169. package/src/base-client/components/common/XForm/XForm.vue +420 -420
  170. package/src/base-client/components/common/XForm/XFormItem.vue +1342 -1342
  171. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  172. package/src/base-client/components/common/XForm/XTreeSelect.vue +276 -276
  173. package/src/base-client/components/common/XForm/demo.vue +105 -105
  174. package/src/base-client/components/common/XForm/index.js +3 -3
  175. package/src/base-client/components/common/XForm/index.md +178 -178
  176. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  177. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -157
  178. package/src/base-client/components/common/XFormCol/index.js +3 -3
  179. package/src/base-client/components/common/XFormCol/index.md +35 -35
  180. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +301 -301
  181. package/src/base-client/components/common/XFormGroup/demo.vue +41 -41
  182. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  183. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  184. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  185. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  186. package/src/base-client/components/common/XFormTable/XFormTable.vue +938 -938
  187. package/src/base-client/components/common/XFormTable/demo.vue +87 -87
  188. package/src/base-client/components/common/XFormTable/index.js +3 -3
  189. package/src/base-client/components/common/XFormTable/index.md +92 -92
  190. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +174 -174
  191. package/src/base-client/components/common/XImportExcel/index.js +3 -3
  192. package/src/base-client/components/common/XImportExcel/index.md +38 -38
  193. package/src/base-client/components/common/XInput/XInput.vue +128 -128
  194. package/src/base-client/components/common/XInput/index.js +3 -3
  195. package/src/base-client/components/common/XInput/index.md +97 -97
  196. package/src/base-client/components/common/XIntervalPicker/XIntervalPicker.vue +121 -121
  197. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  198. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  199. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  200. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  201. package/src/base-client/components/common/XLicensePlate/index.js +3 -3
  202. package/src/base-client/components/common/XLicensePlate/index.md +38 -38
  203. package/src/base-client/components/common/XPrint/Demo.vue +41 -41
  204. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  205. package/src/base-client/components/common/XPrint/PrintBill.vue +304 -304
  206. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  207. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  208. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  209. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  210. package/src/base-client/components/common/XPrint/index.vue +97 -97
  211. package/src/base-client/components/common/XRate/demo.vue +102 -102
  212. package/src/base-client/components/common/XRate/index.vue +149 -149
  213. package/src/base-client/components/common/XReport/XReport.vue +963 -963
  214. package/src/base-client/components/common/XReport/XReportDemo.vue +70 -70
  215. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  216. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  217. package/src/base-client/components/common/XReport/XReportTrGroup.vue +1005 -1005
  218. package/src/base-client/components/common/XReport/index.js +3 -3
  219. package/src/base-client/components/common/XReport/index.md +103 -103
  220. package/src/base-client/components/common/XReport/print.js +186 -186
  221. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  222. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  223. package/src/base-client/components/common/XReportGrid/XReport.vue +1075 -1075
  224. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +44 -44
  225. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +620 -620
  226. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +731 -731
  227. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  228. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  229. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  230. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  231. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  232. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  233. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  234. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  235. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  236. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  237. package/src/base-client/components/common/XStepView/index.js +3 -3
  238. package/src/base-client/components/common/XStepView/index.md +31 -31
  239. package/src/base-client/components/common/XTab/XTab.vue +299 -299
  240. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  241. package/src/base-client/components/common/XTab/index.js +3 -3
  242. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  243. package/src/base-client/components/common/XTable/ExportExcel.vue +282 -282
  244. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  245. package/src/base-client/components/common/XTable/XTable.vue +1600 -1600
  246. package/src/base-client/components/common/XTable/XTableWrapper.vue +584 -584
  247. package/src/base-client/components/common/XTable/index.js +3 -3
  248. package/src/base-client/components/common/XTable/index.md +255 -255
  249. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  250. package/src/base-client/components/common/XTimeline/XTimeline.vue +358 -358
  251. package/src/base-client/components/common/XTimeline/index.md +191 -191
  252. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  253. package/src/base-client/components/common/XTree/XTreePro.vue +452 -452
  254. package/src/base-client/components/common/XTree/index.js +3 -3
  255. package/src/base-client/components/common/XTree/index.md +36 -36
  256. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  257. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  258. package/src/base-client/components/common/XTreeOne/index.js +3 -3
  259. package/src/base-client/components/common/XUploadFilesView/index.vue +485 -485
  260. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  261. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  262. package/src/base-client/components/his/XCharge/XCharge.vue +238 -238
  263. package/src/base-client/components/his/XCheckbox/XCheckbox.vue +105 -105
  264. package/src/base-client/components/his/XCheckbox/index.md +253 -253
  265. package/src/base-client/components/his/XHDescriptions/XHDescriptions.vue +430 -430
  266. package/src/base-client/components/his/XHDescriptions/index.md +217 -217
  267. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +457 -457
  268. package/src/base-client/components/his/XHisEditor/diagnosisAutocomplete.js +263 -263
  269. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  270. package/src/base-client/components/his/XList/XList.vue +306 -306
  271. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.json +3 -3
  272. package/src/base-client/components/his/XQuestionnaire/XQuestionnaire.vue +89 -89
  273. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireDemo.vue +51 -51
  274. package/src/base-client/components/his/XQuestionnaire/XQuestionnaireItem.vue +252 -252
  275. package/src/base-client/components/his/XRadio/XRadio.vue +125 -125
  276. package/src/base-client/components/his/XRadio/index.md +234 -234
  277. package/src/base-client/components/his/XSelect/XSelect.vue +72 -72
  278. package/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +234 -234
  279. package/src/base-client/components/his/XShiftSchedule/dome.vue +29 -29
  280. package/src/base-client/components/his/XSidebar/XSidebar.vue +240 -240
  281. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  282. package/src/base-client/components/his/XTimeSelect/XTimeSelect.vue +162 -162
  283. package/src/base-client/components/his/XTimeSelect/XTimeSelectDemo.vue +23 -23
  284. package/src/base-client/components/his/XTitle/README.md +113 -113
  285. package/src/base-client/components/his/XTitle/XTitle.vue +123 -123
  286. package/src/base-client/components/his/XTreeRows/TreeNode.vue +100 -100
  287. package/src/base-client/components/his/XTreeRows/XTreeRows.vue +197 -197
  288. package/src/base-client/components/his/threeTestOrders/dome.vue +68 -68
  289. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  290. package/src/base-client/components/his/threeTestOrders/textBox.vue +457 -457
  291. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +475 -475
  292. package/src/base-client/components/index.js +51 -51
  293. package/src/base-client/components/layout/XPageView/RenderRow.vue +88 -88
  294. package/src/base-client/components/layout/XPageView/XErrorView.vue +22 -22
  295. package/src/base-client/components/layout/XPageView/XPageRowTemplate.vue +37 -37
  296. package/src/base-client/components/layout/XPageView/XPageView.vue +223 -223
  297. package/src/base-client/components/layout/XPageView/XTab/XTab.vue +96 -96
  298. package/src/base-client/components/layout/XPageView/XTab/index.js +3 -3
  299. package/src/base-client/components/layout/XPageView/componentTypes.js +22 -22
  300. package/src/base-client/components/layout/XPageView/index.js +2 -2
  301. package/src/base-client/components/layout/XPageView/index.md +96 -96
  302. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  303. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  304. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  305. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  306. package/src/base-client/components/system/DictionaryDetailsView/index.js +3 -3
  307. package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -41
  308. package/src/base-client/components/system/LogDetailsView/LogDetailsView.vue +376 -376
  309. package/src/base-client/components/system/LogDetailsView/index.js +3 -3
  310. package/src/base-client/components/system/LogDetailsView/index.md +41 -41
  311. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  312. package/src/base-client/components/system/QueryParamsDetailsView/index.js +3 -3
  313. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  314. package/src/base-client/components/ticket/TicketDetailsView/index.js +3 -3
  315. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  316. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  317. package/src/base-client/components/ticket/TicketDetailsView/part/index.js +3 -3
  318. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  319. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.js +3 -3
  320. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  321. package/src/base-client/plugins/AppData.js +126 -126
  322. package/src/base-client/plugins/Config.js +19 -19
  323. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  324. package/src/base-client/plugins/PagedList.js +177 -177
  325. package/src/base-client/plugins/Recording.js +258 -258
  326. package/src/base-client/plugins/authority-plugin.js +167 -167
  327. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  328. package/src/base-client/plugins/i18n-extend.js +32 -32
  329. package/src/base-client/plugins/index.js +23 -23
  330. package/src/base-client/plugins/moment.js +8 -8
  331. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  332. package/src/bootstrap.js +51 -51
  333. package/src/components/Charts/Bar.vue +62 -62
  334. package/src/components/Charts/ChartCard.vue +134 -134
  335. package/src/components/Charts/Liquid.vue +67 -67
  336. package/src/components/Charts/MiniArea.vue +39 -39
  337. package/src/components/Charts/MiniBar.vue +39 -39
  338. package/src/components/Charts/MiniProgress.vue +75 -75
  339. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  340. package/src/components/Charts/Radar.vue +68 -68
  341. package/src/components/Charts/RankList.vue +77 -77
  342. package/src/components/Charts/TagCloud.vue +113 -113
  343. package/src/components/Charts/TransferBar.vue +64 -64
  344. package/src/components/Charts/Trend.vue +82 -82
  345. package/src/components/Charts/chart.less +12 -12
  346. package/src/components/Charts/smooth.area.less +13 -13
  347. package/src/components/CodeMirror/inedx.vue +118 -118
  348. package/src/components/CodeMirror/setting.js +40 -40
  349. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  350. package/src/components/Ellipsis/index.js +3 -3
  351. package/src/components/Ellipsis/index.md +38 -38
  352. package/src/components/FileImageItem/FileItem.vue +305 -305
  353. package/src/components/FileImageItem/FileItemGroup.vue +197 -197
  354. package/src/components/FileImageItem/ImageItem.vue +107 -107
  355. package/src/components/FileImageItem/index.js +4 -4
  356. package/src/components/FilePreview/FilePreview.vue +181 -181
  357. package/src/components/FilePreview/FilePreviewDemo.vue +30 -30
  358. package/src/components/FilePreview/index.js +3 -3
  359. package/src/components/HeightScanner/index.vue +615 -615
  360. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  361. package/src/components/NumberInfo/index.js +3 -3
  362. package/src/components/NumberInfo/index.less +54 -54
  363. package/src/components/NumberInfo/index.md +43 -43
  364. package/src/components/STable/README.md +341 -341
  365. package/src/components/STable/index.js +558 -558
  366. package/src/components/TableSetting/TableSetting.vue +143 -143
  367. package/src/components/TableSetting/index.js +3 -3
  368. package/src/components/Trend/Trend.vue +41 -41
  369. package/src/components/Trend/index.js +3 -3
  370. package/src/components/Trend/index.less +41 -41
  371. package/src/components/Trend/index.md +45 -45
  372. package/src/components/_util/util.js +46 -46
  373. package/src/components/cache/AKeepAlive.js +179 -179
  374. package/src/components/card/ChartCard.vue +79 -79
  375. package/src/components/chart/Bar.vue +60 -60
  376. package/src/components/chart/MiniArea.vue +67 -67
  377. package/src/components/chart/MiniBar.vue +59 -59
  378. package/src/components/chart/MiniProgress.vue +57 -57
  379. package/src/components/chart/Radar.vue +80 -80
  380. package/src/components/chart/RankingList.vue +60 -60
  381. package/src/components/chart/Trend.vue +79 -79
  382. package/src/components/chart/index.less +9 -9
  383. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  384. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  385. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  386. package/src/components/checkbox/index.js +9 -9
  387. package/src/components/exception/ExceptionPage.vue +70 -70
  388. package/src/components/exception/typeConfig.js +19 -19
  389. package/src/components/form/FormRow.vue +52 -52
  390. package/src/components/g2Charts/constants.js +202 -202
  391. package/src/components/g2Charts/demo.vue +808 -808
  392. package/src/components/g2Charts/designer.vue +228 -228
  393. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  394. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  395. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  396. package/src/components/g2Charts/index.vue +397 -397
  397. package/src/components/index.js +36 -36
  398. package/src/components/index.less +5 -5
  399. package/src/components/input/IInput.vue +66 -66
  400. package/src/components/menu/Contextmenu.vue +84 -84
  401. package/src/components/menu/SideMenu.vue +75 -75
  402. package/src/components/menu/index.less +38 -38
  403. package/src/components/menu/menu.js +273 -273
  404. package/src/components/page/header/PageHeader.vue +64 -64
  405. package/src/components/page/header/index.less +40 -40
  406. package/src/components/result/Result.vue +77 -77
  407. package/src/components/setting/Setting.vue +234 -234
  408. package/src/components/setting/SettingItem.vue +26 -26
  409. package/src/components/setting/i18n.js +117 -117
  410. package/src/components/table/StandardTable.vue +141 -141
  411. package/src/components/table/advance/ActionColumns.vue +158 -158
  412. package/src/components/table/advance/ActionSize.vue +45 -45
  413. package/src/components/table/advance/AdvanceTable.vue +275 -275
  414. package/src/components/table/advance/SearchArea.vue +355 -355
  415. package/src/components/table/advance/index.js +2 -2
  416. package/src/components/table/api/ApiTable.vue +50 -50
  417. package/src/components/task/TaskGroup.vue +80 -80
  418. package/src/components/task/TaskItem.vue +26 -26
  419. package/src/components/tool/AStepItem.vue +60 -60
  420. package/src/components/tool/AvatarList.vue +68 -68
  421. package/src/components/tool/DetailList.vue +157 -157
  422. package/src/components/tool/Drawer.vue +142 -142
  423. package/src/components/tool/FooterToolBar.vue +30 -30
  424. package/src/components/tool/HeadInfo.vue +35 -35
  425. package/src/components/tool/TagSelect.vue +83 -83
  426. package/src/components/tool/TagSelectOption.vue +33 -33
  427. package/src/components/transition/PageToggleTransition.vue +97 -97
  428. package/src/config/CreateQueryConfig.js +325 -325
  429. package/src/config/default/admin.config.js +18 -18
  430. package/src/config/default/animate.config.js +21 -21
  431. package/src/config/default/antd.config.js +89 -89
  432. package/src/config/default/index.js +6 -6
  433. package/src/config/default/setting.config.js +55 -55
  434. package/src/config/index.js +3 -3
  435. package/src/config/replacer/index.js +10 -10
  436. package/src/config/replacer/resolve.config.js +67 -67
  437. package/src/expression/ExpressionRunner.js +26 -26
  438. package/src/expression/TestExpression.js +509 -509
  439. package/src/expression/core/Delegate.js +115 -115
  440. package/src/expression/core/Expression.js +1358 -1358
  441. package/src/expression/core/Program.js +932 -932
  442. package/src/expression/core/Token.js +27 -27
  443. package/src/expression/enums/ExpressionType.js +81 -81
  444. package/src/expression/enums/TokenType.js +11 -11
  445. package/src/expression/exception/BreakWayException.js +2 -2
  446. package/src/expression/exception/ContinueWayException.js +2 -2
  447. package/src/expression/exception/ExpressionException.js +28 -28
  448. package/src/expression/exception/ReturnWayException.js +14 -14
  449. package/src/expression/exception/ServiceException.js +22 -22
  450. package/src/expression/instances/LogicConsole.js +44 -44
  451. package/src/expression/ts/ExpressionRunner.ts +28 -28
  452. package/src/expression/ts/TestExpression.ts +509 -509
  453. package/src/expression/ts/core/Delegate.ts +114 -114
  454. package/src/expression/ts/core/Expression.ts +1309 -1309
  455. package/src/expression/ts/core/Program.ts +950 -950
  456. package/src/expression/ts/core/Token.ts +29 -29
  457. package/src/expression/ts/enums/ExpressionType.ts +81 -81
  458. package/src/expression/ts/enums/TokenType.ts +13 -13
  459. package/src/expression/ts/exception/BreakWayException.ts +2 -2
  460. package/src/expression/ts/exception/ContinueWayException.ts +2 -2
  461. package/src/expression/ts/exception/ExpressionException.ts +28 -28
  462. package/src/expression/ts/exception/ReturnWayException.ts +14 -14
  463. package/src/expression/ts/exception/ServiceException.ts +22 -22
  464. package/src/expression/ts/instances/JSONArray.ts +48 -48
  465. package/src/expression/ts/instances/JSONObject.ts +109 -109
  466. package/src/expression/ts/instances/LogicConsole.ts +32 -32
  467. package/src/font-style/font.css +4 -4
  468. package/src/layouts/AdminLayout.vue +174 -174
  469. package/src/layouts/BlankView.vue +79 -79
  470. package/src/layouts/CommonLayout.vue +56 -56
  471. package/src/layouts/ComponentLayoutOne.vue +47 -47
  472. package/src/layouts/GridView.vue +43 -43
  473. package/src/layouts/PageLayout.vue +151 -151
  474. package/src/layouts/PageView.vue +55 -55
  475. package/src/layouts/SinglePageView.vue +136 -136
  476. package/src/layouts/footer/PageFooter.vue +49 -49
  477. package/src/layouts/header/AdminHeader.vue +132 -132
  478. package/src/layouts/header/HeaderAvatar.vue +64 -64
  479. package/src/layouts/header/HeaderNotice.vue +177 -177
  480. package/src/layouts/header/HeaderSearch.vue +67 -67
  481. package/src/layouts/header/InstitutionDetail.vue +181 -181
  482. package/src/layouts/header/index.less +92 -92
  483. package/src/layouts/tabs/TabsHead.vue +189 -189
  484. package/src/layouts/tabs/TabsView.vue +389 -389
  485. package/src/layouts/tabs/i18n.js +25 -25
  486. package/src/layouts/tabs/index.js +2 -2
  487. package/src/lib.js +1 -1
  488. package/src/logic/LogicRunner.js +62 -62
  489. package/src/logic/TestLogic.js +13 -13
  490. package/src/logic/plugins/common/DateTools.js +35 -35
  491. package/src/logic/plugins/common/VueTools.js +30 -30
  492. package/src/logic/plugins/index.js +7 -7
  493. package/src/logic/ts/LogicRunner.ts +67 -67
  494. package/src/logic/ts/TestLogic.ts +13 -13
  495. package/src/main.js +33 -33
  496. package/src/mixins/formValidationMixin.js +46 -46
  497. package/src/mock/common/activityData.js +32 -32
  498. package/src/mock/common/index.js +89 -89
  499. package/src/mock/common/reportData.js +20 -20
  500. package/src/mock/common/tableData.js +118 -118
  501. package/src/mock/extend/index.js +84 -84
  502. package/src/mock/goods/index.js +108 -108
  503. package/src/mock/index.js +12 -12
  504. package/src/mock/project/index.js +17 -17
  505. package/src/mock/user/current.js +13 -13
  506. package/src/mock/user/login.js +39 -39
  507. package/src/mock/user/routes.js +61 -61
  508. package/src/mock/workplace/index.js +15 -15
  509. package/src/pages/DefaultExample/index.vue +77 -77
  510. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  511. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  512. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  513. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  514. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  515. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  516. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  517. package/src/pages/DynamicStatistics/index.vue +282 -282
  518. package/src/pages/Example/childIndex.vue +15 -15
  519. package/src/pages/Example/index.vue +30 -30
  520. package/src/pages/LogicCallExample/index.vue +46 -46
  521. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  522. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  523. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  524. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  525. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  526. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  527. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  528. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  529. package/src/pages/Recording/index.vue +77 -77
  530. package/src/pages/ReportGrid/index.vue +76 -76
  531. package/src/pages/ReportView.vue +50 -50
  532. package/src/pages/ServiceReview/index.vue +284 -284
  533. package/src/pages/SubExample/index.vue +26 -26
  534. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +47 -47
  535. package/src/pages/WorkflowDetail/WorkFlowDemo2.vue +204 -204
  536. package/src/pages/WorkflowDetail/WorkFlowDemo3.vue +203 -204
  537. package/src/pages/WorkflowDetail/WorkflowDetail.vue +379 -399
  538. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +388 -388
  539. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  540. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +415 -415
  541. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +276 -276
  542. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +1757 -1757
  543. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +975 -975
  544. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowPreview.vue +109 -109
  545. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +987 -987
  546. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +222 -222
  547. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +243 -243
  548. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +248 -248
  549. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +188 -188
  550. package/src/pages/WorkflowDetail/WorkflowPageDetail/components/WorkflowPersonSelector.vue +109 -109
  551. package/src/pages/XPageViewExample/index.vue +149 -149
  552. package/src/pages/XReportView/index.vue +64 -64
  553. package/src/pages/XTreeOneProExample/index.vue +67 -67
  554. package/src/pages/addressSelect/addressDemo.vue +24 -24
  555. package/src/pages/addressSelect/index.vue +270 -270
  556. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  557. package/src/pages/dashboard/workplace/i18n.js +40 -40
  558. package/src/pages/dashboard/workplace/index.js +2 -2
  559. package/src/pages/dashboard/workplace/index.less +59 -59
  560. package/src/pages/exception/403.vue +21 -21
  561. package/src/pages/exception/404.vue +24 -24
  562. package/src/pages/exception/500.vue +21 -21
  563. package/src/pages/login/Login.vue +378 -378
  564. package/src/pages/login/LoginV3.vue +389 -389
  565. package/src/pages/login/index.js +2 -2
  566. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  567. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  568. package/src/pages/report/ReportTable.js +124 -124
  569. package/src/pages/report/ReportTableHome.vue +28 -28
  570. package/src/pages/resourceManage/depListManage.vue +23 -23
  571. package/src/pages/resourceManage/funListManage.vue +23 -23
  572. package/src/pages/resourceManage/index.js +15 -15
  573. package/src/pages/resourceManage/orgListManage.vue +98 -98
  574. package/src/pages/resourceManage/resourceManageMain.vue +57 -57
  575. package/src/pages/resourceManage/roleListManage.vue +23 -23
  576. package/src/pages/resourceManage/staffListManage.vue +23 -23
  577. package/src/pages/system/dictionary/index.vue +44 -44
  578. package/src/pages/system/file/Info.vue +56 -56
  579. package/src/pages/system/file/index.vue +317 -317
  580. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  581. package/src/pages/system/monitor/operLog/index.vue +37 -37
  582. package/src/pages/system/settings/index.vue +126 -126
  583. package/src/pages/system/settings/modifyPassword.vue +117 -117
  584. package/src/pages/system/ticket/index.vue +480 -480
  585. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  586. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  587. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +77 -77
  588. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +75 -75
  589. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  590. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  591. package/src/pages/userInfoDetailManage/InsuranceDetailQuery/index.vue +64 -64
  592. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +75 -75
  593. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  594. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +75 -75
  595. package/src/pages/userInfoDetailManage/PriceAdjustments/index.vue +64 -64
  596. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  597. package/src/pages/userInfoDetailManage/UserChargeRecordQuery/index.vue +94 -94
  598. package/src/pages/userInfoDetailManage/UserException/index.vue +64 -64
  599. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +87 -87
  600. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +74 -74
  601. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  602. package/src/pages/userInfoDetailManage/index.vue +290 -290
  603. package/src/pages/userInfoDetailManage/uploadFilesHistory/index.vue +120 -120
  604. package/src/pages/userInfoDetailManage/userInfoDetailQueryTabs.vue +144 -144
  605. package/src/plugins/EventLogPlugin.js +33 -33
  606. package/src/plugins/FindParentsData.js +17 -17
  607. package/src/plugins/HiPrintPlugin.js +164 -164
  608. package/src/router/async/config.async.js +35 -35
  609. package/src/router/async/router.map.js +127 -126
  610. package/src/router/guards.js +260 -260
  611. package/src/router/i18n.js +57 -57
  612. package/src/router/index.js +27 -27
  613. package/src/router.js +17 -17
  614. package/src/services/DataModel.js +30 -30
  615. package/src/services/LodopFuncs.js +137 -137
  616. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  617. package/src/services/api/LogDetailsViewApi.js +10 -10
  618. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  619. package/src/services/api/TicketDetailsViewApi.js +46 -46
  620. package/src/services/api/cas.js +79 -79
  621. package/src/services/api/common.js +346 -346
  622. package/src/services/api/entity.js +18 -18
  623. package/src/services/api/index.js +17 -17
  624. package/src/services/api/logininfor/index.js +6 -6
  625. package/src/services/api/manage.js +8 -8
  626. package/src/services/api/restTools.js +215 -215
  627. package/src/services/api/workFlow.js +57 -57
  628. package/src/services/apiService.js +16 -16
  629. package/src/services/dataSource.js +12 -12
  630. package/src/services/index.js +7 -7
  631. package/src/services/user.js +92 -92
  632. package/src/services/v3Api.js +116 -116
  633. package/src/store/index.js +5 -5
  634. package/src/store/modules/account.js +115 -115
  635. package/src/store/modules/index.js +5 -5
  636. package/src/store/modules/lowCode.js +33 -33
  637. package/src/store/modules/setting.js +119 -119
  638. package/src/store/mutation-types.js +4 -4
  639. package/src/theme/antd/ant-menu.less +2 -2
  640. package/src/theme/antd/ant-message.less +3 -3
  641. package/src/theme/antd/ant-table.less +22 -22
  642. package/src/theme/antd/ant-time-picker.less +3 -3
  643. package/src/theme/antd/index.less +3 -3
  644. package/src/theme/default/color.less +43 -43
  645. package/src/theme/default/index.less +3 -3
  646. package/src/theme/default/nprogress.less +76 -76
  647. package/src/theme/default/style.less +58 -58
  648. package/src/theme/global.less +271 -271
  649. package/src/theme/index.less +5 -5
  650. package/src/theme/reportTable.less +58 -58
  651. package/src/theme/theme.less +1 -1
  652. package/src/utils/EncryptUtil.js +75 -75
  653. package/src/utils/Objects.js +25 -25
  654. package/src/utils/authority-utils.js +85 -85
  655. package/src/utils/axios-interceptors.js +100 -100
  656. package/src/utils/colors.js +107 -107
  657. package/src/utils/common.js +10 -10
  658. package/src/utils/errorCode.js +6 -6
  659. package/src/utils/excel/Blob.js +180 -180
  660. package/src/utils/excel/Export2Excel.js +141 -141
  661. package/src/utils/filter.js +21 -21
  662. package/src/utils/formatter.js +74 -74
  663. package/src/utils/htmlToPDF.js +108 -108
  664. package/src/utils/htmlToPDFApi.js +5 -5
  665. package/src/utils/i18n.js +80 -80
  666. package/src/utils/indexedDB.js +549 -549
  667. package/src/utils/login.js +188 -188
  668. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  669. package/src/utils/lowcode/lowcodeLog.js +29 -29
  670. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  671. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  672. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  673. package/src/utils/map-utils.js +47 -47
  674. package/src/utils/microAppUtils.js +49 -49
  675. package/src/utils/reg.js +95 -95
  676. package/src/utils/request.js +383 -383
  677. package/src/utils/routerUtil.js +553 -553
  678. package/src/utils/runEvalFunction.js +14 -14
  679. package/src/utils/theme-color-replacer-extend.js +92 -92
  680. package/src/utils/themeUtil.js +100 -100
  681. package/src/utils/util.js +329 -329
  682. package/src/utils/waterMark.js +31 -31
  683. package/test/Tree.spec.js +168 -168
  684. package/test/myDialog.spec.js +47 -47
  685. package/test/request.test.js +17 -17
  686. package/test/util.test.js +53 -53
  687. package/test/v3Api.test.js +1984 -1984
  688. package/tests/unit/ReportTable.spec.js +16 -16
  689. package/vue.config.js +222 -222
  690. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
  691. package/.claude/settings.local.json +0 -9
@@ -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>