Reverted to edit edt-cc8c9d33-73bd-45b2-a3f9-92544ffafa1a: "Implement user authentication
Implement login functionality and user authentication logic."
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user