@utogether/udp-core 1.0.1-beta.9 → 1.0.2

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 (168) hide show
  1. package/build/plugins.ts +37 -39
  2. package/dist/{403-BOzKHdlm.js → 403-B1rIjAAu.js} +6 -6
  3. package/dist/{404-uwgt4Nll.js → 404-mBqc2y4t.js} +4 -4
  4. package/dist/{500-4HBf6V9m.js → 500-BoI45Zdh.js} +2 -2
  5. package/dist/{AuthorityInfo-DvbIh1vT.js → AuthorityInfo-B08NBIIn.js} +1 -1
  6. package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-BlCPvwXU.js → AuthorityInfo.vue_vue_type_style_index_0_lang-BLP1SaiH.js} +3 -3
  7. package/dist/{Company-D7Q9BFmr.js → Company-JGGyWEWH.js} +3 -3
  8. package/dist/{CompanyPanel-C0-PJlrt.js → CompanyPanel-BQ_cCmDx.js} +7 -7
  9. package/dist/{Department-h2hlXACv.js → Department-z2iO6hwM.js} +10 -10
  10. package/dist/{DepartmentPanel-B6hDEQpG.js → DepartmentPanel-BtQe7zwU.js} +108 -78
  11. package/dist/{DesignPanel-cS58-1v9.js → DesignPanel-7mhtVWas.js} +1 -1
  12. package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-LdvLC8VU.js → DesignPanel.vue_vue_type_style_index_0_lang-4EsHemj_.js} +6 -6
  13. package/dist/{DictView-T3TmpBa8.js → DictView-CjchV2Yk.js} +15 -16
  14. package/dist/InvOrganization-Pn1O_XP0.js +74 -0
  15. package/dist/{Org-CnCBDGKF.js → Org-BqytV_vi.js} +1 -1
  16. package/dist/{Preview-BaktKXB1.js → Preview-CLpUUMay.js} +2 -2
  17. package/dist/{ReportDefine-5Rb0PO9A.js → ReportDefine-Cz1KtEUF.js} +1 -1
  18. package/dist/{ReportDesign-DYdkVREA.js → ReportDesign-BaORYud4.js} +13 -13
  19. package/dist/{ReportQuery-BwhzIXMt.js → ReportQuery-CPCPXiXz.js} +1 -1
  20. package/dist/{ReportQueryFrom-PHtWwlOe.js → ReportQueryFrom-C_AcrfkJ.js} +1 -1
  21. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-BE5yZNPM.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-Bm67ejay.js} +1 -1
  22. package/dist/{ReportTemplate-DaadVXIi.js → ReportTemplate-CFiNMz79.js} +11 -11
  23. package/dist/{Role-Dtg3nAmG.js → Role-B-XDoJd5.js} +3 -3
  24. package/dist/{RoleAssign-DEGtLssH.js → RoleAssign-BolW8YVs.js} +8 -8
  25. package/dist/{RolePanel-DpUzfE_o.js → RolePanel-2kfs5tw9.js} +1 -1
  26. package/dist/{RolePanel-CT7BTPmy.js → RolePanel-HilSuYns.js} +1 -1
  27. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-Xyo0YEI0.js → RolePanel.vue_vue_type_script_setup_true_lang-CE4gApUY.js} +7 -7
  28. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-Dg2A6DJu.js → RolePanel.vue_vue_type_script_setup_true_lang-DPzgfAyV.js} +13 -13
  29. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-CyutzDZS.js → ScrollPanel.vue_vue_type_style_index_0_lang-CCTH4RkH.js} +4 -4
  30. package/dist/{Staff-_NlAGkrh.js → Staff-BTk3whFC.js} +3 -3
  31. package/dist/{StaffInfo-DVgUvVgd.js → StaffInfo-d3AuSzlA.js} +1 -1
  32. package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-C8hmlFgX.js → StaffInfo.vue_vue_type_script_setup_true_lang-eOL4VlfE.js} +5 -5
  33. package/dist/{StaffPanel-DKNZE3IE.js → StaffPanel-DV-D4jjz.js} +1 -1
  34. package/dist/StaffPanel.vue_vue_type_script_setup_true_lang-4sFq3CEo.js +135 -0
  35. package/dist/{SysUser-kQUf7XKz.js → SysUser-BnjYytws.js} +2 -2
  36. package/dist/{SysUserPanel-C191uX3U.js → SysUserPanel-CBoyD-Qi.js} +1 -1
  37. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-PrTlTZR-.js +341 -0
  38. package/dist/{SystemMenu-DwuSvHnj.js → SystemMenu-kYB_ZaUt.js} +36 -36
  39. package/dist/{UserInfo-DIsInFld.js → UserInfo-4dx97VBL.js} +1 -1
  40. package/dist/{UserInfo.vue_vue_type_style_index_0_lang-CnvGdbej.js → UserInfo.vue_vue_type_style_index_0_lang-BpbC_ZDm.js} +10 -10
  41. package/dist/{childView-3Bs2UBEw.js → childView-CHPNfTEb.js} +1 -1
  42. package/dist/{childView-BawyULD7.js → childView-CKA_JgVZ.js} +1 -1
  43. package/dist/{childView.vue_vue_type_style_index_0_lang-YpWF-p2F.js → childView.vue_vue_type_style_index_0_lang-Bym2fQRd.js} +7 -7
  44. package/dist/childView.vue_vue_type_style_index_0_lang-W7bCtXeu.js +177 -0
  45. package/dist/{code-rule-DVaYcn8S.js → code-rule-CbxuZg0-.js} +40 -38
  46. package/dist/core.es.js +18 -12
  47. package/dist/{cron-task-xuzP-BpE.js → cron-task-nTOpqQYf.js} +7 -7
  48. package/dist/flow-task-B07st2aD.js +10 -0
  49. package/dist/{frameView-Cudt06qS.js → frameView-Z1tPUyCh.js} +1 -1
  50. package/dist/index-C3q8HoJM.js +4650 -0
  51. package/dist/{layoutView-BlFTV2jX.js → layoutView--MGA9zUB.js} +1766 -1760
  52. package/dist/{log-in-e7D5Ss1P.js → log-in-CSYJDA6m.js} +36 -29
  53. package/dist/log-out-DiwGCg7p.js +130 -0
  54. package/dist/login-C6Y0ajDp.js +251 -0
  55. package/dist/{login-log-kqKzKTto.js → login-log-C0V-_l3F.js} +5 -3
  56. package/dist/{lov-view-B2HaxyMs.js → lov-view-Cmv7wZZ9.js} +6 -6
  57. package/dist/{menuInfo-BxCTJ1VW.js → menuInfo-UeutJpOa.js} +1 -1
  58. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-CLOPNeUW.js → menuInfo.vue_vue_type_style_index_0_lang-CWX4Mu67.js} +118 -98
  59. package/dist/{pda-app-DPsAFNiw.js → pda-app-B6w99SJo.js} +10 -10
  60. package/dist/{resource-Dibb7t8u.js → resource-BybJvUv0.js} +4 -4
  61. package/dist/{su-welcome-DejR0KkM.js → su-welcome-C1bmxHoY.js} +119 -121
  62. package/dist/sys-config-BnmIDnCj.js +370 -0
  63. package/dist/udp-core.css +1 -9
  64. package/dist/utogether-MlnyYtNS.js +4 -0
  65. package/index.ts +49 -40
  66. package/package.json +18 -18
  67. package/src/App.vue +65 -65
  68. package/src/api/http.ts +1 -4
  69. package/src/api/index.ts +4 -2
  70. package/src/api/user.ts +2 -2
  71. package/src/components/SuCharts/src/UserInfo.vue +78 -78
  72. package/src/components/SuScrollTree/ScrollPanel.vue +1 -6
  73. package/src/components/udp/content/index.vue +88 -0
  74. package/src/components/udp/{form.vue → form/form.vue} +13 -16
  75. package/src/components/udp/{grid.vue → grid/index.vue} +56 -27
  76. package/src/components/udp/index.ts +4 -9
  77. package/src/components/udp/ut-stamp-badge/index.vue +271 -0
  78. package/src/components/udp/utils.ts +66 -105
  79. package/src/layout/components/lay-navbar/index.vue +8 -6
  80. package/src/layout/components/lay-panel/index.vue +150 -150
  81. package/src/layout/components/lay-search/index.vue +25 -25
  82. package/src/layout/components/lay-select-org/index.vue +4 -9
  83. package/src/layout/components/lay-setting/index.vue +503 -510
  84. package/src/layout/components/lay-sidebar/horizontal.vue +8 -6
  85. package/src/layout/components/lay-sidebar/mixNav.vue +260 -258
  86. package/src/layout/components/lay-sidebar/sidebar-logo.vue +101 -98
  87. package/src/layout/components/lay-tag/index.vue +24 -51
  88. package/src/layout/hooks/useDataThemeChange.ts +1 -1
  89. package/src/layout/hooks/useNav.ts +176 -173
  90. package/src/layout/hooks/useTag.ts +227 -233
  91. package/src/layout/types.ts +93 -92
  92. package/src/main.ts +115 -119
  93. package/src/plugins/i18n/en.ts +302 -302
  94. package/src/plugins/i18n/module/u-workflow.ts +1 -1
  95. package/src/plugins/i18n/zh.ts +21 -6
  96. package/src/plugins/vxe-table/index.ts +116 -53
  97. package/src/plugins/vxe-table/render.tsx +945 -956
  98. package/src/router/index.ts +17 -17
  99. package/src/router/modules/flow.ts +35 -0
  100. package/src/router/modules/home.ts +32 -32
  101. package/src/router/modules/remaining.ts +58 -58
  102. package/src/router/utils.ts +420 -377
  103. package/src/store/modules/app.ts +2 -4
  104. package/src/store/modules/epTheme.ts +48 -49
  105. package/src/store/modules/multiTags.ts +15 -14
  106. package/src/store/modules/permission.ts +25 -15
  107. package/src/store/modules/system.ts +1 -3
  108. package/src/style/button.scss +85 -85
  109. package/src/style/login.css +1 -1
  110. package/src/style/vxetable.scss +61 -2
  111. package/src/utils/dataFormat/index.ts +223 -223
  112. package/src/utils/index.ts +3 -1
  113. package/src/utils/lifecycle.ts +39 -20
  114. package/src/utils/propTypes.ts +1 -6
  115. package/src/utils/storage/index.ts +2 -2
  116. package/src/utils/udp/http/index.ts +24 -11
  117. package/src/utils/udp/http/types.d.ts +3 -10
  118. package/src/views/login/login-view.vue +4 -18
  119. package/src/views/organization/company/CompanyPanel.vue +259 -259
  120. package/src/views/organization/department/Department.vue +58 -58
  121. package/src/views/organization/department/DepartmentPanel.vue +303 -283
  122. package/src/views/organization/inv-org/InvOrganization.vue +22 -7
  123. package/src/views/organization/staff/StaffInfo.vue +127 -133
  124. package/src/views/organization/staff/StaffPanel.vue +162 -145
  125. package/src/views/system/cron/cron-task.vue +2 -12
  126. package/src/views/system/menu/SystemMenu.vue +185 -183
  127. package/src/views/system/menu/menuInfo.vue +384 -363
  128. package/src/views/system/role/UserInfo.vue +195 -195
  129. package/src/views/system/role-assign/RoleAssign.vue +57 -57
  130. package/src/views/system/role-assign/RolePanel.vue +139 -139
  131. package/src/views/system/sys/sys-config.vue +69 -20
  132. package/src/views/system/sysUser/SysUserPanel.vue +97 -28
  133. package/src/views/uapp/pda/pda-app.vue +208 -208
  134. package/src/views/udev/coderule/code-rule.vue +132 -121
  135. package/src/views/udev/dict/DictView.vue +2 -2
  136. package/src/views/udev/dict/childView.vue +183 -222
  137. package/src/views/udev/lov/childView.vue +1 -7
  138. package/src/views/udev/lov/lov-view.vue +91 -91
  139. package/src/views/uhome/components/menu-favorite.vue +314 -331
  140. package/src/views/uhome/su-welcome.vue +319 -339
  141. package/src/views/ulogin/login.vue +325 -321
  142. package/src/views/upms/interface/log-in.vue +100 -106
  143. package/src/views/upms/interface/log-out.vue +104 -107
  144. package/src/views/upms/user/login-log.vue +54 -60
  145. package/src/views/urpt/design/DesignPanel.vue +507 -507
  146. package/src/views/urpt/design/Preview.vue +1 -0
  147. package/src/views/urpt/design/ReportDesign.vue +2 -4
  148. package/src/views/utask/flow-task.vue +18 -0
  149. package/types/global.d.ts +231 -236
  150. package/dist/InvOrganization-BVuOhzbt.js +0 -66
  151. package/dist/StaffPanel.vue_vue_type_script_setup_true_lang-BOOO6Cek.js +0 -111
  152. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-SwNbAEvW.js +0 -294
  153. package/dist/childView.vue_vue_type_style_index_0_lang-DWIFCX3X.js +0 -187
  154. package/dist/index-CKnq5xIa.js +0 -2623
  155. package/dist/log-out--RRncZhN.js +0 -120
  156. package/dist/login-CpKykfdf.js +0 -253
  157. package/dist/sys-config-DiySRWns.js +0 -277
  158. package/dist/utogether-Dct_14Zk.js +0 -182
  159. package/src/components/udp/count-down.vue +0 -536
  160. package/src/components/udp/flip-down/FlipCard/flip-card.vue +0 -251
  161. package/src/components/udp/flip-down/FlipCard/interfaces.ts +0 -4
  162. package/src/components/udp/flip-down/FlipClock/flip-clock.vue +0 -113
  163. package/src/components/udp/form-upload.vue +0 -482
  164. package/src/components/udp/lov.vue +0 -388
  165. package/src/components/udp/modal-form.vue +0 -189
  166. package/src/components/udp/modal-grid.vue +0 -288
  167. package/src/components/udp/upload.vue +0 -423
  168. package/src/utils/udp/useRender.ts +0 -431
