@utogether/udp-core 1.0.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 (343) hide show
  1. package/build/index.ts +90 -0
  2. package/build/plugins.ts +26 -0
  3. package/dist/403-B1R-4vXw.js +64 -0
  4. package/dist/404-fXPl8csw.js +64 -0
  5. package/dist/500-eI5842YB.js +66 -0
  6. package/dist/AuthorityInfo-CfVH6PaB.js +4 -0
  7. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-DbK-f8jH.js +102 -0
  8. package/dist/AuthorityPanel-BaLMwMgW.js +4 -0
  9. package/dist/AuthorityPanel.vue_vue_type_style_index_0_lang-C_bkqLD9.js +107 -0
  10. package/dist/Company-CYC9Avfz.js +25 -0
  11. package/dist/CompanyPanel-B4MzoqN_.js +206 -0
  12. package/dist/DataSet-DT-rGICv.js +147 -0
  13. package/dist/Department-B4BNSiYx.js +25 -0
  14. package/dist/DepartmentPanel-zJO89L2O.js +224 -0
  15. package/dist/DesignPanel-S8P0J97f.js +4 -0
  16. package/dist/DesignPanel.vue_vue_type_style_index_0_lang-DW-_Vqrr.js +1015 -0
  17. package/dist/DictView-bIS5-rK-.js +95 -0
  18. package/dist/InvOrganization-MuM2jtsG.js +66 -0
  19. package/dist/Org-kXHSjsgJ.js +35 -0
  20. package/dist/Preview-CRyiwUIR.js +48 -0
  21. package/dist/ReportDefine-WZYIx8Sm.js +10 -0
  22. package/dist/ReportDesign-D-7GKgpb.js +165 -0
  23. package/dist/ReportQuery-BIIJny6w.js +75 -0
  24. package/dist/ReportQueryFrom-OoUl7N2O.js +4 -0
  25. package/dist/ReportQueryFrom.vue_vue_type_style_index_0_lang-B878fgj8.js +177 -0
  26. package/dist/ReportTemplate-Cfeq9US-.js +161 -0
  27. package/dist/Role-BwTV2QMH.js +25 -0
  28. package/dist/RoleAssign-De1JjOun.js +26 -0
  29. package/dist/RolePanel-E3RcdByM.js +4 -0
  30. package/dist/RolePanel-pUBXsqCM.js +4 -0
  31. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-B2pQwHb0.js +148 -0
  32. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-CTIad9_Q.js +126 -0
  33. package/dist/ScrollPanel.vue_vue_type_style_index_0_lang-vMR1fBi0.js +100 -0
  34. package/dist/Staff-Czm7A8vI.js +25 -0
  35. package/dist/StaffInfo-DJzvBuxy.js +4 -0
  36. package/dist/StaffInfo.vue_vue_type_style_index_0_lang-DMTL7KCh.js +108 -0
  37. package/dist/StaffPanel-CHk60LEz.js +4 -0
  38. package/dist/StaffPanel.vue_vue_type_script_setup_true_lang-iPKLb5wG.js +114 -0
  39. package/dist/SysUser-BGwbttRn.js +15 -0
  40. package/dist/SysUserPanel-BCbKoLKt.js +4 -0
  41. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-0QUjnhjF.js +289 -0
  42. package/dist/SystemMenu-BkqZSDKl.js +151 -0
  43. package/dist/UserInfo-BsyAcT2d.js +4 -0
  44. package/dist/UserInfo.vue_vue_type_style_index_0_lang-D0-KDxAh.js +158 -0
  45. package/dist/await-to-js.es5-BtRbN2QH.js +10 -0
  46. package/dist/childView-CF83nhxb.js +4 -0
  47. package/dist/childView-CyuLTUqC.js +4 -0
  48. package/dist/childView.vue_vue_type_style_index_0_lang-CNSgGda3.js +187 -0
  49. package/dist/childView.vue_vue_type_style_index_0_lang-Cch4lE-i.js +144 -0
  50. package/dist/code-rule-Bz-gnktN.js +147 -0
  51. package/dist/core.es.js +13 -0
  52. package/dist/core.umd.js +173 -0
  53. package/dist/cron-task-CIifSUdW.js +135 -0
  54. package/dist/frameView-_d2mqjjQ.js +43 -0
  55. package/dist/img/l_img.svg +1 -0
  56. package/dist/img/minicolors.png +0 -0
  57. package/dist/img/v_img.svg +1 -0
  58. package/dist/index-BKIw8tSn.js +9195 -0
  59. package/dist/layoutView-DLKVepB8.js +3317 -0
  60. package/dist/log-in-e7D5Ss1P.js +110 -0
  61. package/dist/log-out--RRncZhN.js +120 -0
  62. package/dist/login-LREiDfFU.js +251 -0
  63. package/dist/login-log-CvVnyGi3.js +68 -0
  64. package/dist/lov-view-DDrIVILB.js +97 -0
  65. package/dist/menuInfo-B1FUV-Sk.js +4 -0
  66. package/dist/menuInfo.vue_vue_type_style_index_0_lang-Cnk3vdtD.js +338 -0
  67. package/dist/pda-app-CRhVGijN.js +2209 -0
  68. package/dist/redirect-DiaNDu8F.js +15 -0
  69. package/dist/resource-BCwx9fEv.js +97 -0
  70. package/dist/su-welcome-189A7N4r.js +526 -0
  71. package/dist/sys-config-BZ3sejow.js +277 -0
  72. package/dist/udp-core.css +9 -0
  73. package/dist/utogether-r08LNiIZ.js +182 -0
  74. package/index.ts +36 -0
  75. package/package.json +16 -0
  76. package/public/img/l_img.svg +1 -0
  77. package/public/img/minicolors.png +0 -0
  78. package/public/img/v_img.svg +1 -0
  79. package/src/App.vue +70 -0
  80. package/src/api/http.ts +50 -0
  81. package/src/api/index.ts +31 -0
  82. package/src/api/mock.ts +20 -0
  83. package/src/api/user.ts +43 -0
  84. package/src/assets/images/avatars.jpg +0 -0
  85. package/src/assets/images/empty.png +0 -0
  86. package/src/assets/images/login.png +0 -0
  87. package/src/assets/images/logo.png +0 -0
  88. package/src/assets/images/mask-text.jpg +0 -0
  89. package/src/assets/images/minicolors.png +0 -0
  90. package/src/assets/images/utogether.png +0 -0
  91. package/src/assets/images/welcome.png +0 -0
  92. package/src/assets/status/403.svg +1 -0
  93. package/src/assets/status/404.svg +1 -0
  94. package/src/assets/status/500.svg +1 -0
  95. package/src/assets/svg/back_top.svg +1 -0
  96. package/src/assets/svg/bg.svg +1 -0
  97. package/src/assets/svg/close.svg +1 -0
  98. package/src/assets/svg/close_all.svg +1 -0
  99. package/src/assets/svg/close_left.svg +1 -0
  100. package/src/assets/svg/close_other.svg +1 -0
  101. package/src/assets/svg/close_right.svg +1 -0
  102. package/src/assets/svg/dark.svg +1 -0
  103. package/src/assets/svg/day.svg +1 -0
  104. package/src/assets/svg/enter_outlined.svg +1 -0
  105. package/src/assets/svg/exit_screen.svg +1 -0
  106. package/src/assets/svg/full_screen.svg +1 -0
  107. package/src/assets/svg/globalization.svg +1 -0
  108. package/src/assets/svg/loading.svg +17 -0
  109. package/src/assets/svg/mdi_keyboard_esc.svg +1 -0
  110. package/src/assets/svg/refresh.svg +1 -0
  111. package/src/assets/svg/system.svg +1 -0
  112. package/src/components/ReCountTo/README.md +2 -0
  113. package/src/components/ReCountTo/index.ts +18 -0
  114. package/src/components/ReCountTo/src/normal/index.tsx +165 -0
  115. package/src/components/ReCountTo/src/normal/props.ts +37 -0
  116. package/src/components/ReCountTo/src/rebound/index.tsx +67 -0
  117. package/src/components/ReCountTo/src/rebound/props.ts +14 -0
  118. package/src/components/ReCountTo/src/rebound/rebound.css +77 -0
  119. package/src/components/ReCropper/index.ts +14 -0
  120. package/src/components/ReCropper/src/index.tsx +141 -0
  121. package/src/components/ReFlicker/index.css +39 -0
  122. package/src/components/ReFlicker/index.ts +50 -0
  123. package/src/components/ReFlop/index.ts +14 -0
  124. package/src/components/ReFlop/src/Filpper.tsx +99 -0
  125. package/src/components/ReFlop/src/filpper.css +184 -0
  126. package/src/components/ReFlop/src/index.vue +126 -0
  127. package/src/components/ReFlowChart/index.ts +24 -0
  128. package/src/components/ReFlowChart/src/Control.vue +139 -0
  129. package/src/components/ReFlowChart/src/DataDialog.vue +12 -0
  130. package/src/components/ReFlowChart/src/NodePanel.vue +151 -0
  131. package/src/components/ReFlowChart/src/adpterForTurbo.ts +160 -0
  132. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.css +49 -0
  133. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.eot +0 -0
  134. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.js +61 -0
  135. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.json +58 -0
  136. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.svg +47 -0
  137. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.ttf +0 -0
  138. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.woff +0 -0
  139. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.woff2 +0 -0
  140. package/src/components/ReFlowChart/src/config.ts +62 -0
  141. package/src/components/ReIcon/index.ts +12 -0
  142. package/src/components/ReIcon/src/Icon.vue +81 -0
  143. package/src/components/ReIcon/src/hooks.ts +63 -0
  144. package/src/components/ReIcon/src/iconfont.ts +45 -0
  145. package/src/components/ReIcon/src/iconifyIconOffline.ts +36 -0
  146. package/src/components/ReIcon/src/iconifyIconOnline.ts +28 -0
  147. package/src/components/ReIcon/src/offlineIcon.ts +64 -0
  148. package/src/components/ReIcon/src/types.ts +20 -0
  149. package/src/components/ReSplitPane/index.css +49 -0
  150. package/src/components/ReSplitPane/index.tsx +119 -0
  151. package/src/components/ReSplitPane/resizer.css +45 -0
  152. package/src/components/ReSplitPane/resizer.tsx +30 -0
  153. package/src/components/SuCharts/index.ts +36 -0
  154. package/src/components/SuCharts/src/EchartBar.vue +134 -0
  155. package/src/components/SuCharts/src/UserInfo.vue +78 -0
  156. package/src/components/SuCharts/src/echart-line.vue +85 -0
  157. package/src/components/SuCharts/src/echart-pie.vue +95 -0
  158. package/src/components/SuCommon/card/components/Card.vue +148 -0
  159. package/src/components/SuCommon/card/components/DialogForm.vue +127 -0
  160. package/src/components/SuCommon/card/index.vue +142 -0
  161. package/src/components/SuCommon/icon-select/index.vue +241 -0
  162. package/src/components/SuCommon/table/index.vue +208 -0
  163. package/src/components/SuCommon/utils/index.ts +103 -0
  164. package/src/components/SuCommon/utils/slot.tsx +50 -0
  165. package/src/components/SuFloatButton/index.vue +159 -0
  166. package/src/components/SuQrcode/index.ts +14 -0
  167. package/src/components/SuQrcode/src/index.scss +9 -0
  168. package/src/components/SuQrcode/src/index.tsx +236 -0
  169. package/src/components/SuScrollTree/ScrollPanel.vue +175 -0
  170. package/src/components/SuTable/SuTable.vue +334 -0
  171. package/src/components/SuTypeit/index.ts +51 -0
  172. package/src/config/index.ts +35 -0
  173. package/src/contant/index.ts +20 -0
  174. package/src/directives/elResizeDetector/index.ts +33 -0
  175. package/src/directives/index.ts +11 -0
  176. package/src/directives/permission/index.ts +29 -0
  177. package/src/layout/components/lay-chrome/index.vue +30 -0
  178. package/src/layout/components/lay-content/index.vue +143 -0
  179. package/src/layout/components/lay-navbar/index.vue +237 -0
  180. package/src/layout/components/lay-notice/data.ts +59 -0
  181. package/src/layout/components/lay-notice/index.vue +83 -0
  182. package/src/layout/components/lay-notice/noticeItem.vue +160 -0
  183. package/src/layout/components/lay-notice/noticeList.vue +19 -0
  184. package/src/layout/components/lay-panel/index.vue +150 -0
  185. package/src/layout/components/lay-search/components/SearchFooter.vue +67 -0
  186. package/src/layout/components/lay-search/components/SearchModal.vue +189 -0
  187. package/src/layout/components/lay-search/components/SearchResult.vue +132 -0
  188. package/src/layout/components/lay-search/components/index.ts +10 -0
  189. package/src/layout/components/lay-search/index.vue +25 -0
  190. package/src/layout/components/lay-select-org/index.vue +69 -0
  191. package/src/layout/components/lay-setting/index.vue +510 -0
  192. package/src/layout/components/lay-sidebar/breadCrumb.vue +131 -0
  193. package/src/layout/components/lay-sidebar/extraIcon.vue +25 -0
  194. package/src/layout/components/lay-sidebar/hamBurger.vue +72 -0
  195. package/src/layout/components/lay-sidebar/horizontal.vue +191 -0
  196. package/src/layout/components/lay-sidebar/mixNav.vue +258 -0
  197. package/src/layout/components/lay-sidebar/sidebar-logo.vue +98 -0
  198. package/src/layout/components/lay-sidebar/sidebarItem.vue +205 -0
  199. package/src/layout/components/lay-sidebar/vertical.vue +94 -0
  200. package/src/layout/components/lay-tag/index.scss +375 -0
  201. package/src/layout/components/lay-tag/index.vue +625 -0
  202. package/src/layout/frameView.vue +71 -0
  203. package/src/layout/hooks/useBoolean.ts +33 -0
  204. package/src/layout/hooks/useDataThemeChange.ts +142 -0
  205. package/src/layout/hooks/useLayout.ts +65 -0
  206. package/src/layout/hooks/useNav.ts +173 -0
  207. package/src/layout/hooks/useTag.ts +233 -0
  208. package/src/layout/hooks/useTranslationLang.ts +51 -0
  209. package/src/layout/layoutView.vue +215 -0
  210. package/src/layout/redirect.vue +30 -0
  211. package/src/layout/routerView/parent.vue +23 -0
  212. package/src/layout/types.ts +92 -0
  213. package/src/main.ts +108 -0
  214. package/src/plugins/echarts/index.ts +58 -0
  215. package/src/plugins/echarts/theme.json +394 -0
  216. package/src/plugins/i18n/en.ts +289 -0
  217. package/src/plugins/i18n/index.ts +76 -0
  218. package/src/plugins/i18n/module/u-report.ts +64 -0
  219. package/src/plugins/i18n/module/u-workflow.ts +71 -0
  220. package/src/plugins/i18n/module/umsg.ts +28 -0
  221. package/src/plugins/i18n/zh.ts +337 -0
  222. package/src/plugins/vxe-table/index.ts +46 -0
  223. package/src/plugins/vxe-table/render.tsx +397 -0
  224. package/src/router/createComponent.tsx +25 -0
  225. package/src/router/index.ts +183 -0
  226. package/src/router/modules/error.ts +32 -0
  227. package/src/router/modules/home.ts +32 -0
  228. package/src/router/modules/nested.ts +93 -0
  229. package/src/router/modules/remaining.ts +83 -0
  230. package/src/router/modules/tabs.ts +55 -0
  231. package/src/router/utils.ts +377 -0
  232. package/src/store/index.ts +9 -0
  233. package/src/store/modules/app.ts +69 -0
  234. package/src/store/modules/epTheme.ts +49 -0
  235. package/src/store/modules/multiTags.ts +109 -0
  236. package/src/store/modules/permission.ts +103 -0
  237. package/src/store/modules/settings.ts +40 -0
  238. package/src/store/modules/system.ts +180 -0
  239. package/src/store/modules/types.ts +49 -0
  240. package/src/style/button.scss +78 -0
  241. package/src/style/clear-mixin.scss +28 -0
  242. package/src/style/dark.scss +218 -0
  243. package/src/style/element-plus.scss +206 -0
  244. package/src/style/index.scss +76 -0
  245. package/src/style/login.css +336 -0
  246. package/src/style/login2.css +106 -0
  247. package/src/style/print-lock.css +375 -0
  248. package/src/style/reset.scss +272 -0
  249. package/src/style/sidebar.scss +770 -0
  250. package/src/style/suprint.css +985 -0
  251. package/src/style/tailwind.css +68 -0
  252. package/src/style/theme.scss +143 -0
  253. package/src/style/transition.scss +42 -0
  254. package/src/style/vxetable.scss +256 -0
  255. package/src/utils/authority/index.ts +29 -0
  256. package/src/utils/browers.ts +59 -0
  257. package/src/utils/dataFormat/index.ts +223 -0
  258. package/src/utils/http/index.ts +297 -0
  259. package/src/utils/http/types.d.ts +46 -0
  260. package/src/utils/index.ts +47 -0
  261. package/src/utils/lifecycle.ts +20 -0
  262. package/src/utils/mitt.ts +19 -0
  263. package/src/utils/propTypes.ts +47 -0
  264. package/src/utils/storage/index.ts +51 -0
  265. package/src/views/components/contextmenu/basic.vue +74 -0
  266. package/src/views/components/contextmenu/context-menu.vue +40 -0
  267. package/src/views/components/contextmenu/menuDynamic.vue +99 -0
  268. package/src/views/components/contextmenu/menuGroup.vue +71 -0
  269. package/src/views/components/count-to/index.vue +43 -0
  270. package/src/views/components/cropping/index.vue +59 -0
  271. package/src/views/components/cropping/picture.jpeg +0 -0
  272. package/src/views/components/split-pane/index.vue +82 -0
  273. package/src/views/components/video/index.vue +57 -0
  274. package/src/views/error/403.vue +50 -0
  275. package/src/views/error/404.vue +50 -0
  276. package/src/views/error/500.vue +52 -0
  277. package/src/views/login/login-view.vue +314 -0
  278. package/src/views/login/utils/motion.ts +47 -0
  279. package/src/views/login/utils/rule.ts +70 -0
  280. package/src/views/login/utils/verifyCode.ts +52 -0
  281. package/src/views/organization/company/Company.vue +56 -0
  282. package/src/views/organization/company/CompanyPanel.vue +259 -0
  283. package/src/views/organization/department/Department.vue +58 -0
  284. package/src/views/organization/department/DepartmentPanel.vue +283 -0
  285. package/src/views/organization/inv-org/InvOrganization.vue +53 -0
  286. package/src/views/organization/org/Org.vue +43 -0
  287. package/src/views/organization/staff/Staff.vue +58 -0
  288. package/src/views/organization/staff/StaffInfo.vue +163 -0
  289. package/src/views/organization/staff/StaffPanel.vue +144 -0
  290. package/src/views/system/cron/cron-task.vue +157 -0
  291. package/src/views/system/menu/AuthorityPanel.vue +140 -0
  292. package/src/views/system/menu/SystemMenu.vue +191 -0
  293. package/src/views/system/menu/menuInfo.vue +368 -0
  294. package/src/views/system/role/AuthorityInfo.vue +147 -0
  295. package/src/views/system/role/Role.vue +57 -0
  296. package/src/views/system/role/RolePanel.vue +191 -0
  297. package/src/views/system/role/UserInfo.vue +193 -0
  298. package/src/views/system/role-assign/RoleAssign.vue +57 -0
  299. package/src/views/system/role-assign/RolePanel.vue +136 -0
  300. package/src/views/system/sys/sys-config.vue +291 -0
  301. package/src/views/system/sysUser/SysUser.vue +45 -0
  302. package/src/views/system/sysUser/SysUserPanel.vue +278 -0
  303. package/src/views/uapp/pda/pda-app.vue +176 -0
  304. package/src/views/udev/coderule/code-rule.vue +121 -0
  305. package/src/views/udev/dict/DictView.vue +106 -0
  306. package/src/views/udev/dict/childView.vue +222 -0
  307. package/src/views/udev/lov/childView.vue +180 -0
  308. package/src/views/udev/lov/lov-view.vue +91 -0
  309. package/src/views/ufile/aggregation/File.vue +87 -0
  310. package/src/views/ufile/file/water-mark.vue +103 -0
  311. package/src/views/uhome/components/menu-favorite.vue +331 -0
  312. package/src/views/uhome/su-welcome.vue +339 -0
  313. package/src/views/ulogin/login.vue +316 -0
  314. package/src/views/umsg/monitor/msg-monitor.vue +36 -0
  315. package/src/views/umsg/msg/TemplateContent.vue +103 -0
  316. package/src/views/umsg/msg/msg-template.vue +66 -0
  317. package/src/views/umsg/send/childView.vue +142 -0
  318. package/src/views/umsg/send/msg-send.vue +95 -0
  319. package/src/views/upms/interface/log-in.vue +106 -0
  320. package/src/views/upms/interface/log-out.vue +107 -0
  321. package/src/views/upms/user/login-log.vue +60 -0
  322. package/src/views/urpt/dataSet/DataSet.vue +139 -0
  323. package/src/views/urpt/design/DesignPanel.vue +526 -0
  324. package/src/views/urpt/design/Preview.vue +65 -0
  325. package/src/views/urpt/design/ReportDesign.vue +249 -0
  326. package/src/views/urpt/design/bg.png +0 -0
  327. package/src/views/urpt/design/panel.ts +841 -0
  328. package/src/views/urpt/design/print-data.ts +59 -0
  329. package/src/views/urpt/query/ReportQuery.vue +122 -0
  330. package/src/views/urpt/query/ReportQueryFrom.vue +252 -0
  331. package/src/views/urpt/report-request/ReportDefine.vue +10 -0
  332. package/src/views/urpt/static-resource/resource.vue +116 -0
  333. package/src/views/urpt/template/ReportTemplate.vue +198 -0
  334. package/tsconfig.json +30 -0
  335. package/types/env.d.ts +1 -0
  336. package/types/global-components.d.ts +12 -0
  337. package/types/global.d.ts +236 -0
  338. package/types/image.d.ts +7 -0
  339. package/types/index.d.ts +73 -0
  340. package/types/router.d.ts +107 -0
  341. package/types/shims-tsx.d.ts +22 -0
  342. package/types/shims-vue.d.ts +20 -0
  343. package/vite.config.ts +73 -0
