@utogether/udp-core 1.0.1-beta.2 → 1.0.1-beta.20

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 (159) hide show
  1. package/build/plugins.ts +8 -1
  2. package/dist/{403-BBQoJwTM.js → 403-Bz5EJPLA.js} +1 -1
  3. package/dist/{404-BbJPSIWM.js → 404-ClOnaj9V.js} +1 -1
  4. package/dist/{500-BtFL9R4M.js → 500-DCUfhV7Y.js} +1 -1
  5. package/dist/{AuthorityInfo-DhiwCeLN.js → AuthorityInfo-q6E-js1r.js} +1 -1
  6. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-BM52QDgn.js +100 -0
  7. package/dist/{Company-CGqmslx-.js → Company-BSShW3Q4.js} +3 -3
  8. package/dist/{CompanyPanel-hlDsxD-6.js → CompanyPanel-Dl8eOYLk.js} +26 -26
  9. package/dist/{Department-BZyJtacc.js → Department-CVIxAnUN.js} +3 -3
  10. package/dist/{DepartmentPanel-D-a_EBFt.js → DepartmentPanel-Sa3IDl4z.js} +25 -25
  11. package/dist/{DesignPanel-Bl4luWDV.js → DesignPanel-DnRipagE.js} +1 -1
  12. package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-I8C3iGvz.js → DesignPanel.vue_vue_type_style_index_0_lang-DGNyp3Vl.js} +28 -30
  13. package/dist/DictView-uf2K9A1d.js +109 -0
  14. package/dist/InvOrganization-CG9VCpXl.js +74 -0
  15. package/dist/Org-W2CBN1B8.js +39 -0
  16. package/dist/{Preview-pHD84xqI.js → Preview-DPBxdDvW.js} +2 -2
  17. package/dist/{ReportDefine-DnnCNQWS.js → ReportDefine-Dsx9VM-I.js} +1 -1
  18. package/dist/{ReportDesign-BnI_Q4pg.js → ReportDesign-DiIGfte0.js} +43 -43
  19. package/dist/{ReportQuery-Dby2MmtM.js → ReportQuery-9A4Bfs1M.js} +1 -1
  20. package/dist/{ReportQueryFrom-Blm1N8P1.js → ReportQueryFrom-M5qLoGAa.js} +1 -1
  21. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-CnG_Ybnt.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-OQ9pUCKP.js} +1 -1
  22. package/dist/{ReportTemplate-D65RXRY_.js → ReportTemplate-C34FWAuK.js} +28 -28
  23. package/dist/{Role-eFZoTpXc.js → Role-jG3VTeOF.js} +6 -6
  24. package/dist/{RoleAssign-D9-Y3UNz.js → RoleAssign-BfHpCequ.js} +9 -9
  25. package/dist/{RolePanel-DlFw6HSf.js → RolePanel-DW9pNl0L.js} +1 -1
  26. package/dist/{RolePanel-CoUOc3sX.js → RolePanel-xRN2-rkk.js} +1 -1
  27. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-Clwk-MHw.js → RolePanel.vue_vue_type_script_setup_true_lang-BVEHqEq9.js} +44 -38
  28. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-C0rTy6vZ.js +132 -0
  29. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-M2FQJwPU.js → ScrollPanel.vue_vue_type_style_index_0_lang-D65sJYWT.js} +23 -23
  30. package/dist/{Staff-DFBLCsAd.js → Staff-BqBVEjau.js} +3 -3
  31. package/dist/{StaffInfo-d2CK0oBA.js → StaffInfo-DXeyyEFL.js} +1 -1
  32. package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-4m8wK9tq.js → StaffInfo.vue_vue_type_script_setup_true_lang-Dg0iYgRf.js} +16 -16
  33. package/dist/{StaffPanel-D6aWLKN3.js → StaffPanel-iE-8VtUm.js} +1 -1
  34. package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-C7YT2CVb.js → StaffPanel.vue_vue_type_script_setup_true_lang-BrrvE1xm.js} +2 -2
  35. package/dist/{SysUser-BdZvYxQH.js → SysUser-DSZyW30i.js} +2 -2
  36. package/dist/{SysUserPanel-BIVa6LLr.js → SysUserPanel-CbiG6GQF.js} +1 -1
  37. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-B1Y1fmBe.js +298 -0
  38. package/dist/{SystemMenu-C-5VKlHK.js → SystemMenu-DreuWY-a.js} +33 -33
  39. package/dist/{UserInfo-DqXCRZts.js → UserInfo-DXrzKAim.js} +1 -1
  40. package/dist/{UserInfo.vue_vue_type_style_index_0_lang-N3TwfpPx.js → UserInfo.vue_vue_type_style_index_0_lang-C44E20b4.js} +41 -39
  41. package/dist/{childView-B2lSsqS3.js → childView-VCidWgY6.js} +1 -1
  42. package/dist/{childView-DRUNqgjI.js → childView-k5IkJOBr.js} +1 -1
  43. package/dist/{childView.vue_vue_type_style_index_0_lang-B9XBDDU_.js → childView.vue_vue_type_style_index_0_lang-C6ftwwvZ.js} +1 -1
  44. package/dist/{childView.vue_vue_type_style_index_0_lang-oGriyFTv.js → childView.vue_vue_type_style_index_0_lang-DmG82dVB.js} +43 -43
  45. package/dist/{code-rule-DZC9T6cl.js → code-rule-7WQMabpW.js} +13 -15
  46. package/dist/core.es.js +18 -10
  47. package/dist/{cron-task-BJwPeA5F.js → cron-task-D1t56MSu.js} +11 -11
  48. package/dist/{frameView-C6wkvok-.js → frameView-CWsIFBgU.js} +1 -1
  49. package/dist/img/l_img.svg +1 -1
  50. package/dist/img/minicolors.png +0 -0
  51. package/dist/img/v_img.svg +1 -1
  52. package/dist/index-DxWAYxai.js +5495 -0
  53. package/dist/{layoutView-CeJBpZb_.js → layoutView-DLpHSner.js} +1564 -1559
  54. package/dist/{log-in-e7D5Ss1P.js → log-in-CpGqc33f.js} +5 -4
  55. package/dist/{log-out--RRncZhN.js → log-out-D1b4VRMZ.js} +30 -24
  56. package/dist/login-OjDiQmz8.js +249 -0
  57. package/dist/{login-log-CvVnyGi3.js → login-log-BNRXLeMi.js} +4 -3
  58. package/dist/{lov-view-DRF-99U4.js → lov-view-D28X6m3k.js} +5 -5
  59. package/dist/{menuInfo-3Sjvs9nM.js → menuInfo-DwPB6rHz.js} +1 -1
  60. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-DrQ560nm.js → menuInfo.vue_vue_type_style_index_0_lang-l5DNRfb7.js} +34 -32
  61. package/dist/{pda-app-B9tn7jdv.js → pda-app-Bdms2PRY.js} +202 -188
  62. package/dist/{resource-BqnxbQNe.js → resource-y6SHrHoq.js} +18 -18
  63. package/dist/{su-welcome-VwifUK_O.js → su-welcome-D9G6EuK2.js} +118 -120
  64. package/dist/sys-config-DFnGHiFc.js +355 -0
  65. package/dist/udp-core.css +1 -9
  66. package/dist/utogether-MlnyYtNS.js +4 -0
  67. package/index.ts +17 -5
  68. package/package.json +1 -1
  69. package/src/App.vue +2 -7
  70. package/src/api/http.ts +1 -4
  71. package/src/api/index.ts +5 -3
  72. package/src/api/user.ts +2 -2
  73. package/src/components/SuCharts/src/UserInfo.vue +3 -3
  74. package/src/components/SuScrollTree/ScrollPanel.vue +170 -175
  75. package/src/components/udp/form/form.vue +109 -0
  76. package/src/components/udp/grid/index.vue +509 -0
  77. package/src/components/udp/index.ts +4 -4
  78. package/src/components/udp/utils.ts +405 -40
  79. package/src/directives/permission/index.ts +1 -1
  80. package/src/layout/components/lay-navbar/index.vue +9 -7
  81. package/src/layout/components/lay-panel/index.vue +3 -3
  82. package/src/layout/components/lay-search/index.vue +1 -1
  83. package/src/layout/components/lay-select-org/index.vue +4 -9
  84. package/src/layout/components/lay-sidebar/breadCrumb.vue +1 -1
  85. package/src/layout/components/lay-sidebar/horizontal.vue +4 -5
  86. package/src/layout/components/lay-sidebar/mixNav.vue +6 -4
  87. package/src/layout/components/lay-sidebar/sidebar-logo.vue +94 -98
  88. package/src/layout/components/lay-tag/index.vue +596 -625
  89. package/src/layout/hooks/useTag.ts +223 -233
  90. package/src/layout/layoutView.vue +215 -215
  91. package/src/layout/types.ts +3 -2
  92. package/src/main.ts +39 -31
  93. package/src/plugins/i18n/en.ts +26 -13
  94. package/src/plugins/i18n/zh.ts +35 -16
  95. package/src/plugins/vxe-table/index.ts +67 -4
  96. package/src/plugins/vxe-table/render.tsx +945 -817
  97. package/src/router/index.ts +186 -183
  98. package/src/router/modules/remaining.ts +1 -26
  99. package/src/router/utils.ts +393 -377
  100. package/src/store/modules/app.ts +1 -3
  101. package/src/store/modules/multiTags.ts +110 -109
  102. package/src/store/modules/permission.ts +113 -103
  103. package/src/store/modules/system.ts +1 -3
  104. package/src/style/button.scss +10 -3
  105. package/src/style/login.css +1 -1
  106. package/src/style/tailwind.css +1 -68
  107. package/src/style/vxetable.scss +348 -256
  108. package/src/utils/authority/index.ts +1 -1
  109. package/src/utils/index.ts +3 -1
  110. package/src/utils/propTypes.ts +1 -6
  111. package/src/views/login/login-view.vue +6 -20
  112. package/src/views/organization/company/CompanyPanel.vue +2 -2
  113. package/src/views/organization/department/DepartmentPanel.vue +269 -283
  114. package/src/views/organization/inv-org/InvOrganization.vue +23 -9
  115. package/src/views/organization/org/Org.vue +9 -5
  116. package/src/views/system/menu/SystemMenu.vue +183 -197
  117. package/src/views/system/menu/menuInfo.vue +8 -18
  118. package/src/views/system/role/AuthorityInfo.vue +19 -15
  119. package/src/views/system/role/Role.vue +1 -5
  120. package/src/views/system/role/RolePanel.vue +11 -2
  121. package/src/views/system/role/UserInfo.vue +11 -9
  122. package/src/views/system/role-assign/RoleAssign.vue +2 -2
  123. package/src/views/system/role-assign/RolePanel.vue +12 -9
  124. package/src/views/system/sys/sys-config.vue +66 -21
  125. package/src/views/system/sysUser/SysUserPanel.vue +44 -43
  126. package/src/views/uapp/pda/pda-app.vue +48 -16
  127. package/src/views/udev/coderule/code-rule.vue +120 -121
  128. package/src/views/udev/dict/DictView.vue +16 -4
  129. package/src/views/udev/dict/childView.vue +8 -8
  130. package/src/views/ufile/aggregation/File.vue +5 -5
  131. package/src/views/ufile/file/water-mark.vue +14 -14
  132. package/src/views/uhome/components/menu-favorite.vue +314 -331
  133. package/src/views/uhome/su-welcome.vue +3 -3
  134. package/src/views/ulogin/login.vue +19 -12
  135. package/src/views/upms/interface/log-in.vue +100 -106
  136. package/src/views/upms/interface/log-out.vue +2 -8
  137. package/src/views/upms/user/login-log.vue +54 -60
  138. package/src/views/urpt/design/DesignPanel.vue +16 -35
  139. package/src/views/urpt/design/Preview.vue +1 -0
  140. package/src/views/urpt/design/ReportDesign.vue +17 -23
  141. package/src/views/urpt/static-resource/resource.vue +3 -3
  142. package/src/views/urpt/template/ReportTemplate.vue +7 -7
  143. package/types/global.d.ts +4 -9
  144. package/vite.config.ts +6 -2
  145. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-Duyweh89.js +0 -102
  146. package/dist/DictView-B4a7Hs1X.js +0 -95
  147. package/dist/InvOrganization-q4T3y8dQ.js +0 -260
  148. package/dist/Org-BTGTrAVz.js +0 -35
  149. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-DKHgNWQP.js +0 -126
  150. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-BsBKpYR7.js +0 -288
  151. package/dist/index-DZc3qRTx.js +0 -2650
  152. package/dist/login-BOxwzwdB.js +0 -252
  153. package/dist/sys-config-C0-gSBFO.js +0 -277
  154. package/dist/utogether-Di1byIum.js +0 -182
  155. package/src/components/udp/form-upload.vue +0 -183
  156. package/src/components/udp/modal-form.vue +0 -180
  157. package/src/utils/http/index.ts +0 -297
  158. package/src/utils/http/types.d.ts +0 -46
  159. package/src/utils/udp/useRender.ts +0 -420
