let currentUser = null; let users = []; let tasks = []; let filteredUsers = []; let expandedTasks = new Set(); document.addEventListener('DOMContentLoaded', function() { checkAuth(); setupEventListeners(); }); async function checkAuth() { try { const response = await fetch('/api/user'); if (response.ok) { const data = await response.json(); currentUser = data.user; showMainInterface(); } else { showLoginInterface(); } } catch (error) { showLoginInterface(); } } function showLoginInterface() { document.getElementById('login-modal').style.display = 'block'; document.querySelector('.container').style.display = 'none'; } function showMainInterface() { document.getElementById('login-modal').style.display = 'none'; document.querySelector('.container').style.display = 'block'; let userInfo = `Вы вошли как: ${currentUser.name}`; if (currentUser.auth_type === 'ldap') { userInfo += ` (LDAP)`; } if (currentUser.groups && currentUser.groups.length > 0) { userInfo += ` | Группы: ${currentUser.groups.join(', ')}`; } document.getElementById('current-user').textContent = userInfo; document.getElementById('tasks-controls').style.display = 'block'; const showDeletedLabel = document.querySelector('.show-deleted-label'); if (showDeletedLabel) { if (currentUser.role === 'admin') { showDeletedLabel.style.display = 'flex'; } else { showDeletedLabel.style.display = 'none'; } } loadUsers(); loadTasks(); loadActivityLogs(); showSection('tasks'); } function setupEventListeners() { document.getElementById('login-form').addEventListener('submit', login); document.getElementById('create-task-form').addEventListener('submit', createTask); document.getElementById('edit-task-form').addEventListener('submit', updateTask); document.getElementById('copy-task-form').addEventListener('submit', copyTask); document.getElementById('edit-assignment-form').addEventListener('submit', updateAssignment); document.getElementById('rework-task-form').addEventListener('submit', sendForRework); document.getElementById('files').addEventListener('change', updateFileList); document.getElementById('edit-files').addEventListener('change', updateEditFileList); } async function login(event) { event.preventDefault(); const login = document.getElementById('login').value; const password = document.getElementById('password').value; try { const response = await fetch('/api/login', { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ login, password }) }); if (response.ok) { const data = await response.json(); currentUser = data.user; showMainInterface(); } else { const error = await response.json(); alert(error.error || 'Ошибка входа'); } } catch (error) { console.error('Ошибка:', error); alert('Ошибка подключения к серверу'); } } async function logout() { try { await fetch('/api/logout', { method: 'POST' }); currentUser = null; showLoginInterface(); } catch (error) { console.error('Ошибка выхода:', error); } } function showSection(sectionName) { document.querySelectorAll('.section').forEach(section => { section.classList.remove('active'); }); document.getElementById(sectionName + '-section').classList.add('active'); if (sectionName === 'tasks') { loadTasks(); } else if (sectionName === 'logs') { loadActivityLogs(); } } async function loadUsers() { try { const response = await fetch('/api/users'); users = await response.json(); filteredUsers = [...users]; renderUsersChecklist(); renderEditUsersChecklist(); renderCopyUsersChecklist(); populateFilterDropdowns(); } catch (error) { console.error('Ошибка загрузки пользователей:', error); } } function populateFilterDropdowns() { const creatorFilter = document.getElementById('creator-filter'); const assigneeFilter = document.getElementById('assignee-filter'); creatorFilter.innerHTML = ''; assigneeFilter.innerHTML = ''; users.forEach(user => { const creatorOption = document.createElement('option'); creatorOption.value = user.id; creatorOption.textContent = `${user.name} (${user.login})`; creatorFilter.appendChild(creatorOption.cloneNode(true)); const assigneeOption = creatorOption.cloneNode(true); assigneeFilter.appendChild(assigneeOption); }); } function filterUsers() { const search = document.getElementById('user-search').value.toLowerCase(); filteredUsers = users.filter(user => user.name.toLowerCase().includes(search) || user.login.toLowerCase().includes(search) || user.email.toLowerCase().includes(search) ); renderUsersChecklist(); } function filterEditUsers() { const search = document.getElementById('edit-user-search').value.toLowerCase(); const filtered = users.filter(user => user.name.toLowerCase().includes(search) || user.login.toLowerCase().includes(search) || user.email.toLowerCase().includes(search) ); renderEditUsersChecklist(filtered); } function filterCopyUsers() { const search = document.getElementById('copy-user-search').value.toLowerCase(); const filtered = users.filter(user => user.name.toLowerCase().includes(search) || user.login.toLowerCase().includes(search) || user.email.toLowerCase().includes(search) ); renderCopyUsersChecklist(filtered); } async function loadTasks() { try { const search = document.getElementById('search-tasks')?.value || ''; const statusFilter = document.getElementById('status-filter')?.value || 'active,in_progress,assigned,overdue,rework'; const creatorFilter = document.getElementById('creator-filter')?.value || ''; const assigneeFilter = document.getElementById('assignee-filter')?.value || ''; const deadlineFilter = document.getElementById('deadline-filter')?.value || ''; const showDeleted = document.getElementById('show-deleted')?.checked || false; let url = '/api/tasks?'; if (search) url += `search=${encodeURIComponent(search)}&`; if (statusFilter) url += `status=${encodeURIComponent(statusFilter)}&`; if (creatorFilter) url += `creator=${encodeURIComponent(creatorFilter)}&`; if (assigneeFilter) url += `assignee=${encodeURIComponent(assigneeFilter)}&`; if (deadlineFilter) url += `deadline=${encodeURIComponent(deadlineFilter)}&`; if (showDeleted) url += `showDeleted=true&`; const response = await fetch(url); tasks = await response.json(); renderTasks(); tasks.forEach(task => { loadTaskFiles(task.id); }); } catch (error) { console.error('Ошибка загрузки задач:', error); } } async function loadActivityLogs() { try { const response = await fetch('/api/activity-logs'); const logs = await response.json(); renderLogs(logs); } catch (error) { console.error('Ошибка загрузки логов:', error); } } function renderUsersChecklist() { const container = document.getElementById('users-checklist'); container.innerHTML = filteredUsers .filter(user => user.id !== currentUser.id) .map(user => `
Общий размер: ${(totalSize / 1024 / 1024).toFixed(2)} MB / 300 MB
`; fileList.innerHTML = html; } function renderLogs(logs) { const container = document.getElementById('logs-list'); if (logs.length === 0) { container.innerHTML = '