Visual edit in Lovable

Edited UI in Lovable
This commit is contained in:
gpt-engineer-app[bot]
2025-03-15 22:44:03 +00:00
parent 2f5f62cd96
commit 668d100dd8

View File

@@ -1,11 +1,9 @@
import React from "react"; import React from "react";
import { Link } from "react-router-dom"; import { Link } from "react-router-dom";
import { Label } from "@/components/ui/label"; import { Label } from "@/components/ui/label";
import { Input } from "@/components/ui/input"; import { Input } from "@/components/ui/input";
import { Button } from "@/components/ui/button"; import { Button } from "@/components/ui/button";
import { ArrowRight, Mail, KeyRound, Eye, EyeOff, AlertTriangle, Loader2 } from "lucide-react"; import { ArrowRight, Mail, KeyRound, Eye, EyeOff, AlertTriangle, Loader2 } from "lucide-react";
interface LoginFormProps { interface LoginFormProps {
email: string; email: string;
setEmail: (email: string) => void; setEmail: (email: string) => void;
@@ -18,7 +16,6 @@ interface LoginFormProps {
loginError: string | null; loginError: string | null;
handleLogin: (e: React.FormEvent) => Promise<void>; handleLogin: (e: React.FormEvent) => Promise<void>;
} }
const LoginForm: React.FC<LoginFormProps> = ({ const LoginForm: React.FC<LoginFormProps> = ({
email, email,
setEmail, setEmail,
@@ -32,28 +29,15 @@ const LoginForm: React.FC<LoginFormProps> = ({
handleLogin handleLogin
}) => { }) => {
// CORS 또는 JSON 관련 오류인지 확인 // CORS 또는 JSON 관련 오류인지 확인
const isCorsOrJsonError = loginError && const isCorsOrJsonError = loginError && (loginError.includes('JSON') || loginError.includes('CORS') || loginError.includes('프록시') || loginError.includes('서버 응답') || loginError.includes('네트워크') || loginError.includes('404') || loginError.includes('Not Found'));
(loginError.includes('JSON') || loginError.includes('CORS') || return <div className="neuro-flat p-8 mb-6">
loginError.includes('프록시') || loginError.includes('서버 응답') ||
loginError.includes('네트워크') ||
loginError.includes('404') || loginError.includes('Not Found'));
return (
<div className="neuro-flat p-8 mb-6">
<form onSubmit={handleLogin}> <form onSubmit={handleLogin}>
<div className="space-y-6"> <div className="space-y-6">
<div className="space-y-2"> <div className="space-y-2">
<Label htmlFor="email" className="text-base"></Label> <Label htmlFor="email" className="text-base"></Label>
<div className="relative"> <div className="relative">
<Mail className="absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-500 h-5 w-5" /> <Mail className="absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-500 h-5 w-5" />
<Input <Input id="email" type="email" placeholder="your@email.com" value={email} onChange={e => setEmail(e.target.value)} className="pl-10 neuro-pressed" />
id="email"
type="email"
placeholder="your@email.com"
value={email}
onChange={e => setEmail(e.target.value)}
className="pl-10 neuro-pressed"
/>
</div> </div>
</div> </div>
@@ -61,42 +45,27 @@ const LoginForm: React.FC<LoginFormProps> = ({
<Label htmlFor="password" className="text-base"></Label> <Label htmlFor="password" className="text-base"></Label>
<div className="relative"> <div className="relative">
<KeyRound className="absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-500 h-5 w-5" /> <KeyRound className="absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-500 h-5 w-5" />
<Input <Input id="password" type={showPassword ? "text" : "password"} placeholder="••••••••" value={password} onChange={e => setPassword(e.target.value)} className="pl-10 neuro-pressed" />
id="password" <button type="button" onClick={() => setShowPassword(!showPassword)} className="absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-500">
type={showPassword ? "text" : "password"}
placeholder="••••••••"
value={password}
onChange={e => setPassword(e.target.value)}
className="pl-10 neuro-pressed"
/>
<button
type="button"
onClick={() => setShowPassword(!showPassword)}
className="absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-500"
>
{showPassword ? <EyeOff className="h-5 w-5" /> : <Eye className="h-5 w-5" />} {showPassword ? <EyeOff className="h-5 w-5" /> : <Eye className="h-5 w-5" />}
</button> </button>
</div> </div>
</div> </div>
{loginError && ( {loginError && <div className={`p-3 ${isCorsOrJsonError ? 'bg-amber-50 text-amber-800' : 'bg-red-50 text-red-600'} rounded-md text-sm`}>
<div className={`p-3 ${isCorsOrJsonError ? 'bg-amber-50 text-amber-800' : 'bg-red-50 text-red-600'} rounded-md text-sm`}>
<div className="flex items-start gap-2"> <div className="flex items-start gap-2">
<AlertTriangle className="h-5 w-5 flex-shrink-0 mt-0.5 text-amber-500" /> <AlertTriangle className="h-5 w-5 flex-shrink-0 mt-0.5 text-amber-500" />
<div> <div>
<p className="font-medium">{loginError}</p> <p className="font-medium">{loginError}</p>
{isCorsOrJsonError && ( {isCorsOrJsonError && <ul className="mt-2 list-disc pl-5 text-xs space-y-1 text-amber-700">
<ul className="mt-2 list-disc pl-5 text-xs space-y-1 text-amber-700">
<li> CORS .</li> <li> CORS .</li>
<li>HTTPS URL을 Supabase .</li> <li>HTTPS URL을 Supabase .</li>
<li> .</li> <li> .</li>
</ul> </ul>}
)}
</div> </div>
</div> </div>
</div> </div>}
)}
<div className="text-right"> <div className="text-right">
<Link to="/forgot-password" className="text-sm text-neuro-income hover:underline"> <Link to="/forgot-password" className="text-sm text-neuro-income hover:underline">
@@ -104,22 +73,12 @@ const LoginForm: React.FC<LoginFormProps> = ({
</Link> </Link>
</div> </div>
<Button <Button type="submit" disabled={isLoading || isSettingUpTables} className="w-full hover:bg-neuro-income/80 text-white h-auto bg-neuro-income text-lg py-[10px]">
type="submit" {isLoading ? "로그인 중..." : isSettingUpTables ? "데이터베이스 설정 중..." : "로그인"}
disabled={isLoading || isSettingUpTables} {!isLoading && !isSettingUpTables ? <ArrowRight className="ml-2 h-5 w-5" /> : <Loader2 className="ml-2 h-5 w-5 animate-spin" />}
className="w-full hover:bg-neuro-income/80 text-white py-6 h-auto bg-neuro-income"
>
{isLoading ? "로그인 중..." :
isSettingUpTables ? "데이터베이스 설정 중..." :
"로그인"}
{!isLoading && !isSettingUpTables ?
<ArrowRight className="ml-2 h-5 w-5" /> :
<Loader2 className="ml-2 h-5 w-5 animate-spin" />}
</Button> </Button>
</div> </div>
</form> </form>
</div> </div>;
);
}; };
export default LoginForm; export default LoginForm;