feat: add auth to context

This commit is contained in:
Max Koon
2025-11-15 22:08:58 -05:00
parent 641dc25bee
commit 114eaf88eb
11 changed files with 250 additions and 37 deletions

View File

@@ -1,17 +1,18 @@
import { useLocalSearchParams } from "expo-router";
import { Text } from "react-native";
import { App } from "@money/ui";
import { App, type Route } from "@money/ui";
import { useEffect, useState } from "react";
import { authClient } from "@/lib/auth-client";
export default function Page() {
const { route: initalRoute } = useLocalSearchParams<{ route: string[] }>();
const [route, setRoute] = useState(initalRoute[0]!);
const [route, setRoute] = useState(initalRoute ? "/" + initalRoute.join("/") : "/");
const { data } = authClient.useSession();
// detect back/forward
useEffect(() => {
const handler = () => {
const newRoute = window.location.pathname.slice(1);
// call your apps page change logic
setRoute(newRoute);
};
@@ -21,9 +22,11 @@ export default function Page() {
return (
<App
page={route as any}
onPageChange={(page) => {
window.history.pushState({}, "", "/" + page);
auth={data}
route={route as Route}
setRoute={(page) => {
window.history.pushState({}, "", page);
setRoute(page);
}}
/>
);

View File

@@ -1,8 +1,9 @@
import { RGBA, TextAttributes, createCliRenderer } from "@opentui/core";
import { createRoot } from "@opentui/react";
import { App } from "@money/ui";
import { App, type Route } from "@money/ui";
import { ZeroProvider } from "@rocicorp/zero/react";
import { schema } from '@money/shared';
import { useState } from "react";
const userID = "anon";
const server = "http://laptop:4848";
@@ -11,10 +12,22 @@ const auth = undefined;
function Main() {
return (
<ZeroProvider {...{ userID, auth, server, schema }}>
<App />
<Router />
</ZeroProvider>
);
}
function Router() {
const [route, setRoute] = useState<Route>("/");
return (
<App
auth={null}
route={route}
setRoute={setRoute}
/>
);
}
const renderer = await createCliRenderer();
createRoot(renderer).render(<Main />);