From 662856f7e52418475044e52f0b57cf01c4135b8e Mon Sep 17 00:00:00 2001 From: markgol777 Date: Tue, 12 Nov 2024 21:53:40 +0100 Subject: [PATCH 1/2] converted ResetPassword component from jsx to tsx --- .../{ResetPassword.jsx => ResetPassword.tsx} | 26 +++++++++++-------- src/services/auth-service.ts | 2 +- .../user/user-interfaces/user.interfaces.ts | 9 +++++++ 3 files changed, 25 insertions(+), 12 deletions(-) rename src/containers/guest-home-page/reset-password/{ResetPassword.jsx => ResetPassword.tsx} (88%) diff --git a/src/containers/guest-home-page/reset-password/ResetPassword.jsx b/src/containers/guest-home-page/reset-password/ResetPassword.tsx similarity index 88% rename from src/containers/guest-home-page/reset-password/ResetPassword.jsx rename to src/containers/guest-home-page/reset-password/ResetPassword.tsx index 3268f712d..f96213611 100644 --- a/src/containers/guest-home-page/reset-password/ResetPassword.jsx +++ b/src/containers/guest-home-page/reset-password/ResetPassword.tsx @@ -1,4 +1,4 @@ -import { useEffect, useMemo } from 'react' +import { FC, useEffect, useMemo } from 'react' import { useTranslation } from 'react-i18next' import useForm from '~/hooks/use-form' @@ -19,14 +19,20 @@ import TitleWithDescription from '~/components/title-with-description/TitleWithD import LoginDialog from '~/containers/guest-home-page/login-dialog/LoginDialog' import { styles } from '~/containers/guest-home-page/reset-password/ResetPassword.styles' -import { ButtonVariantEnum, SizeEnum } from '~/types' +import { ButtonVariantEnum, SizeEnum, NewPassword } from '~/types' import { confirmPassword, password } from '~/utils/validations/login' import { snackbarVariants } from '~/constants' import imgSuccess from '~/assets/img/email-confirmation-modals/success-icon.svg' import { openAlert } from '~/redux/features/snackbarSlice' import { getErrorKey } from '~/utils/get-error-key' +import { Component } from '~/context/modal-context' -const ResetPassword = ({ resetToken, openModal }) => { +interface ResetPasswordProps { + resetToken: string + openModal: (component: Component, delayToClose?: number) => void +} + +const ResetPassword: FC = ({ resetToken, openModal }) => { const { t } = useTranslation() const dispatch = useAppDispatch() @@ -57,7 +63,7 @@ const ResetPassword = ({ resetToken, openModal }) => { loading, fetchData: sendResetPassword } = useAxios({ - service: (newPassword) => + service: (newPassword: NewPassword) => AuthService.resetPassword(resetToken, newPassword), fetchOnMount: false, defaultResponse: null @@ -76,13 +82,13 @@ const ResetPassword = ({ resetToken, openModal }) => { } }, [error, openModal, response, dispatch, successNotification]) - const { handleSubmit, handleInputChange, handleBlur, errors, data } = useForm( - { - onSubmit: () => sendResetPassword({ password: data.password }), + const { handleSubmit, handleInputChange, handleBlur, errors, data } = + useForm({ + onSubmit: (): Promise => + sendResetPassword({ password: data.password }), initialValues: { password: '', confirmPassword: '' }, validations: { password, confirmPassword } - } - ) + }) const { inputVisibility: passwordVisibility, showInputText: showPassword } = useInputVisibility(errors.password) @@ -107,7 +113,6 @@ const ResetPassword = ({ resetToken, openModal }) => { onBlur={handleBlur('password')} onChange={handleInputChange('password')} required - size='large' sx={{ mb: '5px' }} type={showPassword ? 'text' : 'password'} value={data.password} @@ -120,7 +125,6 @@ const ResetPassword = ({ resetToken, openModal }) => { onBlur={handleBlur('confirmPassword')} onChange={handleInputChange('confirmPassword')} required - size='large' type={showConfirmPassword ? 'text' : 'password'} value={data.confirmPassword} /> diff --git a/src/services/auth-service.ts b/src/services/auth-service.ts index ee50a04d5..76c2f1a15 100644 --- a/src/services/auth-service.ts +++ b/src/services/auth-service.ts @@ -30,7 +30,7 @@ export const AuthService = { }, resetPassword: ( resetToken: string, - newPassword: string + newPassword: { password: string } ): Promise => { const confirmUrl = createUrlPath(URLs.auth.resetPassword, resetToken) return axiosClient.patch(confirmUrl, newPassword) diff --git a/src/types/user/user-interfaces/user.interfaces.ts b/src/types/user/user-interfaces/user.interfaces.ts index 71523dc54..f9ce8f30b 100644 --- a/src/types/user/user-interfaces/user.interfaces.ts +++ b/src/types/user/user-interfaces/user.interfaces.ts @@ -103,6 +103,15 @@ export interface ChangePasswordParams { confirmPassword: string } +export interface NewPassword { + confirmPassword?: string + password: string +} + +export interface SendResetPasswordPayload { + password: string +} + export interface SignupResponse { userId: string userEmail: string From 602909372b230cf2e29254639624fccaf8b7b6d5 Mon Sep 17 00:00:00 2001 From: markgol777 Date: Thu, 14 Nov 2024 13:11:15 +0100 Subject: [PATCH 2/2] added async for clarity of the code --- src/containers/guest-home-page/reset-password/ResetPassword.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/containers/guest-home-page/reset-password/ResetPassword.tsx b/src/containers/guest-home-page/reset-password/ResetPassword.tsx index f96213611..135b8c468 100644 --- a/src/containers/guest-home-page/reset-password/ResetPassword.tsx +++ b/src/containers/guest-home-page/reset-password/ResetPassword.tsx @@ -84,7 +84,7 @@ const ResetPassword: FC = ({ resetToken, openModal }) => { const { handleSubmit, handleInputChange, handleBlur, errors, data } = useForm({ - onSubmit: (): Promise => + onSubmit: async (): Promise => sendResetPassword({ password: data.password }), initialValues: { password: '', confirmPassword: '' }, validations: { password, confirmPassword }