@@ -21,6 +21,10 @@ const routeStore = usePermissionStoreHook();
21
21
  const sysConfig = storageLocal.getItem(kSYSCONFIG) || {};
22
22
 
23
23
  const logo = ref(sysConfig['logo'] || utogether);
24
+ const showTitle = ref(sysConfig['showTitle']);
25
+
26
+ console.log({ showTitle });
27
+
24
28
  const {
25
29
  title,
26
30
  logout,
@@ -64,7 +68,7 @@ export default { name: 'LayoutHorizontal' };
64
68
  <div v-spinning="usePermissionStoreHook().wholeMenus.length === 0" class="horizontal-header">
65
69
  <div class="flex flex-1 horizontal-header-left" @click="backHome">
66
70
  <img :src="logo" class="h-full" />
67
- <span class="text-xl u-project-text">{{ title }}</span>
71
+ <span v-if="showTitle === 'Y'" class="text-xl u-project-text">{{ title }}</span>
68
72
  </div>
69
73
  <el-scrollbar ref="refScrollbar" class="flex-[3]" @wheel.prevent="handleScroll">
70
74
  <template #default>
@@ -88,16 +92,14 @@ export default { name: 'LayoutHorizontal' };
88
92
  </el-scrollbar>
89
93
  <div class="horizontal-header-right flex-[2]">
90
94
  <!-- 业务单元选择 -->
91
- <OrgSelect class="udp-horizontal" />
95
+ <OrgSelect v-if="sysConfig['orgTaggle'] === 'Y'" class="udp-horizontal" />
92
96
  <!-- 菜单搜索 -->
93
97
  <Search />
94
98
  <!-- 通知 -->
95
99
  <!-- <Notice id="header-notice" /> -->
96
100
  <!-- 国际化 -->
97
- <el-dropdown id="header-translation" trigger="click">
98
- <globalization
99
- class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden"
100
- />
101
+ <el-dropdown id="header-translation" class="px-2" trigger="click">
102
+ <globalization class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" />
101
103
  <template #dropdown>
102
104
  <el-dropdown-menu class="translation">
103
105
  <el-dropdown-item
@@ -1,258 +1,260 @@
1
- <script setup lang="ts">
2
- import { ref, watch, toRaw, onMounted, nextTick } from 'vue';
3
- import OrgSelect from '../lay-select-org/index.vue';
4
- import Search from '../lay-search/index.vue';
5
- // import Notice from '../lay-notice/index.vue';
6
- import extraIcon from './extraIcon.vue';
7
- import avatars from '../../../assets/images/avatars.jpg';
8
- import { transformI18n } from '../../../plugins/i18n';
9
- import { useRenderIcon } from '../../../components/ReIcon/src/hooks';
10
- import { useEpThemeStoreHook } from '../../../store/modules/epTheme';
11
- import { getParentPaths, findRouteByPath } from '../../../router/utils';
12
- import { useNav } from '../../hooks/useNav';
13
- import { useTranslationLang } from '../../hooks/useTranslationLang';
14
- import { usePermissionStoreHook } from '../../../store/modules/permission';
15
- import globalization from '../../../assets/svg/globalization.svg?component';
16
-
17
- const menuRef = ref();
18
- const { route, locale, translationCh, translationEn } = useTranslationLang(menuRef);
19
-
20
- const {
21
- device,
22
- logout,
23
- onPanel,
24
- toggleSideBar,
25
- resolvePath,
26
- appHook,
27
- userInfo,
28
- getDivStyle,
29
- avatarsStyle,
30
- getDropdownItemStyle,
31
- getDropdownItemClass,
32
- passwordItems
33
- } = useNav();
34
-
35
- const refScrollbar = ref(null);
36
- const defaultActive = ref(null);
37
- const record: IRecord = {};
38
-
39
- const showModal = ref(false);
40
-
41
- function getDefaultActive(routePath) {
42
- const wholeMenus = usePermissionStoreHook().wholeMenus;
43
- // 当前路由的父级路径
44
- const parentRoutes = getParentPaths(routePath, wholeMenus)[0];
45
- defaultActive.value = findRouteByPath(parentRoutes, wholeMenus)?.children[0]?.path;
46
- }
47
-
48
- onMounted(() => {
49
- getDefaultActive(route.path);
50
- });
51
-
52
- nextTick(() => {
53
- menuRef.value?.handleResize();
54
- });
55
-
56
- watch(
57
- () => route.path,
58
- () => {
59
- getDefaultActive(route.path);
60
- }
61
- );
62
-
63
- const handleResetPwd = (): void => {
64
- record.id = userInfo['id'];
65
- showModal.value = true;
66
- };
67
-
68
- const handleScroll = e => {
69
- const wheelDelta = e.wheelDelta || -e.deltaY * 40;
70
- const scrollbar = refScrollbar.value;
71
- // scrollbar.wrap$获取到包裹容器的element对象
72
- scrollbar.setScrollLeft(scrollbar.wrapRef.scrollLeft + wheelDelta);
73
- };
74
- </script>
75
-
76
- <template>
77
- <div v-if="device !== 'mobile'" class="horizontal-header">
78
- <div
79
- :class="classes.container"
80
- :title="appHook.sidebar.opened ? $t('message.udp.collapse') : $t('message.udp.expand')"
81
- @click="toggleSideBar"
82
- >
83
- <svg
84
- :fill="useEpThemeStoreHook().fill"
85
- :class="['hamburger', appHook.sidebar.opened ? 'is-active-hamburger' : '']"
86
- viewBox="0 0 1024 1024"
87
- xmlns="http://www.w3.org/2000/svg"
88
- width="64"
89
- height="64"
90
- >
91
- <path
92
- d="M408 442h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-8 204c0 4.4 3.6 8 8 8h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56zm504-486H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 632H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM142.4 642.1L298.7 519a8.84 8.84 0 0 0 0-13.9L142.4 381.9c-5.8-4.6-14.4-.5-14.4 6.9v246.3a8.9 8.9 0 0 0 14.4 7z"
93
- />
94
- </svg>
95
- </div>
96
-
97
- <el-scrollbar ref="refScrollbar" style="max-width: 66%" @wheel.prevent="handleScroll">
98
- <template #default>
99
- <el-menu
100
- ref="menu"
101
- :default-active="defaultActive"
102
- :ellipsis="false"
103
- class="horizontal-header-menu"
104
- mode="horizontal"
105
- router
106
- >
107
- <el-menu-item
108
- v-for="route in usePermissionStoreHook().wholeMenus"
109
- :key="route.path"
110
- :index="resolvePath(route) || route.redirect"
111
- >
112
- <template #title>
113
- <div v-if="toRaw(route.meta.icon)" :class="['sub-menu-icon', route.meta.icon]">
114
- <component :is="useRenderIcon(route.meta && toRaw(route.meta.icon))" />
115
- </div>
116
- <!-- <span class="select-none">{{ transformI18n(route.meta.title) }}</span>
117
- <FontIcon
118
- v-if="route.meta.extraIcon"
119
- width="30px"
120
- height="30px"
121
- style="position: absolute; right: 10px"
122
- :icon="route.meta.extraIcon"
123
- :svg="route.meta.extraIcon ? true : false"
124
- /> -->
125
- <div :style="getDivStyle">
126
- <span class="select-none">
127
- {{ transformI18n(route.meta.title) }}
128
- </span>
129
- <extraIcon :extra-icon="route.meta.extraIcon" />
130
- </div>
131
- </template>
132
- </el-menu-item>
133
- </el-menu>
134
- </template>
135
- </el-scrollbar>
136
- <div class="horizontal-header-right">
137
- <!-- 业务单元选择 -->
138
- <OrgSelect />
139
- <!-- 菜单搜索 -->
140
- <Search />
141
- <!-- 通知 -->
142
- <!-- <Notice id="header-notice" /> -->
143
- <!-- 国际化 -->
144
- <el-dropdown id="header-translation" trigger="click">
145
- <globalization
146
- class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden"
147
- />
148
- <template #dropdown>
149
- <el-dropdown-menu class="translation">
150
- <el-dropdown-item
151
- :style="getDropdownItemStyle(locale, 'zh')"
152
- :class="['dark:text-white!', getDropdownItemClass(locale, 'zh')]"
153
- @click="translationCh"
154
- >
155
- <span v-show="locale === 'zh'" class="check-zh">
156
- <IconifyIconOffline icon="ri:check-line" />
157
- </span>
158
- 简体中文
159
- </el-dropdown-item>
160
- <el-dropdown-item
161
- :style="getDropdownItemStyle(locale, 'en')"
162
- :class="['dark:text-white!', getDropdownItemClass(locale, 'en')]"
163
- @click="translationEn"
164
- >
165
- <span v-show="locale === 'en'" class="check-en">
166
- <IconifyIconOffline icon="ri:check-line" />
167
- </span>
168
- English
169
- </el-dropdown-item>
170
- </el-dropdown-menu>
171
- </template>
172
- </el-dropdown>
173
- <!-- 退出登陆 -->
174
- <el-dropdown trigger="click">
175
- <span class="select-none el-dropdown-link navbar-bg-hover">
176
- <img v-if="avatars" :src="avatars" :style="avatarsStyle" />
177
- <p class="dark:text-white">{{ userInfo.name }}</p>
178
- </span>
179
- <template #dropdown>
180
- <el-dropdown-menu class="logout">
181
- <el-dropdown-item @click="handleResetPwd">
182
- <IconifyIconOffline icon="ri:edit-2-fill" />
183
- {{ $t('message.udp.passwordReset') }}
184
- </el-dropdown-item>
185
- <el-divider style="margin: 3px 0 !important" />
186
- <el-dropdown-item @click="logout">
187
- <IconifyIconOffline icon="switch-button" />
188
- {{ $t('message.udp.logout') }}
189
- </el-dropdown-item>
190
- </el-dropdown-menu>
191
- </template>
192
- </el-dropdown>
193
- <span class="el-icon-setting navbar-bg-hover" @click="onPanel">
194
- <IconifyIconOffline icon="ri:settings-5-fill" />
195
- </span>
196
- </div>
197
-
198
- <ut-modal-form
199
- v-if="showModal"
200
- :record="record"
201
- :items="passwordItems()"
202
- :width="360"
203
- :height="240"
204
- :title="$t('message.udp.passwordReset')"
205
- data-status="update"
206
- url="/uums/user/updatePwd"
207
- method="put"
208
- @close="showModal = false"
209
- />
210
- </div>
211
- </template>
212
-
213
- <style module="classes" scoped>
214
- .container {
215
- padding: 0 15px;
216
- }
217
- </style>
218
-
219
- <style lang="scss" scoped>
220
- .hamburger {
221
- width: 20px;
222
- height: 20px;
223
-
224
- &:hover {
225
- cursor: pointer;
226
- }
227
- }
228
-
229
- .is-active-hamburger {
230
- transform: rotate(180deg);
231
- }
232
-
233
- .translation {
234
- ::v-deep(.el-dropdown-menu__item) {
235
- padding: 5px 40px;
236
- }
237
-
238
- .check-zh {
239
- position: absolute;
240
- left: 20px;
241
- }
242
-
243
- .check-en {
244
- position: absolute;
245
- left: 20px;
246
- }
247
- }
248
-
249
- .logout {
250
- max-width: 120px;
251
-
252
- ::v-deep(.el-dropdown-menu__item) {
253
- display: inline-flex;
254
- flex-wrap: wrap;
255
- min-width: 100%;
256
- }
257
- }
258
- </style>
1
+ <script setup lang="ts">
2
+ import { ref, watch, toRaw, onMounted, nextTick } from 'vue';
3
+ import { storageLocal } from '@utogether/utils';
4
+ import OrgSelect from '../lay-select-org/index.vue';
5
+ import Search from '../lay-search/index.vue';
6
+ // import Notice from '../lay-notice/index.vue';
7
+ import extraIcon from './extraIcon.vue';
8
+ import avatars from '../../../assets/images/avatars.jpg';
9
+ import { transformI18n } from '../../../plugins/i18n';
10
+ import { useRenderIcon } from '../../../components/ReIcon/src/hooks';
11
+ import { useEpThemeStoreHook } from '../../../store/modules/epTheme';
12
+ import { getParentPaths, findRouteByPath } from '../../../router/utils';
13
+ import { useNav } from '../../hooks/useNav';
14
+ import { useTranslationLang } from '../../hooks/useTranslationLang';
15
+ import { usePermissionStoreHook } from '../../../store/modules/permission';
16
+ import globalization from '../../../assets/svg/globalization.svg?component';
17
+ import { kSYSCONFIG } from '../../../contant';
18
+
19
+ const menuRef = ref();
20
+ const { route, locale, translationCh, translationEn } = useTranslationLang(menuRef);
21
+
22
+ const {
23
+ device,
24
+ logout,
25
+ onPanel,
26
+ toggleSideBar,
27
+ resolvePath,
28
+ appHook,
29
+ userInfo,
30
+ getDivStyle,
31
+ avatarsStyle,
32
+ getDropdownItemStyle,
33
+ getDropdownItemClass,
34
+ passwordItems
35
+ } = useNav();
36
+
37
+ const refScrollbar = ref(null);
38
+ const defaultActive = ref(null);
39
+ const record: IRecord = {};
40
+
41
+ const showModal = ref(false);
42
+
43
+ const sysConfig = storageLocal.getItem(kSYSCONFIG) || {};
44
+
45
+ function getDefaultActive(routePath) {
46
+ const wholeMenus = usePermissionStoreHook().wholeMenus;
47
+ // 当前路由的父级路径
48
+ const parentRoutes = getParentPaths(routePath, wholeMenus)[0];
49
+ defaultActive.value = findRouteByPath(parentRoutes, wholeMenus)?.children[0]?.path;
50
+ }
51
+
52
+ onMounted(() => {
53
+ getDefaultActive(route.path);
54
+ });
55
+
56
+ nextTick(() => {
57
+ menuRef.value?.handleResize();
58
+ });
59
+
60
+ watch(
61
+ () => route.path,
62
+ () => {
63
+ getDefaultActive(route.path);
64
+ }
65
+ );
66
+
67
+ const handleResetPwd = (): void => {
68
+ record.id = userInfo['id'];
69
+ showModal.value = true;
70
+ };
71
+
72
+ const handleScroll = e => {
73
+ const wheelDelta = e.wheelDelta || -e.deltaY * 40;
74
+ const scrollbar = refScrollbar.value;
75
+ // scrollbar.wrap$获取到包裹容器的element对象
76
+ scrollbar.setScrollLeft(scrollbar.wrapRef.scrollLeft + wheelDelta);
77
+ };
78
+ </script>
79
+
80
+ <template>
81
+ <div v-if="device !== 'mobile'" class="horizontal-header">
82
+ <div
83
+ :class="classes.container"
84
+ :title="appHook.sidebar.opened ? $t('message.udp.collapse') : $t('message.udp.expand')"
85
+ @click="toggleSideBar"
86
+ >
87
+ <svg
88
+ :fill="useEpThemeStoreHook().fill"
89
+ :class="['hamburger', appHook.sidebar.opened ? 'is-active-hamburger' : '']"
90
+ viewBox="0 0 1024 1024"
91
+ xmlns="http://www.w3.org/2000/svg"
92
+ width="64"
93
+ height="64"
94
+ >
95
+ <path
96
+ d="M408 442h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-8 204c0 4.4 3.6 8 8 8h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56zm504-486H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 632H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM142.4 642.1L298.7 519a8.84 8.84 0 0 0 0-13.9L142.4 381.9c-5.8-4.6-14.4-.5-14.4 6.9v246.3a8.9 8.9 0 0 0 14.4 7z"
97
+ />
98
+ </svg>
99
+ </div>
100
+
101
+ <el-scrollbar ref="refScrollbar" style="max-width: 66%" @wheel.prevent="handleScroll">
102
+ <template #default>
103
+ <el-menu
104
+ ref="menu"
105
+ :default-active="defaultActive"
106
+ :ellipsis="false"
107
+ class="horizontal-header-menu"
108
+ mode="horizontal"
109
+ router
110
+ >
111
+ <el-menu-item
112
+ v-for="route in usePermissionStoreHook().wholeMenus"
113
+ :key="route.path"
114
+ :index="resolvePath(route) || route.redirect"
115
+ >
116
+ <template #title>
117
+ <div v-if="toRaw(route.meta.icon)" :class="['sub-menu-icon', route.meta.icon]">
118
+ <component :is="useRenderIcon(route.meta && toRaw(route.meta.icon))" />
119
+ </div>
120
+ <!-- <span class="select-none">{{ transformI18n(route.meta.title) }}</span>
121
+ <FontIcon
122
+ v-if="route.meta.extraIcon"
123
+ width="30px"
124
+ height="30px"
125
+ style="position: absolute; right: 10px"
126
+ :icon="route.meta.extraIcon"
127
+ :svg="route.meta.extraIcon ? true : false"
128
+ /> -->
129
+ <div :style="getDivStyle">
130
+ <span class="select-none">
131
+ {{ transformI18n(route.meta.title) }}
132
+ </span>
133
+ <extraIcon :extra-icon="route.meta.extraIcon" />
134
+ </div>
135
+ </template>
136
+ </el-menu-item>
137
+ </el-menu>
138
+ </template>
139
+ </el-scrollbar>
140
+ <div class="horizontal-header-right">
141
+ <!-- 业务单元选择 -->
142
+ <OrgSelect v-if="sysConfig['orgTaggle'] === 'Y'" />
143
+ <!-- 菜单搜索 -->
144
+ <Search />
145
+ <!-- 通知 -->
146
+ <!-- <Notice id="header-notice" /> -->
147
+ <!-- 国际化 -->
148
+ <el-dropdown id="header-translation" trigger="click">
149
+ <globalization class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" />
150
+ <template #dropdown>
151
+ <el-dropdown-menu class="translation">
152
+ <el-dropdown-item
153
+ :style="getDropdownItemStyle(locale, 'zh')"
154
+ :class="['dark:text-white!', getDropdownItemClass(locale, 'zh')]"
155
+ @click="translationCh"
156
+ >
157
+ <span v-show="locale === 'zh'" class="check-zh">
158
+ <IconifyIconOffline icon="ri:check-line" />
159
+ </span>
160
+ 简体中文
161
+ </el-dropdown-item>
162
+ <el-dropdown-item
163
+ :style="getDropdownItemStyle(locale, 'en')"
164
+ :class="['dark:text-white!', getDropdownItemClass(locale, 'en')]"
165
+ @click="translationEn"
166
+ >
167
+ <span v-show="locale === 'en'" class="check-en">
168
+ <IconifyIconOffline icon="ri:check-line" />
169
+ </span>
170
+ English
171
+ </el-dropdown-item>
172
+ </el-dropdown-menu>
173
+ </template>
174
+ </el-dropdown>
175
+ <!-- 退出登陆 -->
176
+ <el-dropdown trigger="click">
177
+ <span class="select-none el-dropdown-link navbar-bg-hover">
178
+ <img v-if="avatars" :src="avatars" :style="avatarsStyle" />
179
+ <p class="dark:text-white">{{ userInfo.name }}</p>
180
+ </span>
181
+ <template #dropdown>
182
+ <el-dropdown-menu class="logout">
183
+ <el-dropdown-item @click="handleResetPwd">
184
+ <IconifyIconOffline icon="ri:edit-2-fill" />
185
+ {{ $t('message.udp.passwordReset') }}
186
+ </el-dropdown-item>
187
+ <el-divider style="margin: 3px 0 !important" />
188
+ <el-dropdown-item @click="logout">
189
+ <IconifyIconOffline icon="switch-button" />
190
+ {{ $t('message.udp.logout') }}
191
+ </el-dropdown-item>
192
+ </el-dropdown-menu>
193
+ </template>
194
+ </el-dropdown>
195
+ <span class="el-icon-setting navbar-bg-hover" @click="onPanel">
196
+ <IconifyIconOffline icon="ri:settings-5-fill" />
197
+ </span>
198
+ </div>
199
+
200
+ <ut-modal-form
201
+ v-if="showModal"
202
+ :record="record"
203
+ :items="passwordItems()"
204
+ :width="360"
205
+ :height="240"
206
+ :title="$t('message.udp.passwordReset')"
207
+ data-status="update"
208
+ url="/uums/user/updatePwd"
209
+ method="put"
210
+ @close="showModal = false"
211
+ />
212
+ </div>
213
+ </template>
214
+
215
+ <style module="classes" scoped>
216
+ .container {
217
+ padding: 0 15px;
218
+ }
219
+ </style>
220
+
221
+ <style lang="scss" scoped>
222
+ .hamburger {
223
+ width: 20px;
224
+ height: 20px;
225
+
226
+ &:hover {
227
+ cursor: pointer;
228
+ }
229
+ }
230
+
231
+ .is-active-hamburger {
232
+ transform: rotate(180deg);
233
+ }
234
+
235
+ .translation {
236
+ ::v-deep(.el-dropdown-menu__item) {
237
+ padding: 5px 40px;
238
+ }
239
+
240
+ .check-zh {
241
+ position: absolute;
242
+ left: 20px;
243
+ }
244
+
245
+ .check-en {
246
+ position: absolute;
247
+ left: 20px;
248
+ }
249
+ }
250
+
251
+ .logout {
252
+ max-width: 120px;
253
+
254
+ ::v-deep(.el-dropdown-menu__item) {
255
+ display: inline-flex;
256
+ flex-wrap: wrap;
257
+ min-width: 100%;
258
+ }
259
+ }
260
+ </style>