diff --git a/components/Notification/Notification.tsx b/components/Notification/Notification.tsx new file mode 100644 index 00000000..9a6a18a3 --- /dev/null +++ b/components/Notification/Notification.tsx @@ -0,0 +1,42 @@ +import React, { useEffect } from "react"; + +interface INotificationProps { + title: string; + onClose: () => void; +} + +const Notification: React.FC = ({ title, onClose }) => { + useEffect(() => { + const timer = setTimeout(() => { + onClose(); + }, 2500); + + return () => clearTimeout(timer); + }, [onClose]); + + return ( +
+
+
+
+
+
+

{title}

+
+
+ +
+
+
+
+
+ ); +}; + +export default Notification; diff --git a/components/Notification/index.tsx b/components/Notification/index.tsx new file mode 100644 index 00000000..4dfbd4b0 --- /dev/null +++ b/components/Notification/index.tsx @@ -0,0 +1 @@ +export { default } from "./Notification"; diff --git a/components/ResetPassword/index.tsx b/components/ResetPassword/index.tsx new file mode 100644 index 00000000..9e0ba863 --- /dev/null +++ b/components/ResetPassword/index.tsx @@ -0,0 +1,41 @@ +import { useState } from "react"; +import { resetPassword } from "@lib/api"; +import Notification from "@components/Notification"; + +export default function ResetPassword(user: any) { + const [showNotification, setShowNotification] = useState(false); + + const onResetPassword = (user: any) => { + resetPassword(user.email) + .then((_) => { + setShowNotification(true); + }) + .catch((_) => { + setShowNotification(false); + }); + }; + + const handleNotificationClose = () => { + setShowNotification(false); + }; + + return ( + <> + + {showNotification && ( + + )} + + ); +} diff --git a/layout/Attendee/Profile/Profile.tsx b/layout/Attendee/Profile/Profile.tsx index 4464b19f..e02f00ee 100644 --- a/layout/Attendee/Profile/Profile.tsx +++ b/layout/Attendee/Profile/Profile.tsx @@ -9,6 +9,7 @@ import Select from "@components/Select"; import Layout from "@components/Layout"; import Button from "@components/Button"; import Heading from "@components/Heading"; +import ResetPassword from "@components/ResetPassword"; import { CheckpointTracker, CodeInput } from "./components"; import CVInput from "./components/CVInput"; @@ -54,16 +55,6 @@ function Profile({ courses }) { const levelEntries = [10, 30, 60, 100, 150]; - const onResetPassword = () => { - resetPassword(user.email) - .then((_) => - alert( - "An email has been sent to your account for you to recover your password" - ) - ) - .catch((_) => alert("An error occured")); - }; - const handleSubmitForm = (e: React.FormEvent) => { e.preventDefault(); const formData = new FormData(); @@ -172,16 +163,7 @@ function Profile({ courses }) { enabled={editing} onChange={(e) => setCourse(e.currentTarget.value)} /> - - + diff --git a/package-lock.json b/package-lock.json index 65e72624..1df722c7 100644 --- a/package-lock.json +++ b/package-lock.json @@ -8475,6 +8475,15 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/sweetalert2": { + "version": "11.10.1", + "resolved": "https://registry.npmjs.org/sweetalert2/-/sweetalert2-11.10.1.tgz", + "integrity": "sha512-qu145oBuFfjYr5yZW9OSdG6YmRxDf8CnkgT/sXMfrXGe+asFy2imC2vlaLQ/L/naZ/JZna1MPAY56G4qYM0VUQ==", + "funding": { + "type": "individual", + "url": "https://github.com/sponsors/limonte" + } + }, "node_modules/tailwindcss": { "version": "3.2.6", "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.2.6.tgz", @@ -15398,6 +15407,11 @@ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", "dev": true }, + "sweetalert2": { + "version": "11.10.1", + "resolved": "https://registry.npmjs.org/sweetalert2/-/sweetalert2-11.10.1.tgz", + "integrity": "sha512-qu145oBuFfjYr5yZW9OSdG6YmRxDf8CnkgT/sXMfrXGe+asFy2imC2vlaLQ/L/naZ/JZna1MPAY56G4qYM0VUQ==" + }, "tailwindcss": { "version": "3.2.6", "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.2.6.tgz",