From c87db85815d84ddf907d0a1d26226a2ab911181b Mon Sep 17 00:00:00 2001 From: MohamedBassem Date: Mon, 11 Mar 2024 12:24:51 +0000 Subject: mobile: An ugly yet functional signin workflow --- packages/mobile/app/_layout.tsx | 4 +- packages/mobile/app/dashboard.tsx | 35 +++++++++++++++ packages/mobile/app/index.tsx | 7 ++- packages/mobile/app/signin.tsx | 83 ++++++++++++++++++++++++++++++++++-- packages/mobile/lib/providers.tsx | 5 ++- packages/mobile/lib/settings.ts | 28 ++++-------- packages/mobile/lib/storage-state.ts | 50 ++++++++++++++++++++++ 7 files changed, 182 insertions(+), 30 deletions(-) create mode 100644 packages/mobile/app/dashboard.tsx create mode 100644 packages/mobile/lib/storage-state.ts diff --git a/packages/mobile/app/_layout.tsx b/packages/mobile/app/_layout.tsx index b37585e2..d3cbbee1 100644 --- a/packages/mobile/app/_layout.tsx +++ b/packages/mobile/app/_layout.tsx @@ -11,9 +11,7 @@ import { Providers } from "@/lib/providers"; export default function RootLayout() { const router = useRouter(); - const { hasShareIntent, shareIntent, resetShareIntent } = useShareIntent({ - debug: true, - }); + const { hasShareIntent, shareIntent, resetShareIntent } = useShareIntent(); useEffect(() => { if (hasShareIntent) { diff --git a/packages/mobile/app/dashboard.tsx b/packages/mobile/app/dashboard.tsx new file mode 100644 index 00000000..8be57615 --- /dev/null +++ b/packages/mobile/app/dashboard.tsx @@ -0,0 +1,35 @@ +import { useRouter } from "expo-router"; +import { useEffect } from "react"; +import { Text, View } from "react-native"; + +import Logo from "@/components/Logo"; +import { Button } from "@/components/ui/Button"; +import useAppSettings from "@/lib/settings"; +import { api } from "@/lib/trpc"; + +export default function Main() { + const router = useRouter(); + const { settings, setSettings, isLoading } = useAppSettings(); + + useEffect(() => { + if (!isLoading && !settings.apiKey) { + router.replace("signin"); + } + }, [settings, isLoading]); + + const onLogout = () => { + setSettings({ ...settings, apiKey: undefined }); + }; + + const { data } = api.users.whoami.useQuery(); + + return ( + + + + Logged in as: {isLoading ? "Loading ..." : data?.email} + +