From 1f099d2c5516763a47e6b26046e5a72e5474b614 Mon Sep 17 00:00:00 2001 From: Jadowacu1 <152473876+Jadowacu1@users.noreply.github.com> Date: Mon, 8 Jul 2024 17:16:49 +0200 Subject: [PATCH] Users should be presented with a reset password link --- public/assets/images/resetPassword.png | Bin 0 -> 14865 bytes src/components/layout/Header.tsx | 2 +- src/pages/ResetPassword.tsx | 57 +++++++++++------- src/pages/SendResetPasswordLink.tsx | 41 +++++++------ src/styles/Colors.scss | 2 +- src/styles/colors.scss | 2 +- src/styles/reset-password.scss | 78 ++++++++++++++++++------- 7 files changed, 121 insertions(+), 61 deletions(-) create mode 100644 public/assets/images/resetPassword.png diff --git a/public/assets/images/resetPassword.png b/public/assets/images/resetPassword.png new file mode 100644 index 0000000000000000000000000000000000000000..1cd42109d6dba8e9d1ff8fb804ddcd038a307252 GIT binary patch literal 14865 zcmZX*bySpJ^e#Tb3@t5<(jeU>E!_wLL(eGP-7!cAqM&pMND2%vBAvq+G)hY&0xI1d z_vQ2b-QT+F-alBZ^`3e6IcJ~qp7ZQyKRdxtUxS2*fd~Wwk!WeE8i7Dy{@XtSJm5)i zc#=Qx5A18C@d#8i%=8ZgVgYHXDnALb*|H{VHyxw7srBtt&lc4Yjd9eC8`RF$vZu+{ zh+Tdwa*(ClN1o7+qJ2b2sAjWwx8Jbrj@q}uv~^j>j<)TP(7FF@7Tyu95K?1`TXr=e{YmnFkHL1gM@;0bzOo7 zh_6sTqxs#-vyJx=SCcF*xNGi8_0-6r)cqc>uAS&JdGZd(TGL0T5pkEfQ=QM@A6o9R z7RIC(bqoI@67$5HawmoxfZ8BV2&_k(+aR7WA%+i)N>DvS#D$reC9(iN-Q&RyZeYA0 zK9MWjQuY%@N{HT1aX#t7KNzEiDu5g1^W*IzbvcWHq1byZWd$2FZ%44q;19|=2*<2g zape%L(ZbDt$Nx=VVH(Mg1`JX|8?yYff;pv!l|iJ?5irO!aXQv$Ya3rU8F!c8?Sh`| zyx|E%AiX&aZS*iDy*8v~mQeLxcNkoIo?oCTJ|Fjh4mRl&?yvjj2QQ-3$*NLw-H_ZL z{Ap9Cf+H3*5+tlhI1uuvkFP=*)@jR$is>m@_unCaP5y!}C?W#uFLKCPLP%?5DI2e{ zIwiSe)zZ+E*n)$zVU~wPm=VI3!g)LuI5dm-y_LrkVgCuDXe6a6-C@|esIP0Y$JEPL zTff1mRb%Via^fgYK79f?f&m77)v?i4i+>@-G1Q-b`Y0?CX86~6CtP6)IOqN3$`xJ8Xm3Y~Tx$SdVc(3v!km(jsM5aSj2&^c-ewSe!;$_C~k=cj)d; zW%QT0P(xpOCAhv?&72Z!vRbuX8glLMO^uUZMdj-t$*)$&=nqm^M?tSxt;9UmLP1TK zIy~}`0{Uc5>TNzmEEAqX<5KG%uyj+U!xPQKN}J~dn$@+}XcS{YuR!_%TBeuh^2x6eWk34(nG3_QvX@Fj1i}WO1CuAU3#zfbj5yk``(BkO@9kDI zoWE=DTO=PtFWH3eWcasCqJ>CvDNQL}{q(jIyK(`MBz~?CxEqBb=r#MI)7N-`-)M;U zQXAHAM^voo#cwO(B1wB;GVw3kHelHL@0*sM1};+UKR#I*!bZnkRRoN+?d5GW-Q81)5HI=2-ruE9o!Gf5>7eZClVhMjM4%-;s zy|CAVZAwdlrDY!mP1Lc$nWDgUvw!HCawwwhwP1to@=T6zBEW;a{3cSFYK6O;A89E% z%sqaj-9vo*eFzo)Fo*Zhu)XU$r1J`TdTqSaBZQ2N1QGwCy|(7Kxx)Ve$1S`jij8Cx z7rdOUmqCA1$5=2z^i0Xd8+d~s71B;0zstAC&@8TF<#*s}uDNSE=600Bwc~k!lo^Xk z=7tpL;dWj?VeqA#PIW%8tH&L;W_EO+2j+YhhmSXbeub9^}hxS-K7S#`-k-gwNk{6-BRft5 z*kITls}ma#iFUZK{MVB)tEDZ+sK9)%!n<`X&QW#7Edn=R@*nF;@Ck>v0Vd1eXt8zr z97Q*2K6#wC&NF*bVs35I5BV$8XkH8Ulq1y*twf)sNxtocq`nH$0rH&JwBjHBOf1siy7RDs84ZkQ^SY%d?tpLEi;4HUhrhf4tG60 zm(Wf^2X#NE`Czt#Am7S}IAuTF9pa8kP(jMjFHFL^sDCu#qr)=^qIe&V4W@n!+WR>E zVPwr0JOgm4EN8(16n7V!GN4XaTR6kPGI2+}~F z+4ZlAMs~Zd5hmXI6V{UO<)SwoHekjKRkwXNEEM@zS%43vpNZ3UpV@@0)TN1R`k2I= zRB$ZjYZ7~DqEO#HC}#g^gc!t%@}Xu$vDflV{f+)MpXqinTG+3(VV{BS?;ORx>j5!$ zrW{^sb>0jeLqjtBYV7XPIW{hDjeSJN0gl!MDNmSMRA!achEW?XU?vZ@TSfjXF5Q zQh2bup>+?tIMJFr93PJURW1@VBTOCcccw|_@Qn7~L8M=~!f&pSLjJgq4_R$J`IhFq z)pDJq?a6xwHxOI|Rhv>jcVuz1uIm+^*--pEhA-I$2D?{p5fRuuWmhZR&_VR)XCyB^6c$ZeSZOS)R`h}#L7)%7D>A->FHUO9f7hIAHjBo zL9nI-B0b#bgI%pbd`r%!b|d!|A@rFI1`ls|JN%kv_gV+@>d)`UQuoEGH`KMu_)$-| zGs^%cUN;Zj#6j4H55z{EH>Ib1ZMz<0(wbQ7qudWU0xM~Y_ONO!5^T;%B;{+DC*NiM zt;LBjxo^i6Qsn1={H|H@bHTa?oOp9s@%K}3G#6%@8`O41<Xl3_0Gomwsf_Aj_CY)1YTef$^g-RZy%z z@x?|QuzKlmFMVGu3I;tq#Ccd2L>02BhiL|nd|B{PD?D+6Zw(cFw5>GF<~9~=3bnxM zkRY5%0zjX?%@qYncZL1H$b zxXXdd6%tukE$Z=x`@P~Wjl+pUExA^i-J^{CTXCO{*R^tm?;wg|O#ImoHtZw&{#h0y z@$Z-onA^KAy_A9s4Lso?kpX8Rn*9b9cR-CBd6mLq%de~^Ta8nsbh*`GgSuYUJdbLo zdKM?AF9in8Itfu$$`++8W;+(r>(8`T8vlu@XV;l}1OTV#mZoZ+>QWy?#_v10KLipA zjVJ!Nl0lL+%|oJn&U;6-(=J`OyrO@Fmlu100!BguAj7Q)yV-fjdYq9?4Em>ci4$z_ z#mb{!ci-(77DpvtyADT~cH*7CK7HLoY)husR~8EDP|vC}O$rEk>(00U=O=x(8S`~; z_Ot)ugKZ1?`qSlmOJ$HjTwV>gq~^)Ij(YQuP3$9wb{-i={vTnC#*_WulkB&YR6ly8 zeKUZaU2d?r7)KOas(eWq5zOA=Ql(`7&HzC*BoMm(tKZw|!3^CS;+)i8YqP^tK~<2! zM5{isxW=Sq)O^54#M-(3%x+&aA$%A_x=!UrW2d!|y%9z0A@=*DjST{)2S$AJ74Tjd zfmL8VVT?BR8@>=En#BEF(%lATZ7(1r-m7$d9F9mo`c11`pE)ISgjizU8vMy?#+NaX z5TE~&{SpS8*tr=0MO?Hpld^qLa(OMphRNyM#Be5LOJDLCAF-)TCnKGIDZRnTwUpN` zu7g{8ZTfeFxh2)(FAdL;K?DQdaUjhVF(;QlZz|@h)+`|%0D9{fk8_z5aTM{=(O4or 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 Cart - $ 100 + $ 0
{ const [showNewPassword, setShowNewPassword] = useState(false); @@ -27,6 +25,10 @@ const ResetPassword: React.FC = () => { const location = useLocation(); const dispatch = useAppDispatch(); const { user, isError, isSuccess, isLoading, message } = useAppSelector((state) => state?.auth); + const [isFormVisible, setIsFormVisible] = useState(true); + const [successMessage, setSuccessVisible] = useState(false); + // const [errorMessage, setErrorMessage] = useState(''); + const formik = useFormik({ initialValues: { password: '', @@ -34,32 +36,38 @@ const ResetPassword: React.FC = () => { }, onSubmit: (values) => { if (values.password !== values.confirmPassword) { - toast.error("Passwords do not match"); + formik.setStatus("Passwords do not match"); } else{ const pathParts = location.pathname.split('/'); const token = pathParts[pathParts.length - 1]; dispatch(resetPassword({ token, password: values.password })); + } }, }) useEffect(() => { if (isError) { - toast.error(message); + formik.setStatus(message); } if (isSuccess) { toast.success(message) - navigate('/login'); + setIsFormVisible(false); + setSuccessVisible(true); + } }, [user, isError, isSuccess, isLoading, message]) return ( <> +
+
+ {isFormVisible ? (
-

Reset password

-
+

Reset password

+
{ > -
+

{
- {isLoading ? ( -
- -
- ) : ( -
-
- )} -
+

{formik.status}


+ +
+ ) : ( +
+
+
+ +

Password is changed

navigate("/login")}>Continue to login

+
+
+
+ )}





); diff --git a/src/pages/SendResetPasswordLink.tsx b/src/pages/SendResetPasswordLink.tsx index aac7aaa0..83c27b13 100644 --- a/src/pages/SendResetPasswordLink.tsx +++ b/src/pages/SendResetPasswordLink.tsx @@ -8,7 +8,7 @@ import { sendResetLink } from '../store/features/auth/authSlice'; import '../styles/reset-password.scss'; import { toast } from 'react-toastify'; import * as Yup from 'yup'; -import { CircleLoader, PuffLoader } from 'react-spinners'; +import { PulseLoader } from 'react-spinners'; const ResetPasswordSchema = Yup.object().shape({ email: Yup.string().email('Email must be valid').required('Email is required'), @@ -21,19 +21,26 @@ const SendResetPasswordLink: React.FC = () => { email: '', }, validationSchema: ResetPasswordSchema, - onSubmit: (values) => { - dispatch(sendResetLink(values.email)); + onSubmit: (values, { setStatus }) => { + dispatch(sendResetLink(values.email)) + .then(() => { + if (isError) { + setStatus(message); + } + }); }, - }) + }); + useEffect(() => { if (isError) { - toast.error(message) - } + formik.setStatus(message); + } if (isSuccess) { toast.success(message) - formik.resetForm(); + formik.resetForm() } - }, [user, isError, isSuccess, isLoading, message]) + }, [isError, isSuccess, message]); + return ( <>
@@ -57,16 +64,14 @@ const SendResetPasswordLink: React.FC = () => { /> - {isLoading ? ( -
- -
- ) : ( -
-
- )} - +

{formik.status}



+






diff --git a/src/styles/Colors.scss b/src/styles/Colors.scss index 9e8a98b7..4e749c4f 100644 --- a/src/styles/Colors.scss +++ b/src/styles/Colors.scss @@ -24,4 +24,4 @@ $text2-color: #666666; $text-family: 'Averia Serif Libre'; $white-color: #FFFFFF; $border-color: #D9D9D9; -$red-color:red; \ No newline at end of file +$red-color:red; diff --git a/src/styles/colors.scss b/src/styles/colors.scss index 9e8a98b7..4e749c4f 100644 --- a/src/styles/colors.scss +++ b/src/styles/colors.scss @@ -24,4 +24,4 @@ $text2-color: #666666; $text-family: 'Averia Serif Libre'; $white-color: #FFFFFF; $border-color: #D9D9D9; -$red-color:red; \ No newline at end of file +$red-color:red; diff --git a/src/styles/reset-password.scss b/src/styles/reset-password.scss index 6e1fd784..f5f3eb98 100644 --- a/src/styles/reset-password.scss +++ b/src/styles/reset-password.scss @@ -30,12 +30,6 @@ hr{ font-size: 2rem; font-family: $text-family; } - .success { - color: $primary-color; - padding-left: 1.2rem; - font-size: 2rem; - font-family: $text-family; - } .input-container { position: relative; margin: 1rem 0; @@ -74,7 +68,7 @@ hr{ } } - .reset-Button button { + .reset-Button { background-color: $primary-color; color: $button-text-color; font-size: $button-font-size; @@ -91,6 +85,9 @@ hr{ &:hover { background-color: $button-hover-bg-color; } + .loading { + cursor: not-allowed; + } } } @@ -106,12 +103,11 @@ hr{ font-family: $text-family; font-size: 4rem; } - .input-containers { - margin-top: 30px; + margin-top: 90px; display: flex; flex-direction: column; - gap: 5px; + gap: 9px; .input-container1, .input-container2 { position: relative; @@ -135,7 +131,7 @@ hr{ width: 25vw; height: 7vh; border: 2px solid #f5a773; - border-radius: 0.25rem; + border-radius: 0.27rem; font-size: 1.5rem; outline: none; font-family: inherit; @@ -153,14 +149,13 @@ hr{ } } .error { - color: $red-color; - padding-left: 1.2rem; + color: $red-color; font-size: 2rem; + width: 25vw; font-family: $text-family; } } - - .reset-Button button { + .reset-Button { background-color: $primary-color; color: $button-text-color; font-size: $button-font-size; @@ -174,19 +169,21 @@ hr{ display: inline-block; font-weight: $button-font-weight; font-family: $button-font-family; - &:hover { - background-color: $button-hover-bg-color; + background-color: $button-hover-bg-color; } - } + .loading { + cursor: not-allowed; + } + } } .resetPasswordForm { .input-containers { .input-container1, .input-container2 { - position: relative; + position: relative; .toggle-password { position: absolute; color: #777777; @@ -199,5 +196,46 @@ hr{ outline: none; } } - } + } +} +.redirect-page{ + display: flex; + justify-content: center; +.success-page{ + width: 50vw; + display: flex; + justify-content: center; + align-items: center; + flex-direction: column; + background-color: $white-color; + border-radius: 10px; + padding: 2rem; + border: none; + box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5); + transition: all 0.3s ease-in-out; + .isSuccess { + p { + display: flex; + flex-direction: row; + align-items: center; + gap: 5px; + span { + color: $primary-color; + font-weight: 700; + font-size: 1.9rem; + line-height: 2.4rem; + letter-spacing: 0.05rem; + // margin-left: 4vw; + text-decoration: none; + transition: all 0.3s ease-in-out; + cursor: pointer; + + &:hover { + text-decoration: underline; + transition: all 0.3s ease-in-out; + } + } + } +} +} } \ No newline at end of file