2024-06-23 23:18:55 +08:00
|
|
|
|
<script lang="ts" setup>
|
|
|
|
|
|
import type {
|
|
|
|
|
|
WorkbenchProjectItem,
|
|
|
|
|
|
WorkbenchQuickNavItem,
|
2024-06-29 14:45:02 +08:00
|
|
|
|
WorkbenchTodoItem,
|
|
|
|
|
|
WorkbenchTrendItem,
|
2024-07-13 17:25:15 +08:00
|
|
|
|
} from '@vben/common-ui';
|
2024-06-23 23:18:55 +08:00
|
|
|
|
|
2024-06-29 14:45:02 +08:00
|
|
|
|
import { ref } from 'vue';
|
2024-11-09 10:26:58 +08:00
|
|
|
|
import { useRouter } from 'vue-router';
|
2024-06-29 14:45:02 +08:00
|
|
|
|
|
2024-06-23 23:18:55 +08:00
|
|
|
|
import {
|
2024-06-29 14:45:02 +08:00
|
|
|
|
AnalysisChartCard,
|
2024-06-23 23:18:55 +08:00
|
|
|
|
WorkbenchHeader,
|
|
|
|
|
|
WorkbenchProject,
|
|
|
|
|
|
WorkbenchQuickNav,
|
2024-06-29 14:45:02 +08:00
|
|
|
|
WorkbenchTodo,
|
|
|
|
|
|
WorkbenchTrends,
|
2024-07-13 17:25:15 +08:00
|
|
|
|
} from '@vben/common-ui';
|
2024-07-23 00:03:59 +08:00
|
|
|
|
import { preferences } from '@vben/preferences';
|
2024-07-30 21:10:28 +08:00
|
|
|
|
import { useUserStore } from '@vben/stores';
|
2024-11-09 10:26:58 +08:00
|
|
|
|
import { openWindow } from '@vben/utils';
|
2024-06-23 23:18:55 +08:00
|
|
|
|
|
2024-06-29 14:45:02 +08:00
|
|
|
|
import AnalyticsVisitsSource from '../analytics/analytics-visits-source.vue';
|
|
|
|
|
|
|
2024-07-30 21:10:28 +08:00
|
|
|
|
const userStore = useUserStore();
|
2024-06-23 23:18:55 +08:00
|
|
|
|
|
2024-11-09 10:26:58 +08:00
|
|
|
|
// 这是一个示例数据,实际项目中需要根据实际情况进行调整
|
|
|
|
|
|
// url 也可以是内部路由,在 navTo 方法中识别处理,进行内部跳转
|
|
|
|
|
|
// 例如:url: /dashboard/workspace
|
2024-06-23 23:18:55 +08:00
|
|
|
|
const projectItems: WorkbenchProjectItem[] = [
|
|
|
|
|
|
{
|
2025-04-19 19:05:42 +08:00
|
|
|
|
color: '#6DB33F',
|
|
|
|
|
|
content: 'github.com/YunaiV/ruoyi-vue-pro',
|
|
|
|
|
|
date: '2025-01-02',
|
|
|
|
|
|
group: 'Spring Boot 单体架构',
|
|
|
|
|
|
icon: 'simple-icons:springboot',
|
|
|
|
|
|
title: 'ruoyi-vue-pro',
|
|
|
|
|
|
url: 'https://github.com/YunaiV/ruoyi-vue-pro',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#409EFF',
|
|
|
|
|
|
content: 'github.com/yudaocode/yudao-ui-admin-vue3',
|
|
|
|
|
|
date: '2025-02-03',
|
|
|
|
|
|
group: 'Vue3 + element-plus 管理后台',
|
|
|
|
|
|
icon: 'ep:element-plus',
|
|
|
|
|
|
title: 'yudao-ui-admin-vue3',
|
|
|
|
|
|
url: 'https://github.com/yudaocode/yudao-ui-admin-vue3',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#ff4d4f',
|
|
|
|
|
|
content: 'github.com/yudaocode/yudao-ui-mall-uniapp',
|
|
|
|
|
|
date: '2025-03-04',
|
|
|
|
|
|
group: 'Vue3 + uniapp 商城手机端',
|
|
|
|
|
|
icon: 'icon-park-outline:mall-bag',
|
|
|
|
|
|
title: 'yudao-ui-mall-uniapp',
|
|
|
|
|
|
url: 'https://github.com/yudaocode/yudao-ui-mall-uniapp',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#1890ff',
|
|
|
|
|
|
content: 'github.com/YunaiV/yudao-cloud',
|
|
|
|
|
|
date: '2025-04-05',
|
|
|
|
|
|
group: 'Spring Cloud 微服务架构',
|
|
|
|
|
|
icon: 'material-symbols:cloud-outline',
|
|
|
|
|
|
title: 'yudao-cloud',
|
|
|
|
|
|
url: 'https://github.com/YunaiV/yudao-cloud',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#e18525',
|
2025-04-19 19:05:42 +08:00
|
|
|
|
content: 'github.com/yudaocode/yudao-ui-admin-vben',
|
|
|
|
|
|
date: '2025-05-06',
|
|
|
|
|
|
group: 'Vue3 + vben5(antd) 管理后台',
|
|
|
|
|
|
icon: 'devicon:antdesign',
|
|
|
|
|
|
title: 'yudao-ui-admin-vben',
|
|
|
|
|
|
url: 'https://github.com/yudaocode/yudao-ui-admin-vben',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#2979ff',
|
|
|
|
|
|
content: 'github.com/yudaocode/yudao-ui-admin-uniapp',
|
|
|
|
|
|
date: '2025-06-01',
|
|
|
|
|
|
group: 'Vue3 + uniapp 管理手机端',
|
|
|
|
|
|
icon: 'ant-design:mobile',
|
|
|
|
|
|
title: 'yudao-ui-admin-uniapp',
|
|
|
|
|
|
url: 'https://github.com/yudaocode/yudao-ui-admin-uniapp',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
];
|
|
|
|
|
|
|
2024-11-09 10:26:58 +08:00
|
|
|
|
// 同样,这里的 url 也可以使用以 http 开头的外部链接
|
2024-06-23 23:18:55 +08:00
|
|
|
|
const quickNavItems: WorkbenchQuickNavItem[] = [
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#1fdaca',
|
|
|
|
|
|
icon: 'ion:home-outline',
|
|
|
|
|
|
title: '首页',
|
2024-11-09 10:26:58 +08:00
|
|
|
|
url: '/',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-04-19 19:05:42 +08:00
|
|
|
|
color: '#ff6b6b',
|
2025-06-15 15:53:12 +08:00
|
|
|
|
icon: 'lucide:shopping-bag',
|
2025-04-19 19:05:42 +08:00
|
|
|
|
title: '商城中心',
|
|
|
|
|
|
url: '/mall',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-04-19 19:05:42 +08:00
|
|
|
|
color: '#7c3aed',
|
|
|
|
|
|
icon: 'tabler:ai',
|
|
|
|
|
|
title: 'AI 大模型',
|
|
|
|
|
|
url: '/ai',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#3fb27f',
|
2025-04-19 19:05:42 +08:00
|
|
|
|
icon: 'simple-icons:erpnext',
|
|
|
|
|
|
title: 'ERP 系统',
|
|
|
|
|
|
url: '/erp',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
color: '#4daf1bc9',
|
2025-04-19 19:05:42 +08:00
|
|
|
|
icon: 'simple-icons:civicrm',
|
|
|
|
|
|
title: 'CRM 系统',
|
|
|
|
|
|
url: '/crm',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-04-19 19:05:42 +08:00
|
|
|
|
color: '#1a73e8',
|
|
|
|
|
|
icon: 'fa-solid:hdd',
|
|
|
|
|
|
title: 'IoT 物联网',
|
|
|
|
|
|
url: '/iot',
|
2024-06-23 23:18:55 +08:00
|
|
|
|
},
|
|
|
|
|
|
];
|
2024-06-29 14:45:02 +08:00
|
|
|
|
|
|
|
|
|
|
const todoItems = ref<WorkbenchTodoItem[]>([
|
|
|
|
|
|
{
|
|
|
|
|
|
completed: false,
|
2025-04-19 19:05:42 +08:00
|
|
|
|
content: `系统支持 JDK 8/17/21,Vue 2/3`,
|
|
|
|
|
|
date: '2024-07-15 09:30:00',
|
|
|
|
|
|
title: '技术兼容性',
|
2024-06-29 14:45:02 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
completed: false,
|
2025-04-19 19:05:42 +08:00
|
|
|
|
content: `后端提供 Spring Boot 2.7/3.2 + Cloud 双架构`,
|
|
|
|
|
|
date: '2024-08-30 14:20:00',
|
|
|
|
|
|
title: '架构灵活性',
|
2024-06-29 14:45:02 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
completed: false,
|
2025-04-19 19:05:42 +08:00
|
|
|
|
content: `全部开源,个人与企业可 100% 直接使用,无需授权`,
|
|
|
|
|
|
date: '2024-07-25 16:45:00',
|
|
|
|
|
|
title: '开源免授权',
|
2024-06-29 14:45:02 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
completed: false,
|
2025-04-19 19:05:42 +08:00
|
|
|
|
content: `国内使用最广泛的快速开发平台,远超 10w+ 企业使用`,
|
|
|
|
|
|
date: '2024-07-10 11:15:00',
|
|
|
|
|
|
title: '广泛企业认可',
|
2025-04-24 17:56:02 +08:00
|
|
|
|
},
|
2024-06-29 14:45:02 +08:00
|
|
|
|
]);
|
|
|
|
|
|
const trendItems: WorkbenchTrendItem[] = [
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-1',
|
|
|
|
|
|
content: `在 <a>开源组</a> 创建了项目 <a>Vue</a>`,
|
|
|
|
|
|
date: '刚刚',
|
|
|
|
|
|
title: '威廉',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-2',
|
|
|
|
|
|
content: `关注了 <a>威廉</a> `,
|
|
|
|
|
|
date: '1个小时前',
|
|
|
|
|
|
title: '艾文',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-3',
|
|
|
|
|
|
content: `发布了 <a>个人动态</a> `,
|
|
|
|
|
|
date: '1天前',
|
|
|
|
|
|
title: '克里斯',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-4',
|
|
|
|
|
|
content: `发表文章 <a>如何编写一个Vite插件</a> `,
|
|
|
|
|
|
date: '2天前',
|
|
|
|
|
|
title: 'Vben',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-1',
|
|
|
|
|
|
content: `回复了 <a>杰克</a> 的问题 <a>如何进行项目优化?</a>`,
|
|
|
|
|
|
date: '3天前',
|
|
|
|
|
|
title: '皮特',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-2',
|
|
|
|
|
|
content: `关闭了问题 <a>如何运行项目</a> `,
|
|
|
|
|
|
date: '1周前',
|
|
|
|
|
|
title: '杰克',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-3',
|
|
|
|
|
|
content: `发布了 <a>个人动态</a> `,
|
|
|
|
|
|
date: '1周前',
|
|
|
|
|
|
title: '威廉',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-4',
|
|
|
|
|
|
content: `推送了代码到 <a>Github</a>`,
|
|
|
|
|
|
date: '2021-04-01 20:00',
|
|
|
|
|
|
title: '威廉',
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
avatar: 'svg:avatar-4',
|
|
|
|
|
|
content: `发表文章 <a>如何编写使用 Admin Vben</a> `,
|
|
|
|
|
|
date: '2021-03-01 20:00',
|
|
|
|
|
|
title: 'Vben',
|
|
|
|
|
|
},
|
|
|
|
|
|
];
|
2024-11-09 10:26:58 +08:00
|
|
|
|
|
|
|
|
|
|
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}`);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2024-06-23 23:18:55 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
|
<div class="p-5">
|
|
|
|
|
|
<WorkbenchHeader
|
2024-07-30 21:10:28 +08:00
|
|
|
|
:avatar="userStore.userInfo?.avatar || preferences.app.defaultAvatar"
|
2024-06-23 23:18:55 +08:00
|
|
|
|
>
|
|
|
|
|
|
<template #title>
|
2025-03-28 19:59:06 +08:00
|
|
|
|
早安, {{ userStore.userInfo?.nickname }}, 开始您一天的工作吧!
|
2024-06-23 23:18:55 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
<template #description> 今日晴,20℃ - 32℃! </template>
|
|
|
|
|
|
</WorkbenchHeader>
|
|
|
|
|
|
|
2024-07-14 11:17:40 +08:00
|
|
|
|
<div class="mt-5 flex flex-col lg:flex-row">
|
|
|
|
|
|
<div class="mr-4 w-full lg:w-3/5">
|
2024-11-09 10:26:58 +08:00
|
|
|
|
<WorkbenchProject :items="projectItems" title="项目" @click="navTo" />
|
2024-06-29 14:45:02 +08:00
|
|
|
|
<WorkbenchTrends :items="trendItems" class="mt-5" title="最新动态" />
|
2024-06-23 23:18:55 +08:00
|
|
|
|
</div>
|
2024-07-14 11:17:40 +08:00
|
|
|
|
<div class="w-full lg:w-2/5">
|
2024-08-31 13:06:53 +08:00
|
|
|
|
<WorkbenchQuickNav
|
|
|
|
|
|
:items="quickNavItems"
|
|
|
|
|
|
class="mt-5 lg:mt-0"
|
|
|
|
|
|
title="快捷导航"
|
2024-11-09 10:26:58 +08:00
|
|
|
|
@click="navTo"
|
2024-08-31 13:06:53 +08:00
|
|
|
|
/>
|
2024-06-29 14:45:02 +08:00
|
|
|
|
<WorkbenchTodo :items="todoItems" class="mt-5" title="待办事项" />
|
|
|
|
|
|
<AnalysisChartCard class="mt-5" title="访问来源">
|
|
|
|
|
|
<AnalyticsVisitsSource />
|
|
|
|
|
|
</AnalysisChartCard>
|
2024-06-23 23:18:55 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|