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 { 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

View File

@@ -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
} }

View File

@@ -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
} }
} }