Files
xrlms/src/app/login/page.tsx

138 lines
4.4 KiB
TypeScript
Raw Normal View History

2025-11-16 18:29:54 +09:00
"use client";
import { useState } from "react";
import Link from "next/link";
2025-11-17 10:36:53 +09:00
import MainLogo from "@/app/svgs/mainlogosvg"
2025-11-16 18:29:54 +09:00
export default function LoginPage() {
const [userId, setUserId] = useState("");
const [password, setPassword] = useState("");
const [rememberId, setRememberId] = useState(false);
const [autoLogin, setAutoLogin] = useState(false);
function handleSubmit(e: React.FormEvent<HTMLFormElement>) {
e.preventDefault();
2025-11-17 22:51:23 +09:00
/* todo */
2025-11-16 18:29:54 +09:00
console.log({ userId, password, rememberId, autoLogin });
}
return (
2025-11-17 22:51:23 +09:00
<div className="min-h-screen w-full flex flex-col items-center justify-between">
<div></div>
<div className="rounded-xl bg-white max-w-[560px] px-[40px] w-full">
2025-11-16 18:29:54 +09:00
{/* 로고 영역 */}
2025-11-17 22:51:23 +09:00
<div className="my-10 flex flex-col items-center">
2025-11-17 10:36:53 +09:00
<div className="mb-[7px]">
<MainLogo/>
</div>
2025-11-17 22:51:23 +09:00
<div className="text-[28.8px] font-extrabold leading-[145%] text-neutral-700" >
2025-11-16 18:29:54 +09:00
XR LMS
</div>
</div>
{/* 폼 */}
<form onSubmit={handleSubmit} className="space-y-6">
<div className="space-y-4">
{/* 아이디 */}
<div>
<label htmlFor="userId" className="sr-only">
</label>
<input
id="userId"
name="userId"
value={userId}
onChange={(e) => setUserId(e.target.value)}
2025-11-17 10:36:53 +09:00
placeholder="아이디 (이메일)"
2025-11-17 22:51:23 +09:00
className="
h-[56px] px-[12px] py-[7px] w-full rounded-[8px] border border-neutral-40
2025-11-17 10:36:53 +09:00
focus:outline-none focus:ring-0 focus:ring-offset-0 focus:shadow-none
focus:appearance-none focus:border-neutral-700
2025-11-17 22:51:23 +09:00
text-[18px] text-neutral-700 font-normal leading-[150%] placeholder:text-input-placeholder-text
"
2025-11-16 18:29:54 +09:00
/>
</div>
{/* 비밀번호 */}
<div>
<label htmlFor="password" className="sr-only">
</label>
<input
id="password"
name="password"
type="password"
value={password}
onChange={(e) => setPassword(e.target.value)}
placeholder="비밀번호"
2025-11-17 22:51:23 +09:00
className="
h-[56px] px-[12px] py-[7px] rounded-[8px] w-full border border-neutral-40
focus:outline-none focus:ring-0 focus:ring-offset-0 focus:shadow-none
focus:appearance-none focus:border-neutral-700
text-[18px] text-neutral-700 font-normal leading-[150%] placeholder:text-input-placeholder-text
"
2025-11-16 18:29:54 +09:00
/>
</div>
</div>
{/* 체크박스들 */}
<div className="flex items-center justify-start gap-6">
2025-11-17 22:51:23 +09:00
<label className="flex cursor-pointer select-none items-center gap-2 text-[15px] font-normal text-basic-text">
2025-11-16 18:29:54 +09:00
<input
type="checkbox"
checked={rememberId}
onChange={(e) => setRememberId(e.target.checked)}
2025-11-17 22:51:23 +09:00
className="h-[18px] w-[18px] cursor-pointer rounded border
accent-input-border-select border-inactive-checkbox"
2025-11-16 18:29:54 +09:00
/>
</label>
2025-11-17 22:51:23 +09:00
<label className="flex cursor-pointer select-none items-center gap-2 text-[15px] font-normal text-basic-text">
2025-11-16 18:29:54 +09:00
<input
type="checkbox"
checked={autoLogin}
onChange={(e) => setAutoLogin(e.target.checked)}
2025-11-17 22:51:23 +09:00
className="h-[18px] w-[18px] cursor-pointer rounded border
accent-input-border-select border-inactive-checkbox"
2025-11-16 18:29:54 +09:00
/>
</label>
</div>
{/* 로그인 버튼 */}
<button
type="submit"
2025-11-17 22:51:23 +09:00
className="h-14 w-full rounded-lg text-[16px] font-semibold text-white transition-opacity cursor-pointer bg-inactive-button"
2025-11-16 18:29:54 +09:00
>
</button>
{/* 하단 링크들 */}
<div className="flex items-center justify-between text-[15px]">
<Link
2025-11-17 22:51:23 +09:00
href="/register"
className="underline-offset-2 text-basic-text"
2025-11-16 18:29:54 +09:00
>
</Link>
<div
2025-11-17 22:51:23 +09:00
className="flex items-center gap-3 text-basic-text"
2025-11-16 18:29:54 +09:00
>
2025-11-17 22:51:23 +09:00
<Link href="#" className="underline-offset-2">
2025-11-16 18:29:54 +09:00
</Link>
2025-11-17 22:51:23 +09:00
<span className="h-3 w-px bg-input-border" />
<Link href="#" className="underline-offset-2">
2025-11-16 18:29:54 +09:00
</Link>
</div>
</div>
</form>
</div>
2025-11-17 22:51:23 +09:00
<div></div>
<p className="text-center py-[40px] text-[15px] text-basic-text">
2025-11-16 18:29:54 +09:00
Copyright 2025 XL LMS. All rights reserved
</p>
</div>
);
}