@@ -0,0 +1,4 @@
1
+ const A = "";
2
+ export {
3
+ A as u
4
+ };
package/index.ts CHANGED
@@ -1,8 +1,8 @@
1
1
  /*
2
2
  * @Author: levi7754 levi7754@163.com
3
3
  * @Date: 2024-04-14 19:10:28
4
- * @LastEditors: wei.li
5
- * @LastEditTime: 2024-06-26 17:08:49
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-09-12 14:48:18
6
6
  * @FilePath: /udp-front/packages/udp-core/index.ts
7
7
  * @Description:
8
8
  */
@@ -18,10 +18,14 @@ import { useMultiTagsStoreHook as useMultiTagsStore } from './src/store/modules/
18
18
  import { usePermissionStoreHook as usePermissionStore } from './src/store/modules/permission';
19
19
 
20
20
  import { handleAliveRoute, delCurrentRoute } from './src/router/utils';
21
-
22
- import { lifeCycleEvent } from './src/utils/lifecycle';
21
+ import { useLayout } from './src/layout/hooks/useLayout';
22
+ import { useDataThemeChange } from './src/layout/hooks/useDataThemeChange';
23
+ import { constantRoutes, remainingRouters, routerBefore } from './src/router';
23
24
 
24
25
  import { getServiceApi } from './src/api';
