189 lines
5.3 KiB
JavaScript
189 lines
5.3 KiB
JavaScript
|
|
import {createRouter, createWebHistory} from 'vue-router'
|
||
|
|
import {useUserStore} from '@/stores/user'
|
||
|
|
import {ElMessage} from 'element-plus'
|
||
|
|
import NProgress from 'nprogress'
|
||
|
|
|
||
|
|
const routes = [
|
||
|
|
{
|
||
|
|
path: '/login',
|
||
|
|
name: 'Login',
|
||
|
|
component: () => import('@/views/Login.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '登录 - 炬融圈',
|
||
|
|
requiresAuth: false
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: '/',
|
||
|
|
component: () => import('@/layout/Layout.vue'),
|
||
|
|
redirect: '/dashboard',
|
||
|
|
meta: {
|
||
|
|
requiresAuth: true
|
||
|
|
},
|
||
|
|
children: [
|
||
|
|
{
|
||
|
|
path: 'dashboard',
|
||
|
|
name: 'Dashboard',
|
||
|
|
component: () => import('@/views/Dashboard.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '仪表盘 - 炬融圈',
|
||
|
|
icon: 'Odometer'
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'users',
|
||
|
|
name: 'Users',
|
||
|
|
component: () => import('@/views/Users.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '用户管理 - 炬融圈',
|
||
|
|
icon: 'User',
|
||
|
|
requiresAdmin: true
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'user-audit',
|
||
|
|
name: 'UserAudit',
|
||
|
|
component: () => import('@/views/UserAudit.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '用户审核 - 炬融圈',
|
||
|
|
icon: 'DocumentChecked',
|
||
|
|
requiresAdmin: true
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'points',
|
||
|
|
name: 'Points',
|
||
|
|
component: () => import('@/views/Points.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '积分管理 - 积分商城管理系统',
|
||
|
|
icon: 'Coin',
|
||
|
|
requiresAdmin: true
|
||
|
|
}
|
||
|
|
},
|
||
|
|
|
||
|
|
{
|
||
|
|
path: 'transfers',
|
||
|
|
name: 'Transfers',
|
||
|
|
component: () => import('@/views/Transfers.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '转账管理 - 炬融圈',
|
||
|
|
icon: 'Money',
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'beans',
|
||
|
|
name: 'Beans',
|
||
|
|
component: () => import('@/views/Beans.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '融豆管理 - 炬融圈',
|
||
|
|
icon: 'Promotion',
|
||
|
|
requiresAdmin: true
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'projects',
|
||
|
|
name: 'Projects',
|
||
|
|
component: () => import('@/views/Project.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '项目管理 - 炬融圈',
|
||
|
|
icon: 'Project',
|
||
|
|
requiresAdmin: true
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'profile',
|
||
|
|
name: 'Profile',
|
||
|
|
component: () => import('@/views/Profile.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '个人资料 - 炬融圈',
|
||
|
|
icon: 'UserFilled'
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: 'program',
|
||
|
|
name: 'Program',
|
||
|
|
component: () => import('@/views/Program.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '项目管理 - 炬融圈',
|
||
|
|
icon: 'Project'
|
||
|
|
}
|
||
|
|
}
|
||
|
|
]
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: '/404',
|
||
|
|
name: 'NotFound',
|
||
|
|
component: () => import('@/views/404.vue'),
|
||
|
|
meta: {
|
||
|
|
title: '页面未找到 - 炬融圈'
|
||
|
|
}
|
||
|
|
},
|
||
|
|
{
|
||
|
|
path: '/:pathMatch(.*)*',
|
||
|
|
redirect: '/404'
|
||
|
|
}
|
||
|
|
]
|
||
|
|
|
||
|
|
const router = createRouter({
|
||
|
|
history: createWebHistory('/admin/'),
|
||
|
|
routes
|
||
|
|
})
|
||
|
|
|
||
|
|
// 路由守卫
|
||
|
|
router.beforeEach(async (to, from, next) => {
|
||
|
|
NProgress.start()
|
||
|
|
|
||
|
|
const userStore = useUserStore()
|
||
|
|
|
||
|
|
// 设置页面标题
|
||
|
|
if (to.meta.title) {
|
||
|
|
document.title = to.meta.title
|
||
|
|
}
|
||
|
|
|
||
|
|
// 检查是否需要认证
|
||
|
|
if (to.meta.requiresAuth !== false) {
|
||
|
|
if (!userStore.isAuthenticated) {
|
||
|
|
// 只在没有token或用户信息时才尝试从本地存储恢复登录状态
|
||
|
|
const token = localStorage.getItem('admin_token')
|
||
|
|
const userStr = localStorage.getItem('admin_user')
|
||
|
|
|
||
|
|
if (token && userStr) {
|
||
|
|
try {
|
||
|
|
const user = JSON.parse(userStr)
|
||
|
|
userStore.token = token
|
||
|
|
userStore.user = user
|
||
|
|
} catch (error) {
|
||
|
|
console.error('解析用户信息失败:', error)
|
||
|
|
localStorage.removeItem('admin_token')
|
||
|
|
localStorage.removeItem('admin_user')
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
if (!userStore.isAuthenticated) {
|
||
|
|
next('/login')
|
||
|
|
return
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
// 检查管理员权限
|
||
|
|
if (to.meta.requiresAdmin && !userStore.isAdmin) {
|
||
|
|
ElMessage.error('您没有权限访问此页面')
|
||
|
|
next('/dashboard')
|
||
|
|
return
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
// 如果已登录用户访问登录页,重定向到仪表盘
|
||
|
|
if (to.name === 'Login' && userStore.isAuthenticated) {
|
||
|
|
next('/dashboard')
|
||
|
|
return
|
||
|
|
}
|
||
|
|
|
||
|
|
next()
|
||
|
|
})
|
||
|
|
|
||
|
|
router.afterEach(() => {
|
||
|
|
NProgress.done()
|
||
|
|
})
|
||
|
|
|
||
|
|
export default router
|