vue2-client 1.15.85 → 1.15.86

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