mirror of
https://gitlab.com/MoonTestUse1/AdministrationItDepartmens.git
synced 2025-08-14 00:25:46 +02:00
чиним билд05
This commit is contained in:
@@ -1,60 +1,22 @@
|
|||||||
import { createRouter, createWebHistory } from 'vue-router';
|
import { createRouter, createWebHistory } from 'vue-router';
|
||||||
import { useAuthStore } from '@/stores/auth';
|
|
||||||
|
|
||||||
const router = createRouter({
|
const router = createRouter({
|
||||||
history: createWebHistory(),
|
history: createWebHistory(),
|
||||||
routes: [
|
routes: [
|
||||||
{
|
{
|
||||||
path: '/',
|
path: '/',
|
||||||
component: () => import('@/layouts/MainLayout.vue'),
|
name: 'home',
|
||||||
children: [
|
component: () => import('@/views/HomeView.vue')
|
||||||
{
|
},
|
||||||
path: '',
|
{
|
||||||
name: 'Home',
|
path: '/login',
|
||||||
component: () => import('@/views/HomeView.vue')
|
name: 'login',
|
||||||
},
|
component: () => import('@/views/LoginView.vue')
|
||||||
{
|
|
||||||
path: 'login',
|
|
||||||
name: 'Login',
|
|
||||||
component: () => import('@/views/LoginView.vue')
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '/admin',
|
path: '/admin',
|
||||||
component: () => import('@/layouts/AdminLayout.vue'),
|
name: 'admin-login',
|
||||||
meta: { requiresAdmin: true },
|
component: () => import('@/views/AdminLoginView.vue')
|
||||||
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')
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '/requests',
|
path: '/requests',
|
||||||
@@ -65,20 +27,23 @@ const router = createRouter({
|
|||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
router.beforeEach((to, _, next) => {
|
router.beforeEach((to, from, next) => {
|
||||||
const authStore = useAuthStore();
|
console.log('Проверка маршрута:', to.path)
|
||||||
|
|
||||||
if (to.meta.requiresAdmin && !authStore.isAdmin) {
|
if (to.meta.requiresAuth) {
|
||||||
next({ name: 'AdminLogin' });
|
console.log('Маршрут требует авторизации')
|
||||||
} else if (to.meta.requiresAuth) {
|
const token = localStorage.getItem('token')
|
||||||
const token = localStorage.getItem('token');
|
console.log('Токен:', token ? 'Присутствует' : 'Отсутствует')
|
||||||
|
|
||||||
if (!token) {
|
if (!token) {
|
||||||
next('/login');
|
console.log('Перенаправление на /login')
|
||||||
return;
|
next('/login')
|
||||||
|
return
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
next();
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
console.log('Разрешаем переход')
|
||||||
|
next()
|
||||||
|
})
|
||||||
|
|
||||||
export default router;
|
export default router
|
@@ -69,19 +69,23 @@ const handleLogin = async () => {
|
|||||||
error.value = ''
|
error.value = ''
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
console.log('Отправка запроса на авторизацию...')
|
||||||
const response = await axios.post('/api/auth/login', {
|
const response = await axios.post('/api/auth/login', {
|
||||||
last_name: lastName.value,
|
last_name: lastName.value,
|
||||||
password: password.value
|
password: password.value
|
||||||
})
|
})
|
||||||
|
console.log('Ответ от сервера:', response.data)
|
||||||
|
|
||||||
// Сохраняем данные сотрудника и токен
|
// Сохраняем данные сотрудника и токен
|
||||||
localStorage.setItem('employee', JSON.stringify(response.data))
|
localStorage.setItem('employee', JSON.stringify(response.data))
|
||||||
localStorage.setItem('token', response.data.access_token)
|
localStorage.setItem('token', response.data.access_token)
|
||||||
|
|
||||||
|
console.log('Перенаправление на /requests...')
|
||||||
// Перенаправляем на страницу заявок
|
// Перенаправляем на страницу заявок
|
||||||
router.push('/requests')
|
await router.push('/requests')
|
||||||
} catch (e: any) {
|
} catch (e: any) {
|
||||||
error.value = e.response?.data?.detail || 'Произошла ошибка при входе'
|
console.error('Ошибка при авторизации:', e)
|
||||||
|
error.value = e.response?.data?.detail || 'Неверная фамилия или пароль'
|
||||||
} finally {
|
} finally {
|
||||||
loading.value = false
|
loading.value = false
|
||||||
}
|
}
|
||||||
|
@@ -1,23 +1,19 @@
|
|||||||
import { defineConfig } from 'vite';
|
import { defineConfig } from 'vite';
|
||||||
import vue from '@vitejs/plugin-vue';
|
import vue from '@vitejs/plugin-vue';
|
||||||
import { fileURLToPath, URL } from 'url';
|
import path from 'path';
|
||||||
|
|
||||||
|
// https://vitejs.dev/config/
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
plugins: [vue()],
|
plugins: [vue()],
|
||||||
resolve: {
|
resolve: {
|
||||||
alias: {
|
alias: {
|
||||||
'@': fileURLToPath(new URL('./src', import.meta.url))
|
'@': path.resolve(__dirname, './src'),
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
server: {
|
server: {
|
||||||
host: true,
|
|
||||||
port: 5173,
|
|
||||||
watch: {
|
|
||||||
usePolling: true
|
|
||||||
},
|
|
||||||
proxy: {
|
proxy: {
|
||||||
'/api': {
|
'/api': {
|
||||||
target: 'http://support-backend:8000',
|
target: 'http://backend:8000',
|
||||||
changeOrigin: true
|
changeOrigin: true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user