Compare commits

...

9 Commits

Author SHA1 Message Date
ChineseChikki 590293d561 reset password implemented 2023-01-31 22:59:13 +01:00
jenkins 9b2145ff00 Profile layout 2023-01-28 23:52:14 -05:00
jenkins 7ce87a3ee8 test 2023-01-28 23:13:13 -05:00
jenkins 37fa170108 Headet token 2023-01-28 22:54:47 -05:00
jenkins 9a269b5732 Addreminder 2023-01-28 22:27:03 -05:00
jenkins f766c19465 Login hx 2023-01-28 21:25:55 -05:00
jenkins 30a344970a Reminder table demo 2023-01-28 20:41:21 -05:00
jenkins e4b1ceae30 env update 2023-01-28 19:59:42 -05:00
ameye aae99a7b50 Merge branch 'task-9-login-implementation' of MyFit/users-myfit into master 2023-01-28 11:59:55 +00:00
9 changed files with 229 additions and 882 deletions
+4 -1
View File
@@ -8,4 +8,7 @@ REACT_APP_APPSITE=" https://myfitapp.mermsemr.com"
REACT_APP_AUX_ENDPOINT = "https://devapi.mermsemr.com/en/desktop/api/v2/myfit" REACT_APP_AUX_ENDPOINT = "https://devapi.mermsemr.com/en/desktop/api/v2/myfit"
REACT_APP_USERS_ENDPOINT = "https://devapi.mermsemr.com/en/desktop/api/v2/myfituser" REACT_APP_USERS_ENDPOINT = "https://devapi.mermsemr.com/en/desktop/api/v2/myfituser"
# REACT_APP_PASSWORD_ENDPOINT = "https://devapi.mermsemr.com/en/desktop/api/v2/myfituser/resetpass"
REACT_APP_SESSION_EXPIRE_MINUTES = 5
@@ -145,6 +145,7 @@ export default function AuthProfile() {
</div> </div>
</div> </div>
<ActivitiesTab />
</div> </div>
</Layout> </Layout>
</> </>
@@ -1,10 +1,40 @@
import React from "react"; import React, { useState, useEffect } from "react";
import { Link } from 'react-router-dom'; import { Link, useNavigate } from 'react-router-dom';
import titleShape from "../../../assets/images/shape/title-shape-two.svg"; import titleShape from "../../../assets/images/shape/title-shape-two.svg";
import InputCom from "../../Helpers/Inputs/InputCom"; import InputCom from "../../Helpers/Inputs/InputCom";
import AuthLayout from "../AuthLayout"; import AuthLayout from "../AuthLayout";
export default function ForgotPassword() { export default function ForgotPassword() {
const navigate = useNavigate();
const [validation, setValidation] = useState("")
const [buttonDisabled, setButtonDisabled] = useState(true)
// email
const [email, setEmail] = useState("");
const handleEmail = (e) => {
setEmail(e.target.value);
};
function validationChecker(email) {
const emailCheck = /^[^0-9][a-zA-Z0-9._%+-]+@[a-zA-Z]+(\.[a-zA-Z]+)+$/;
if (email === "") {
setValidation("email is required");
} else if (!email.match(emailCheck)) {
setValidation('Please input a valid email address');
} else {
setValidation("");
setButtonDisabled(false)
}
}
useEffect(() => {
validationChecker(email)
}, [email])
return ( return (
<> <>
<AuthLayout <AuthLayout
@@ -28,19 +58,24 @@ export default function ForgotPassword() {
name="email" name="email"
type="email" type="email"
iconName="message" iconName="message"
inputHandler={handleEmail}
value={email}
/> />
{validation && <p className="my-5 font-bold text-red-500">{validation}</p>}
</div> </div>
<div className="signin-area mb-3.5"> <div className="signin-area mb-3.5">
<a
href="/verify-you" <button
className="w-full rounded-[50px] mb-5 h-[58px] text-xl text-white font-bold flex justify-center bg-purple items-center" className="w-full rounded-[50px] mb-5 h-[58px] text-xl text-white font-bold flex justify-center bg-purple items-center"
disabled={buttonDisabled}
onClick={() => navigate("/verify-you")}
> >
Send Code Send Code
</a> </button>
<Link to="/" <Link to="/"
className=" my-40 font-bold flex justify-center text-red-500 items-center" className="my-40 font-bold flex justify-center text-red-500 items-center"
> >
Back to Home Back to Home
</Link> </Link>
+5 -3
View File
@@ -20,12 +20,12 @@ export default function Login() {
}; };
// email // email
const [email, setMail] = useState("support@mermsemr.com"); const [email, setMail] = useState("");
const handleEmail = (e) => { const handleEmail = (e) => {
setMail(e.target.value); setMail(e.target.value);
}; };
// password // password
const [password, setPassword] = useState("123456"); const [password, setPassword] = useState("");
const handlePassword = (e) => { const handlePassword = (e) => {
setPassword(e.target.value); setPassword(e.target.value);
}; };
@@ -39,9 +39,11 @@ export default function Login() {
}; };
const loginResult = await userApi.logInUser(postData); // just for a test const loginResult = await userApi.logInUser(postData); // just for a test
// if (email === "support@mermsemr.com") { // if (email === "support@mermsemr.com") {
if (loginResult.data.status > 0) { // just for a start if (loginResult.data.status > 0 && loginResult.data.session_token !='') { // just for a start
localStorage.setItem("email", `${email}`); localStorage.setItem("email", `${email}`);
localStorage.setItem("session_token", `${loginResult.data.session_token}`);
setLoginLoading(true); setLoginLoading(true);
// userApi.getUserReminders(); //testing
setTimeout(() => { setTimeout(() => {
toast.success("Login Successfully"); toast.success("Login Successfully");
navigate("/", { replace: true }); navigate("/", { replace: true });
@@ -104,9 +104,7 @@ export default function SellHistoryMarketVisitorAnalytic({ className }) {
}`} }`}
> >
<div className="content-wrapper w-full lg:flex xl:space-x-8 lg:space-x-4"> <div className="content-wrapper w-full lg:flex xl:space-x-8 lg:space-x-4">
<div className="lg:w-1/2 w-full mb-10 lg:mb-0">
<SellHistoryWidget />
</div>
<div className="flex-1 "> <div className="flex-1 ">
<div className="market-visitor w-full md:p-8 p-4 h-full bg-white dark:bg-dark-white overflow-hidden rounded-2xl section-shadow"> <div className="market-visitor w-full md:p-8 p-4 h-full bg-white dark:bg-dark-white overflow-hidden rounded-2xl section-shadow">
<div className="flex flex-col justify-between h-full"> <div className="flex flex-col justify-between h-full">
@@ -127,6 +125,11 @@ export default function SellHistoryMarketVisitorAnalytic({ className }) {
</div> </div>
</div> </div>
</div> </div>
<div className="lg:w-1/2 w-full mb-10 lg:mb-0">
<SellHistoryWidget />
</div>
</div> </div>
</div> </div>
); );
File diff suppressed because it is too large Load Diff
+22 -5
View File
@@ -1,12 +1,29 @@
import React from "react"; import React from 'react'
import HistoryAnalyticsCard from "../Cards/HistoryAnalyticsCard"; import HistoryAnalyticsCard from '../Cards/HistoryAnalyticsCard'
import Layout from "../Partials/Layout"; import Layout from '../Partials/Layout'
import ReminderTable from "./ReminderTable"; import ReminderTable from './ReminderTable'
import { Link } from 'react-router-dom'
export default function Reminders() { export default function Reminders() {
return ( return (
<> <>
<Layout> <Layout>
<div className="content-wrapper-profile-only w-full mb-6">
<div className="auth-tab-content relative mb-10">
<div className="lg:flex justify-between">
<div className="tab-items"></div>
<div style={{ transform: 'translateY(-22px)' }}>
<Link
to="/add-reminder"
className="btn-gradient lg:flex hidden w-[153px] h-[46px] rounded-full text-white justify-center items-center"
>
Add Reminder
</Link>
</div>
</div>
<div className="hidden lg:block w-full h-[1px] bg-[#DCD5FE] dark:bg-[#5356fb29] absolute top-[42px] left-0"></div>
</div>
</div>
<div className="history-wrapper w-full mb-10"> <div className="history-wrapper w-full mb-10">
<div className="main-wrapper w-full"> <div className="main-wrapper w-full">
<ReminderTable /> <ReminderTable />
@@ -14,5 +31,5 @@ export default function Reminders() {
</div> </div>
</Layout> </Layout>
</> </>
); )
} }
+20 -131
View File
@@ -8,246 +8,135 @@ export default function LoginActivityTab() {
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400"> <table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
<tbody> <tbody>
<tr className="text-base text-thin-light-gray border-b dark:border-[#5356fb29] default-border-b dark:border-[#5356fb29] ottom "> <tr className="text-base text-thin-light-gray border-b dark:border-[#5356fb29] default-border-b dark:border-[#5356fb29] ottom ">
<td className="py-4 text-center">OS</td> <td className="py-4 text-center">Channel</td>
<td className="py-4 text-center">Browser</td> <td className="py-4 text-center">Date</td>
<td className="py-4 text-center">Location</td> <td className="py-4 text-center">Location</td>
<td className="py-4 text-center">Last session</td>
<td className="py-4 text-center">Status</td>
<td className="py-4 text-center"></td>
</tr> </tr>
<tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"> <tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50">
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex items-center justify-center"> <div className="flex items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Windows Desktop
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex space-x-1 items-center justify-center"> <div className="flex space-x-1 items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Google Chrome 10-10-2035
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2">
Dhaka , Bangladesh 10.0.0.1000
</span> </span>
</td> </td>
<td className="text-center py-4">
<span className="text-base text-thin-light-gray font-medium whitespace-nowrap px-2">
2 days ago
</span>
</td>
<td className="text-center py-4">
<span className="text-sm px-[10px] py-[6px] rounded-full bg-light-green text-white capitalize">
active
</span>
</td>
<td className="text-center py-4">
<button
type="button"
className=" text-thin-light-gray hover:text-red-400"
>
<Icons name="deep-delete" />
</button>
</td>
</tr> </tr>
<tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"> <tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50">
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex items-center justify-center"> <div className="flex items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Mac Desktop
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex space-x-1 items-center justify-center"> <div className="flex space-x-1 items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Firefox 10-10-2035
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2">
Tokyo,japan 10.0.0.1000
</span> </span>
</td> </td>
<td className="text-center py-4">
<span className="text-base text-thin-light-gray font-medium whitespace-nowrap px-2">
5 days ago
</span>
</td>
<td className="text-center py-4">
<span className="text-sm px-[10px] py-[6px] rounded-full bg-light-red text-white capitalize">
Inactive
</span>
</td>
<td className="text-center py-4">
<button
type="button"
className=" text-thin-light-gray hover:text-red-400"
>
<Icons name="deep-delete" />
</button>
</td>
</tr> </tr>
<tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"> <tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50">
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex items-center justify-center"> <div className="flex items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
App Desktop
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex space-x-1 items-center justify-center"> <div className="flex space-x-1 items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
App 10-10-2035
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2">
Barhin,Dubai 10.0.0.1000
</span> </span>
</td> </td>
<td className="text-center py-4">
<span className="text-base text-thin-light-gray font-medium whitespace-nowrap px-2">
2 days ago
</span>
</td>
<td className="text-center py-4">
<span className="text-sm px-[10px] py-[6px] rounded-full bg-light-green text-white capitalize">
active
</span>
</td>
<td className="text-center py-4">
<button
type="button"
className=" text-thin-light-gray hover:text-red-400"
>
<Icons name="deep-delete" />
</button>
</td>
</tr> </tr>
<tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"> <tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50">
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex items-center justify-center"> <div className="flex items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Windows Desktop
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex space-x-1 items-center justify-center"> <div className="flex space-x-1 items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Google Chrome 10-10-2035
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2">
Dhaka , Bangladesh 10.0.0.1000
</span> </span>
</td> </td>
<td className="text-center py-4">
<span className="text-base text-thin-light-gray font-medium whitespace-nowrap px-2">
2 days ago
</span>
</td>
<td className="text-center py-4">
<span className="text-sm px-[10px] py-[6px] rounded-full bg-light-green text-white capitalize">
active
</span>
</td>
<td className="text-center py-4">
<button
type="button"
className=" text-thin-light-gray hover:text-red-400"
>
<Icons name="deep-delete" />
</button>
</td>
</tr> </tr>
<tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"> <tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50">
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex items-center justify-center"> <div className="flex items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Mac Desktop
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex space-x-1 items-center justify-center"> <div className="flex space-x-1 items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
Firefox 10-10-2035
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2">
Tokyo,japan 10.0.0.1000
</span> </span>
</td> </td>
<td className="text-center py-4">
<span className="text-base text-thin-light-gray font-medium whitespace-nowrap px-2">
5 days ago
</span>
</td>
<td className="text-center py-4">
<span className="text-sm px-[10px] py-[6px] rounded-full bg-light-red text-white capitalize">
Inactive
</span>
</td>
<td className="text-center py-4">
<button
type="button"
className=" text-thin-light-gray hover:text-red-400"
>
<Icons name="deep-delete" />
</button>
</td>
</tr> </tr>
<tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"> <tr className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50">
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex items-center justify-center"> <div className="flex items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
App Mobile
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<div className="flex space-x-1 items-center justify-center"> <div className="flex space-x-1 items-center justify-center">
<span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white font-medium whitespace-nowrap px-2">
App 10-10-2035
</span> </span>
</div> </div>
</td> </td>
<td className="text-center py-4"> <td className="text-center py-4">
<span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2"> <span className="text-base text-dark-gray dark:text-white whitespace-nowrap px-2">
Barhin,Dubai 10.0.0.1000
</span> </span>
</td> </td>
<td className="text-center py-4">
<span className="text-base text-thin-light-gray font-medium whitespace-nowrap px-2">
2 days ago
</span>
</td>
<td className="text-center py-4">
<span className="text-sm px-[10px] py-[6px] rounded-full bg-light-green text-white capitalize">
active
</span>
</td>
<td className="text-center py-4">
<button
type="button"
className=" text-thin-light-gray hover:text-red-400"
>
<Icons name="deep-delete" />
</button>
</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
+16 -1
View File
@@ -11,17 +11,31 @@ class usersService {
/* /*
clean up the request data here clean up the request data here
*/ */
localStorage.setItem("session_token", ``);
return this.postAuxEnd("/login", reqData); return this.postAuxEnd("/login", reqData);
} }
getUserReminders(){
return this.getAuxEnd("/reminders", null);
}
//---------------------------------------- ----- //---------------------------------------- -----
//---------------------------------------- ----- //---------------------------------------- -----
// Unified call below // Unified call below
//---------------------------------------- ----- //---------------------------------------- -----
//---------------------------------------- ----- //---------------------------------------- -----
getAuxEnd(uri, reqData) { getAuxEnd(uri, reqData) {
debugger;
const session_token = localStorage.getItem("session_token");
let axiosConfig = {
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json;charset=UTF-8',
'Authorization': `Basic ${session_token}`,
}
};
const endPoint = process.env.REACT_APP_USERS_ENDPOINT + uri; const endPoint = process.env.REACT_APP_USERS_ENDPOINT + uri;
return Axios.get(endPoint) return Axios.get(endPoint,axiosConfig)
.then((response) => { .then((response) => {
// console.log(response); // console.log(response);
// res = response; // res = response;
@@ -42,6 +56,7 @@ class usersService {
}); });
} }
postAuxEnd(uri, reqData) { postAuxEnd(uri, reqData) {
const endPoint = process.env.REACT_APP_USERS_ENDPOINT + uri; const endPoint = process.env.REACT_APP_USERS_ENDPOINT + uri;
const token = '..your token..' const token = '..your token..'