From da7d61b1603f67e0a221b66ade5d4a94935b9d3c Mon Sep 17 00:00:00 2001 From: Xiaoyu <614422099@QQ.com> Date: Sat, 9 Nov 2024 10:26:58 +0800 Subject: [PATCH] feat: add click-to-click event support to the WorkenchProject and WorkenchQuickNav components (#4831) * feat(@vben/common-ui): add click event emission to WorkbenchProject and WorkbenchQuickNav components * feat: add navigation and project link functionality to dashboard workspace * feat: add URL property to WorkbenchProjectItem and WorkbenchQuickNavItem for enhanced navigation --------- Co-authored-by: XiaoyuDing --- .../src/views/dashboard/workspace/index.vue | 39 ++++++++++++++++++- .../src/views/dashboard/workspace/index.vue | 39 ++++++++++++++++++- .../src/views/dashboard/workspace/index.vue | 39 ++++++++++++++++++- .../common-ui/src/ui/dashboard/typing.ts | 2 + .../dashboard/workbench/workbench-project.vue | 3 ++ .../workbench/workbench-quick-nav.vue | 3 ++ .../src/views/dashboard/workspace/index.vue | 39 ++++++++++++++++++- 7 files changed, 160 insertions(+), 4 deletions(-) diff --git a/apps/web-antd/src/views/dashboard/workspace/index.vue b/apps/web-antd/src/views/dashboard/workspace/index.vue index b84ceebb..b95d6138 100644 --- a/apps/web-antd/src/views/dashboard/workspace/index.vue +++ b/apps/web-antd/src/views/dashboard/workspace/index.vue @@ -7,6 +7,7 @@ import type { } from '@vben/common-ui'; import { ref } from 'vue'; +import { useRouter } from 'vue-router'; import { AnalysisChartCard, @@ -18,11 +19,15 @@ import { } from '@vben/common-ui'; import { preferences } from '@vben/preferences'; import { useUserStore } from '@vben/stores'; +import { openWindow } from '@vben/utils'; import AnalyticsVisitsSource from '../analytics/analytics-visits-source.vue'; const userStore = useUserStore(); +// 这是一个示例数据,实际项目中需要根据实际情况进行调整 +// url 也可以是内部路由,在 navTo 方法中识别处理,进行内部跳转 +// 例如:url: /dashboard/workspace const projectItems: WorkbenchProjectItem[] = [ { color: '', @@ -31,6 +36,7 @@ const projectItems: WorkbenchProjectItem[] = [ group: '开源组', icon: 'carbon:logo-github', title: 'Github', + url: 'https://github.com', }, { color: '#3fb27f', @@ -39,6 +45,7 @@ const projectItems: WorkbenchProjectItem[] = [ group: '算法组', icon: 'ion:logo-vue', title: 'Vue', + url: 'https://vuejs.org', }, { color: '#e18525', @@ -47,6 +54,7 @@ const projectItems: WorkbenchProjectItem[] = [ group: '上班摸鱼', icon: 'ion:logo-html5', title: 'Html5', + url: 'https://developer.mozilla.org/zh-CN/docs/Web/HTML', }, { color: '#bf0c2c', @@ -55,6 +63,7 @@ const projectItems: WorkbenchProjectItem[] = [ group: 'UI', icon: 'ion:logo-angular', title: 'Angular', + url: 'https://angular.io', }, { color: '#00d8ff', @@ -63,6 +72,7 @@ const projectItems: WorkbenchProjectItem[] = [ group: '技术牛', icon: 'bx:bxl-react', title: 'React', + url: 'https://reactjs.org', }, { color: '#EBD94E', @@ -71,39 +81,47 @@ const projectItems: WorkbenchProjectItem[] = [ group: '架构组', icon: 'ion:logo-javascript', title: 'Js', + url: 'https://developer.mozilla.org/zh-CN/docs/Web/JavaScript', }, ]; +// 同样,这里的 url 也可以使用以 http 开头的外部链接 const quickNavItems: WorkbenchQuickNavItem[] = [ { color: '#1fdaca', icon: 'ion:home-outline', title: '首页', + url: '/', }, { color: '#bf0c2c', icon: 'ion:grid-outline', title: '仪表盘', + url: '/dashboard', }, { color: '#e18525', icon: 'ion:layers-outline', title: '组件', + url: '/demos/features/icons', }, { color: '#3fb27f', icon: 'ion:settings-outline', title: '系统管理', + url: '/demos/features/login-expired', // 这里的 URL 是示例,实际项目中需要根据实际情况进行调整 }, { color: '#4daf1bc9', icon: 'ion:key-outline', title: '权限管理', + url: '/demos/access/page-control', }, { color: '#00d8ff', icon: 'ion:bar-chart-outline', title: '图表', + url: '/analytics', }, ]; @@ -195,6 +213,24 @@ const trendItems: WorkbenchTrendItem[] = [ title: 'Vben', }, ]; + +const router = useRouter(); + +// 这是一个示例方法,实际项目中需要根据实际情况进行调整 +// This is a sample method, adjust according to the actual project requirements +function navTo(nav: WorkbenchProjectItem | WorkbenchQuickNavItem) { + if (nav.url?.startsWith('http')) { + openWindow(nav.url); + return; + } + if (nav.url?.startsWith('/')) { + router.push(nav.url).catch((error) => { + console.error('Navigation failed:', error); + }); + } else { + console.warn(`Unknown URL for navigation item: ${nav.title} -> ${nav.url}`); + } +}