aboutsummaryrefslogtreecommitdiffstats
path: root/packages/mobile/app/dashboard.tsx
diff options
context:
space:
mode:
authorMohamedBassem <me@mbassem.com>2024-03-11 14:36:04 +0000
committerMohamedBassem <me@mbassem.com>2024-03-11 14:36:47 +0000
commite1c511c7c27034f94b8598b44467782af346b9c1 (patch)
tree3b75e0277e3c795d6f03a60007363e54ad73e2ac /packages/mobile/app/dashboard.tsx
parentb3f081b300125cfe43af38001fee392083a4b880 (diff)
downloadkarakeep-e1c511c7c27034f94b8598b44467782af346b9c1.tar.zst
mobile: Do the session routing in the homescreen
Diffstat (limited to 'packages/mobile/app/dashboard.tsx')
-rw-r--r--packages/mobile/app/dashboard.tsx23
1 files changed, 13 insertions, 10 deletions
diff --git a/packages/mobile/app/dashboard.tsx b/packages/mobile/app/dashboard.tsx
index 8be57615..b4f535c5 100644
--- a/packages/mobile/app/dashboard.tsx
+++ b/packages/mobile/app/dashboard.tsx
@@ -4,24 +4,27 @@ import { Text, View } from "react-native";
import Logo from "@/components/Logo";
import { Button } from "@/components/ui/Button";
-import useAppSettings from "@/lib/settings";
+import { useSession } from "@/lib/session";
import { api } from "@/lib/trpc";
-export default function Main() {
+export default function Dashboard() {
const router = useRouter();
- const { settings, setSettings, isLoading } = useAppSettings();
+
+ const { isLoggedIn, logout } = useSession();
useEffect(() => {
- if (!isLoading && !settings.apiKey) {
+ if (isLoggedIn !== undefined && !isLoggedIn) {
router.replace("signin");
}
- }, [settings, isLoading]);
+ }, [isLoggedIn]);
- const onLogout = () => {
- setSettings({ ...settings, apiKey: undefined });
- };
+ const { data, error, isLoading } = api.users.whoami.useQuery();
- const { data } = api.users.whoami.useQuery();
+ useEffect(() => {
+ if (error?.data?.code === "UNAUTHORIZED") {
+ logout();
+ }
+ }, [error]);
return (
<View className="flex h-full items-center justify-center gap-4 px-4">
@@ -29,7 +32,7 @@ export default function Main() {
<Text className="justify-center">
Logged in as: {isLoading ? "Loading ..." : data?.email}
</Text>
- <Button label="Log Out" onPress={onLogout} />
+ <Button label="Log Out" onPress={logout} />
</View>
);
}