import { IdentityProvider } from "@prisma/client"; import { Trans } from "next-i18next"; import { Controller, useForm } from "react-hook-form"; import { useLocale } from "@calcom/lib/hooks/useLocale"; import { trpc } from "@calcom/trpc/react"; import { Button } from "@calcom/ui/v2/core/Button"; import Meta from "@calcom/ui/v2/core/Meta"; import { Form, TextField } from "@calcom/ui/v2/core/form/fields"; import { getLayout } from "@calcom/ui/v2/core/layouts/AdminLayout"; import showToast from "@calcom/ui/v2/core/notifications"; import { identityProviderNameMap } from "@lib/auth"; const PasswordView = () => { const { t } = useLocale(); const { data: user } = trpc.useQuery(["viewer.me"]); const mutation = trpc.useMutation("viewer.auth.changePassword", { onSuccess: () => { showToast(t("password_updated_successfully"), "success"); }, onError: (error) => { showToast(`${t("error_updating_password")}, ${error.message}`, "error"); }, }); const formMethods = useForm(); return ( <> {user && user.identityProvider !== IdentityProvider.CAL ? (

{t("account_managed_by_identity_provider", { provider: identityProviderNameMap[user.identityProvider], })}

{t("account_managed_by_identity_provider_description", { provider: identityProviderNameMap[user.identityProvider], })}

) : (
{ const { oldPassword, newPassword } = values; mutation.mutate({ oldPassword, newPassword }); }}>
( { formMethods.setValue("oldPassword", e?.target.value); }} /> )} /> ( { formMethods.setValue("newPassword", e?.target.value); }} /> )} />

Password must be at least at least 7 characters, mix of uppercase & lowercase letters, and contain at least 1 number

)} ); }; PasswordView.getLayout = getLayout; export default PasswordView;