26
+ import { initDict } from './src/api/user';
27
+
28
+ import { lifeCycleEvent, getPlatform, getBrower } from './src/utils';
25
29
 
26
30
  export {
27
31
  store,
@@ -32,5 +36,13 @@ export {
32
36
  delCurrentRoute,
33
37
  handleAliveRoute,
34
38
  getServiceApi,
35
- lifeCycleEvent
39
+ lifeCycleEvent,
40
+ routerBefore,
41
+ constantRoutes,
42
+ remainingRouters,
43
+ useDataThemeChange,
44
+ useLayout,
45
+ initDict,
46
+ getPlatform,
47
+ getBrower
36
48
  };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@utogether/udp-core",
3
3
  "private": false,
4
- "version": "1.0.1-beta.2",
4
+ "version": "1.0.1-beta.20",
5
5
  "description": "",
6
6
  "type": "module",
7
7
  "main1": "index.ts",
package/src/App.vue CHANGED
@@ -2,11 +2,11 @@
2
2
  * @Author: wei.li
3
3
  * @Date: 2021-12-23 17:33:19
4
4
  * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2025-04-08 14:44:35
5
+ * @LastEditTime: 2025-08-13 08:39:18
6
6
  * @Description: file content
7
7
  -->
8
8
  <template>
9
- <el-config-provider size="small" :z-index="2000" :locale="currentLocale">
9
+ <el-config-provider size="small" :z-index="5555" :locale="currentLocale">
10
10
  <router-view />
11
11
  </el-config-provider>
12
12
  </template>
@@ -63,8 +63,3 @@ export default defineComponent({
63
63
  }
64
64
  });
