- 순찰/점검 기능 개선 (zone-detail 페이지 추가) - 출근/근태 시스템 개선 (연차 조회, 근무현황) - 작업분석 대분류 그룹화 및 마이그레이션 스크립트 - 모바일 네비게이션 UI 추가 - NAS 배포 도구 및 문서 추가 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
49 lines
1.8 KiB
JavaScript
49 lines
1.8 KiB
JavaScript
// /js/login.js
|
|
import { saveAuthData, clearAuthData } from './auth.js';
|
|
import { redirectToDefaultDashboard } from './navigation.js';
|
|
// api-helper.js가 ES6 모듈로 변환되면 import를 사용해야 합니다.
|
|
// import { login } from './api-helper.js';
|
|
|
|
document.getElementById('loginForm').addEventListener('submit', async function (e) {
|
|
e.preventDefault();
|
|
|
|
const username = document.getElementById('username').value;
|
|
const password = document.getElementById('password').value;
|
|
const errorDiv = document.getElementById('error');
|
|
|
|
const submitBtn = e.target.querySelector('button[type="submit"]');
|
|
const originalText = submitBtn.textContent;
|
|
|
|
// 로딩 상태 시작
|
|
submitBtn.disabled = true;
|
|
submitBtn.textContent = '로그인 중...';
|
|
errorDiv.style.display = 'none';
|
|
|
|
try {
|
|
// 현재는 window 객체를 통해 호출하지만, 향후 모듈화 필요
|
|
const result = await window.login(username, password);
|
|
|
|
if (result.success && result.data && result.data.token) {
|
|
// auth.js에서 가져온 함수로 인증 정보 저장
|
|
saveAuthData(result.data.token, result.data.user);
|
|
|
|
// navigation.js를 통해 리디렉션
|
|
redirectToDefaultDashboard(result.data.redirectUrl);
|
|
|
|
} else {
|
|
// api-helper가 에러를 throw하므로 이 블록은 실행될 가능성이 낮음
|
|
clearAuthData();
|
|
errorDiv.textContent = result.error || '로그인에 실패했습니다.';
|
|
errorDiv.style.display = 'block';
|
|
}
|
|
} catch (err) {
|
|
console.error('로그인 오류:', err);
|
|
clearAuthData();
|
|
errorDiv.textContent = err.message || '서버 연결에 실패했습니다.';
|
|
errorDiv.style.display = 'block';
|
|
} finally {
|
|
// 로딩 상태 해제
|
|
submitBtn.disabled = false;
|
|
submitBtn.textContent = originalText;
|
|
}
|
|
}); |