vue2-client 1.15.32 → 1.15.34

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