@arkxos/arkos-system 0.1.0

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 (494) hide show
  1. package/README.md +36 -0
  2. package/ark_dist/664d11f069eab128.css +2 -0
  3. package/ark_dist/ArkOsConfig.js +136 -0
  4. package/ark_dist/ark-meta.json +92 -0
  5. package/ark_dist/ark_userChunk_1.js +3 -0
  6. package/ark_dist/ark_userChunk_2.js +5 -0
  7. package/ark_dist/ark_userChunk_3.js +49 -0
  8. package/ark_dist/config.js +75 -0
  9. package/ark_dist/css/views/views-flow-flow.ca26b106.css +5784 -0
  10. package/ark_dist/favicon.ico +0 -0
  11. package/ark_dist/fonts/bpmn.5d33bee4.eot +0 -0
  12. package/ark_dist/fonts/bpmn.67058807.woff2 +0 -0
  13. package/ark_dist/fonts/bpmn.b5c9250d.ttf +0 -0
  14. package/ark_dist/fonts/bpmn.e9e7d076.woff +0 -0
  15. package/ark_dist/img/404.png +0 -0
  16. package/ark_dist/img/auth_banner.jpg +0 -0
  17. package/ark_dist/img/avatar.jpg +0 -0
  18. package/ark_dist/img/avatar2.gif +0 -0
  19. package/ark_dist/img/avatar3.gif +0 -0
  20. package/ark_dist/img/bpmn.74eea12b.svg +224 -0
  21. package/ark_dist/img/loginbg.svg +1 -0
  22. package/ark_dist/img/logo-r.png +0 -0
  23. package/ark_dist/img/logo.png +0 -0
  24. package/ark_dist/img/mobile-bg.d055fadc.png +0 -0
  25. package/ark_dist/img/no-widgets.svg +57 -0
  26. package/ark_dist/img/tasks-example.png +0 -0
  27. package/ark_dist/img/ver.svg +236 -0
  28. package/ark_dist/index.html +118 -0
  29. package/ark_dist/js/app.e39a548a.js +1 -0
  30. package/ark_dist/js/views/views-flow-flow.84dc5300.js +3 -0
  31. package/ark_dist/js/views/views-flow-flow.84dc5300.js.LICENSE.txt +182 -0
  32. package/ark_dist/js/views/views-flow-flow.84dc5300.js.map +1 -0
  33. package/ark_proxy/entry.js +28 -0
  34. package/ark_proxy_es/entry.js +16 -0
  35. package/package.json +173 -0
  36. package/scripts/check.js +13 -0
  37. package/scripts/meta.js +21 -0
  38. package/scripts/prepublishOnly.js +28 -0
  39. package/src/admin/App.vue +13 -0
  40. package/src/admin/bpmn/custom/context-pad.js +405 -0
  41. package/src/admin/bpmn/custom/index.js +8 -0
  42. package/src/admin/bpmn/custom/palette.js +159 -0
  43. package/src/admin/bpmn/properties-panel/PropertiesView.vue +620 -0
  44. package/src/admin/bpmn/translate.js +23 -0
  45. package/src/admin/bpmn/translations.js +211 -0
  46. package/src/admin/components/affix/index.vue +385 -0
  47. package/src/admin/components/area-select/index.vue +52 -0
  48. package/src/admin/components/buttons/index.vue +47 -0
  49. package/src/admin/components/checkbox/index.vue +83 -0
  50. package/src/admin/components/code/code.js +149 -0
  51. package/src/admin/components/code/index.vue +450 -0
  52. package/src/admin/components/color/index.vue +30 -0
  53. package/src/admin/components/color-picker/index.vue +57 -0
  54. package/src/admin/components/color-scheme/index.vue +234 -0
  55. package/src/admin/components/condition-list/index.vue +170 -0
  56. package/src/admin/components/date/index.vue +29 -0
  57. package/src/admin/components/datetime/index.vue +45 -0
  58. package/src/admin/components/default-value-tips/index.vue +44 -0
  59. package/src/admin/components/dict-buttons/index.vue +53 -0
  60. package/src/admin/components/dict-checkbox/index.vue +45 -0
  61. package/src/admin/components/dict-radio/index.vue +68 -0
  62. package/src/admin/components/dict-select/index.vue +93 -0
  63. package/src/admin/components/dict-selects/index.vue +105 -0
  64. package/src/admin/components/dict-switch/index.vue +64 -0
  65. package/src/admin/components/dict-tree/index.vue +17 -0
  66. package/src/admin/components/dm-tree/index.vue +224 -0
  67. package/src/admin/components/edit-table/index.vue +171 -0
  68. package/src/admin/components/employee-tree/index.vue +247 -0
  69. package/src/admin/components/employees-tree/index.vue +80 -0
  70. package/src/admin/components/entp-tree/index.vue +266 -0
  71. package/src/admin/components/file/index.vue +310 -0
  72. package/src/admin/components/form/index.vue +141 -0
  73. package/src/admin/components/icon/index.vue +77 -0
  74. package/src/admin/components/icon-buttons/index.vue +52 -0
  75. package/src/admin/components/icon-select/index.vue +140 -0
  76. package/src/admin/components/image/index.vue +207 -0
  77. package/src/admin/components/index.js +16 -0
  78. package/src/admin/components/input/index.vue +41 -0
  79. package/src/admin/components/local-img/index.vue +49 -0
  80. package/src/admin/components/multiple-input/index.vue +64 -0
  81. package/src/admin/components/multiple-number/index.vue +70 -0
  82. package/src/admin/components/number/index.vue +134 -0
  83. package/src/admin/components/organization/index.vue +303 -0
  84. package/src/admin/components/organization-tree/index.vue +269 -0
  85. package/src/admin/components/page/index.vue +149 -0
  86. package/src/admin/components/password/index.vue +21 -0
  87. package/src/admin/components/radio/index.vue +46 -0
  88. package/src/admin/components/region-tree/index.vue +269 -0
  89. package/src/admin/components/remote-select/index.vue +315 -0
  90. package/src/admin/components/rich-editor/index.vue +152 -0
  91. package/src/admin/components/role-select/index.vue +58 -0
  92. package/src/admin/components/script-input/index.vue +97 -0
  93. package/src/admin/components/select/index.vue +105 -0
  94. package/src/admin/components/selects/index.vue +100 -0
  95. package/src/admin/components/style-list/index.vue +500 -0
  96. package/src/admin/components/switch/index.vue +54 -0
  97. package/src/admin/components/table/index.vue +920 -0
  98. package/src/admin/components/textarea/index.vue +28 -0
  99. package/src/admin/components/tree/index.vue +247 -0
  100. package/src/admin/components/tree-selects/index.vue +66 -0
  101. package/src/admin/components/unit-tree/index.vue +269 -0
  102. package/src/admin/console/index.vue +122 -0
  103. package/src/admin/layout/console/index.vue +15 -0
  104. package/src/admin/layout/fullscreen/index.vue +32 -0
  105. package/src/admin/layout/home/index.vue +11 -0
  106. package/src/admin/layout/index.vue +139 -0
  107. package/src/admin/layout/menu/index.vue +102 -0
  108. package/src/admin/layout/personnel/index.vue +166 -0
  109. package/src/admin/layout/search/index.vue +78 -0
  110. package/src/admin/main.js +30 -0
  111. package/src/admin/pinia/router.js +179 -0
  112. package/src/admin/router.js +91 -0
  113. package/src/admin/visual/comp-data.vue +1107 -0
  114. package/src/admin/visual/comp-event.vue +1677 -0
  115. package/src/admin/visual/components/app/list/goods/double.vue +184 -0
  116. package/src/admin/visual/components/app/list/nav/image.vue +114 -0
  117. package/src/admin/visual/components/app/list/nav/text.vue +130 -0
  118. package/src/admin/visual/components/button/index.vue +58 -0
  119. package/src/admin/visual/components/container/index.vue +37 -0
  120. package/src/admin/visual/components/custom-list/index.vue +127 -0
  121. package/src/admin/visual/components/data/index.vue +46 -0
  122. package/src/admin/visual/components/data-table/index.vue +203 -0
  123. package/src/admin/visual/components/echarts/annular.vue +140 -0
  124. package/src/admin/visual/components/echarts/bar.vue +115 -0
  125. package/src/admin/visual/components/echarts/funnel.vue +115 -0
  126. package/src/admin/visual/components/echarts/gauge.vue +158 -0
  127. package/src/admin/visual/components/echarts/line.vue +110 -0
  128. package/src/admin/visual/components/echarts/map.vue +150 -0
  129. package/src/admin/visual/components/echarts/pie.vue +114 -0
  130. package/src/admin/visual/components/echarts/radar.vue +145 -0
  131. package/src/admin/visual/components/echarts/scatter.vue +106 -0
  132. package/src/admin/visual/components/edit-table/index.vue +71 -0
  133. package/src/admin/visual/components/form/affix.vue +107 -0
  134. package/src/admin/visual/components/form/area.vue +76 -0
  135. package/src/admin/visual/components/form/buttons.vue +90 -0
  136. package/src/admin/visual/components/form/checkbox.vue +85 -0
  137. package/src/admin/visual/components/form/date-range.vue +61 -0
  138. package/src/admin/visual/components/form/date.vue +59 -0
  139. package/src/admin/visual/components/form/datetime.vue +59 -0
  140. package/src/admin/visual/components/form/employee-tree.vue +88 -0
  141. package/src/admin/visual/components/form/employees-tree.vue +6 -0
  142. package/src/admin/visual/components/form/image.vue +103 -0
  143. package/src/admin/visual/components/form/index.vue +59 -0
  144. package/src/admin/visual/components/form/input.vue +84 -0
  145. package/src/admin/visual/components/form/item.vue +68 -0
  146. package/src/admin/visual/components/form/number.vue +130 -0
  147. package/src/admin/visual/components/form/organization-tree.vue +88 -0
  148. package/src/admin/visual/components/form/password.vue +74 -0
  149. package/src/admin/visual/components/form/radio.vue +87 -0
  150. package/src/admin/visual/components/form/rate.vue +66 -0
  151. package/src/admin/visual/components/form/region-tree.vue +88 -0
  152. package/src/admin/visual/components/form/rich-editor.vue +94 -0
  153. package/src/admin/visual/components/form/select.vue +156 -0
  154. package/src/admin/visual/components/form/switch.vue +85 -0
  155. package/src/admin/visual/components/form/textarea.vue +62 -0
  156. package/src/admin/visual/components/form/unit-tree.vue +88 -0
  157. package/src/admin/visual/components/icon/index.vue +65 -0
  158. package/src/admin/visual/components/image/index.vue +170 -0
  159. package/src/admin/visual/components/index.js +44 -0
  160. package/src/admin/visual/components/list/block.vue +160 -0
  161. package/src/admin/visual/components/list/button.vue +80 -0
  162. package/src/admin/visual/components/list/card.vue +101 -0
  163. package/src/admin/visual/components/list/custom.vue +150 -0
  164. package/src/admin/visual/components/list/image.vue +116 -0
  165. package/src/admin/visual/components/list/news.vue +138 -0
  166. package/src/admin/visual/components/page/index.vue +88 -0
  167. package/src/admin/visual/components/page-comp/index.vue +110 -0
  168. package/src/admin/visual/components/portal-menu/index.vue +92 -0
  169. package/src/admin/visual/components/qrcode/index.vue +77 -0
  170. package/src/admin/visual/components/router-view/index.vue +12 -0
  171. package/src/admin/visual/components/row/index.vue +139 -0
  172. package/src/admin/visual/components/search/index.vue +40 -0
  173. package/src/admin/visual/components/tabs/index.vue +125 -0
  174. package/src/admin/visual/components/text/index.vue +64 -0
  175. package/src/admin/visual/components/video/index.vue +41 -0
  176. package/src/admin/visual/draggable.vue +49 -0
  177. package/src/admin/visual/editor.vue +602 -0
  178. package/src/admin/visual/js/app-form.config.js +1301 -0
  179. package/src/admin/visual/js/app.config.js +86 -0
  180. package/src/admin/visual/js/common.config.js +687 -0
  181. package/src/admin/visual/js/component.config.js +741 -0
  182. package/src/admin/visual/js/echarts.config.js +2440 -0
  183. package/src/admin/visual/js/form.config.js +2837 -0
  184. package/src/admin/visual/js/list.config.js +578 -0
  185. package/src/admin/visual/js/menu.config.js +62 -0
  186. package/src/admin/visual/js/visual-comp.js +48 -0
  187. package/src/admin/visual/tool.vue +1223 -0
  188. package/src/assets/images/background.jpg +0 -0
  189. package/src/assets/images/login-bg.jpg +0 -0
  190. package/src/assets/images/mobile-bg.png +0 -0
  191. package/src/assets/images/no-data.png +0 -0
  192. package/src/assets/style/base.css +48 -0
  193. package/src/assets/style/business.css +5 -0
  194. package/src/assets/style/code.css +36 -0
  195. package/src/assets/style/codeless.css +195 -0
  196. package/src/assets/style/flow.css +12 -0
  197. package/src/assets/style/global/blue.css +83 -0
  198. package/src/assets/style/global/default.css +71 -0
  199. package/src/assets/style/global/green.css +83 -0
  200. package/src/assets/style/global/purple.css +83 -0
  201. package/src/assets/style/global/red.css +83 -0
  202. package/src/assets/style/main.css +608 -0
  203. package/src/assets/style/menu/black.css +9 -0
  204. package/src/assets/style/menu/default.css +9 -0
  205. package/src/assets/style/menu/grey.css +9 -0
  206. package/src/assets/style/visual.css +204 -0
  207. package/src/auto-imports.d.ts +307 -0
  208. package/src/business/App.vue +131 -0
  209. package/src/business/components/dict-select/index.vue +88 -0
  210. package/src/business/components/index.js +13 -0
  211. package/src/business/components/input/index.vue +38 -0
  212. package/src/business/components/table/index.vue +928 -0
  213. package/src/business/home/index.vue +45 -0
  214. package/src/business/iframe/index.vue +63 -0
  215. package/src/business/layout/aside/history/history.vue +518 -0
  216. package/src/business/layout/aside/index.vue +116 -0
  217. package/src/business/layout/aside/menu/index.vue +47 -0
  218. package/src/business/layout/aside/menu/menuItem.vue +83 -0
  219. package/src/business/layout/aside/menu/submenu.vue +88 -0
  220. package/src/business/layout/fullscreen/index.vue +41 -0
  221. package/src/business/layout/header/index.vue +81 -0
  222. package/src/business/layout/header/menu/index.vue +47 -0
  223. package/src/business/layout/header/menu/menuItem.vue +43 -0
  224. package/src/business/layout/header/menu/submenu.vue +34 -0
  225. package/src/business/layout/home/index.vue +20 -0
  226. package/src/business/layout/index.vue +330 -0
  227. package/src/business/layout/message/index.vue +250 -0
  228. package/src/business/layout/personnel/index.vue +549 -0
  229. package/src/business/layout/search/index.vue +75 -0
  230. package/src/business/layout/subsystem/index.vue +124 -0
  231. package/src/business/main.js +36 -0
  232. package/src/business/pinia/menuBadge.js +58 -0
  233. package/src/business/pinia/router.js +190 -0
  234. package/src/business/router.js +98 -0
  235. package/src/choose/App.vue +203 -0
  236. package/src/choose/main.js +22 -0
  237. package/src/choose/router.js +33 -0
  238. package/src/codeless/components/affix/index.vue +393 -0
  239. package/src/codeless/components/affix-view/index.vue +244 -0
  240. package/src/codeless/components/buttons/index.vue +59 -0
  241. package/src/codeless/components/checkbox/index.vue +107 -0
  242. package/src/codeless/components/date/index.vue +105 -0
  243. package/src/codeless/components/datetime/index.vue +65 -0
  244. package/src/codeless/components/dialog-select/index.vue +170 -0
  245. package/src/codeless/components/dict-buttons/index.vue +97 -0
  246. package/src/codeless/components/dict-radio/index.vue +94 -0
  247. package/src/codeless/components/dict-select/index.vue +181 -0
  248. package/src/codeless/components/dict-selects/index.vue +145 -0
  249. package/src/codeless/components/dict-switch/index.vue +94 -0
  250. package/src/codeless/components/dict-tree/index.vue +116 -0
  251. package/src/codeless/components/edit-table/index.vue +160 -0
  252. package/src/codeless/components/employee-tree/index.vue +254 -0
  253. package/src/codeless/components/employees-tree/index.vue +87 -0
  254. package/src/codeless/components/entp-tree/index.vue +261 -0
  255. package/src/codeless/components/entps-tree/index.vue +93 -0
  256. package/src/codeless/components/icon/index.vue +65 -0
  257. package/src/codeless/components/image/index.vue +298 -0
  258. package/src/codeless/components/index.js +16 -0
  259. package/src/codeless/components/input/index.vue +63 -0
  260. package/src/codeless/components/number/index.vue +150 -0
  261. package/src/codeless/components/organization-tree/index.vue +262 -0
  262. package/src/codeless/components/organizations-tree/index.vue +79 -0
  263. package/src/codeless/components/password/index.vue +42 -0
  264. package/src/codeless/components/radio/index.vue +57 -0
  265. package/src/codeless/components/region-tree/index.vue +262 -0
  266. package/src/codeless/components/remote-distinct/index.vue +354 -0
  267. package/src/codeless/components/remote-select/index.vue +363 -0
  268. package/src/codeless/components/rich-editor/index.vue +159 -0
  269. package/src/codeless/components/roles/index.vue +68 -0
  270. package/src/codeless/components/select/index.vue +95 -0
  271. package/src/codeless/components/selects/index.vue +116 -0
  272. package/src/codeless/components/show-dict/index.vue +52 -0
  273. package/src/codeless/components/show-employees/index.vue +29 -0
  274. package/src/codeless/components/show-organizations/index.vue +29 -0
  275. package/src/codeless/components/show-roles/index.vue +45 -0
  276. package/src/codeless/components/signature-pad/index.vue +224 -0
  277. package/src/codeless/components/switch/index.vue +56 -0
  278. package/src/codeless/components/textarea/index.vue +37 -0
  279. package/src/codeless/components/tree/index.vue +244 -0
  280. package/src/codeless/components/unit-tree/index.vue +262 -0
  281. package/src/codeless/components/units-tree/index.vue +93 -0
  282. package/src/codeless/components/video/index.vue +255 -0
  283. package/src/codeless/components/video-view/index.vue +130 -0
  284. package/src/codeless/js/codeless.js +47 -0
  285. package/src/codeless/view/form-auto.vue +192 -0
  286. package/src/codeless/view/form-custom.vue +10 -0
  287. package/src/codeless/view/form-model.vue +421 -0
  288. package/src/codeless/view/form-query.vue +171 -0
  289. package/src/codeless/view/form.vue +575 -0
  290. package/src/codeless/view/page-comp.vue +1318 -0
  291. package/src/codeless/view/page.vue +280 -0
  292. package/src/codeless/view/table-edit-item.vue +184 -0
  293. package/src/codeless/view/table-edit.vue +490 -0
  294. package/src/codeless/view/table.vue +1606 -0
  295. package/src/codeless/view/tree.vue +431 -0
  296. package/src/configs/subApp.ts +9 -0
  297. package/src/directives/collapse/index.js +123 -0
  298. package/src/directives/drag/index.js +43 -0
  299. package/src/directives/index.js +9 -0
  300. package/src/directives/resize/index.js +23 -0
  301. package/src/entrance/libProperties.ts +24 -0
  302. package/src/entrance/libTypes.ts +26 -0
  303. package/src/error/404.vue +23 -0
  304. package/src/flow/chart.vue +130 -0
  305. package/src/flow/deal.vue +776 -0
  306. package/src/flow/signature.vue +216 -0
  307. package/src/flow/start.vue +18 -0
  308. package/src/http/api.js +192 -0
  309. package/src/http/request.js +81 -0
  310. package/src/login/App.vue +421 -0
  311. package/src/login/main.js +30 -0
  312. package/src/login/router.js +33 -0
  313. package/src/main.ts +20 -0
  314. package/src/mobile/App.vue +51 -0
  315. package/src/mobile/home/index.vue +34 -0
  316. package/src/mobile/main.js +26 -0
  317. package/src/mobile/router.js +101 -0
  318. package/src/mobile/view/page.vue +99 -0
  319. package/src/pinia/index.js +5 -0
  320. package/src/pinia/modules/dataField.js +77 -0
  321. package/src/pinia/modules/dataForm.js +46 -0
  322. package/src/pinia/modules/dataTable.js +46 -0
  323. package/src/pinia/modules/dictionary.js +66 -0
  324. package/src/pinia/modules/employee.js +46 -0
  325. package/src/pinia/modules/icon.js +46 -0
  326. package/src/pinia/modules/keepAlive.js +35 -0
  327. package/src/pinia/modules/organization.js +189 -0
  328. package/src/pinia/modules/page.js +46 -0
  329. package/src/pinia/modules/pageButton.js +44 -0
  330. package/src/pinia/modules/pageComp.js +46 -0
  331. package/src/pinia/modules/role.js +46 -0
  332. package/src/pinia/modules/setting.js +56 -0
  333. package/src/pinia/modules/subsystem.js +64 -0
  334. package/src/pinia/modules/user.js +177 -0
  335. package/src/plugins/index.ts +24 -0
  336. package/src/portal/App.vue +27 -0
  337. package/src/portal/home/index.vue +52 -0
  338. package/src/portal/main.js +31 -0
  339. package/src/portal/page/index.vue +39 -0
  340. package/src/portal/pinia/router.js +176 -0
  341. package/src/portal/router.js +86 -0
  342. package/src/router/constantRoutes.ts +13 -0
  343. package/src/router/loadComponent.ts +29 -0
  344. package/src/router/readme.txt +21 -0
  345. package/src/sso/sso.js +19 -0
  346. package/src/sso/sso.vue +138 -0
  347. package/src/types/axios.d.ts +13 -0
  348. package/src/types/func.ts +14 -0
  349. package/src/types/global.d.ts +108 -0
  350. package/src/types/layout.d.ts +59 -0
  351. package/src/types/mitt.d.ts +40 -0
  352. package/src/types/pinia.d.ts +93 -0
  353. package/src/types/views.d.ts +27 -0
  354. package/src/types/window.d.ts +8 -0
  355. package/src/utils/aes.js +75 -0
  356. package/src/utils/browser.js +13 -0
  357. package/src/utils/bus.js +4 -0
  358. package/src/utils/cache.js +6 -0
  359. package/src/utils/codeless.js +92 -0
  360. package/src/utils/color.js +274 -0
  361. package/src/utils/date.js +180 -0
  362. package/src/utils/loading.js +22 -0
  363. package/src/utils/page.js +36 -0
  364. package/src/utils/progress.js +19 -0
  365. package/src/utils/system.js +92 -0
  366. package/src/utils/theme.js +79 -0
  367. package/src/utils/tool.js +431 -0
  368. package/src/utils/websocket.js +124 -0
  369. package/src/views/codeless/appVersion.vue +593 -0
  370. package/src/views/codeless/dataFormEdit.vue +1463 -0
  371. package/src/views/codeless/dataModel.vue +2584 -0
  372. package/src/views/codeless/dataModelPage.vue +535 -0
  373. package/src/views/codeless/dataTableEdit.vue +1678 -0
  374. package/src/views/codeless/datasource.vue +308 -0
  375. package/src/views/codeless/interface.vue +833 -0
  376. package/src/views/codeless/interfaceToken.vue +255 -0
  377. package/src/views/codeless/page.vue +752 -0
  378. package/src/views/codeless/pageButton.vue +255 -0
  379. package/src/views/codeless/pageCompEdit.vue +2330 -0
  380. package/src/views/codeless/pageEdit.vue +661 -0
  381. package/src/views/codeless/relationPage.vue +349 -0
  382. package/src/views/codeless/scriptGroovy.vue +736 -0
  383. package/src/views/codeless/scriptGroovyEdit.vue +248 -0
  384. package/src/views/codeless/scriptGroovyExecute.vue +212 -0
  385. package/src/views/codeless/scriptGroovySimple.vue +1057 -0
  386. package/src/views/codeless/scriptTool.vue +563 -0
  387. package/src/views/codeless/subsystem.vue +309 -0
  388. package/src/views/codeless/template.vue +739 -0
  389. package/src/views/codeless/variable.vue +727 -0
  390. package/src/views/codeless/view.vue +738 -0
  391. package/src/views/codeless/viewEdit.vue +244 -0
  392. package/src/views/codeless/viewSimple.vue +1034 -0
  393. package/src/views/collect/task.vue +898 -0
  394. package/src/views/collect/taskLog.vue +238 -0
  395. package/src/views/dictionary/dictionary.vue +866 -0
  396. package/src/views/employee/employee.vue +355 -0
  397. package/src/views/flow/flow.vue +369 -0
  398. package/src/views/flow/flowInst.vue +73 -0
  399. package/src/views/flow/flowLineBranch.vue +406 -0
  400. package/src/views/flow/flowNodeMan.vue +426 -0
  401. package/src/views/flow/flowOpinion.vue +188 -0
  402. package/src/views/icon/icon.vue +242 -0
  403. package/src/views/log/loginLog.vue +41 -0
  404. package/src/views/log/operatorLog.vue +176 -0
  405. package/src/views/menu/menu.vue +883 -0
  406. package/src/views/menu/menuList.vue +858 -0
  407. package/src/views/message/message.vue +299 -0
  408. package/src/views/mobile/editor.vue +1100 -0
  409. package/src/views/mobile/mobile.vue +568 -0
  410. package/src/views/mobile/tool.vue +1258 -0
  411. package/src/views/monitor/database.vue +11 -0
  412. package/src/views/monitor/details-diskspace.vue +56 -0
  413. package/src/views/monitor/details-gc.vue +93 -0
  414. package/src/views/monitor/details-memory.vue +143 -0
  415. package/src/views/monitor/details-process.vue +132 -0
  416. package/src/views/monitor/details-threads.vue +106 -0
  417. package/src/views/monitor/line-chart.vue +93 -0
  418. package/src/views/monitor/mem-chart.vue +22 -0
  419. package/src/views/monitor/panel.vue +90 -0
  420. package/src/views/monitor/performance.vue +36 -0
  421. package/src/views/monitor/threads-chart.vue +16 -0
  422. package/src/views/operation/backup.vue +593 -0
  423. package/src/views/operation/center.vue +420 -0
  424. package/src/views/operation/restore.vue +94 -0
  425. package/src/views/organization/organization.vue +366 -0
  426. package/src/views/role/role.vue +502 -0
  427. package/src/views/schedule/schedule.vue +338 -0
  428. package/src/views/schedule/scheduleLog.vue +40 -0
  429. package/src/views/sequence/sequence.vue +283 -0
  430. package/src/views/setting/setting.vue +371 -0
  431. package/src/visual/components/app/list/goods/double.vue +241 -0
  432. package/src/visual/components/app/list/nav/image.vue +135 -0
  433. package/src/visual/components/app/list/nav/text.vue +159 -0
  434. package/src/visual/components/button/index.vue +95 -0
  435. package/src/visual/components/container/index.vue +128 -0
  436. package/src/visual/components/data/index.vue +60 -0
  437. package/src/visual/components/data-table/index.vue +260 -0
  438. package/src/visual/components/echarts/annular.vue +173 -0
  439. package/src/visual/components/echarts/bar.vue +172 -0
  440. package/src/visual/components/echarts/funnel.vue +167 -0
  441. package/src/visual/components/echarts/gauge.vue +186 -0
  442. package/src/visual/components/echarts/line.vue +172 -0
  443. package/src/visual/components/echarts/map.vue +206 -0
  444. package/src/visual/components/echarts/pie.vue +158 -0
  445. package/src/visual/components/echarts/radar.vue +196 -0
  446. package/src/visual/components/echarts/scatter.vue +153 -0
  447. package/src/visual/components/edit-table/index.vue +71 -0
  448. package/src/visual/components/form/affix.vue +440 -0
  449. package/src/visual/components/form/area.vue +134 -0
  450. package/src/visual/components/form/buttons.vue +120 -0
  451. package/src/visual/components/form/checkbox.vue +126 -0
  452. package/src/visual/components/form/date-range.vue +97 -0
  453. package/src/visual/components/form/date.vue +88 -0
  454. package/src/visual/components/form/datetime.vue +87 -0
  455. package/src/visual/components/form/employee-tree.vue +300 -0
  456. package/src/visual/components/form/employees-tree.vue +91 -0
  457. package/src/visual/components/form/image.vue +440 -0
  458. package/src/visual/components/form/index.vue +85 -0
  459. package/src/visual/components/form/input.vue +116 -0
  460. package/src/visual/components/form/item.vue +68 -0
  461. package/src/visual/components/form/number.vue +157 -0
  462. package/src/visual/components/form/organization-tree.vue +300 -0
  463. package/src/visual/components/form/password.vue +103 -0
  464. package/src/visual/components/form/radio.vue +122 -0
  465. package/src/visual/components/form/rate.vue +93 -0
  466. package/src/visual/components/form/region-tree.vue +300 -0
  467. package/src/visual/components/form/rich-editor.vue +114 -0
  468. package/src/visual/components/form/select.vue +172 -0
  469. package/src/visual/components/form/switch.vue +105 -0
  470. package/src/visual/components/form/textarea.vue +91 -0
  471. package/src/visual/components/form/unit-tree.vue +300 -0
  472. package/src/visual/components/icon/index.vue +73 -0
  473. package/src/visual/components/image/index.vue +445 -0
  474. package/src/visual/components/index.js +26 -0
  475. package/src/visual/components/list/block.vue +234 -0
  476. package/src/visual/components/list/button.vue +123 -0
  477. package/src/visual/components/list/card.vue +129 -0
  478. package/src/visual/components/list/custom.vue +214 -0
  479. package/src/visual/components/list/image.vue +182 -0
  480. package/src/visual/components/list/news.vue +174 -0
  481. package/src/visual/components/page-comp/index.vue +67 -0
  482. package/src/visual/components/portal-menu/index.vue +191 -0
  483. package/src/visual/components/qrcode/index.vue +98 -0
  484. package/src/visual/components/router-view/index.vue +51 -0
  485. package/src/visual/components/row/index.vue +175 -0
  486. package/src/visual/components/search/index.vue +96 -0
  487. package/src/visual/components/tabs/index.vue +103 -0
  488. package/src/visual/components/text/index.vue +111 -0
  489. package/src/visual/components/video/index.vue +93 -0
  490. package/src/visual/js/echarts.js +220 -0
  491. package/src/visual/js/event.js +476 -0
  492. package/src/visual/js/visual-comp.js +48 -0
  493. package/src/visual/js/visual.js +508 -0
  494. package/src/visual/view/page.vue +357 -0
