import { usePathname, useRouter } from "next/navigation";
import { z } from "zod";
import NoSSR from "@calcom/core/components/NoSSR";
import { useParamsWithFallback } from "@calcom/lib/hooks/useParamsWithFallback";
import { getParserWithGeneric } from "@calcom/prisma/zod-utils";
import { trpc } from "@calcom/trpc/react";
import { Meta, showToast } from "@calcom/ui";
import { getLayout } from "../../../settings/layouts/SettingsLayout";
import LicenseRequired from "../../common/components/LicenseRequired";
import { UserForm } from "../components/UserForm";
import { userBodySchema } from "../schemas/userBodySchema";
const userIdSchema = z.object({ id: z.coerce.number() });
const UsersEditPage = () => {
const params = useParamsWithFallback();
const input = userIdSchema.safeParse(params);
if (!input.success) return
Invalid input
;
return ;
};
const UsersEditView = ({ userId }: { userId: number }) => {
const pathname = usePathname();
const router = useRouter();
const [data] = trpc.viewer.users.get.useSuspenseQuery({ userId });
const { user } = data;
const utils = trpc.useContext();
const mutation = trpc.viewer.users.update.useMutation({
onSuccess: async () => {
Promise.all([utils.viewer.users.list.invalidate(), utils.viewer.users.get.invalidate()]);
showToast("User updated successfully", "success");
router.replace(`${pathname?.split("/users/")[0]}/users`);
},
onError: (err) => {
console.error(err.message);
showToast("There has been an error updating this user.", "error");
},
});
return (
{
const parser = getParserWithGeneric(userBodySchema);
const parsedValues = parser(values);
const data: Partial = {
...parsedValues,
userId: user.id,
};
// Don't send username if it's the same as the current one
if (user.username === data.username) delete data.username;
mutation.mutate(data);
}}
defaultValues={user}
/>
);
};
UsersEditPage.getLayout = getLayout;
export default UsersEditPage;