api link to page
This commit is contained in:
@@ -6,6 +6,7 @@ import ChangePasswordModal from "../ChangePasswordModal";
|
||||
import PasswordChangeDoneModal from "../PasswordChangeDoneModal";
|
||||
import AccountDeleteModal from "../AccountDeleteModal";
|
||||
import MenuAccountOption from "@/app/menu/account/MenuAccountOption";
|
||||
import apiService from "@/app/lib/apiService";
|
||||
|
||||
type VerificationState = 'initial' | 'sent' | 'verified' | 'failed' | 'changed';
|
||||
|
||||
@@ -51,38 +52,19 @@ export default function AccountPage() {
|
||||
localStorage.setItem('token', cookieToken);
|
||||
}
|
||||
|
||||
const apiUrl = process.env.NEXT_PUBLIC_API_BASE_URL
|
||||
? `${process.env.NEXT_PUBLIC_API_BASE_URL}/auth/me`
|
||||
: 'https://hrdi.coconutmeet.net/auth/me';
|
||||
const response = await apiService.getCurrentUser();
|
||||
|
||||
const response = await fetch(apiUrl, {
|
||||
method: 'GET',
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
...(token && { Authorization: `Bearer ${token}` }),
|
||||
},
|
||||
});
|
||||
if (response.status === 401) {
|
||||
// 토큰이 만료되었거나 유효하지 않은 경우
|
||||
localStorage.removeItem('token');
|
||||
if (isMounted) {
|
||||
router.push('/login');
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if (!response.ok) {
|
||||
if (response.status === 401) {
|
||||
// 토큰이 만료되었거나 유효하지 않은 경우
|
||||
localStorage.removeItem('token');
|
||||
if (isMounted) {
|
||||
router.push('/login');
|
||||
}
|
||||
return;
|
||||
}
|
||||
let errorMessage = `사용자 정보 조회 실패 (${response.status})`;
|
||||
try {
|
||||
const errorData = await response.json();
|
||||
if (errorData.error) {
|
||||
errorMessage = errorData.error;
|
||||
} else if (errorData.message) {
|
||||
errorMessage = errorData.message;
|
||||
}
|
||||
} catch (parseError) {
|
||||
// ignore
|
||||
}
|
||||
if (response.status !== 200) {
|
||||
const errorMessage = response.message || `사용자 정보 조회 실패 (${response.status})`;
|
||||
console.error('사용자 정보 조회 실패:', errorMessage);
|
||||
if (isMounted) {
|
||||
setIsLoading(false);
|
||||
@@ -90,7 +72,7 @@ export default function AccountPage() {
|
||||
return;
|
||||
}
|
||||
|
||||
const data = await response.json();
|
||||
const data = response.data;
|
||||
if (isMounted) {
|
||||
setUserInfo(data);
|
||||
setIsLoading(false);
|
||||
@@ -191,35 +173,7 @@ export default function AccountPage() {
|
||||
onClose={() => setDeleteOpen(false)}
|
||||
onConfirm={async () => {
|
||||
try {
|
||||
const token = localStorage.getItem('token');
|
||||
const response = await fetch('https://hrdi.coconutmeet.net/auth/delete/me', {
|
||||
method: 'DELETE',
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
...(token && { Authorization: `Bearer ${token}` }),
|
||||
},
|
||||
});
|
||||
|
||||
if (!response.ok) {
|
||||
let errorMessage = `회원 탈퇴 실패 (${response.status})`;
|
||||
try {
|
||||
const errorData = await response.json();
|
||||
if (errorData.error) {
|
||||
errorMessage = errorData.error;
|
||||
} else if (errorData.message) {
|
||||
errorMessage = errorData.message;
|
||||
} else if (response.statusText) {
|
||||
errorMessage = `${response.statusText} (${response.status})`;
|
||||
}
|
||||
} catch (parseError) {
|
||||
if (response.statusText) {
|
||||
errorMessage = `${response.statusText} (${response.status})`;
|
||||
}
|
||||
}
|
||||
console.error('회원 탈퇴 실패:', errorMessage);
|
||||
alert(errorMessage);
|
||||
return;
|
||||
}
|
||||
await apiService.deleteAccount();
|
||||
|
||||
// 성공 시 토큰 제거 및 로그인 페이지로 이동
|
||||
localStorage.removeItem('token');
|
||||
|
||||
Reference in New Issue
Block a user