@@ -0,0 +1,2330 @@
1
+ <template>
2
+ <div class="page-container">
3
+ <el-form
4
+ ref="dataForm"
5
+ label-width="110px"
6
+ :model="formData"
7
+ class="fit-box full-height"
8
+ :rules="rules"
9
+ >
10
+ <el-row style="margin-top: 10px;">
11
+ <el-col :span="6">
12
+ <el-form-item label="组件名称" prop="name">
13
+ <el-input v-model="formData.name" />
14
+ </el-form-item>
15
+ </el-col>
16
+ <el-col :span="6">
17
+ <el-form-item label="组件类型" prop="type">
18
+ <ac-buttons v-model="formData.type" options="表格,表单,页面" />
19
+ </el-form-item>
20
+ </el-col>
21
+ <el-col :span="6" v-if="formData.type === '页面'">
22
+ <el-form-item label="页面名称" prop="dataPageId">
23
+ <ac-tree
24
+ v-model="formData.dataPageId"
25
+ data-url="/system/page/queryTree"
26
+ typeSelect="page"
27
+ @change="changeDataModel"
28
+ />
29
+ </el-form-item>
30
+ </el-col>
31
+ <el-col :span="6" v-if="formData.type === '表格' || formData.type === '表单'">
32
+ <el-form-item label="数据源类型" prop="dataType">
33
+ <ac-buttons v-model="formData.dataType" options="数据模型" options1="数据模型,数据集" />
34
+ </el-form-item>
35
+ </el-col>
36
+ <el-col :span="6">
37
+ <el-form-item label="是否显示" prop="showComp">
38
+ <ac-dict-switch v-model="formData.showComp" dictCode="dictYesNo" />
39
+ </el-form-item>
40
+ </el-col>
41
+ <el-col :span="6">
42
+ <el-form-item label="高度自适应" prop="autoHeight">
43
+ <ac-dict-switch v-model="formData.autoHeight" dictCode="dictYesNo" />
44
+ </el-form-item>
45
+ </el-col>
46
+ <el-col :span="6" v-if="(formData.type === '表格' || formData.type === '表单') && formData.dataType === '数据模型'">
47
+ <el-form-item label="数据模型" prop="dataModelId">
48
+ <ac-tree
49
+ v-model="formData.dataModelId"
50
+ data-url="/system/dataModel/queryTree"
51
+ typeSelect="model"
52
+ @change="changeDataModel"
53
+ />
54
+ </el-form-item>
55
+ </el-col>
56
+ <el-col :span="6" v-if="formData.dataType === '数据集'">
57
+ <el-form-item label="数据集" prop="datasetId">
58
+ <ac-tree
59
+ v-model="formData.datasetId"
60
+ data-url="/system/dataset/queryTree"
61
+ typeSelect="model"
62
+ @change="changeDataset"
63
+ />
64
+ </el-form-item>
65
+ </el-col>
66
+ <el-col :span="6" v-if="formData.type === '表格' && formData.dataType">
67
+ <el-form-item label="表格名称" prop="dataTableId">
68
+ <ac-select v-model="formData.dataTableId" :options="dataTableOptions" />
69
+ </el-form-item>
70
+ </el-col>
71
+ <el-col :span="6" v-if="(formData.type === '表格' || formData.type === '表单') && formData.dataType">
72
+ <el-form-item label="表单名称" prop="dataFormId">
73
+ <ac-select v-model="formData.dataFormId" :options="dataFormOptions" />
74
+ </el-form-item>
75
+ </el-col>
76
+ <el-col :span="6" v-if="formData.type === '表格'">
77
+ <el-form-item label="显示树控件" prop="showTree">
78
+ <ac-dict-switch v-model="formData.showTree" dictCode="dictYesNo" />
79
+ </el-form-item>
80
+ </el-col>
81
+ <el-col :span="6" v-if="formData.type === '表格' && formData.showTree === '1'">
82
+ <el-form-item label="树控件名称" prop="showTree">
83
+ <el-input v-model="formData.treeName" />
84
+ </el-form-item>
85
+ </el-col>
86
+ <el-col :span="6" v-if="formData.type === '表格' && formData.showTree === '1'">
87
+ <el-form-item label="树控件宽度" prop="treeWidth">
88
+ <ac-number v-model="formData.treeWidth" :point="0" />
89
+ </el-form-item>
90
+ </el-col>
91
+ <el-col :span="6" v-if="formData.type === '表格'">
92
+ <el-form-item label="显示自动刷新" prop="showRefresh">
93
+ <ac-dict-switch v-model="formData.showRefresh" dictCode="dictYesNo" />
94
+ </el-form-item>
95
+ </el-col>
96
+ <el-col :span="6" v-if="formData.type === '表格'">
97
+ <el-form-item label="翻页保持选中" prop="pageSelected">
98
+ <ac-dict-switch v-model="formData.pageSelected" dictCode="dictYesNo" />
99
+ </el-form-item>
100
+ </el-col>
101
+ </el-row>
102
+ <el-row v-if="formData.type === '表格' && formData.showTree === '1'">
103
+ <el-col :span="24">
104
+ <el-row style="margin-bottom: 8px;">
105
+ <el-col :span="24"><span class="section-tips">树控件设置</span></el-col>
106
+ </el-row>
107
+ <el-row>
108
+ <el-col :span="8">
109
+ <el-form-item label="数据模型" prop="treeDataModelId">
110
+ <ac-tree
111
+ v-model="formData.treeDataModelId"
112
+ data-url="/system/dataModel/queryTree"
113
+ typeSelect="model"
114
+ @change="changeTreeDataModel"
115
+ />
116
+ </el-form-item>
117
+ </el-col>
118
+ <el-col :span="8">
119
+ <el-form-item label="节点字段" prop="treeNodeFieldId">
120
+ <ac-select v-model="formData.treeNodeFieldId" :options="treeDataFieldOptions" />
121
+ </el-form-item>
122
+ </el-col>
123
+ <el-col :span="8">
124
+ <el-form-item label="父节点字段" prop="treeParentFieldId">
125
+ <ac-select v-model="formData.treeParentFieldId" :options="treeDataFieldOptions" />
126
+ </el-form-item>
127
+ </el-col>
128
+ </el-row>
129
+ <el-row>
130
+ <el-col :span="8">
131
+ <el-form-item label="显示字段" prop="treeShowFieldId">
132
+ <ac-select v-model="formData.treeShowFieldId" :options="treeDataFieldOptions" />
133
+ </el-form-item>
134
+ </el-col>
135
+ <el-col :span="8">
136
+ <el-form-item label="排序字段" prop="treeOrdinalFieldId">
137
+ <ac-select v-model="formData.treeOrdinalFieldId" :options="treeDataFieldOptions" />
138
+ </el-form-item>
139
+ </el-col>
140
+ <el-col :span="8">
141
+ <el-form-item label="操作表单" prop="treeFormId">
142
+ <template #label>
143
+ <span style="margin-right: 5px">操作表单</span>
144
+ <el-tooltip content="为空时,树节点上无操作功能。不为空时,可以在树节点上通过此表单操作树节点内容">
145
+ <ac-icon iconId="018dca8ec9890493be26" />
146
+ </el-tooltip>
147
+ </template>
148
+ <ac-select v-model="formData.treeFormId" :options="treeDataFormOptions" />
149
+ </el-form-item>
150
+ </el-col>
151
+ </el-row>
152
+ <el-row v-if="formData.treeFormId">
153
+ <el-col :span="8">
154
+ <el-form-item label="新增脚本" prop="treeAddScriptId">
155
+ <ac-tree
156
+ v-model="formData.treeAddScriptId"
157
+ data-url="/system/scriptGroovy/queryTree"
158
+ type-select="script"
159
+ />
160
+ </el-form-item>
161
+ </el-col>
162
+ <el-col :span="8">
163
+ <el-form-item label="编辑脚本" prop="treeEditScriptId">
164
+ <ac-tree
165
+ v-model="formData.treeEditScriptId"
166
+ data-url="/system/scriptGroovy/queryTree"
167
+ type-select="script"
168
+ />
169
+ </el-form-item>
170
+ </el-col>
171
+ <el-col :span="8">
172
+ <el-form-item label="删除脚本" prop="treeDeleteScriptId">
173
+ <ac-tree
174
+ v-model="formData.treeDeleteScriptId"
175
+ data-url="/system/scriptGroovy/queryTree"
176
+ type-select="script"
177
+ />
178
+ </el-form-item>
179
+ </el-col>
180
+ </el-row>
181
+ <el-row>
182
+ <el-col :span="8">
183
+ <el-form-item label="关系映射" prop="treeMappingType">
184
+ <ac-buttons v-model="formData.treeMappingType" options="一对多,多对多" />
185
+ </el-form-item>
186
+ </el-col>
187
+ <el-col :span="8">
188
+ <el-form-item label="出参字段" prop="treeOutputFieldId">
189
+ <ac-select v-model="formData.treeOutputFieldId" :options="treeDataFieldOptions" />
190
+ </el-form-item>
191
+ </el-col>
192
+ <el-col :span="8">
193
+ <el-form-item label="数据过滤字段" prop="filterFieldId">
194
+ <ac-select v-model="formData.filterFieldId" :options="dataFieldOptions" />
195
+ </el-form-item>
196
+ </el-col>
197
+ </el-row>
198
+ <el-row v-if="formData.treeMappingType === '多对多'">
199
+ <el-col :span="8">
200
+ <el-form-item label="中间模型" prop="middleModelId">
201
+ <ac-tree
202
+ v-model="formData.middleModelId"
203
+ data-url="/system/dataModel/queryTree"
204
+ typeSelect="model"
205
+ @change="changeMiddleDataModel"
206
+ />
207
+ </el-form-item>
208
+ </el-col>
209
+ <el-col :span="8">
210
+ <el-form-item label="入参字段" prop="middleInputFieldId">
211
+ <ac-select v-model="formData.middleInputFieldId" :options="middleFieldOptions" />
212
+ </el-form-item>
213
+ </el-col>
214
+ <el-col :span="8">
215
+ <el-form-item label="出参字段" prop="middleOutputFieldId">
216
+ <ac-select v-model="formData.middleOutputFieldId" :options="middleFieldOptions" />
217
+ </el-form-item>
218
+ </el-col>
219
+ </el-row>
220
+ <el-row v-if="formData.treeMappingType === '一对多'">
221
+ <el-col :span="8">
222
+ <el-form-item label="开启递归查询" prop="recursiveQuery">
223
+ <ac-dict-switch v-model="formData.recursiveQuery" dictCode="dictYesNo" />
224
+ </el-form-item>
225
+ </el-col>
226
+ </el-row>
227
+ <el-row style="margin-bottom: 15px;">
228
+ <el-col :span="24">
229
+ <el-button
230
+ type="success"
231
+ @click="addPrivilege"
232
+ >添加权限组</el-button>
233
+ </el-col>
234
+ </el-row>
235
+ <el-row
236
+ v-for="(privilege, privilegeIndex) in formData.privilegeList || []"
237
+ style="margin-bottom: 15px;"
238
+ :key="privilege.id || privilege.rowFlag"
239
+ >
240
+ <el-col :span="24">
241
+ <el-row>
242
+ <el-col :span="6">
243
+ <el-form-item label="角色" prop="imageStyle">
244
+ <ac-role-select showAll v-model="privilege.roleId" />
245
+ </el-form-item>
246
+ </el-col>
247
+ <el-col :span="6">
248
+ <el-form-item label="排序" prop="ordinal">
249
+ <ac-number v-model="privilege.ordinal" :point="0" />
250
+ </el-form-item>
251
+ </el-col>
252
+ <el-col :span="12" style="text-align: right;align-content: center">
253
+ <el-button
254
+ v-if="(!sortableInst || sortingId !== (privilege.id || privilege.rowFlag))
255
+ && (privilege.conditionList || []).length > 1"
256
+ type="primary"
257
+ @click="sortPrivilegeField(privilege)"
258
+ >开启排序</el-button>
259
+ <el-button
260
+ v-if="sortableInst && sortingId === (privilege.id || privilege.rowFlag)"
261
+ type="info"
262
+ @click="unSortPrivilegeField"
263
+ >关闭排序</el-button>
264
+ <el-button
265
+ type="success"
266
+ @click="addPrivilegeCondition(privilege)"
267
+ >添加过滤条件</el-button>
268
+ <el-button
269
+ type="danger"
270
+ @click="deletePrivilege(privilege)"
271
+ >删除权限组</el-button>
272
+ </el-col>
273
+ </el-row>
274
+ <el-table
275
+ :show-overflow-tooltip="false"
276
+ tooltip-effect="light"
277
+ class="field-table edit-table"
278
+ width="100%"
279
+ :ref="el => setRefs(el, privilege)"
280
+ :row-key="getPrivilegeRowKey"
281
+ :data="privilege.conditionList"
282
+ :border="true"
283
+ :stripe="false"
284
+ >
285
+ <el-table-column
286
+ header-align="center"
287
+ label="拼接方式"
288
+ :min-width="120"
289
+ prop="connectSymbol"
290
+ >
291
+ <template #default="scope">
292
+ <el-form-item
293
+ label-width="0"
294
+ :prop="scope.$index === 0 ? null : ('privilegeList.' + privilegeIndex + '.conditionList.' + scope.$index +'.connectSymbol')"
295
+ :rules="[{required: true, message: '拼接方式不能为空!', trigger: ['change', 'blur']}]"
296
+ >
297
+ <ac-select v-model="scope.row.connectSymbol" options="and,or"/>
298
+ </el-form-item>
299
+ </template>
300
+ </el-table-column>
301
+ <el-table-column
302
+ header-align="center"
303
+ label="前置括号"
304
+ :min-width="120"
305
+ prop="frontBracket"
306
+ >
307
+ <template #default="scope">
308
+ <ac-select v-model="scope.row.frontBracket" options="(,((,(((,((((" />
309
+ </template>
310
+ </el-table-column>
311
+ <el-table-column
312
+ header-align="center"
313
+ label="过滤字段"
314
+ :min-width="120"
315
+ prop="fieldId"
316
+ >
317
+ <template #default="scope">
318
+ <el-form-item
319
+ label-width="0"
320
+ :prop="'privilegeList.' + privilegeIndex + '.conditionList.' + scope.$index +'.fieldId'"
321
+ :rules="[{required: true, message: '过滤字段不能为空!', trigger: ['change', 'blur']}]"
322
+ >
323
+ <ac-select v-model="scope.row.fieldId" :options="treeDataFieldOptions" />
324
+ </el-form-item>
325
+ </template>
326
+ </el-table-column>
327
+ <el-table-column
328
+ header-align="center"
329
+ label="比较符"
330
+ :min-width="120"
331
+ prop="compareSymbol"
332
+ >
333
+ <template #default="scope">
334
+ <el-form-item
335
+ label-width="0"
336
+ :prop="'privilegeList.' + privilegeIndex + '.conditionList.' + scope.$index +'.compareSymbol'"
337
+ :rules="[{required: true, message: '比较符不能为空!', trigger: ['change', 'blur']}]"
338
+ >
339
+ <ac-select
340
+ v-model="scope.row.compareSymbol"
341
+ options="大于,大于等于,等于,小于,小于等于,不等于,模糊"
342
+ />
343
+ </el-form-item>
344
+ </template>
345
+ </el-table-column>
346
+ <el-table-column
347
+ header-align="center"
348
+ label="比较值"
349
+ :min-width="120"
350
+ prop="compareValue"
351
+ >
352
+ <template #header>
353
+ <span style="margin-right: 5px">默认值</span>
354
+ <ac-default-value-tips />
355
+ </template>
356
+ <template #default="scope">
357
+ <ac-tree
358
+ v-if="scope.row.compareSymbol === 'script'"
359
+ v-model="scope.row.compareValue"
360
+ data-url="/system/scriptGroovy/queryTree"
361
+ type-select="script"
362
+ />
363
+ <ac-input
364
+ v-else-if="scope.row.compareSymbol !== 'script' && scope.row.manually === '1'"
365
+ v-model="scope.row.compareValue"
366
+ />
367
+ <component
368
+ v-else-if="scope.row.compareSymbol !== 'script' && scope.row.fieldId"
369
+ v-model="scope.row.compareValue"
370
+ :is="getComponent(scope.row.fieldId) || 'ac-input'"
371
+ v-bind="getOptions(scope.row.fieldId)"
372
+ />
373
+ <el-input v-else v-model="scope.row.compareValue" />
374
+ <ac-dict-switch
375
+ v-if="scope.row.compareSymbol !== 'script'"
376
+ v-model="scope.row.manually"
377
+ dictCode="dictYesNo"
378
+ style="margin: 0 5px;"
379
+ title="手动录入"
380
+ />
381
+ </template>
382
+ </el-table-column>
383
+ <el-table-column
384
+ header-align="center"
385
+ label="后置括号"
386
+ :min-width="120"
387
+ prop="behindBracket"
388
+ >
389
+ <template #default="scope">
390
+ <ac-select v-model="scope.row.behindBracket" options="),)),))),))))" />
391
+ </template>
392
+ </el-table-column>
393
+ <el-table-column
394
+ header-align="center"
395
+ align="center"
396
+ label="操作"
397
+ :min-width="80"
398
+ prop="ordinal"
399
+ >
400
+ <template #default="scope">
401
+ <el-button
402
+ type="danger"
403
+ @click="deletePrivilegeCondition(privilege, scope.row)"
404
+ link
405
+ >删除</el-button>
406
+ </template>
407
+ </el-table-column>
408
+ </el-table>
409
+ </el-col>
410
+ </el-row>
411
+ </el-col>
412
+ </el-row>
413
+ <el-row v-if="formData.type === '表格'">
414
+ <el-col :span="24">
415
+ <el-row style="margin-bottom: 8px;">
416
+ <el-col :span="24"><span class="section-tips">查询设置</span></el-col>
417
+ </el-row>
418
+ <el-row>
419
+ <el-col :span="6">
420
+ <el-form-item label="开启高级查询" prop="advanceQuery">
421
+ <ac-dict-switch v-model="formData.advanceQuery" dictCode="dictYesNo" />
422
+ </el-form-item>
423
+ </el-col>
424
+ </el-row>
425
+ <el-row>
426
+ <el-col :span="24">
427
+ <el-form-item>
428
+ <template #label>
429
+ <span style="margin-right: 5px">查询条件</span>
430
+ <el-tooltip content="开启排序后可拖动排序">
431
+ <ac-icon iconId="018dca8ec9890493be26" />
432
+ </el-tooltip>
433
+ </template>
434
+ <div
435
+ ref="sortFilterRadioGroup"
436
+ :class="['sort-box', sortableFilterInst ? 'pointer' : '']"
437
+ >
438
+ <div
439
+ class="sort-item"
440
+ v-for="filter in formData.filterList || []"
441
+ :key="filter.rowFlag"
442
+ >
443
+ <span>{{filter.name}}</span>
444
+ <ac-icon
445
+ iconId="018dca6db20c6a3aaf68"
446
+ color="#409EFF"
447
+ @click.stop="editFilter(filter)"
448
+ />
449
+ <ac-icon
450
+ iconId="018dca412c4ebd53fd1d"
451
+ color="red"
452
+ @click.prevent="deleteFilter(filter)"
453
+ />
454
+ </div>
455
+ <el-button
456
+ @click="editFilter(null)"
457
+ type="success"
458
+ >添加查询</el-button>
459
+ <el-button
460
+ v-if="!sortableFilterInst && (formData.filterList || []).length > 1"
461
+ @click="sortFilterList"
462
+ type="primary"
463
+ >开启排序</el-button>
464
+ <el-button
465
+ v-if="sortableFilterInst"
466
+ @click="closeFilterList"
467
+ type="info"
468
+ >关闭排序</el-button>
469
+ </div>
470
+ </el-form-item>
471
+ </el-col>
472
+ </el-row>
473
+ </el-col>
474
+ </el-row>
475
+ <el-row>
476
+ <el-col :span="24">
477
+ <el-row style="margin-bottom: 8px;">
478
+ <el-col :span="24"><span class="section-tips">按钮设置</span></el-col>
479
+ </el-row>
480
+ <el-row>
481
+ <el-col :span="24">
482
+ <el-form-item label="按钮换行">
483
+ <ac-dict-switch v-model="formData.buttonWrap" dictCode="dictYesNo" />
484
+ </el-form-item>
485
+ </el-col>
486
+ </el-row>
487
+ <el-row v-if="
488
+ buttonList.filter(item =>
489
+ formData.type === '表格' ? item.type === '表格按钮' || item.type === '通用按钮'
490
+ : formData.type === '表单' ? item.type === '表单按钮' || item.type === '通用按钮'
491
+ : item.type === '通用按钮').length > 0"
492
+ >
493
+ <el-col :span="24">
494
+ <el-form-item label="内置按钮">
495
+ <el-checkbox-group v-model="selectButtonIds" @change="changeSelectButton">
496
+ <el-checkbox-button
497
+ v-for="button in buttonList.filter(item =>
498
+ formData.type === '表格' ? item.type === '表格按钮' || item.type === '通用按钮'
499
+ : formData.type === '表单' ? item.type === '表单按钮' || item.type === '通用按钮'
500
+ : item.type === '通用按钮')"
501
+ :key="button.id"
502
+ :value="button.id"
503
+ >{{ button.name }}</el-checkbox-button>
504
+ </el-checkbox-group>
505
+ </el-form-item>
506
+ </el-col>
507
+ </el-row>
508
+ <el-row>
509
+ <el-col :span="24">
510
+ <el-form-item>
511
+ <template #label>
512
+ <span style="margin-right: 5px">已选按钮</span>
513
+ <el-tooltip content="开启排序后可拖动排序">
514
+ <ac-icon iconId="018dca8ec9890493be26" />
515
+ </el-tooltip>
516
+ </template>
517
+ <div
518
+ ref="sortRadioGroup"
519
+ :class="['sort-box', sortableInst ? 'pointer' : '']"
520
+ >
521
+ <div
522
+ class="sort-item"
523
+ v-for="button in formData.buttonList || []"
524
+ :key="button.rowFlag"
525
+ >
526
+ <span>{{button.name}}</span>
527
+ <ac-icon
528
+ v-if="!button.buttonId || (button.buttonId && '新增,编辑,复制,明细,删除,批量编辑'.indexOf(button.name) >= 0)"
529
+ iconId="018dca6db20c6a3aaf68"
530
+ color="#409EFF"
531
+ @click.stop="editButton(button)"
532
+ />
533
+ <ac-icon
534
+ iconId="018dca412c4ebd53fd1d"
535
+ color="red"
536
+ @click.prevent="deleteSelectedButton(button)"
537
+ />
538
+ </div>
539
+ <el-button
540
+ @click="editButton(null)"
541
+ type="success"
542
+ >添加按钮</el-button>
543
+ <el-button
544
+ v-if="!sortableInst && (formData.buttonList || []).length > 1"
545
+ @click="sortButtonList"
546
+ type="primary"
547
+ >开启排序</el-button>
548
+ <el-button
549
+ v-if="sortableInst"
550
+ @click="closeButtonList"
551
+ type="info"
552
+ >关闭排序</el-button>
553
+ </div>
554
+ </el-form-item>
555
+ </el-col>
556
+ </el-row>
557
+ </el-col>
558
+ </el-row>
559
+ <el-row>
560
+ <el-col :span="24">
561
+ <el-row>
562
+ <el-col :span="12"><span class="section-tips">参数配置</span></el-col>
563
+ <el-col :span="12" style="text-align: right">
564
+ <el-button
565
+ v-if="!sortParamIndexInst && (formData.paramList || []).length > 1"
566
+ type="primary"
567
+ @click="sortParamIndex"
568
+ >开启排序</el-button>
569
+ <el-button
570
+ v-if="sortParamIndexInst"
571
+ type="info"
572
+ @click="unSortParamIndex"
573
+ >关闭排序</el-button>
574
+ <el-button
575
+ type="success"
576
+ @click="addCompParam"
577
+ >添加参数</el-button>
578
+ </el-col>
579
+ </el-row>
580
+ <el-row>
581
+ <el-col :span="24">
582
+ <el-row>
583
+ <el-col :span="24" style="padding: 5px 0 10px 0">
584
+ <el-table
585
+ ref="sortParamTable"
586
+ :show-overflow-tooltip="false"
587
+ tooltip-effect="light"
588
+ width="100%"
589
+ class="edit-table"
590
+ :data="formData.paramList"
591
+ :row-key="getParamRowKey"
592
+ :border="true"
593
+ :stripe="false"
594
+ >
595
+ <el-table-column
596
+ header-align="center"
597
+ label="参数类型"
598
+ min-width="100"
599
+ >
600
+ <template #default="scope">
601
+ <ac-select v-model="scope.row.type" options="入参,出参" />
602
+ </template>
603
+ </el-table-column>
604
+ <el-table-column
605
+ header-align="center"
606
+ label="页面参数"
607
+ :min-width="120"
608
+ >
609
+ <template #default="scope">
610
+ <ac-select
611
+ v-model="scope.row.pageParamId"
612
+ :options="currPageParamList.map(param => ({'key': param.id, 'value': param.name}))"
613
+ />
614
+ </template>
615
+ </el-table-column>
616
+ <el-table-column
617
+ header-align="center"
618
+ label="应用类型"
619
+ :min-width="120"
620
+ >
621
+ <template #default="scope">
622
+ <ac-select
623
+ v-model="scope.row.useType"
624
+ options="表格,表单,页面,全部"
625
+ />
626
+ </template>
627
+ </el-table-column>
628
+ <el-table-column
629
+ header-align="center"
630
+ label="匹配方式"
631
+ :min-width="120"
632
+ >
633
+ <template #default="scope">
634
+ <ac-select
635
+ v-model="scope.row.matchMode"
636
+ options="大于,大于等于,等于,小于,小于等于,不等于,模糊"
637
+ />
638
+ </template>
639
+ </el-table-column>
640
+ <el-table-column
641
+ header-align="center"
642
+ label="组件参数"
643
+ :min-width="120"
644
+ >
645
+ <template #default="scope">
646
+ <ac-select
647
+ v-model="scope.row.pageCompParamId"
648
+ :options="compParamOptions"
649
+ />
650
+ </template>
651
+ </el-table-column>
652
+ <el-table-column
653
+ header-align="center"
654
+ align="center"
655
+ label="操作"
656
+ width="80"
657
+ prop="width"
658
+ >
659
+ <template #default="scope">
660
+ <el-button
661
+ type="danger"
662
+ @click="deleteCompParam(scope.row)"
663
+ link
664
+ >删除</el-button>
665
+ </template>
666
+ </el-table-column>
667
+ </el-table>
668
+ </el-col>
669
+ </el-row>
670
+ </el-col>
671
+ </el-row>
672
+ </el-col>
673
+ </el-row>
674
+ </el-form>
675
+ </div>
676
+
677
+ <!--按钮编辑-->
678
+ <el-dialog
679
+ v-model="buttonVisible"
680
+ width="950px"
681
+ :title="buttonTitle"
682
+ :close-on-click-modal="false"
683
+ destroy-on-close
684
+ append-to-body
685
+ draggable
686
+ fullscreen
687
+ >
688
+ <el-form
689
+ ref="buttonForm"
690
+ label-width="130px"
691
+ label-position="right"
692
+ :model="buttonData"
693
+ :rules="buttonRules"
694
+ >
695
+ <el-row v-if="buttonData.buttonId">
696
+ <el-col :span="8">
697
+ <el-form-item label="全屏弹窗">
698
+ <ac-dict-switch v-model="buttonData.dialogFullscreen" dictCode="dictYesNo" />
699
+ </el-form-item>
700
+ </el-col>
701
+ <el-col :span="8" v-if="buttonData.dialogFullscreen === '0'">
702
+ <el-form-item label="弹窗大小">
703
+ <ac-input v-model="buttonData.dialogWidth" />
704
+ </el-form-item>
705
+ </el-col>
706
+ <el-col :span="8">
707
+ <el-form-item label="显示位置">
708
+ <ac-checkbox v-model="buttonData.showPosition" options="顶部,行内,底部,表单" />
709
+ </el-form-item>
710
+ </el-col>
711
+ </el-row>
712
+ <el-row v-if="!buttonData.buttonId">
713
+ <el-col :span="8">
714
+ <el-form-item label="名称" prop="name">
715
+ <el-input v-model="buttonData.name" />
716
+ </el-form-item>
717
+ </el-col>
718
+ <el-col :span="8">
719
+ <el-form-item label="类型" prop="type">
720
+ <ac-select
721
+ v-model="buttonData.type"
722
+ options="新增,编辑,删除,上传,下载,打印,提交数据,下载模板,弹出页面,批量编辑,调用脚本"
723
+ @change="changeType"
724
+ />
725
+ </el-form-item>
726
+ </el-col>
727
+ <el-col :span="8">
728
+ <el-form-item label="数据数量">
729
+ <ac-buttons v-model="buttonData.dataVolume" options="不限,单条,多条" />
730
+ </el-form-item>
731
+ </el-col>
732
+ <el-col :span="8">
733
+ <el-form-item label="显示位置">
734
+ <ac-checkbox v-model="buttonData.showPosition" options="顶部,行内,底部,表单" />
735
+ </el-form-item>
736
+ </el-col>
737
+ <el-col :span="8" v-if="'新增,编辑,弹出页面,批量编辑'.indexOf(buttonData.type) >= 0">
738
+ <el-form-item label="全屏弹窗">
739
+ <ac-dict-switch v-model="buttonData.dialogFullscreen" dictCode="dictYesNo" />
740
+ </el-form-item>
741
+ </el-col>
742
+ <el-col
743
+ v-if="buttonData.dialogFullscreen === '0' && '新增,编辑,弹出页面,批量编辑'.indexOf(buttonData.type) >= 0"
744
+ :span="8"
745
+ >
746
+ <el-form-item label="弹窗大小">
747
+ <ac-input v-model="buttonData.dialogWidth" />
748
+ </el-form-item>
749
+ </el-col>
750
+ <el-col
751
+ v-if="'新增,编辑,批量编辑'.indexOf(buttonData.type) >= 0 && (buttonData.dialogPageId || '') === ''"
752
+ :span="8"
753
+ >
754
+ <el-form-item label="弹窗表单">
755
+ <ac-tree
756
+ v-model="buttonData.dialogFormId"
757
+ data-url="/system/dataForm/queryTree"
758
+ typeSelect="form"
759
+ />
760
+ </el-form-item>
761
+ </el-col>
762
+ <el-col
763
+ v-if="'新增,编辑,弹出页面,批量编辑'.indexOf(buttonData.type) >= 0 && (buttonData.dialogFormId || '') === ''"
764
+ :span="8"
765
+ >
766
+ <el-form-item label="弹窗页面">
767
+ <ac-tree
768
+ v-model="buttonData.dialogPageId"
769
+ data-url="/system/page/queryTree"
770
+ typeSelect="page"
771
+ @change="changePage"
772
+ />
773
+ </el-form-item>
774
+ </el-col>
775
+ <el-col
776
+ v-if="'新增,编辑,批量编辑'.indexOf(buttonData.type) >= 0"
777
+ :span="8"
778
+ >
779
+ <el-form-item label="保存后执行脚本">
780
+ <ac-dict-switch v-model="buttonData.saveAndRun" dictCode="dictYesNo" />
781
+ </el-form-item>
782
+ </el-col>
783
+ <el-col
784
+ v-if="'新增,编辑,弹出页面'.indexOf(buttonData.type) >= 0 && buttonData.dialogPageId"
785
+ :span="24"
786
+ >
787
+ <el-form-item
788
+ v-if="buttonData.paramList && buttonData.paramList.length > 0"
789
+ label="出参配置"
790
+ prop="pageId"
791
+ >
792
+ <div style="display: flex;flex-direction: column">
793
+ <div
794
+ class="param-item"
795
+ v-for="(param, index) in buttonData.paramList"
796
+ :key="index"
797
+ >
798
+ <div class="param-field">
799
+ <ac-select
800
+ v-model="param.fieldName"
801
+ :options="dataFieldNameOptions"
802
+ />
803
+ </div>
804
+ <div class="param-split"><ac-icon iconId="018eecae20bd010c2adf" /></div>
805
+ <div class="param-page">
806
+ <el-input v-model="param.pageParamName" disabled />
807
+ </div>
808
+ </div>
809
+ </div>
810
+ </el-form-item>
811
+ </el-col>
812
+ <el-col :span="8" v-if="'新增,编辑,提交数据,批量编辑,调用脚本'.indexOf(buttonData.type) >= 0">
813
+ <el-form-item label="提交校验">
814
+ <ac-dict-switch v-model="buttonData.submitValidate" dictCode="dictYesNo" />
815
+ </el-form-item>
816
+ </el-col>
817
+ <el-col :span="8" v-if="'上传,下载,下载模板'.indexOf(buttonData.type) < 0">
818
+ <el-form-item label="提交确认语">
819
+ <el-input v-model="buttonData.submitPrompt" />
820
+ </el-form-item>
821
+ </el-col>
822
+ <el-col :span="8" v-if="!buttonData.buttonId
823
+ && '上传,下载,提交数据,下载模板'.indexOf(buttonData.type) < 0
824
+ && '新增,编辑,批量编辑,调用脚本'.indexOf(buttonData.type) >= 0"
825
+ >
826
+ <el-form-item label="提交执行脚本">
827
+ <template #label>
828
+ <span style="margin-right: 5px">提交执行脚本</span>
829
+ <el-tooltip>
830
+ <template #content>
831
+ <div>脚本接收参数:</div>
832
+ <div>1、dataList: 表格勾选的数据。</div>
833
+ <div>2、当为上传时,importList: 导入的excel数据</div>
834
+ </template>
835
+ <ac-icon iconId="018dca8ec9890493be26" />
836
+ </el-tooltip>
837
+ </template>
838
+ <ac-tree
839
+ v-model="buttonData.executeScriptId"
840
+ data-url="/system/scriptGroovy/queryTree"
841
+ type-select="script"
842
+ />
843
+ </el-form-item>
844
+ </el-col>
845
+ <el-col
846
+ v-if="!buttonData.buttonId
847
+ && '上传,下载,提交数据,下载模板'.indexOf(buttonData.type) < 0
848
+ && '新增,编辑,批量编辑,调用脚本'.indexOf(buttonData.type) >= 0"
849
+ :span="8"
850
+ >
851
+ <el-form-item label="显示执行结果">
852
+ <ac-dict-switch v-model="buttonData.showExecuteResult" dictCode="dictYesNo" />
853
+ </el-form-item>
854
+ </el-col>
855
+ <el-col
856
+ v-if="!buttonData.buttonId
857
+ && '弹出页面,调用脚本'.indexOf(buttonData.type) >= 0"
858
+ :span="8"
859
+ >
860
+ <el-form-item :label="buttonData.type === '弹出页面' ? '关闭时刷新' : '执行后刷新'">
861
+ <ac-dict-switch v-model="buttonData.endRefresh" dictCode="dictYesNo" />
862
+ </el-form-item>
863
+ </el-col>
864
+ <el-col
865
+ v-if="!buttonData.buttonId && buttonData.type === '弹出页面'"
866
+ :span="8"
867
+ >
868
+ <el-form-item label="显示关闭按钮">
869
+ <ac-dict-switch v-model="buttonData.showCloseButton" dictCode="dictYesNo" />
870
+ </el-form-item>
871
+ </el-col>
872
+ <el-col
873
+ v-if="!buttonData.buttonId && buttonData.showPosition.indexOf('表单') >= 0"
874
+ :span="8"
875
+ >
876
+ <el-form-item label="绑定按钮名称">
877
+ <ac-input v-model="buttonData.bindButton" />
878
+ </el-form-item>
879
+ </el-col>
880
+ </el-row>
881
+ <el-row v-if="!buttonData.buttonId">
882
+ <el-col :span="5">
883
+ <el-form-item label="按钮图标">
884
+ <ac-icon-select v-model="buttonData.iconId" size="22px" />
885
+ </el-form-item>
886
+ </el-col>
887
+ <el-col :span="5">
888
+ <el-form-item label="字体颜色">
889
+ <el-color-picker
890
+ v-model="buttonData.fontColor"
891
+ show-alpha
892
+ :predefine="predefineColors"
893
+ color-format="hex"
894
+ />
895
+ </el-form-item>
896
+ </el-col>
897
+ <el-col :span="5">
898
+ <el-form-item label="背景颜色">
899
+ <el-color-picker
900
+ v-model="buttonData.backgroundColor"
901
+ show-alpha
902
+ :predefine="predefineColors"
903
+ color-format="hex"
904
+ />
905
+ </el-form-item>
906
+ </el-col>
907
+ <el-col :span="5">
908
+ <el-form-item label="边框颜色">
909
+ <el-color-picker
910
+ v-model="buttonData.borderColor"
911
+ show-alpha
912
+ :predefine="predefineColors"
913
+ color-format="hex"
914
+ />
915
+ </el-form-item>
916
+ </el-col>
917
+ </el-row>
918
+ <div
919
+ v-if="buttonData.type === '新增'
920
+ || buttonData.type === '编辑'
921
+ || buttonData.type === '提交数据'
922
+ || buttonData.type === '批量编辑'"
923
+ style="padding-left: 70px;"
924
+ >
925
+ <el-row>
926
+ <el-col :span="24" style="margin-bottom: 5px;">
927
+ <el-button
928
+ type="success"
929
+ @click="addUpdate"
930
+ >添加默认值</el-button>
931
+ </el-col>
932
+ </el-row>
933
+ <el-table
934
+ :show-overflow-tooltip="false"
935
+ tooltip-effect="light"
936
+ class="field-table edit-table"
937
+ style="margin-bottom: 20px"
938
+ width="100%"
939
+ :data="buttonData.updateList"
940
+ :border="true"
941
+ :stripe="false"
942
+ >
943
+ <el-table-column
944
+ header-align="center"
945
+ label="字段"
946
+ :min-width="120"
947
+ prop="fieldId"
948
+ >
949
+ <template #default="scope">
950
+ <ac-select v-model="scope.row.fieldId" :options="dataFieldOptions" />
951
+ </template>
952
+ </el-table-column>
953
+ <el-table-column
954
+ header-align="center"
955
+ align="center"
956
+ label="默认值"
957
+ :min-width="120"
958
+ prop="value"
959
+ >
960
+ <template #header>
961
+ <span style="margin-right: 5px">默认值</span>
962
+ <ac-default-value-tips />
963
+ </template>
964
+ <template #default="scope">
965
+ <ac-input
966
+ v-if="scope.row.manually === '1' || !scope.row.fieldId"
967
+ v-model="scope.row.fieldValue"
968
+ />
969
+ <component
970
+ v-else-if="scope.row.fieldId"
971
+ v-model="scope.row.fieldValue"
972
+ :is="getComponent(scope.row.fieldId)"
973
+ v-bind="getOptions(scope.row.fieldId)"
974
+ />
975
+ <ac-dict-switch
976
+ v-model="scope.row.manually"
977
+ dictCode="dictYesNo"
978
+ style="margin: 0 5px;"
979
+ title="手动录入"
980
+ />
981
+ </template>
982
+ </el-table-column>
983
+ <el-table-column
984
+ header-align="center"
985
+ align="center"
986
+ label="操作"
987
+ :width="80"
988
+ prop="ordinal"
989
+ >
990
+ <template #default="scope">
991
+ <el-button
992
+ type="danger"
993
+ @click="deleteUpdate(scope.row)"
994
+ link
995
+ >删除</el-button>
996
+ </template>
997
+ </el-table-column>
998
+ </el-table>
999
+ </div>
1000
+ <div style="padding-left: 70px;">
1001
+ <el-row>
1002
+ <el-col :span="24" style="margin-bottom: 5px;">
1003
+ <el-button
1004
+ type="success"
1005
+ @click="addCondition"
1006
+ >添加显示条件</el-button>
1007
+ </el-col>
1008
+ </el-row>
1009
+ <el-table
1010
+ :show-overflow-tooltip="false"
1011
+ tooltip-effect="light"
1012
+ class="field-table edit-table"
1013
+ style="margin-bottom: 20px"
1014
+ width="100%"
1015
+ :data="buttonData.conditionList"
1016
+ :border="true"
1017
+ :stripe="false"
1018
+ >
1019
+ <el-table-column
1020
+ header-align="center"
1021
+ label="显示分组"
1022
+ :min-width="120"
1023
+ prop="grouping"
1024
+ >
1025
+ <template #header>
1026
+ <span style="margin-right: 5px">显示分组</span>
1027
+ <el-tooltip content="同一分组为 and 条件,不同分组间为 or 条件">
1028
+ <ac-icon iconId="018dca8ec9890493be26" />
1029
+ </el-tooltip>
1030
+ </template>
1031
+ <template #default="scope">
1032
+ <ac-number v-model="scope.row.grouping" :point="0" />
1033
+ </template>
1034
+ </el-table-column>
1035
+ <el-table-column
1036
+ header-align="center"
1037
+ label="条件字段"
1038
+ :min-width="120"
1039
+ prop="fieldId"
1040
+ >
1041
+ <template #default="scope">
1042
+ <ac-select v-model="scope.row.fieldId" :options="dataFieldOptions" />
1043
+ </template>
1044
+ </el-table-column>
1045
+ <el-table-column
1046
+ header-align="center"
1047
+ label="条件类型"
1048
+ :min-width="120"
1049
+ prop="type"
1050
+ >
1051
+ <template #default="scope">
1052
+ <ac-select v-model="scope.row.type" options="等于,不等于,包含,不包含" />
1053
+ </template>
1054
+ </el-table-column>
1055
+ <el-table-column
1056
+ header-align="center"
1057
+ align="center"
1058
+ label="条件值"
1059
+ :min-width="120"
1060
+ prop="value"
1061
+ >
1062
+ <template #header>
1063
+ <span style="margin-right: 5px">默认值</span>
1064
+ <ac-default-value-tips />
1065
+ </template>
1066
+ <template #default="scope">
1067
+ <component
1068
+ v-if="scope.row.fieldId"
1069
+ v-model="scope.row.value"
1070
+ :is="getCondComponent(scope.row.fieldId) || 'ac-input'"
1071
+ v-bind="getOptions(scope.row.fieldId)"
1072
+ />
1073
+ </template>
1074
+ </el-table-column>
1075
+ <el-table-column
1076
+ header-align="center"
1077
+ align="center"
1078
+ label="操作"
1079
+ :width="80"
1080
+ prop="ordinal"
1081
+ >
1082
+ <template #default="scope">
1083
+ <el-button
1084
+ type="danger"
1085
+ @click="deleteCondition(scope.row)"
1086
+ link
1087
+ >删除</el-button>
1088
+ </template>
1089
+ </el-table-column>
1090
+ </el-table>
1091
+ </div>
1092
+ <div
1093
+ v-if="!buttonData.buttonId
1094
+ && (buttonData.type === '上传' || buttonData.type === '下载' || buttonData.type === '下载模板')"
1095
+ style="padding-left: 70px;"
1096
+ >
1097
+ <el-row>
1098
+ <el-col :span="5" v-if="buttonData.type === '上传'">
1099
+ <el-form-item label="上传类型" label-width="70">
1100
+ <ac-buttons
1101
+ v-model="buttonData.tplType"
1102
+ options="脚本,自定义"
1103
+ @change="changeTplType"
1104
+ />
1105
+ </el-form-item>
1106
+ </el-col>
1107
+ <el-col :span="5" v-if="buttonData.type === '下载'">
1108
+ <el-form-item label="下载类型" label-width="70">
1109
+ <ac-buttons
1110
+ v-model="buttonData.tplType"
1111
+ options="脚本,自定义"
1112
+ @change="changeTplType"
1113
+ />
1114
+ </el-form-item>
1115
+ </el-col>
1116
+ <el-col :span="5" v-if="buttonData.type === '下载模板'">
1117
+ <el-form-item label="模板类型" label-width="70">
1118
+ <ac-buttons
1119
+ v-model="buttonData.tplType"
1120
+ options="模板,自定义"
1121
+ @change="changeTplType"
1122
+ />
1123
+ </el-form-item>
1124
+ </el-col>
1125
+ <el-col :span="6" v-if="buttonData.type === '下载模板' || (buttonData.type === '上传' && buttonData.tplType === '自定义')">
1126
+ <el-form-item label="模板名称" label-width="100">
1127
+ <el-input v-model="buttonData.tplName" />
1128
+ </el-form-item>
1129
+ </el-col>
1130
+ <el-col :span="6" v-if="buttonData.type === '下载模板' && buttonData.tplType === '模板'">
1131
+ <el-form-item label="模板" label-width="100">
1132
+ <ac-tree
1133
+ v-model="buttonData.tplFileId"
1134
+ data-url="/system/template/queryTree"
1135
+ type-select="template"
1136
+ />
1137
+ </el-form-item>
1138
+ </el-col>
1139
+ <el-col :span="6" v-if="(buttonData.type === '上传' || buttonData.type === '下载') && buttonData.tplType==='脚本'">
1140
+ <el-form-item label="提交执行脚本" label-width="120">
1141
+ <template #label>
1142
+ <span style="margin-right: 5px">提交执行脚本</span>
1143
+ <el-tooltip>
1144
+ <template #content>
1145
+ <div>脚本接收参数:</div>
1146
+ <div>1、dataList: 表格勾选的数据。</div>
1147
+ <div>2、当为上传时,importList: 导入的excel数据</div>
1148
+ </template>
1149
+ <ac-icon iconId="018dca8ec9890493be26" />
1150
+ </el-tooltip>
1151
+ </template>
1152
+ <ac-tree
1153
+ v-model="buttonData.executeScriptId"
1154
+ data-url="/system/scriptGroovy/queryTree"
1155
+ type-select="script"
1156
+ />
1157
+ </el-form-item>
1158
+ </el-col>
1159
+ <el-col :span="6" v-if="buttonData.tplType === '自定义'">
1160
+ <el-form-item label="数据模型" label-width="100">
1161
+ <ac-tree
1162
+ v-model="buttonData.modelId"
1163
+ data-url="/system/dataModel/queryTree"
1164
+ type-select="model"
1165
+ @change="initButtonField"
1166
+ />
1167
+ </el-form-item>
1168
+ </el-col>
1169
+ <el-col :span="6" v-if="buttonData.tplType === '自定义'">
1170
+ <div style="margin-left: 30px">
1171
+ <el-button
1172
+ v-if="sortFieldInst"
1173
+ type="info"
1174
+ @click="unSortDataField"
1175
+ >关闭排序</el-button>
1176
+ <el-button
1177
+ v-else-if="(buttonData.fieldList || []).length > 1"
1178
+ type="primary"
1179
+ @click="sortDataField"
1180
+ >开启排序</el-button>
1181
+ </div>
1182
+ </el-col>
1183
+ </el-row>
1184
+ <el-table
1185
+ v-if="buttonData.tplType === '自定义'"
1186
+ ref="sortFieldTable"
1187
+ :show-overflow-tooltip="false"
1188
+ tooltip-effect="light"
1189
+ class="field-table fit-table edit-table"
1190
+ width="100%"
1191
+ height="350px"
1192
+ :data="buttonData.fieldList"
1193
+ row-key="id"
1194
+ :border="true"
1195
+ :stripe="false"
1196
+ @cell-click="cellClick"
1197
+ >
1198
+ <el-table-column
1199
+ header-align="center"
1200
+ align="center"
1201
+ label="字段名称"
1202
+ :min-width="120"
1203
+ prop="fieldName"
1204
+ />
1205
+ <el-table-column
1206
+ header-align="center"
1207
+ align="center"
1208
+ label="显示名称"
1209
+ :min-width="120"
1210
+ prop="name"
1211
+ >
1212
+ <template #default="scope">
1213
+ <el-input v-model="scope.row.name" :disabled="scope.row.show !== '1'"/>
1214
+ </template>
1215
+ </el-table-column>
1216
+ <el-table-column
1217
+ v-if="buttonData.type === '下载' || buttonData.type === '下载模板'"
1218
+ header-align="center"
1219
+ label="列宽"
1220
+ :min-width="80"
1221
+ prop="width"
1222
+ >
1223
+ <template #default="scope">
1224
+ <ac-number v-model="scope.row.width" :point="0" />
1225
+ </template>
1226
+ </el-table-column>
1227
+ <el-table-column
1228
+ header-align="center"
1229
+ align="center"
1230
+ :label="'是否' + buttonData.type"
1231
+ width="100"
1232
+ prop="show"
1233
+ >
1234
+ <template #default="scope">
1235
+ <ac-dict-switch v-model="scope.row.show" dictCode="dictYesNo" />
1236
+ </template>
1237
+ </el-table-column>
1238
+ </el-table>
1239
+ </div>
1240
+ </el-form>
1241
+ <template #footer>
1242
+ <el-button
1243
+ size="default"
1244
+ type="info"
1245
+ @click="buttonVisible=false"
1246
+ >取消</el-button>
1247
+ <el-button
1248
+ type="primary"
1249
+ size="default"
1250
+ @click="submitButtonForm"
1251
+ >确定</el-button>
1252
+ </template>
1253
+ </el-dialog>
1254
+
1255
+ <!-- 查询编辑 -->
1256
+ <el-dialog
1257
+ v-model="filterVisible"
1258
+ width="600px"
1259
+ :title="filterTitle"
1260
+ :close-on-click-modal="false"
1261
+ destroy-on-close
1262
+ append-to-body
1263
+ draggable
1264
+ >
1265
+ <el-form
1266
+ ref="filterForm"
1267
+ label-width="120px"
1268
+ label-position="right"
1269
+ :model="filterData"
1270
+ :rules="filterRules"
1271
+ >
1272
+ <el-row>
1273
+ <el-col :span="24">
1274
+ <el-form-item label="名称" prop="name">
1275
+ <el-input v-model="filterData.name" />
1276
+ </el-form-item>
1277
+ </el-col>
1278
+ <el-col :span="24">
1279
+ <el-form-item label="类型" prop="type">
1280
+ <ac-select
1281
+ v-model="filterData.type"
1282
+ options="输入框,下拉框,单选框,按钮组,日期控件,树形控件"
1283
+ @change="changeFilterType"
1284
+ />
1285
+ </el-form-item>
1286
+ </el-col>
1287
+ <el-col :span="24">
1288
+ <el-form-item label="查询字段" prop="fieldIds">
1289
+ <ac-selects
1290
+ v-if="filterData.type === '输入框'"
1291
+ v-model="filterData.fieldIds"
1292
+ filterable
1293
+ :options="dataFieldOptions"
1294
+ @change="changeFilterFieldIds"
1295
+ />
1296
+ <ac-select
1297
+ v-else
1298
+ v-model="filterData.fieldIds"
1299
+ :options="dataFieldOptions"
1300
+ @change="changeFilterFieldIds"
1301
+ />
1302
+ </el-form-item>
1303
+ </el-col>
1304
+ <el-col :span="24">
1305
+ <el-form-item label="占位信息" prop="placeholder">
1306
+ <el-input v-model="filterData.placeholder" />
1307
+ </el-form-item>
1308
+ </el-col>
1309
+ <el-col :span="24">
1310
+ <el-form-item label="查询类型">
1311
+ <ac-select
1312
+ v-model="filterData.queryType"
1313
+ options="大于,大于等于,等于,小于,小于等于,不等于,包含,模糊"
1314
+ />
1315
+ </el-form-item>
1316
+ </el-col>
1317
+ <el-col :span="24">
1318
+ <el-form-item label="默认值" prop="defaultValue">
1319
+ <component
1320
+ v-if="filterData.fieldIds === '' || (filterData.fieldIds || '').indexOf(',') === -1"
1321
+ v-model="filterData.defaultValue"
1322
+ :is="getComponent(filterData.fieldIds, true) || 'ac-input'"
1323
+ v-bind="getOptions(filterData.fieldIds, true)"
1324
+ />
1325
+ <el-input v-else v-model="filterData.defaultValue" />
1326
+ </el-form-item>
1327
+ </el-col>
1328
+ </el-row>
1329
+ </el-form>
1330
+ <template #footer>
1331
+ <el-button
1332
+ size="default"
1333
+ type="info"
1334
+ @click="filterVisible=false"
1335
+ >取消</el-button>
1336
+ <el-button
1337
+ type="primary"
1338
+ size="default"
1339
+ @click="submitFilterForm"
1340
+ >确定</el-button>
1341
+ </template>
1342
+ </el-dialog>
1343
+ </template>
1344
+
1345
+ <script setup>
1346
+ import { ref, onMounted, watch, nextTick } from 'vue';
1347
+ import api from '@/http/api';
1348
+ import { ElMessage, ElMessageBox } from 'element-plus';
1349
+ import Sortable from 'sortablejs';
1350
+ import tool from '@/utils/tool';
1351
+ import loading from '@/utils/loading';
1352
+
1353
+ const emit = defineEmits(['afterSubmit'])
1354
+ const props = defineProps({
1355
+ options: {
1356
+ type: Object,
1357
+ default: () => {}
1358
+ },
1359
+ pageParamList: Array
1360
+ });
1361
+
1362
+ const formData = ref({});
1363
+ const dataForm = ref();
1364
+ const rules = ref({
1365
+ name: [
1366
+ { required: true, message: '请输入名称', trigger: ['change', 'blur'] },
1367
+ { max: 100, message: '长度必须小于等于 200 个字符!', trigger: ['change', 'blur'] }
1368
+ ],
1369
+ });
1370
+
1371
+ const dataTableOptions = ref([]);
1372
+ const dataFormOptions = ref([]);
1373
+ const dataFieldOptions = ref([]);
1374
+ const dataFieldNameOptions = ref([]);
1375
+ const compParamOptions = ref([]);
1376
+ const treeDataFieldOptions = ref([]);
1377
+ const treeDataFormOptions = ref([]);
1378
+ const middleFieldOptions = ref([]);
1379
+
1380
+ const fieldList = ref([]);
1381
+ const buttonList = ref([]);
1382
+ const currPageParamList = ref([]);
1383
+ const selectButtonIds = ref([]);
1384
+
1385
+ const sortRadioGroup = ref();
1386
+ const sortableInst = ref(null);
1387
+ const sortFilterRadioGroup = ref();
1388
+ const sortableFilterInst = ref(null);
1389
+
1390
+ const buttonVisible = ref(false);
1391
+ const buttonTitle = ref('');
1392
+ const buttonForm = ref();
1393
+ const buttonRules = ref({
1394
+ name: [
1395
+ { required: true, message: '请输入名称', trigger: ['change', 'blur'] },
1396
+ { max: 100, message: '长度必须小于等于 20 个字符!', trigger: ['change', 'blur'] }
1397
+ ],
1398
+ type: [
1399
+ { required: true, message: '请选择类型', trigger: ['change', 'blur'] },
1400
+ ],
1401
+ });
1402
+ const buttonData = ref({});
1403
+ const predefineColors = ref([
1404
+ '#409EFF',
1405
+ '#67C23A',
1406
+ '#E6A23C',
1407
+ '#F56C6C',
1408
+ '#909399',
1409
+ '#ff4500',
1410
+ '#ff8c00',
1411
+ '#ffd700',
1412
+ '#90ee90',
1413
+ '#00ced1',
1414
+ '#1e90ff',
1415
+ '#c71585',
1416
+ '#FF7800',
1417
+ ]);
1418
+ const sortFieldTable = ref();
1419
+ const sortFieldInst = ref();
1420
+ const sortingId = ref('');
1421
+
1422
+ const filterVisible = ref(false);
1423
+ const filterTitle = ref('');
1424
+ const filterForm = ref();
1425
+ const filterRules = ref({
1426
+ name: [
1427
+ { required: true, message: '请输入名称', trigger: ['change', 'blur'] },
1428
+ { max: 100, message: '长度必须小于等于 20 个字符!', trigger: ['change', 'blur'] }
1429
+ ],
1430
+ type: [
1431
+ { required: true, message: '请选择类型', trigger: ['change', 'blur'] },
1432
+ ],
1433
+ });
1434
+ const filterData = ref({ queryType: '' });
1435
+ const rowFlag = ref(0);
1436
+
1437
+ const init = async(options) => {
1438
+ loading.showLoading();
1439
+ selectButtonIds.value = [];
1440
+
1441
+ await loadPageButton();
1442
+ await initFormData(options || {});
1443
+ await loadPageParamList(formData.value.pageId);
1444
+ await changeDataModel();
1445
+ await changeTreeDataModel();
1446
+ await changeMiddleDataModel();
1447
+ loading.hideLoading();
1448
+ };
1449
+
1450
+ const initFormData = async(param) => {
1451
+ let data = param || {};
1452
+ if (!data.editing && param.id) {
1453
+ const res = await api.post('/system/pageComp/queryBy', { id: param.id });
1454
+ data = res.data || {};
1455
+ }
1456
+ const bList = data.buttonList || [];
1457
+ bList.forEach(button => {
1458
+ button.rowFlag = ++rowFlag.value;
1459
+ if (button.buttonId) {
1460
+ selectButtonIds.value.push(button.buttonId);
1461
+ const find = buttonList.value.find(item => item.id === button.buttonId);
1462
+ if (find) {
1463
+ button.name = find.showName;
1464
+ }
1465
+ }
1466
+ });
1467
+ data.buttonList = bList;
1468
+
1469
+ const fList = data.filterList || [];
1470
+ fList.forEach(filter => {
1471
+ filter.rowFlag = ++rowFlag.value;
1472
+ });
1473
+ data.filterList = fList;
1474
+ data.editing = true;
1475
+ formData.value = data;
1476
+ };
1477
+
1478
+ const changeDataModel = async() => {
1479
+ dataTableOptions.value = [];
1480
+ dataFormOptions.value = [];
1481
+ dataFieldOptions.value = [];
1482
+ dataFieldNameOptions.value = [];
1483
+ compParamOptions.value = [];
1484
+
1485
+ if (formData.value.type !== '页面') {
1486
+ formData.value.dataPageId = '';
1487
+ } else {
1488
+ formData.value.dataModelId = '';
1489
+ }
1490
+
1491
+ if (formData.value.type === '流程页面') {
1492
+ compParamOptions.value.push({ key: 'instNodeId', value: '流程实例id' });
1493
+ }
1494
+
1495
+ if (formData.value.dataPageId) {
1496
+ const pageParamList = await loadPageParam(formData.value.dataPageId);
1497
+ pageParamList.forEach(param => {
1498
+ compParamOptions.value.push({ key: param.id, value: param.name });
1499
+ });
1500
+ }
1501
+
1502
+ if (currPageParamList.value) {
1503
+ currPageParamList.value.forEach(param => {
1504
+ dataFieldNameOptions.value.push({ key: param.id, value: '[全局]' + param.name });
1505
+ });
1506
+ }
1507
+
1508
+ if (formData.value.dataModelId) {
1509
+ const tableList = await loadDataTable(formData.value.dataModelId);
1510
+ tableList.forEach(table => {
1511
+ dataTableOptions.value.push({ key: table.id, value: table.name });
1512
+ });
1513
+
1514
+ const formList = await loadDataForm(formData.value.dataModelId);
1515
+ formList.forEach(form => {
1516
+ dataFormOptions.value.push({ key: form.id, value: form.name });
1517
+ });
1518
+
1519
+ fieldList.value = await loadDataField(formData.value.dataModelId);
1520
+ fieldList.value.forEach(field => {
1521
+ compParamOptions.value.push({ key: field.id, value: field.showName, label: field.showName });
1522
+ dataFieldOptions.value.push({ key: field.id, value: field.showName, label: field.showName });
1523
+ dataFieldNameOptions.value.push({ key: field.fieldName, value: field.showName });
1524
+ });
1525
+ }
1526
+ };
1527
+
1528
+ const changeTreeDataModel = async() => {
1529
+ treeDataFormOptions.value = [];
1530
+ treeDataFieldOptions.value = [];
1531
+
1532
+ if (!formData.value.treeDataModelId) {
1533
+ return;
1534
+ }
1535
+
1536
+ const formList = await loadDataForm(formData.value.treeDataModelId);
1537
+ formList.forEach(form => {
1538
+ treeDataFormOptions.value.push({ key: form.id, value: form.name });
1539
+ });
1540
+
1541
+ const fieldList = await loadDataField(formData.value.treeDataModelId);
1542
+ fieldList.forEach(field => {
1543
+ treeDataFieldOptions.value.push({ key: field.id, value: field.showName });
1544
+ });
1545
+ };
1546
+
1547
+ const changeMiddleDataModel = async() => {
1548
+ middleFieldOptions.value = [];
1549
+
1550
+ if (!formData.value.middleModelId) {
1551
+ return;
1552
+ }
1553
+
1554
+ const fieldList = await loadDataField(formData.value.middleModelId);
1555
+ fieldList.forEach(field => {
1556
+ middleFieldOptions.value.push({ key: field.id, value: field.showName });
1557
+ });
1558
+ };
1559
+
1560
+ const loadPageParam = async(pageId) => {
1561
+ const res = await api.post('/system/pageParam/queryList', { pageId: pageId });
1562
+ return res.data || [];
1563
+ };
1564
+
1565
+ const loadDataTable = async(modelId) => {
1566
+ const res = await api.post('/system/dataTable/queryList', { modelId: modelId });
1567
+ return res.data || [];
1568
+ };
1569
+
1570
+ const loadDataForm = async(modelId) => {
1571
+ const res = await api.post('/system/dataForm/queryList', { modelId: modelId });
1572
+ return res.data || [];
1573
+ };
1574
+
1575
+ const loadDataField = async(modelId) => {
1576
+ const res = await api.post('/system/dataField/queryList', { modelId: modelId });
1577
+ return res.data || [];
1578
+ };
1579
+
1580
+ const loadPageButton = async() => {
1581
+ const res = await api.post('/system/pageButton/queryList');
1582
+ buttonList.value = res.data || [];
1583
+ };
1584
+
1585
+ const loadPageParamList = async(pageId) => {
1586
+ if (props.pageParamList) {
1587
+ currPageParamList.value = props.pageParamList;
1588
+ } else {
1589
+ currPageParamList.value = await loadPageParam(pageId);
1590
+ }
1591
+ };
1592
+
1593
+ const addPrivilege = () => {
1594
+ if (!formData.value.privilegeList) {
1595
+ formData.value.privilegeList = [];
1596
+ }
1597
+
1598
+ formData.value.privilegeList.push({
1599
+ roleId: '',
1600
+ rowFlag: ++rowFlag.value,
1601
+ conditionList: [{}]
1602
+ });
1603
+ };
1604
+
1605
+ const deletePrivilege = (privilege) => {
1606
+ ElMessageBox.confirm('请确认是否删除?', '提示', { type: 'warning' }).then(() => {
1607
+ const index = formData.value.privilegeList
1608
+ .findIndex(item => privilege.id ? item.id === privilege.id : item.rowFlag === privilege.rowFlag);
1609
+ formData.value.privilegeList.splice(index, 1);
1610
+ });
1611
+ };
1612
+
1613
+ const addPrivilegeCondition = (privilege) => {
1614
+ privilege.conditionList.push({ rowFlag: ++rowFlag.value });
1615
+ };
1616
+
1617
+ const deletePrivilegeCondition = (privilege, data) => {
1618
+ ElMessageBox.confirm('请确认是否删除?', '提示', { type: 'warning' }).then(() => {
1619
+ const index = privilege.conditionList
1620
+ .findIndex(item => item.id ? item.id === data.id : item.rowFlag === data.rowFlag);
1621
+ privilege.conditionList.splice(index, 1);
1622
+ });
1623
+ };
1624
+
1625
+ const getPrivilegeRowKey = row => {
1626
+ return row.id || row.rowFlag;
1627
+ };
1628
+
1629
+ const privilegeRefs = ref([]);
1630
+ const setRefs = (el, privilege) => {
1631
+ if (el) {
1632
+ privilegeRefs.value['privilegeTable_' + (privilege.id || privilege.rowFlag)] = el;
1633
+ }
1634
+ };
1635
+
1636
+ const sortPrivilegeField = (privilege) => {
1637
+ if (sortableInst.value) {
1638
+ sortableInst.value.destroy();
1639
+ }
1640
+
1641
+ const ref = privilegeRefs.value['privilegeTable_' + (privilege.id || privilege.rowFlag)];
1642
+ if (ref) {
1643
+ const el = ref.$el.querySelector('.el-table__body-wrapper tbody');
1644
+ sortableInst.value = Sortable.create(el, {
1645
+ handle: '.el-table__row',
1646
+ onEnd: ({ newIndex, oldIndex }) => {
1647
+ const list = tool.deepClone(privilege.conditionList);
1648
+ const currRow = list.splice(oldIndex, 1)[0];
1649
+ list.splice(newIndex, 0, currRow);
1650
+ nextTick(() => {
1651
+ privilege.conditionList = list;
1652
+ });
1653
+ }
1654
+ });
1655
+ sortingId.value = privilege.id || privilege.rowFlag;
1656
+ }
1657
+ };
1658
+
1659
+ const unSortPrivilegeField = () => {
1660
+ if (sortableInst.value) {
1661
+ sortableInst.value.destroy();
1662
+ }
1663
+ sortableInst.value = null;
1664
+ };
1665
+
1666
+ const getParamRowKey = (row) => {
1667
+ return row.id || row.rowFlag;
1668
+ };
1669
+
1670
+ const addCompParam = () => {
1671
+ if (!formData.value.paramList) {
1672
+ formData.value.paramList = [];
1673
+ }
1674
+
1675
+ formData.value.paramList.push({ rowFlag: ++rowFlag.value });
1676
+ };
1677
+
1678
+ const deleteCompParam = (data) => {
1679
+ ElMessageBox.confirm('请确认是否删除?', '提示', { type: 'warning' }).then(() => {
1680
+ const index = formData.value.paramList
1681
+ .findIndex(item => item.id ? item.id === data.id : item.rowFlag === data.rowFlag);
1682
+ formData.value.paramList.splice(index, 1);
1683
+ }).catch(() => {});
1684
+ };
1685
+
1686
+ const sortParamIndexInst = ref(null);
1687
+ const sortParamTable = ref();
1688
+ const sortParamIndex = () => {
1689
+ if (sortParamIndexInst.value) {
1690
+ sortParamIndexInst.value.destroy();
1691
+ }
1692
+
1693
+ if (sortParamTable.value) {
1694
+ const el = sortParamTable.value.$el.querySelector('.el-table__body-wrapper tbody');
1695
+ sortParamIndexInst.value = Sortable.create(el, {
1696
+ handle: '.el-table__row',
1697
+ onEnd: ({ newIndex, oldIndex }) => {
1698
+ const list = tool.deepClone(formData.value.paramList);
1699
+ const currRow = list.splice(oldIndex, 1)[0];
1700
+ list.splice(newIndex, 0, currRow);
1701
+ nextTick(() => {
1702
+ formData.value.paramList = list;
1703
+ });
1704
+ }
1705
+ });
1706
+ }
1707
+ };
1708
+
1709
+ const unSortParamIndex = () => {
1710
+ if (sortParamIndexInst.value) {
1711
+ sortParamIndexInst.value.destroy();
1712
+ }
1713
+ sortParamIndexInst.value = null;
1714
+ };
1715
+
1716
+ const changeSelectButton = () => {
1717
+ selectButtonIds.value.forEach(id => {
1718
+ const find = formData.value.buttonList.find(item => item.buttonId && item.buttonId === id);
1719
+ if (!find) {
1720
+ const button = buttonList.value.find(item => item.id === id);
1721
+ if (button) {
1722
+ formData.value.buttonList.push({
1723
+ buttonId: button.id,
1724
+ name: button.name,
1725
+ showPosition: button.showPosition,
1726
+ dialogWidth: 800,
1727
+ rowFlag: ++rowFlag.value
1728
+ });
1729
+ }
1730
+ }
1731
+ });
1732
+
1733
+ formData.value.buttonList.filter(item => item.buttonId).forEach(item => {
1734
+ const find = selectButtonIds.value.find(id => id === item.buttonId);
1735
+ if (!find) {
1736
+ const index = formData.value.buttonList.findIndex(index => index.rowFlag === item.rowFlag);
1737
+ formData.value.buttonList.splice(index, 1);
1738
+ }
1739
+ });
1740
+ };
1741
+
1742
+ const deleteSelectedButton = (button) => {
1743
+ ElMessageBox.confirm('请确认是否删除【' + button.name + '】?', '提示', { type: 'warning' }).then(() => {
1744
+ const index = formData.value.buttonList.findIndex(item => item.rowFlag === button.rowFlag);
1745
+ formData.value.buttonList.splice(index, 1);
1746
+
1747
+ const selectIndex = selectButtonIds.value.findIndex(id => id === button.buttonId);
1748
+ if (selectIndex >= 0) {
1749
+ selectButtonIds.value.splice(selectIndex, 1);
1750
+ }
1751
+ }).catch(() => {});
1752
+ };
1753
+
1754
+ const editButton = (button) => {
1755
+ if (button) {
1756
+ buttonData.value = tool.deepClone(button);
1757
+ buttonTitle.value = '编辑按钮【' + button.name + '】';
1758
+ initButtonField();
1759
+ } else {
1760
+ buttonData.value = {
1761
+ dataVolume: '不限',
1762
+ showPosition: '顶部',
1763
+ fontColor: '#ffffff',
1764
+ backgroundColor: '#409eff',
1765
+ borderColor: '#409eff',
1766
+ rowFlag: ++rowFlag.value,
1767
+ fieldList: []
1768
+ };
1769
+ buttonTitle.value = '新增按钮';
1770
+ }
1771
+
1772
+ if (buttonData.value.pageFieldJson) {
1773
+ buttonData.value.paramList = JSON.parse(buttonData.value.pageFieldJson);
1774
+ }
1775
+ changePage();
1776
+ buttonVisible.value = true;
1777
+ };
1778
+
1779
+ const changeType = () => {
1780
+ buttonData.value.iconId = '';
1781
+ buttonData.value.backgroundColor = '#409eff';
1782
+ buttonData.value.borderColor = '#409eff';
1783
+ buttonData.value.submitValidate = '0';
1784
+ buttonData.value.showPosition = '顶部';
1785
+ buttonData.value.submitPrompt = '';
1786
+ buttonData.value.dataVolume = '不限';
1787
+ buttonData.value.endRefresh = '';
1788
+ buttonData.value.showCloseButton = '';
1789
+ buttonData.value.modelId = '';
1790
+ buttonData.value.fieldsJson = '';
1791
+ buttonData.value.dialogWidth = '';
1792
+ buttonData.value.fieldList = [];
1793
+
1794
+ if (buttonData.value.type === '新增') {
1795
+ buttonData.value.name = buttonData.value.name ? buttonData.value.name : '新增';
1796
+ buttonData.value.dataVolume = '不限';
1797
+ buttonData.value.submitValidate = '1';
1798
+ buttonData.value.iconId = '018dc9c3efed46e8b927';
1799
+ buttonData.value.backgroundColor = '#67C23AFF';
1800
+ buttonData.value.borderColor = '#67C23AFF';
1801
+ buttonData.value.showPosition = '顶部';
1802
+ buttonData.value.dialogWidth = 800;
1803
+ } else if (buttonData.value.type === '编辑') {
1804
+ buttonData.value.name = buttonData.value.name ? buttonData.value.name : '编辑';
1805
+ buttonData.value.dataVolume = '单条';
1806
+ buttonData.value.iconId = '018dca6db20c6a3aaf68';
1807
+ buttonData.value.submitValidate = '1';
1808
+ buttonData.value.showPosition = '行内';
1809
+ buttonData.value.dialogWidth = 800;
1810
+ } else if (buttonData.value.type === '批量编辑') {
1811
+ buttonData.value.name = buttonData.value.name ? buttonData.value.name : '批量编辑';
1812
+ buttonData.value.dataVolume = '多条';
1813
+ buttonData.value.iconId = '018dca6db20c6a3aaf68';
1814
+ buttonData.value.submitValidate = '1';
1815
+ buttonData.value.dialogWidth = 800;
1816
+ } else if (buttonData.value.type === '上传') {
1817
+ buttonData.value.iconId = '018ece4f70fcf0627f81';
1818
+ buttonData.value.tplType = '脚本';
1819
+ } else if (buttonData.value.type === '下载') {
1820
+ buttonData.value.iconId = '018ece4f749ec5911772';
1821
+ buttonData.value.tplType = '脚本';
1822
+ } else if (buttonData.value.type === '下载模板') {
1823
+ buttonData.value.iconId = '018ece4f73a3ccb1ca1d';
1824
+ buttonData.value.tplType = '模板';
1825
+ } else if (buttonData.value.type === '弹出页面') {
1826
+ buttonData.value.iconId = '018ece4f758f70a05ff5';
1827
+ buttonData.value.endRefresh = '0';
1828
+ buttonData.value.showCloseButton = '1';
1829
+ buttonData.value.dialogWidth = 800;
1830
+ } else if (buttonData.value.type === '调用脚本') {
1831
+ buttonData.value.iconId = '018ece4f6a7ab5929bbe';
1832
+ buttonData.value.endRefresh = '1';
1833
+ } else if (buttonData.value.type === '删除') {
1834
+ buttonData.value.name = buttonData.value.name ? buttonData.value.name : '删除';
1835
+ buttonData.value.submitPrompt = '请确认是否删除?';
1836
+ buttonData.value.dataVolume = '多条';
1837
+ buttonData.value.iconId = '018dc9c3efd3a0502886';
1838
+ buttonData.value.backgroundColor = '#F56C6CFF';
1839
+ buttonData.value.borderColor = '#F56C6CFF';
1840
+ buttonData.value.showPosition = '顶部,行内';
1841
+ } else if (buttonData.value.type === '提交数据') {
1842
+ buttonData.value.name = buttonData.value.name ? buttonData.value.name : '提交数据';
1843
+ buttonData.value.submitPrompt = '请确认是否提交数据?';
1844
+ buttonData.value.dataVolume = '单条';
1845
+ buttonData.value.iconId = '018ece4f68eaa77e4813';
1846
+ }
1847
+ };
1848
+
1849
+ const changeTplType = () => {
1850
+ if (buttonData.value.tplType === '自定义') {
1851
+ buttonData.value.modelId = formData.value.dataModelId;
1852
+ initButtonField();
1853
+ } else {
1854
+ buttonData.value.modelId = '';
1855
+ }
1856
+ };
1857
+
1858
+ const initButtonField = () => {
1859
+ buttonData.value.fieldList = [];
1860
+ if (buttonData.value.modelId) {
1861
+ api.post('/business/data-field/list/' + buttonData.value.modelId).then(res => {
1862
+ let fieldList = [];
1863
+ if (buttonData.value && buttonData.value.fieldsJson) {
1864
+ fieldList = JSON.parse(buttonData.value && buttonData.value.fieldsJson || '[]');
1865
+ fieldList.forEach(field => field.show = '1');
1866
+ }
1867
+ res.data.forEach(field => {
1868
+ if (fieldList.every(item => item.id !== field.id)) {
1869
+ fieldList.push({ id: field.id, name: field.showName, fieldName: field.fieldName, width: 15, show: '0' });
1870
+ }
1871
+ });
1872
+ buttonData.value.fieldList = fieldList;
1873
+ });
1874
+ }
1875
+ };
1876
+
1877
+ const sortDataField = () => {
1878
+ if (sortFieldInst.value) {
1879
+ sortFieldInst.value.destroy();
1880
+ }
1881
+
1882
+ if (sortFieldTable.value) {
1883
+ const el = sortFieldTable.value.$el.querySelector('.el-table__body-wrapper tbody');
1884
+ sortFieldInst.value = Sortable.create(el, {
1885
+ handle: '.el-table__row',
1886
+ onEnd: ({ newIndex, oldIndex }) => {
1887
+ const list = tool.deepClone(buttonData.value.fieldList);
1888
+ const currRow = list.splice(oldIndex, 1)[0];
1889
+ list.splice(newIndex, 0, currRow);
1890
+ nextTick(() => {
1891
+ buttonData.value.fieldList = list;
1892
+ });
1893
+ }
1894
+ });
1895
+ }
1896
+ };
1897
+
1898
+ const unSortDataField = () => {
1899
+ if (sortFieldInst.value) {
1900
+ sortFieldInst.value.destroy();
1901
+ }
1902
+ sortFieldInst.value = null;
1903
+ };
1904
+
1905
+ const submitButtonForm = () => {
1906
+ if (buttonData.value.dialogPageId && buttonData.value.paramList) {
1907
+ buttonData.value.pageFieldJson = JSON.stringify(
1908
+ buttonData.value.paramList.map(param => ({
1909
+ fieldName: param.fieldName,
1910
+ pageParamId: param.pageParamId,
1911
+ pageParamName: param.pageParamName
1912
+ })));
1913
+ } else {
1914
+ buttonData.value.pageFieldJson = '';
1915
+ }
1916
+
1917
+ buttonForm.value && buttonForm.value.validate(valid => {
1918
+ if (valid) {
1919
+ if (!buttonData.value.buttonId &&
1920
+ buttonData.value.tplType === '自定义' &&
1921
+ (buttonData.value.type === '上传' ||
1922
+ buttonData.value.type === '下载' ||
1923
+ buttonData.value.type === '下载模板')) {
1924
+ buttonData.value.fieldsJson = JSON.stringify(buttonData.value.fieldList.filter(field => field.show === '1'));
1925
+ } else {
1926
+ buttonData.value.fieldsJson = null;
1927
+ }
1928
+ const index = formData.value.buttonList.findIndex(item => item.rowFlag === buttonData.value.rowFlag);
1929
+ if (index >= 0) {
1930
+ formData.value.buttonList[index] = buttonData.value;
1931
+ } else {
1932
+ formData.value.buttonList.push(buttonData.value);
1933
+ }
1934
+
1935
+ buttonVisible.value = false;
1936
+ }
1937
+ });
1938
+ };
1939
+
1940
+ const addUpdate = () => {
1941
+ if (!buttonData.value.updateList) {
1942
+ buttonData.value.updateList = [];
1943
+ }
1944
+ buttonData.value.updateList.push({ rowFlag: ++rowFlag.value });
1945
+ };
1946
+
1947
+ const deleteUpdate = (data) => {
1948
+ ElMessageBox.confirm('请确认是否删除?', '提示', { type: 'warning' }).then(() => {
1949
+ const index = buttonData.value.updateList
1950
+ .findIndex(item => item.id ? item.id === data.id : item.rowFlag === data.rowFlag);
1951
+ buttonData.value.updateList.splice(index, 1);
1952
+ }).catch(() => {});
1953
+ };
1954
+
1955
+ const addCondition = () => {
1956
+ if (!buttonData.value.conditionList) {
1957
+ buttonData.value.conditionList = [];
1958
+ }
1959
+ buttonData.value.conditionList.push({ rowFlag: ++rowFlag.value });
1960
+ };
1961
+
1962
+ const deleteCondition = (data) => {
1963
+ ElMessageBox.confirm('请确认是否删除?', '提示', { type: 'warning' }).then(() => {
1964
+ const index = buttonData.value.conditionList
1965
+ .findIndex(item => item.id ? item.id === data.id : item.rowFlag === data.rowFlag);
1966
+ buttonData.value.conditionList.splice(index, 1);
1967
+ }).catch(() => {});
1968
+ };
1969
+
1970
+ const editFilter = (filter) => {
1971
+ if (filter) {
1972
+ filterData.value = tool.deepClone(filter);
1973
+ filterTitle.value = '编辑查询';
1974
+ } else {
1975
+ filterData.value = {
1976
+ type: '输入框',
1977
+ queryType: '模糊',
1978
+ rowFlag: ++rowFlag.value
1979
+ };
1980
+ filterTitle.value = '新增查询';
1981
+ }
1982
+ filterVisible.value = true;
1983
+ };
1984
+
1985
+ const deleteFilter = (filter) => {
1986
+ ElMessageBox.confirm('请确认是否删除?', '提示', { type: 'warning' }).then(() => {
1987
+ const index = formData.value.filterList.findIndex(item => item.rowFlag === filter.rowFlag);
1988
+ formData.value.filterList.splice(index, 1);
1989
+ }).catch(() => {});
1990
+ };
1991
+
1992
+ const changeFilterType = () => {
1993
+ if ('下拉框,单选框,按钮组,日期控件,树形控件'.indexOf(filterData.value.type) >= 0) {
1994
+ filterData.value.queryType = '等于';
1995
+ } else if ('输入框'.indexOf(filterData.value.type) >= 0) {
1996
+ filterData.value.queryType = '模糊';
1997
+ }
1998
+ };
1999
+
2000
+ const changeFilterFieldIds = () => {
2001
+ const fieldIds = (filterData.value.fieldIds || '').split(',');
2002
+ let fieldNames = '';
2003
+ fieldIds.forEach(id => {
2004
+ const option = dataFieldOptions.value.find(item => item.key === id);
2005
+ if (option) {
2006
+ if (fieldNames) {
2007
+ fieldNames += ',';
2008
+ }
2009
+ fieldNames += option.label;
2010
+ }
2011
+ });
2012
+ filterData.value.placeholder = fieldNames;
2013
+ if (!filterData.value.name) {
2014
+ filterData.value.name = fieldNames.split(',')[0];
2015
+ }
2016
+ };
2017
+
2018
+ const submitFilterForm = () => {
2019
+ if (!formData.value.filterList) {
2020
+ formData.value.filterList = formData.value.filterList || [];
2021
+ }
2022
+
2023
+ filterForm.value && filterForm.value.validate(valid => {
2024
+ if (valid) {
2025
+ if (!filterData.value.name.trim()) {
2026
+ ElMessage.error('名称不能为空!');
2027
+ return;
2028
+ }
2029
+ const index = formData.value.filterList.findIndex(item => item.rowFlag === filterData.value.rowFlag);
2030
+ if (index >= 0) {
2031
+ formData.value.filterList[index] = filterData.value;
2032
+ } else {
2033
+ formData.value.filterList.push(filterData.value);
2034
+ }
2035
+
2036
+ filterVisible.value = false;
2037
+ filterData.value = {};
2038
+ }
2039
+ });
2040
+ };
2041
+
2042
+ const sortButtonList = () => {
2043
+ if (sortableInst.value) {
2044
+ sortableInst.value.destroy();
2045
+ }
2046
+
2047
+ if (sortRadioGroup.value) {
2048
+ const el = sortRadioGroup.value;
2049
+ sortableInst.value = Sortable.create(el, {
2050
+ handle: '.sort-item',
2051
+ onEnd: ({ newIndex, oldIndex }) => {
2052
+ const list = tool.deepClone(formData.value.buttonList);
2053
+ const currRow = list.splice(oldIndex, 1)[0];
2054
+ list.splice(newIndex, 0, currRow);
2055
+ nextTick(() => {
2056
+ formData.value.buttonList = list;
2057
+ });
2058
+ }
2059
+ });
2060
+ }
2061
+ };
2062
+
2063
+ const closeButtonList = () => {
2064
+ if (sortableInst.value) {
2065
+ sortableInst.value.destroy();
2066
+ sortableInst.value = null;
2067
+ }
2068
+ };
2069
+
2070
+ const changePage = () => {
2071
+ if (!buttonData.value.dialogPageId) {
2072
+ buttonData.value.paramList = [];
2073
+ return;
2074
+ }
2075
+
2076
+ api.post('/system/pageParam/queryList', { pageId: buttonData.value.dialogPageId }).then(res => {
2077
+ const pageParamList = res.data || [];
2078
+ let paramList = buttonData.value.paramList || [];
2079
+ pageParamList.forEach(pageParam => {
2080
+ const fieldParam = paramList.find(item => item.pageParamId === pageParam.id);
2081
+ if (fieldParam) {
2082
+ fieldParam.pageParamName = pageParam.name;
2083
+ } else {
2084
+ paramList.push({ pageParamId: pageParam.id, pageParamName: pageParam.name });
2085
+ }
2086
+ });
2087
+
2088
+ paramList = paramList.filter(param => pageParamList.find(item => item.id === param.pageParamId));
2089
+ buttonData.value.paramList = paramList;
2090
+ });
2091
+ };
2092
+
2093
+ const cellClick = async(row, column) => {
2094
+ if (column.property === 'fieldName') {
2095
+ row.show = row.show === '1' ? '0' : '1';
2096
+ }
2097
+ }
2098
+
2099
+ const sortFilterList = () => {
2100
+ if (sortableFilterInst.value) {
2101
+ sortableFilterInst.value.destroy();
2102
+ }
2103
+
2104
+ if (sortFilterRadioGroup.value) {
2105
+ const el = sortFilterRadioGroup.value;
2106
+ sortableFilterInst.value = Sortable.create(el, {
2107
+ handle: '.sort-item',
2108
+ onEnd: ({ newIndex, oldIndex }) => {
2109
+ const list = tool.deepClone(formData.value.filterList);
2110
+ const currRow = list.splice(oldIndex, 1)[0];
2111
+ list.splice(newIndex, 0, currRow);
2112
+ nextTick(() => {
2113
+ formData.value.filterList = list;
2114
+ });
2115
+ }
2116
+ });
2117
+ }
2118
+ };
2119
+
2120
+ const closeFilterList = () => {
2121
+ if (sortableFilterInst.value) {
2122
+ sortableFilterInst.value.destroy();
2123
+ sortableFilterInst.value = null;
2124
+ }
2125
+ };
2126
+
2127
+ const validate = (callback) => {
2128
+ dataForm.value && dataForm.value.validate(callback);
2129
+ };
2130
+
2131
+ const getData = () => {
2132
+ return formData.value;
2133
+ };
2134
+
2135
+ const submitData = () => {
2136
+ dataForm.value && dataForm.value.validate((valid) => {
2137
+ if (valid) {
2138
+ ElMessageBox.confirm('请确认是否提交?', '提示', { type: 'info' }).then(() => {
2139
+ loading.showLoading();
2140
+ api.post('/system/pageComp/save', formData.value).then(res => {
2141
+ ElMessage.success(res.message);
2142
+ emit('afterSubmit')
2143
+ loading.hideLoading();
2144
+ }).catch(() => loading.hideLoading());
2145
+ }).catch(() => {});
2146
+ }
2147
+ });
2148
+ };
2149
+
2150
+ const component = ref({
2151
+ 单行文本框: 'ac-input',
2152
+ 密码文本框: 'ac-password',
2153
+ 多行文本框: 'ac-input',
2154
+ 富文本框: 'ac-rich-editor',
2155
+ 单选框: 'ac-select',
2156
+ 下拉框: 'ac-select',
2157
+ 开关: 'ac-switch',
2158
+ 字符: 'ac-input',
2159
+ 整数: 'ac-number',
2160
+ 小数: 'ac-number',
2161
+ 日期: 'ac-date',
2162
+ 时间: 'ac-datetime',
2163
+ 图片: 'ac-image',
2164
+ 视频: 'ac-video',
2165
+ 附件: 'ac-affix',
2166
+ 下拉选择: 'ac-remote-select',
2167
+ 树形控件: 'ac-dm-tree',
2168
+ 区划树: 'ac-region-tree',
2169
+ 单位树: 'ac-unit-tree',
2170
+ 企业树: 'ac-entp-tree',
2171
+ 部门树: 'ac-organization-tree',
2172
+ 人员树: 'ac-employee-tree',
2173
+ 字典树: 'ac-dm-tree',
2174
+ 字典开关: 'ac-dict-switch',
2175
+ 字典单选框: 'ac-dict-select',
2176
+ 字典下拉框: 'ac-dict-select',
2177
+ });
2178
+ const getComponent = (fieldId, all) => {
2179
+ if (!fieldId) return;
2180
+ const field = fieldList.value.find(item => item.id === fieldId);
2181
+ if (!field) return 'ac-input';
2182
+
2183
+ if (field.fieldType === '字符') {
2184
+ if (field.enumerate === '1') {
2185
+ return all ? 'ac-select' : component.value[field.enumerateType];
2186
+ } else {
2187
+ return component.value[field.inputType];
2188
+ }
2189
+ } else if ('整数、小数、日期、时间、图片、视频、附件'.indexOf(field.fieldType) >= 0) {
2190
+ return component.value[field.fieldType];
2191
+ } else if (field.fieldType === '联动') {
2192
+ if (field.relevanceType === '数据模型') {
2193
+ return component.value['树形控件'];
2194
+ } else {
2195
+ return component.value[field.relevanceType];
2196
+ }
2197
+ } else if (field.fieldType === '大文本') {
2198
+ return component.value[field.inputType];
2199
+ }
2200
+
2201
+ return 'ac-input';
2202
+ };
2203
+
2204
+ const getCondComponent = (fieldId) => {
2205
+ if (!fieldId) return;
2206
+ const field = fieldList.value.find(item => item.id === fieldId);
2207
+ if (!field) return 'ac-input';
2208
+
2209
+ if (field.fieldType === '字符') {
2210
+ if (field.enumerate === '1') {
2211
+ return component.value[field.enumerateType];
2212
+ } else {
2213
+ return component.value[field.inputType];
2214
+ }
2215
+ } else if ('整数、小数、日期、时间'.indexOf(field.fieldType) >= 0) {
2216
+ return component.value[field.fieldType];
2217
+ } else if (field.fieldType === '联动') {
2218
+ if (field.relevanceType === '数据模型') {
2219
+ return component.value['树形控件'];
2220
+ } else {
2221
+ return component.value[field.relevanceType];
2222
+ }
2223
+ }
2224
+
2225
+ return 'ac-input';
2226
+ };
2227
+
2228
+ const getOptions = (fieldId) => {
2229
+ if (!fieldId) return;
2230
+
2231
+ const field = fieldList.value.find(item => item.id === fieldId);
2232
+ if (!field) return {};
2233
+
2234
+ if (field.fieldType === '字符') {
2235
+ if (field.autoCreate === '1') {
2236
+ return {};
2237
+ } else if (field.enumerate === '1') {
2238
+ return { options: field.enumerateValue || '' };
2239
+ } else {
2240
+ return { max: field.fieldSize || 100 };
2241
+ }
2242
+ } else if ('整数、小数'.indexOf(field.fieldType) >= 0) {
2243
+ return {
2244
+ point: field.fieldType === '整数' ? 0 : field.fieldPrecision || 0,
2245
+ max: field.maxValue,
2246
+ min: field.minValue
2247
+ };
2248
+ } else if ('日期'.indexOf(field.fieldType) >= 0) {
2249
+ return { format: field.format || undefined, valueFormat: field.format || undefined };
2250
+ } else if (field.fieldType === '图片') {
2251
+ return { limit: 1, maxSize: field.imageMaxSize };
2252
+ } else if (field.fieldType === '视频') {
2253
+ return { limit: 1, maxSize: field.imageMaxSize };
2254
+ } else if (field.fieldType === '联动') {
2255
+ if (field.relevanceType === '数据模型') {
2256
+ const relevanceList = field.relevanceList || [];
2257
+ return {
2258
+ dataFieldId: field.id,
2259
+ leafSelect: relevanceList.length > 1,
2260
+ typeSelect: relevanceList[relevanceList.length - 1].id
2261
+ };
2262
+ } else {
2263
+ return { dictCode: field.relevanceDict || '' };
2264
+ }
2265
+ }
2266
+
2267
+ return {};
2268
+ };
2269
+
2270
+ watch(() => props.options, (options) => {
2271
+ init(tool.deepClone(options || {}));
2272
+ }, { deep: true });
2273
+
2274
+ onMounted(() => {
2275
+ init(tool.deepClone(props.options || {}));
2276
+ });
2277
+
2278
+ defineExpose({ validate, getData, submitData });
2279
+ </script>
2280
+
2281
+ <style scoped lang="scss">
2282
+ .section-tips {
2283
+ font-size: 15px;
2284
+ font-weight: 900;
2285
+ border-bottom: 1px solid #8c939d;
2286
+ display: inline-flex;
2287
+ align-items: end;
2288
+ height: 100%;
2289
+ }
2290
+ .sort-box {
2291
+ display: contents;
2292
+ .sort-item {
2293
+ padding: 0 15px;
2294
+ border: 1px solid #dcdfe6;
2295
+ border-radius: 5px;
2296
+ margin: 2px 8px 2px 0;
2297
+ display: flex;
2298
+ flex-direction: row;
2299
+ justify-content: center;
2300
+ align-items: center;
2301
+ :deep(.ac-icon) {
2302
+ margin-left: 8px;
2303
+ cursor: pointer;
2304
+ }
2305
+ }
2306
+ :deep(.el-button) {
2307
+ margin: 2px 8px 2px 0 ;
2308
+ }
2309
+ }
2310
+ .param-item {
2311
+ display: flex;
2312
+ flex-direction: row;
2313
+ .param-field {
2314
+ width: 175px;
2315
+ }
2316
+ .param-split {
2317
+ width: 44px;
2318
+ display: flex;
2319
+ justify-content: center;
2320
+ align-items: center;
2321
+ font-size: 20px;
2322
+ }
2323
+ .param-page {
2324
+ flex-grow: 1;
2325
+ }
2326
+ }
2327
+ .param-item+.param-item {
2328
+ margin-top: 5px;
2329
+ }
2330
+ </style>