diff --git a/web/app/routes/$userName+/edit/route.tsx b/web/app/routes/$userName+/edit/route.tsx index 852e6518..ff7bd2d9 100644 --- a/web/app/routes/$userName+/edit/route.tsx +++ b/web/app/routes/$userName+/edit/route.tsx @@ -6,17 +6,20 @@ import { } from "@conform-to/react"; import { getZodConstraint, parseWithZod } from "@conform-to/zod"; import type { ActionFunctionArgs, LoaderFunctionArgs } from "@remix-run/node"; -import { redirect } from "@remix-run/node"; import { Form } from "@remix-run/react"; +import { Link } from "@remix-run/react"; +import { useNavigation } from "@remix-run/react"; +import { ArrowLeft } from "lucide-react"; +import { useState } from "react"; import { typedjson, useTypedLoaderData } from "remix-typedjson"; import { z } from "zod"; import { Button } from "~/components/ui/button"; import { Input } from "~/components/ui/input"; import { Label } from "~/components/ui/label"; +import { GeminiApiKeyDialog } from "~/routes/resources+/gemini-api-key-dialog"; import { authenticator, sanitizeUser } from "~/utils/auth.server"; import { commitSession, getSession } from "~/utils/session.server"; import { updateUser } from "./functions/mutations.server"; - const schema = z.object({ displayName: z .string() @@ -54,17 +57,15 @@ export const action = async ({ request }: ActionFunctionArgs) => { }); const session = await getSession(request.headers.get("Cookie")); session.set("user", sanitizeUser(updatedUser)); - - return redirect(`/${currentUser.userName}`, { - headers: { - "Set-Cookie": await commitSession(session), - }, - }); + await commitSession(session); + return null; }; export default function EditProfile() { const { currentUser } = useTypedLoaderData(); - + const [isGeminiApiKeyDialogOpen, setIsGeminiApiKeyDialogOpen] = + useState(false); + const navigation = useNavigation(); const [form, { displayName, profile }] = useForm({ id: "edit-profile-form", constraint: getZodConstraint(schema), @@ -80,27 +81,51 @@ export default function EditProfile() { }); return (
-

Edit Profile

-
-
- - -
- {displayName.errors} + + + +
+

Edit Profile

+ +
+ + +
+ {displayName.errors} +
-
-
- -