TK-FB(공장관리+신고)와 M-Project(부적합관리)를 3개 독립 시스템으로 분리하기 위한 전체 코드 구조 작성. - SSO 인증 서비스 (bcrypt + pbkdf2 이중 해시 지원) - System 1: 공장관리 (TK-FB 기반, 신고 코드 제거) - System 2: 신고 (TK-FB에서 workIssue 코드 추출) - System 3: 부적합관리 (M-Project 기반) - Gateway 포털 (path-based 라우팅) - 통합 docker-compose.yml 및 배포 스크립트 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;
|
|
}
|
|
}); |