@@ -0,0 +1,237 @@
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2021-11-17 16:02:30
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-04-16 16:20:09
6
+ * @Description: file content
7
+ -->
8
+ <template>
9
+ <div class="system-navbar bg-[#fff] shadow-sm shadow-[rgba(0, 21, 41, 0.08)] dark:shadow-[#0d0d0d]">
10
+ <Hamburger
11
+ v-if="layout !== 'mix'"
12
+ :is-active="appHook.sidebar.opened"
13
+ class="hamburger-container"
14
+ @toggleClick="toggleSideBar"
15
+ />
16
+
17
+ <Breadcrumb v-if="layout !== 'mix'" class="breadcrumb-container" />
18
+
19
+ <mixNav v-if="layout === 'mix'" />
20
+
21
+ <div v-if="layout === 'vertical'" class="vertical-header-right">
22
+ <!-- 业务单元选择 -->
23
+ <OrgSelect />
24
+ <!-- 菜单搜索 -->
25
+ <Search />
26
+ <!-- 通知 -->
27
+ <!-- <Notice id="header-notice" /> -->
28
+ <!-- 国际化 -->
29
+ <el-dropdown id="header-translation" trigge·r="click">
30
+ <globalization
31
+ class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden"
32
+ />
33
+ <template #dropdown>
34
+ <el-dropdown-menu class="translation">
35
+ <el-dropdown-item
36
+ :style="getDropdownItemStyle(locale, 'zh')"
37
+ :class="['dark:text-white!', getDropdownItemClass(locale, 'zh')]"
38
+ @click="translationCh"
39
+ >
40
+ <IconifyIconOffline v-show="locale === 'zh'" class="check-zh" icon="ri:check-line" />
41
+ 简体中文
42
+ </el-dropdown-item>
43
+ <el-dropdown-item
44
+ :style="getDropdownItemStyle(locale, 'en')"
45
+ :class="['dark:text-white!', getDropdownItemClass(locale, 'en')]"
46
+ @click="translationEn"
47
+ >
48
+ <span v-show="locale === 'en'" class="check-en">
49
+ <IconifyIconOffline icon="ri:check-line" />
50
+ </span>
51
+ English
52
+ </el-dropdown-item>
53
+ </el-dropdown-menu>
54
+ </template>
55
+ </el-dropdown>
56
+ <!-- 退出登陆 -->
57
+ <el-dropdown trigger="click">
58
+ <span class="select-none el-dropdown-link navbar-bg-hover">
59
+ <img v-if="avatars" :src="avatars" :style="avatarsStyle" />
60
+ <p class="dark:text-white user-name">
61
+ {{ userInfo?.name }}
62
+ </p>
63
+ </span>
64
+ <template #dropdown>
65
+ <el-dropdown-menu class="user-dropdown">
66
+ <el-dropdown-item @click="handleResetPwd">
67
+ <IconifyIconOffline icon="ri:edit-2-fill" />
68
+ {{ $t('message.udp.passwordReset') }}</el-dropdown-item
69
+ >
70
+ <el-divider style="margin: 3px 0 !important" />
71
+ <el-dropdown-item @click="logout">
72
+ <IconifyIconOffline icon="switch-button" />
73
+ {{ $t('message.udp.logout') }}
74
+ </el-dropdown-item>
75
+ </el-dropdown-menu>
76
+ </template>
77
+ </el-dropdown>
78
+ <span class="el-icon-setting navbar-bg-hover" @click="onPanel">
79
+ <IconifyIconOffline icon="ri:settings-5-fill" />
80
+ </span>
81
+ </div>
82
+ <ut-modal-form
83
+ v-if="showModal"
84
+ :record="record"
85
+ :items="passwordItems()"
86
+ :width="360"
87
+ :height="240"
88
+ data-status="update"
89
+ :title="$t('message.udp.passwordReset')"
90
+ url="/uums/user/updatePwd"
91
+ method="put"
92
+ @close="showModal = false"
93
+ />
94
+ </div>
95
+ </template>
96
+ <script lang="ts">
97
+ export default { name: 'NavBar' };
98
+ </script>
99
+ <script setup lang="ts">
100
+ import { ref } from 'vue';
101
+ // import { useRouter } from 'vue-router';
102
+ import Hamburger from '../lay-sidebar/hamBurger.vue';
103
+ import Breadcrumb from '../lay-sidebar/breadCrumb.vue';
104
+ // import Notice from './lay-notice/index.vue';
105
+ import { useNav } from '../../hooks/useNav';
106
+ import Search from '../lay-search/index.vue';
107
+ import mixNav from '../lay-sidebar/mixNav.vue';
108
+ import OrgSelect from '../lay-select-org/index.vue';
109
+ import { useTranslationLang } from '../../hooks/useTranslationLang';
110
+ import globalization from '../../../assets/svg/globalization.svg?component';
111
+ import avatars from '../../../assets/images/avatars.jpg';
112
+
113
+ // const router = useRouter();
114
+ // const route = useRoute();
115
+ const showModal = ref(false);
116
+
117
+ const {
118
+ layout,
119
+ logout,
120
+ onPanel,
121
+ toggleSideBar,
122
+ appHook,
123
+ userInfo,
124
+ avatarsStyle,
125
+ setDocumentTitle,
126
+ getDropdownItemStyle,
127
+ getDropdownItemClass,
128
+ passwordItems
129
+ } = useNav();
130
+
131
+ const { locale, translationCh, translationEn } = useTranslationLang();
132
+
133
+ const record: IRecord = {};
134
+ /**
135
+ * @description: 重置密码
136
+ */
137
+ const handleResetPwd = (): void => {
138
+ record.id = userInfo.value.id;
139
+ showModal.value = true;
140
+ };
141
+
142
+ setDocumentTitle();
143
+ </script>
144
+
145
+ <style lang="scss" scoped>
146
+ .system-navbar {
147
+ width: 100%;
148
+ height: 48px;
149
+ overflow: hidden;
150
+
151
+ .hamburger-container {
152
+ float: left;
153
+ height: 100%;
154
+ line-height: 48px;
155
+ cursor: pointer;
156
+ }
157
+
158
+ .vertical-header-right {
159
+ display: flex;
160
+ align-items: center;
161
+ justify-content: flex-end;
162
+ min-width: 280px;
163
+ height: 48px;
164
+ color: #000000d9;
165
+
166
+ .el-dropdown-link {
167
+ display: flex;
168
+ align-items: center;
169
+ justify-content: space-around;
170
+ width: 100px;
171
+ height: 48px;
172
+ padding: 10px 6px;
173
+ color: #000000d9;
174
+ cursor: pointer;
175
+
176
+ p {
177
+ font-size: 14px;
178
+ font-weight: 600;
179
+ }
180
+
181
+ img {
182
+ width: 22px;
183
+ height: 22px;
184
+ border-radius: 50%;
185
+ }
186
+ }
187
+
188
+ .el-icon-setting {
189
+ display: flex;
190
+ align-items: center;
191
+ width: 38px;
192
+ height: 48px;
193
+ padding: 12px;
194
+ cursor: pointer;
195
+ }
196
+ }
197
+
198
+ .breadcrumb-container {
199
+ float: left;
200
+ }
201
+
202
+ /* stylelint-disable */
203
+ .user-name {
204
+ -webkit-box-orient: vertical;
205
+ display: -webkit-box;
206
+ overflow: hidden;
207
+ -webkit-line-clamp: 2;
208
+ }
209
+ /* stylelint-enable */
210
+ }
211
+
212
+ .translation {
213
+ ::v-deep(.el-dropdown-menu__item) {
214
+ padding: 5px 40px;
215
+ }
216
+
217
+ .check-zh {
218
+ position: absolute;
219
+ left: 20px;
220
+ }
221
+
222
+ .check-en {
223
+ position: absolute;
224
+ left: 20px;
225
+ }
226
+ }
227
+
228
+ .logout {
229
+ max-width: 120px;
230
+
231
+ ::v-deep(.el-dropdown-menu__item) {
232
+ display: inline-flex;
233
+ flex-wrap: wrap;
234
+ min-width: 100%;
235
+ }
236
+ }
237
+ </style>
@@ -0,0 +1,59 @@
1
+ export interface ListItem {
2
+ avatar: string;
3
+ title: string;
4
+ datetime: string;
5
+ type: string;
6
+ description: string;
7
+ status?: '' | 'success' | 'warning' | 'info' | 'danger';
8
+ extra?: string;
9
+ }
10
+
11
+ export interface TabItem {
12
+ key: string;
13
+ name: string;
14
+ list: ListItem[];
15
+ }
16
+
17
+ export const noticesData: TabItem[] = [
18
+ {
19
+ key: '1',
20
+ name: '通知',
21
+ list: [
22
+ {
23
+ avatar: 'https://gw.alipayobjects.com/zos/rmsportal/ThXAXghbEsBCCSDihZxY.png',
24
+ title: '你收到了 12 份新周报',
25
+ datetime: '一年前',
26
+ description: '',
27
+ type: '1'
28
+ }
29
+ ]
30
+ },
31
+ {
32
+ key: '2',
33
+ name: '消息',
34
+ list: [
35
+ {
36
+ avatar: 'https://gw.alipayobjects.com/zos/rmsportal/fcHMVNCjPOsbUGdEduuv.jpeg',
37
+ title: '李白 评论了你',
38
+ description: '长风破浪会有时,直挂云帆济沧海',
39
+ datetime: '一年前',
40
+ type: '2'
41
+ }
42
+ ]
43
+ },
44
+ {
45
+ key: '3',
46
+ name: '代办',
47
+ list: [
48
+ {
49
+ avatar: '',
50
+ title: '任务名称',
51
+ description: '任务需要在 2021-11-16 20:00 前启动',
52
+ datetime: '',
53
+ extra: '未开始',
54
+ status: 'info',
55
+ type: '3'
56
+ }
57
+ ]
58
+ }
59
+ ];
@@ -0,0 +1,83 @@
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2022-05-24 11:26:59
4
+ * @LastEditors: wei.li
5
+ * @LastEditTime: 2022-08-08 11:27:55
6
+ * @Description: file content
7
+ -->
8
+ <script lang="ts">
9
+ export default { name: 'LayoutNotice' };
10
+ </script>
11
+ <script setup lang="ts">
12
+ import { ref } from 'vue';
13
+ import { noticesData } from './data';
14
+ import NoticeList from './noticeList.vue';
15
+
16
+ const noticesNum = ref(0);
17
+ const notices = ref(noticesData);
18
+ const activeKey = ref(noticesData[0].key);
19
+
20
+ notices.value.map(v => (noticesNum.value += v.list.length));
21
+ </script>
22
+
23
+ <template>
24
+ <el-dropdown trigger="click" placement="bottom-end">
25
+ <span class="dropdown-badge navbar-bg-hover select-none">
26
+ <el-badge :value="noticesNum" :max="99">
27
+ <span class="header-notice-icon">
28
+ <IconifyIconOffline icon="bell" />
29
+ </span>
30
+ </el-badge>
31
+ </span>
32
+ <template #dropdown>
33
+ <el-dropdown-menu>
34
+ <el-tabs v-model="activeKey" :stretch="true" class="dropdown-tabs">
35
+ <template v-for="item in notices" :key="item.key">
36
+ <el-tab-pane :label="`${item.name}(${item.list.length})`" :name="`${item.key}`">
37
+ <el-scrollbar max-height="330px">
38
+ <div class="noticeList-container">
39
+ <NoticeList :list="item.list" />
40
+ </div>
41
+ </el-scrollbar>
42
+ </el-tab-pane>
43
+ </template>
44
+ </el-tabs>
45
+ </el-dropdown-menu>
46
+ </template>
47
+ </el-dropdown>
48
+ </template>
49
+
50
+ <style lang="scss" scoped>
51
+ .dropdown-badge {
52
+ display: flex;
53
+ align-items: center;
54
+ justify-content: center;
55
+ width: 60px;
56
+ height: 48px;
57
+ cursor: pointer;
58
+
59
+ .header-notice-icon {
60
+ font-size: 18px;
61
+ }
62
+ }
63
+
64
+ .dropdown-tabs {
65
+ width: 330px;
66
+
67
+ .noticeList-container {
68
+ padding: 15px 24px 0;
69
+ }
70
+
71
+ :deep(.el-tabs__header) {
72
+ margin: 0;
73
+ }
74
+
75
+ :deep(.el-tabs__nav-wrap)::after {
76
+ height: 1px;
77
+ }
78
+
79
+ :deep(.el-tabs__nav-wrap) {
80
+ padding: 0 36px;
81
+ }
82
+ }
83
+ </style>
@@ -0,0 +1,160 @@
1
+ <script setup lang="ts">
2
+ import { ListItem } from './data';
3
+ import { ref, PropType, nextTick } from 'vue';
4
+
5
+ const props = defineProps({
6
+ noticeItem: {
7
+ type: Object as PropType<ListItem>,
8
+ default: () => {}
9
+ }
10
+ });
11
+
12
+ const titleRef = ref(null);
13
+ const descriptionRef = ref(null);
14
+ const titleTooltip = ref(false);
15
+ const descriptionTooltip = ref(false);
16
+
17
+ function hoverTitle() {
18
+ nextTick(() => {
19
+ titleRef.value?.scrollWidth > titleRef.value?.clientWidth
20
+ ? (titleTooltip.value = true)
21
+ : (titleTooltip.value = false);
22
+ });
23
+ }
24
+
25
+ function hoverDescription(event, description) {
26
+ // currentWidth 为文本在页面中所占的宽度,创建标签,加入到页面,获取currentWidth ,最后在移除
27
+ const tempTag = document.createElement('span');
28
+ tempTag.innerText = description;
29
+ tempTag.className = 'getDescriptionWidth';
30
+ document.querySelector('body').appendChild(tempTag);
31
+ const currentWidth = (document.querySelector('.getDescriptionWidth') as HTMLSpanElement).offsetWidth;
32
+ document.querySelector('.getDescriptionWidth').remove();
33
+
34
+ // cellWidth为容器的宽度
35
+ const cellWidth = event.target.offsetWidth;
36
+
37
+ // 当文本宽度大于容器宽度两倍时,代表文本显示超过两行
38
+ currentWidth > 2 * cellWidth ? (descriptionTooltip.value = true) : (descriptionTooltip.value = false);
39
+ }
40
+ </script>
41
+
42
+ <template>
43
+ <div
44
+ class="notice-container border-0 border-b-[1px] border-solid border-[#f0f0f0] dark:border-[#303030]"
45
+ >
46
+ <el-avatar
47
+ v-if="props.noticeItem.avatar"
48
+ :size="30"
49
+ :src="props.noticeItem.avatar"
50
+ class="notice-container-avatar"
51
+ />
52
+ <div class="notice-container-text">
53
+ <div class="notice-text-title text-[#000000d9] dark:text-white">
54
+ <el-tooltip
55
+ popper-class="notice-title-popper"
56
+ :disabled="!titleTooltip"
57
+ :content="props.noticeItem.title"
58
+ placement="top-start"
59
+ >
60
+ <div ref="titleRef" class="notice-title-content" @mouseover="hoverTitle">
61
+ {{ props.noticeItem.title }}
62
+ </div>
63
+ </el-tooltip>
64
+ <el-tag
65
+ v-if="props.noticeItem?.extra"
66
+ :type="props.noticeItem?.status"
67
+ size="small"
68
+ class="notice-title-extra"
69
+ >{{ props.noticeItem?.extra }}
70
+ </el-tag>
71
+ </div>
72
+
73
+ <el-tooltip
74
+ popper-class="notice-title-popper"
75
+ :disabled="!descriptionTooltip"
76
+ :content="props.noticeItem.description"
77
+ placement="top-start"
78
+ >
79
+ <div
80
+ ref="descriptionRef"
81
+ class="notice-text-description"
82
+ @mouseover="hoverDescription($event, props.noticeItem.description)"
83
+ >
84
+ {{ props.noticeItem.description }}
85
+ </div>
86
+ </el-tooltip>
87
+ <div class="notice-text-datetime text-[#00000073] dark:text-white">
88
+ {{ props.noticeItem.datetime }}
89
+ </div>
90
+ </div>
91
+ </div>
92
+ </template>
93
+
94
+ <style>
95
+ .notice-title-popper {
96
+ max-width: 238px;
97
+ }
98
+ </style>
99
+ <style scoped lang="scss">
100
+ .notice-container {
101
+ display: flex;
102
+ align-items: flex-start;
103
+ justify-content: space-between;
104
+ padding: 12px 0;
105
+ // border-bottom: 1px solid #f0f0f0;
106
+
107
+ .notice-container-avatar {
108
+ margin-right: 16px;
109
+ background: #fff;
110
+ }
111
+
112
+ .notice-container-text {
113
+ display: flex;
114
+ flex: 1;
115
+ flex-direction: column;
116
+ justify-content: space-between;
117
+
118
+ .notice-text-title {
119
+ display: flex;
120
+ margin-bottom: 8px;
121
+ font-size: 14px;
122
+ font-weight: 400;
123
+ line-height: 1.5715;
124
+ cursor: pointer;
125
+
126
+ .notice-title-content {
127
+ flex: 1;
128
+ width: 200px;
129
+ overflow: hidden;
130
+ text-overflow: ellipsis;
131
+ white-space: nowrap;
132
+ }
133
+
134
+ .notice-title-extra {
135
+ float: right;
136
+ margin-top: -1.5px;
137
+ font-weight: 400;
138
+ }
139
+ }
140
+
141
+ .notice-text-description,
142
+ .notice-text-datetime {
143
+ font-size: 12px;
144
+ line-height: 1.5715;
145
+ }
146
+
147
+ .notice-text-description {
148
+ display: box;
149
+ overflow: hidden;
150
+ text-overflow: ellipsis;
151
+ -webkit-line-clamp: 2;
152
+ -webkit-box-orient: vertical;
153
+ }
154
+
155
+ .notice-text-datetime {
156
+ margin-top: 4px;
157
+ }
158
+ }
159
+ }
160
+ </style>
@@ -0,0 +1,19 @@
1
+ <script setup lang="ts">
2
+ import { PropType } from 'vue';
3
+ import NoticeItem from './noticeItem.vue';
4
+ import { ListItem } from './data';
5
+
6
+ const props = defineProps({
7
+ list: {
8
+ type: Array as PropType<Array<ListItem>>,
9
+ default: () => []
10
+ }
11
+ });
12
+ </script>
13
+
14
+ <template>
15
+ <div v-if="props.list.length">
16
+ <NoticeItem v-for="(item, index) in props.list" :key="index" :notice-item="item" />
17
+ </div>
18
+ <el-empty v-else :description="$t('message.emptyData')" />
19
+ </template>
@@ -0,0 +1,150 @@
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2021-12-23 17:33:20
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-04-16 15:54:13
6
+ * @Description: 个性化设置页面
7
+ -->
8
+ <script setup lang="ts">
9
+ import { ref, computed, onMounted, onBeforeUnmount } from 'vue';
10
+ import { useDataThemeChange } from '../../hooks/useDataThemeChange';
11
+ import { onClickOutside } from '@vueuse/core';
12
+ import { emitter } from '../../../utils/mitt';
13
+
14
+ const target = ref(null);
15
+ const show = ref<Boolean>(false);
16
+
17
+ const iconClass = computed(() => {
18
+ return [
19
+ 'w-[22px]',
20
+ 'h-[22px]',
21
+ 'flex',
22
+ 'justify-center',
23
+ 'items-center',
24
+ 'outline-hidden',
25
+ 'rounded-[4px]',
26
+ 'cursor-pointer',
27
+ 'transition-colors',
28
+ 'hover:bg-[#0000000f]',
29
+ 'dark:hover:bg-[#ffffff1f]',
30
+ 'dark:hover:text-[#ffffffd9]'
31
+ ];
32
+ });
33
+
34
+ const { onReset } = useDataThemeChange();
35
+ onClickOutside(target, (event: any) => {
36
+ if (event.clientX > target.value.offsetLeft) return;
37
+ show.value = false;
38
+ });
39
+
40
+ onMounted(() => {
41
+ emitter.on('openPanel', () => {
42
+ show.value = true;
43
+ });
44
+ });
45
+
46
+ onBeforeUnmount(() => {
47
+ // 解绑`openPanel`公共事件,防止多次触发
48
+ emitter.off('openPanel');
49
+ });
50
+ </script>
51
+
52
+ <template>
53
+ <div :class="{ show }">
54
+ <div class="right-panel-background" />
55
+ <div ref="target" class="right-panel bg-bg_color">
56
+ <div
57
+ class="project-configuration border-0 border-b-[1px] border-solid border-[var(--pure-border-color)]"
58
+ >
59
+ <h4 class="dark:text-white">{{ $t('message.tip.projectConfig') }}</h4>
60
+ <span
61
+ v-tippy="{
62
+ content: $t('message.tip.closeConfig'),
63
+ placement: 'bottom-start',
64
+ zIndex: 41000
65
+ }"
66
+ :class="iconClass"
67
+ >
68
+ <IconifyIconOffline
69
+ class="dark:text-white"
70
+ width="18px"
71
+ height="18px"
72
+ icon="ri:close-line"
73
+ @click="show = !show"
74
+ />
75
+ </span>
76
+ </div>
77
+ <el-scrollbar>
78
+ <slot />
79
+ </el-scrollbar>
80
+
81
+ <div
82
+ class="flex justify-end p-3 border-0 border-t-[1px] border-solid border-[var(--pure-border-color)]"
83
+ >
84
+ <el-button
85
+ v-tippy="{
86
+ content: $t('message.tip.toLogin'),
87
+ placement: 'left-start',
88
+ zIndex: 41000
89
+ }"
90
+ type="danger"
91
+ text
92
+ bg
93
+ @click="onReset"
94
+ >
95
+ {{ $t('message.tip.clearCache') }}
96
+ </el-button>
97
+ </div>
98
+ </div>
99
+ </div>
100
+ </template>
101
+
102
+ <style lang="scss" scoped>
103
+ :deep(.el-scrollbar) {
104
+ height: calc(100vh - 110px);
105
+ }
106
+
107
+ .right-panel-background {
108
+ position: fixed;
109
+ top: 0;
110
+ left: 0;
111
+ z-index: -1;
112
+ background: rgb(0 0 0 / 20%);
113
+ opacity: 0;
114
+ transition: opacity 0.3s cubic-bezier(0.7, 0.3, 0.1, 1);
115
+ }
116
+
117
+ .right-panel {
118
+ position: fixed;
119
+ top: 0;
120
+ right: 0;
121
+ z-index: 40000;
122
+ width: 100%;
123
+ max-width: 300px;
124
+ box-shadow: 0 0 15px 0 rgb(0 0 0 / 5%);
125
+ transform: translate(100%);
126
+ transition: all 0.25s cubic-bezier(0.7, 0.3, 0.1, 1);
127
+ }
128
+
129
+ .show {
130
+ transition: all 0.3s cubic-bezier(0.7, 0.3, 0.1, 1);
131
+
132
+ .right-panel-background {
133
+ z-index: 20000;
134
+ width: 100%;
135
+ height: 100%;
136
+ opacity: 1;
137
+ }
138
+
139
+ .right-panel {
140
+ transform: translate(0);
141
+ }
142
+ }
143
+
144
+ .project-configuration {
145
+ display: flex;
146
+ align-items: center;
147
+ justify-content: space-between;
148
+ padding: 14px 20px;
149
+ }
150
+ </style>