1
0
mirror of https://gitlab.com/MoonTestUse1/AdministrationItDepartmens.git synced 2025-08-14 00:25:46 +02:00

чиним билд05

This commit is contained in:
MoonTestUse1
2025-01-02 01:56:58 +06:00
parent 91ffcbe5b1
commit 0a8fc9d245
3 changed files with 36 additions and 71 deletions

View File

@@ -1,60 +1,22 @@
import { createRouter, createWebHistory } from 'vue-router';
import { useAuthStore } from '@/stores/auth';
const router = createRouter({
history: createWebHistory(),
routes: [
{
path: '/',
component: () => import('@/layouts/MainLayout.vue'),
children: [
{
path: '',
name: 'Home',
component: () => import('@/views/HomeView.vue')
},
{
path: 'login',
name: 'Login',
component: () => import('@/views/LoginView.vue')
}
]
name: 'home',
component: () => import('@/views/HomeView.vue')
},
{
path: '/login',
name: 'login',
component: () => import('@/views/LoginView.vue')
},
{
path: '/admin',
component: () => import('@/layouts/AdminLayout.vue'),
meta: { requiresAdmin: true },
children: [
{
path: '',
redirect: '/admin/dashboard'
},
{
path: 'dashboard',
name: 'AdminDashboard',
component: () => import('@/views/admin/DashboardView.vue')
},
{
path: 'requests',
name: 'AdminRequests',
component: () => import('@/views/admin/RequestsView.vue')
},
{
path: 'employees',
name: 'AdminEmployees',
component: () => import('@/views/admin/EmployeesView.vue')
},
{
path: 'employees/add',
name: 'AdminEmployeeAdd',
component: () => import('@/views/admin/AddEmployeeView.vue')
}
]
},
{
path: '/admin/login',
name: 'AdminLogin',
component: () => import('@/views/admin/AdminLoginView.vue')
name: 'admin-login',
component: () => import('@/views/AdminLoginView.vue')
},
{
path: '/requests',
@@ -65,20 +27,23 @@ const router = createRouter({
]
});
router.beforeEach((to, _, next) => {
const authStore = useAuthStore();
if (to.meta.requiresAdmin && !authStore.isAdmin) {
next({ name: 'AdminLogin' });
} else if (to.meta.requiresAuth) {
const token = localStorage.getItem('token');
router.beforeEach((to, from, next) => {
console.log('Проверка маршрута:', to.path)
if (to.meta.requiresAuth) {
console.log('Маршрут требует авторизации')
const token = localStorage.getItem('token')
console.log('Токен:', token ? 'Присутствует' : 'Отсутствует')
if (!token) {
next('/login');
return;
console.log('Перенаправление на /login')
next('/login')
return
}
} else {
next();
}
});
console.log('Разрешаем переход')
next()
})
export default router;
export default router