mirror of
https://github.com/schroinerxy/cloud-mail.git
synced 2026-06-21 19:35:50 +08:00
167 lines
3.7 KiB
JavaScript
167 lines
3.7 KiB
JavaScript
import {createRouter, createWebHistory} from 'vue-router'
|
|
import NProgress from 'nprogress';
|
|
import {useUiStore} from "@/store/ui.js";
|
|
import {useSettingStore} from "@/store/setting.js";
|
|
import {cvtR2Url} from "@/utils/convert.js";
|
|
|
|
const routes = [
|
|
{
|
|
path: '/',
|
|
name: 'layout',
|
|
redirect: '/inbox',
|
|
component: () => import('@/layout/index.vue'),
|
|
children: [
|
|
{
|
|
path: '/inbox',
|
|
name: 'email',
|
|
component: () => import('@/views/email/index.vue'),
|
|
meta: {
|
|
title: 'inbox',
|
|
name: 'email',
|
|
menu: true
|
|
}
|
|
},
|
|
{
|
|
path: '/message',
|
|
name: 'content',
|
|
component: () => import('@/views/content/index.vue'),
|
|
meta: {
|
|
title: 'message',
|
|
name: 'content',
|
|
menu: false
|
|
}
|
|
},
|
|
{
|
|
path: '/settings',
|
|
name: 'setting',
|
|
component: () => import('@/views/setting/index.vue'),
|
|
meta: {
|
|
title: 'settings',
|
|
name: 'setting',
|
|
menu: true
|
|
}
|
|
},
|
|
{
|
|
path: '/starred',
|
|
name: 'star',
|
|
component: () => import('@/views/star/index.vue'),
|
|
meta: {
|
|
title: 'starred',
|
|
name: 'star',
|
|
menu: true
|
|
}
|
|
},
|
|
]
|
|
|
|
},
|
|
{
|
|
path: '/login',
|
|
name: 'login',
|
|
component: () => import('@/views/login/index.vue')
|
|
},
|
|
{
|
|
path: '/test',
|
|
name: 'test',
|
|
component: () => import('@/views/test/index.vue')
|
|
},
|
|
{
|
|
path: '/:pathMatch(.*)*',
|
|
name: '404',
|
|
component: () => import('@/views/404/index.vue')
|
|
}
|
|
]
|
|
|
|
|
|
const router = createRouter({
|
|
history: createWebHistory(import.meta.env.BASE_URL),
|
|
routes
|
|
})
|
|
|
|
NProgress.configure({
|
|
showSpinner: false, // 不显示旋转图标
|
|
trickleSpeed: 50, // 自动递增速度
|
|
minimum: 0.1 // 最小百分比
|
|
});
|
|
|
|
let timer
|
|
let first = true
|
|
|
|
router.beforeEach((to, from, next) => {
|
|
|
|
if (timer) {
|
|
clearTimeout(timer)
|
|
}
|
|
|
|
timer = setTimeout(() => {
|
|
NProgress.start()
|
|
}, first ? 200 : 100)
|
|
|
|
const token = localStorage.getItem('token')
|
|
|
|
if (!token && to.name !== 'login') {
|
|
return next({name: 'login'})
|
|
}
|
|
|
|
if (!token && to.name === 'login') {
|
|
loadBackground(next)
|
|
return
|
|
}
|
|
|
|
if (token && to.name === 'login') {
|
|
return next(from.path)
|
|
}
|
|
|
|
next()
|
|
|
|
})
|
|
|
|
function loadBackground(next) {
|
|
|
|
const settingStore = useSettingStore();
|
|
|
|
if (settingStore.settings.background) {
|
|
|
|
const src = cvtR2Url(settingStore.settings.background);
|
|
|
|
const img = new Image();
|
|
img.src = src;
|
|
|
|
img.onload = () => {
|
|
next()
|
|
};
|
|
|
|
img.onerror = () => {
|
|
console.warn("背景图片加载失败:", img.src);
|
|
next()
|
|
};
|
|
|
|
} else {
|
|
next()
|
|
}
|
|
|
|
|
|
}
|
|
|
|
router.afterEach((to) => {
|
|
|
|
clearTimeout(timer)
|
|
NProgress.done();
|
|
|
|
const uiStore = useUiStore()
|
|
if (to.meta.menu) {
|
|
if (['content', 'email', 'send'].includes(to.meta.name)) {
|
|
uiStore.accountShow = window.innerWidth > 767;
|
|
} else {
|
|
uiStore.accountShow = false
|
|
}
|
|
}
|
|
|
|
if (window.innerWidth < 1025) {
|
|
uiStore.asideShow = false
|
|
}
|
|
|
|
first = false
|
|
})
|
|
|
|
export default router
|