Reverted to edit edt-cc8c9d33-73bd-45b2-a3f9-92544ffafa1a: "Implement user authentication

Implement login functionality and user authentication logic."
This commit is contained in:
gpt-engineer-app[bot]
2025-03-15 06:52:00 +00:00
parent a1dc2b5370
commit b8866daab9

View File

@@ -1,3 +1,4 @@
import React, { useState, useEffect } from 'react'; import React, { useState, useEffect } from 'react';
import { Switch } from "@/components/ui/switch"; import { Switch } from "@/components/ui/switch";
import { Label } from "@/components/ui/label"; import { Label } from "@/components/ui/label";
@@ -7,18 +8,19 @@ import { toast } from "@/components/ui/use-toast";
import { useAuth } from "@/contexts/AuthContext"; import { useAuth } from "@/contexts/AuthContext";
import { useNavigate } from "react-router-dom"; import { useNavigate } from "react-router-dom";
import { Button } from "@/components/ui/button"; import { Button } from "@/components/ui/button";
const SyncSettings = () => { const SyncSettings = () => {
const [enabled, setEnabled] = useState(isSyncEnabled()); const [enabled, setEnabled] = useState(isSyncEnabled());
const [syncing, setSyncing] = useState(false); const [syncing, setSyncing] = useState(false);
const [lastSync, setLastSync] = useState<string | null>(getLastSyncTime()); const [lastSync, setLastSync] = useState<string | null>(getLastSyncTime());
const { const { user } = useAuth();
user
} = useAuth();
const navigate = useNavigate(); const navigate = useNavigate();
useEffect(() => { useEffect(() => {
// 마지막 동기화 시간 업데이트 // 마지막 동기화 시간 업데이트
setLastSync(getLastSyncTime()); setLastSync(getLastSyncTime());
}, []); }, []);
const handleSyncToggle = async (checked: boolean) => { const handleSyncToggle = async (checked: boolean) => {
if (!user && checked) { if (!user && checked) {
toast({ toast({
@@ -28,8 +30,10 @@ const SyncSettings = () => {
}); });
return; return;
} }
setEnabled(checked); setEnabled(checked);
setSyncEnabled(checked); setSyncEnabled(checked);
if (checked && user) { if (checked && user) {
// 동기화 활성화 시 즉시 동기화 실행 // 동기화 활성화 시 즉시 동기화 실행
try { try {
@@ -37,7 +41,7 @@ const SyncSettings = () => {
await syncAllData(user.id); await syncAllData(user.id);
toast({ toast({
title: "동기화 설정 완료", title: "동기화 설정 완료",
description: "모든 데이터가 클라우드에 동기화되었습니다." description: "모든 데이터가 클라우드에 동기화되었습니다.",
}); });
setLastSync(getLastSyncTime()); setLastSync(getLastSyncTime());
} catch (error) { } catch (error) {
@@ -51,6 +55,7 @@ const SyncSettings = () => {
} }
} }
}; };
const handleManualSync = async () => { const handleManualSync = async () => {
if (!user) { if (!user) {
toast({ toast({
@@ -60,12 +65,13 @@ const SyncSettings = () => {
}); });
return; return;
} }
try { try {
setSyncing(true); setSyncing(true);
await syncAllData(user.id); await syncAllData(user.id);
toast({ toast({
title: "동기화 완료", title: "동기화 완료",
description: "모든 데이터가 클라우드에 동기화되었습니다." description: "모든 데이터가 클라우드에 동기화되었습니다.",
}); });
setLastSync(getLastSyncTime()); setLastSync(getLastSyncTime());
} catch (error) { } catch (error) {
@@ -78,12 +84,16 @@ const SyncSettings = () => {
setSyncing(false); setSyncing(false);
} }
}; };
const formatLastSyncTime = () => { const formatLastSyncTime = () => {
if (!lastSync) return "아직 동기화된 적 없음"; if (!lastSync) return "아직 동기화된 적 없음";
const date = new Date(lastSync); const date = new Date(lastSync);
return `${date.toLocaleDateString()} ${date.toLocaleTimeString()}`; return `${date.toLocaleDateString()} ${date.toLocaleTimeString()}`;
}; };
return <div className="space-y-6">
return (
<div className="space-y-6">
<div className="flex items-center justify-between"> <div className="flex items-center justify-between">
<div className="space-y-0.5"> <div className="space-y-0.5">
<div className="flex items-center gap-2"> <div className="flex items-center gap-2">
@@ -96,20 +106,40 @@ const SyncSettings = () => {
. .
</p> </p>
</div> </div>
<Switch id="sync-toggle" checked={enabled} onCheckedChange={handleSyncToggle} /> <Switch
id="sync-toggle"
checked={enabled}
onCheckedChange={handleSyncToggle}
/>
</div> </div>
{enabled && <div className="space-y-3"> {enabled && (
<div className="space-y-3">
<div className="flex justify-between items-center text-sm"> <div className="flex justify-between items-center text-sm">
<span className="text-muted-foreground"> : {formatLastSyncTime()}</span> <span className="text-muted-foreground"> : {formatLastSyncTime()}</span>
{user ? <button onClick={handleManualSync} disabled={syncing} className="neuro-button py-1 px-3 flex items-center gap-1"> {user ? (
<button
onClick={handleManualSync}
disabled={syncing}
className="neuro-button py-1 px-3 flex items-center gap-1"
>
<RefreshCw className={`h-4 w-4 ${syncing ? 'animate-spin' : ''}`} /> <RefreshCw className={`h-4 w-4 ${syncing ? 'animate-spin' : ''}`} />
<span>{syncing ? '동기화 중...' : '지금 동기화'}</span> <span>{syncing ? '동기화 중...' : '지금 동기화'}</span>
</button> : <Button onClick={() => navigate('/login')} size="sm" className="py-1 px-3 text-neuro-income"> </button>
) : (
<Button
onClick={() => navigate('/login')}
size="sm"
className="py-1 px-3"
>
</Button>} </Button>
)}
</div> </div>
</div>} </div>
</div>; )}
</div>
);
}; };
export default SyncSettings;
export default SyncSettings;