65
65
  </script>
66
- <style lang="scss">
67
- // .hiprint-printElement-image-content img {
68
- // content: url('/images/logo.png');
69
- // }
70
- </style>
package/src/api/http.ts CHANGED
@@ -26,10 +26,7 @@ export const getPrintTemp = (printPosition, query?) => {
26
26
  const organizationId = useSystemStoreHook().getOrganizationId;
27
27
  const orgId = useSystemStoreHook().getOrgId;
28
28
  const url = '/upms/v1/printTemplateConfig/ogn';
29
- const param = Object.assign(
30
- { pageSize: 100, pageNum: 1, orgId, organizationId, printPosition },
31
- query || {}
32
- );
29
+ const param = Object.assign({ pageSize: 100, pageNum: 1, orgId, organizationId, printPosition }, query || {});
33
30
  return new Promise(reslove => {
34
31
  http.get(`${getBaseURL()}${url}`, param).then(async (res: IResponseData) => {
35
32
  const templateCode = res.list
package/src/api/index.ts CHANGED
@@ -2,10 +2,11 @@
2
2
  * @Author: wei.li
3
3
  * @Date: 2021-11-17 16:24:43
4
4
  * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2024-11-23 10:13:07
5
+ * @LastEditTime: 2025-09-05 11:53:29
6
6
  * @Description: API封装
7
7
  */
8
8
  import { http } from '@utogether/utils';
9
+ // import { http } from '../utils/udp/http';
9
10
  import { getEnv } from '../config';
10
11
 
11
12
  // 路由相关服务
@@ -20,8 +21,9 @@ export const getServiceApi = () => {
20
21
 
21
22
  export const setRouter = router => {
22
23
  http.setRouter(router);
23
- console.log('====url', getBaseURL());
24
- // http.setBaseUrl(getBaseURL());
24
+ };
25
+ export const setBaseUrl = router => {
26
+ http.setBaseUrl(router);
25
27
  };
26
28
 
27
29
  const origin = window.location.origin + '/gateway';
package/src/api/user.ts CHANGED
@@ -2,13 +2,13 @@
2
2
  * @Author: wei.li
3
3
  * @Date: 2021-11-17 16:02:30
4
4
  * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2024-06-06 16:29:39
5
+ * @LastEditTime: 2025-09-05 12:33:08
6
6
  * @Description: file content
7
7
  */
8
8
  import { http } from '@utogether/utils';
9
+ // import { http } from '../utils/udp/http';
9
10
  import { getBaseURL } from './';
10
11
 
11
- http.setBaseUrl(getBaseURL());
12
12
  // 私钥
13
13
  export const getPublicKey = () => http.get(`${getBaseURL()}/public/request`);
14
14
  // 获取验证码
@@ -1,8 +1,8 @@
1
1
  <!--
2
2
  * @Author: wei.li
3
3
  * @Date: 2021-11-17 16:02:30
4
- * @LastEditors: wei.li
5
- * @LastEditTime: 2021-12-02 09:28:42
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-08-14 10:01:18
6
6
  * @Description: file content
7
7
  -->
8
8
  <script setup lang="ts">
@@ -23,7 +23,7 @@ const lists = ref([
23
23
  <el-descriptions-item>
24
24
  <template #label>
25
25
  <i class="el-icon-user" />
26
- {{ $t('message.userName') }}
26
+ {{ $t('message.udp.userName') }}
27
27
  </template>
28
28
  {{ employee.userName }}
29
29
  </el-descriptions-item>
@@ -1,175 +1,170 @@
1
- <template>
2
- <div class="u-scroll-panel" @click.prevent="handleClickPanel">
3
- <div class="u-panel-header">
4
- <h2>{{ title }}</h2>
5
- <ut-button v-if="showAllButton" content="BtnExpand" @click="handleExpand(data, true)" />
6
- <ut-button
7
- v-if="showAllButton"
8
- status="warning"
9
- content="BtnCollapse"
10
- @click="handleExpand(data, false)"
11
- />
12
- <vxe-button icon="vxe-icon-refresh" @click="onRefresh" />
13
- </div>
14
- <div class="u-panel-content system-scrollbar">
15
- <el-tree
16
- ref="tree"
17
- :data="data"
18
- :props="treeOtions"
19
- :expand-on-click-node="false"
20
- style="background-color: #fff"
21
- class="u-tree-panel"
22
- node-key="id"
23
- highlight-current
24
- @node-click="handleNodeClick"
25
- >
26
- <template #default="{ node }">
27
- <span class="prefix" :class="{ 'is-leaf': node.isLeaf }">
28
- <i class="ri-folder-2-fill ri-lg mr-1" style="color: #fadb14" />
29
- </span>
30
- <span>{{ node.label }}</span>
31
- </template>
32
- </el-tree>
33
- </div>
34
- </div>
35
- </template>
36
-
37
- <script lang="ts" setup>
38
- import { getServiceApi } from '../../api';
39
- import type { Ref } from 'vue';
40
- import { ref, inject, watch, nextTick } from 'vue';
41
-
42
- interface IProps {
43
- title: string;
44
- url: string;
45
- showAllButton?: boolean;
46
- treeOtions: Object;
47
- extParam?: Object;
48
- }
49
- const props = withDefaults(defineProps<IProps>(), {
50
- treeOtions: () => {
51
- return {
52
- children: 'children',
53
- label: 'label'
54
- };
55
- },
56
- extParam: () => {
57
- return {};
58
- },
59
- showAllButton: false
60
- });
61
-
62
- const data = ref<any>([]);
63
- const tree: Ref<any | null> = ref(null);
64
- // 当前激活item
65
- const active: IRecord = inject('active');
66
- // tree面板变更
67
- const scrollPanelChange: IRecord = inject('scrollPanelChange');
68
- // tree 列表
69
- const treeList: IRecord = inject('treeList');
70
-
71
- watch(
72
- () => scrollPanelChange.value,
73
- () => {
74
- scrollPanelChange.value && getDataList();
75
- }
76
- );
77
-
78
- const getDataList = async (params = {}) => {
79
- const query = Object.assign(params, props.extParam);
80
- const serverData = (await getServiceApi().get(props.url, query)) as IResponseData;
81
- data.value = serverData.list || serverData;
82
- treeList.value = serverData.list || serverData;
83
- active.value = serverData.list ? serverData.list[0] : serverData[0];
84
- nextTick(() => {
85
- tree.value && tree?.value.setCurrentKey(active.value?.id || '');
86
- });
87
- scrollPanelChange.value = false;
88
- };
89
- const handleNodeClick = (row: any) => {
90
- active.value = row;
91
- };
92
-
93
- const handleClickPanel = () => {
94
- active.value = {};
95
- };
96
-
97
- const handleExpand = (array, expanded) => {
98
- array.forEach(el => {
99
- tree.value.store.nodesMap[el.id].expanded = expanded;
100
- if (el.children?.length) {
101
- handleExpand(el.children, expanded);
102
- }
103
- });
104
- console.log('[ tree.value ] >', tree.value);
105
- };
106
-
107
- const onRefresh = () => {
108
- getDataList();
109
- };
110
- defineExpose({
111
- onRefresh
112
- });
113
- getDataList();
114
- </script>
115
-
116
- <style lang="scss">
117
- .u-scroll-panel {
118
- display: flex;
119
- flex-direction: column;
120
- width: 100%;
121
- height: 100%;
122
- background: #fff;
123
-
124
- .u-panel-header {
125
- display: flex;
126
- align-items: center;
127
- padding: 10px;
128
- border-bottom: 1px solid #eee;
129
-
130
- h2 {
131
- // display: box;
132
- height: 30px;
133
- padding: 0;
134
- margin: 0;
135
- margin-right: 20px;
136
- overflow: hidden;
137
- -webkit-line-clamp: 1;
138
- font-size: 14px;
139
- line-height: 30px;
140
- -webkit-box-orient: vertical;
141
- }
142
-
143
- .el-input {
144
- flex: 1;
145
- }
146
- }
147
-
148
- .u-panel-content {
149
- flex: 1;
150
- overflow: auto;
151
- }
152
-
153
- .u-tree-panel {
154
- height: 100%; // 0630
155
- :deep(.el-tree-node__content) {
156
- height: 36px;
157
- }
158
-
159
- :deep(.el-tree-node.is-current > .el-tree-node__content) {
160
- background-color: rgb(64 158 255 / 40%);
161
- }
162
-
163
- :deep(.el-tree-node > .el-tree-node__content) {
164
- transition: 0.2s;
165
- }
166
- }
167
-
168
- .el-vl__window {
169
- height: 360px !important;
170
- // &:first-child {
171
- // height: 100% !important;
172
- // }
173
- }
174
- }
175
- </style>
1
+ <template>
2
+ <div class="u-scroll-panel" @click.prevent="handleClickPanel">
3
+ <div class="u-panel-header">
4
+ <h2>{{ title }}</h2>
5
+ <ut-button v-if="showAllButton" content="BtnExpand" @click="handleExpand(data, true)" />
6
+ <ut-button v-if="showAllButton" status="warning" content="BtnCollapse" @click="handleExpand(data, false)" />
7
+ <vxe-button icon="vxe-icon-refresh" @click="onRefresh" />
8
+ </div>
9
+ <div class="u-panel-content system-scrollbar">
10
+ <el-tree
11
+ ref="tree"
12
+ :data="data"
13
+ :props="treeOtions"
14
+ :expand-on-click-node="false"
15
+ style="background-color: #fff"
16
+ class="u-tree-panel"
17
+ node-key="id"
18
+ highlight-current
19
+ @node-click="handleNodeClick"
20
+ >
21
+ <template #default="{ node }">
22
+ <span class="prefix" :class="{ 'is-leaf': node.isLeaf }">
23
+ <i class="ri-folder-2-fill ri-lg mr-1" style="color: #fadb14" />
24
+ </span>
25
+ <span>{{ node.label }}</span>
26
+ </template>
27
+ </el-tree>
28
+ </div>
29
+ </div>
30
+ </template>
31
+
32
+ <script lang="ts" setup>
33
+ import { getServiceApi } from '../../api';
34
+ import type { Ref } from 'vue';
35
+ import { ref, inject, watch, nextTick } from 'vue';
36
+
37
+ interface IProps {
38
+ title: string;
39
+ url: string;
40
+ showAllButton?: boolean;
41
+ treeOtions: Object;
42
+ defaultParams?: Object;
43
+ }
44
+ const props = withDefaults(defineProps<IProps>(), {
45
+ treeOtions: () => {
46
+ return {
47
+ children: 'children',
48
+ label: 'label'
49
+ };
50
+ },
51
+ defaultParams: () => {
52
+ return {};
53
+ },
54
+ showAllButton: false
55
+ });
56
+
57
+ const data = ref<any>([]);
58
+ const tree: Ref<any | null> = ref(null);
59
+ // 当前激活item
60
+ const active: IRecord = inject('active');
61
+ // tree面板变更
62
+ const scrollPanelChange: IRecord = inject('scrollPanelChange');
63
+ // tree 列表
64
+ const treeList: IRecord = inject('treeList');
65
+
66
+ watch(
67
+ () => scrollPanelChange.value,
68
+ () => {
69
+ scrollPanelChange.value && getDataList();
70
+ }
71
+ );
72
+
73
+ const getDataList = async (params = {}) => {
74
+ const query = Object.assign(params, props.defaultParams);
75
+ const serverData = (await getServiceApi().get(props.url, query)) as IResponseData;
76
+ data.value = serverData.list || serverData;
77
+ treeList.value = serverData.list || serverData;
78
+ active.value = serverData.list ? serverData.list[0] : serverData[0];
79
+ nextTick(() => {
80
+ tree.value && tree?.value.setCurrentKey(active.value?.id || '');
81
+ });
82
+ scrollPanelChange.value = false;
83
+ };
84
+ const handleNodeClick = (row: any) => {
85
+ active.value = row;
86
+ };
87
+
88
+ const handleClickPanel = () => {
89
+ active.value = {};
90
+ };
91
+
92
+ const handleExpand = (array, expanded) => {
93
+ array.forEach(el => {
94
+ tree.value.store.nodesMap[el.id].expanded = expanded;
95
+ if (el.children?.length) {
96
+ handleExpand(el.children, expanded);
97
+ }
98
+ });
99
+ console.log('[ tree.value ] >', tree.value);
100
+ };
101
+
102
+ const onRefresh = () => {
103
+ getDataList();
104
+ };
105
+ defineExpose({
106
+ onRefresh
107
+ });
108
+ getDataList();
109
+ </script>
110
+
111
+ <style lang="scss">
112
+ .u-scroll-panel {
113
+ display: flex;
114
+ flex-direction: column;
115
+ width: 100%;
116
+ height: 100%;
117
+ background: #fff;
118
+
119
+ .u-panel-header {
120
+ display: flex;
121
+ align-items: center;
122
+ padding: 10px;
123
+ border-bottom: 1px solid #eee;
124
+
125
+ h2 {
126
+ // display: box;
127
+ height: 30px;
128
+ padding: 0;
129
+ margin: 0;
130
+ margin-right: 20px;
131
+ overflow: hidden;
132
+ -webkit-line-clamp: 1;
133
+ font-size: 14px;
134
+ line-height: 30px;
135
+ -webkit-box-orient: vertical;
136
+ }
137
+
138
+ .el-input {
139
+ flex: 1;
140
+ }
141
+ }
142
+
143
+ .u-panel-content {
144
+ flex: 1;
145
+ overflow: auto;
146
+ }
147
+
148
+ .u-tree-panel {
149
+ height: 100%; // 0630
150
+ :deep(.el-tree-node__content) {
151
+ height: 36px;
152
+ }
153
+
154
+ :deep(.el-tree-node.is-current > .el-tree-node__content) {
155
+ background-color: rgb(64 158 255 / 40%);
156
+ }
157
+
158
+ :deep(.el-tree-node > .el-tree-node__content) {
159
+ transition: 0.2s;
160
+ }
161
+ }
162
+
163
+ .el-vl__window {
164
+ height: 360px !important;
165
+ // &:first-child {
166
+ // height: 100% !important;
167
+ // }
168
+ }
169
+ }
170
+ </style>
@@ -0,0 +1,109 @@
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2022-03-02 17:07:59
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-09-11 16:24:13
6
+ * @Description: SuForm
7
+ -->
8
+
9
+ <template>
10
+ <div class="width: 100%">
11
+ <vxe-form
12
+ ref="xForm"
13
+ :data="record"
14
+ :items="formItems"
15
+ :rules="rules"
16
+ :loading="loading"
17
+ :vertical="vertical"
18
+ :title-width="titleWidth"
19
+ title-overflow
20
+ title-align="right"
21
+ title-bold
22
+ v-bind="$attrs"
23
+ >
24
+ <template #dividerPrefix />
25
+ <template #collapseNode>
26
+ <vxe-checkbox
27
+ v-model="collapseStatus"
28
+ content="查看更多"
29
+ :checked-value="false"
30
+ :unchecked-value="true"
31
+ class="pl-10"
32
+ @change="onChange"
33
+ />
34
+ </template>
35
+ </vxe-form>
36
+ </div>
37
+ </template>
38
+
39
+ <script lang="ts">
40
+ export default {
41
+ name: 'UtForm'
42
+ };
43
+ </script>
44
+ <script setup lang="ts">
45
+ import { useI18n } from 'vue-i18n';
46
+ import { ref, computed } from 'vue';
47
+ import { formatRules, formatItems } from '@utogether/utils';
48
+ import { clone } from 'xe-utils';
49
+
50
+ export interface IProps {
51
+ record: IRecord; // 数据对象
52
+ items: Array<IFormItemProps>; // form item
53
+ loading?: boolean;
54
+ vertical?: boolean;
55
+ titleWidth?: number;
56
+ span?: number;
57
+ dataStatus?: string;
58
+ }
59
+
60
+ const props = withDefaults(defineProps<IProps>(), {
61
+ record: (): IRecord => {
62
+ return {};
63
+ },
64
+ items: () => [],
65
+ loading: false,
66
+ vertical: false,
67
+ titleWidth: 100,
68
+ span: 6,
69
+ dataStatus: 'detail'
70
+ });
71
+ const xForm = ref(undefined);
72
+ const { t } = useI18n();
73
+ const collapseStatus = ref(true);
74
+ /**
75
+ * @description: 根据items 获取必填选
76
+ */
77
+ const rules = computed(() => {
78
+ if (!props.items.length) return {};
79
+ return formatRules(props.items, t);
80
+ });
81
+
82
+ const formItems = computed(() => {
83
+ if (!props.items.length) return props.items;
84
+ return formatItems(clone(props.items, true), props.dataStatus, 6);
85
+ });
86
+
87
+ const onChange = () => {
88
+ xForm.value.toggleCollapse();
89
+ };
90
+
91
+ /**
92
+ * @deprecated
93
+ * @description 使用validate替换
94
+ * @param cb
95
+ */
96
+ const validateForm = (cb: Function) => {
97
+ (xForm as any).value.validate(cb);
98
+ };
99
+ const validate = (cb: Function) => {
100
+ (xForm as any).value.validate(cb);
101
+ setTimeout(() => {
102
+ xForm.value.clearValidate();
103
+ }, 1600);
104
+ };
105
+ defineExpose({
106
+ validateForm,
107
+ validate
108
+ });
109
+ </script>