Skip to content

Commit

Permalink
styled profile page
Browse files Browse the repository at this point in the history
  • Loading branch information
dulanjaya-premarathne committed Oct 28, 2023
1 parent 8032dbf commit 6a36c6e
Show file tree
Hide file tree
Showing 5 changed files with 336 additions and 38 deletions.
10 changes: 10 additions & 0 deletions frontend/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions frontend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"jwt-decode": "^3.1.2",
"react": "^18.2.0",
"react-dom": "^18.2.0",
"react-google-charts": "^4.0.1",
"react-hot-toast": "^2.4.1",
"react-icons": "^4.8.0",
"react-router": "^6.11.2",
Expand Down
96 changes: 58 additions & 38 deletions frontend/src/components/Profile.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,11 @@ import { useNavigate } from 'react-router-dom'
import styles from '../styles/Username.module.scss';
import extend from '../styles/Profile.module.scss';
import Header from './Header';
import BarChart from './chart';


import '../styles/Base.scss';
import '../styles/Profile.scss';

export default function Profile() {

Expand Down Expand Up @@ -61,57 +66,72 @@ export default function Profile() {
return (
<>
<Header/>
<div className="container mx-auto">
<div className="container">

<Toaster position='top-center' reverseOrder={false}></Toaster>

<div className='flex justify-center items-center h-screen'>
<div className={`${styles.glass} ${extend.glass}`} style={{ width: "45%", paddingTop: '3em'}}>

<div className="title flex flex-col items-center">
<h4 className='text-5xl font-bold'>Profile</h4>
<span className='py-4 text-xl w-2/3 text-center text-gray-500'>
You can update the details.
</span>
<div className = "Profile_Wrapper" >
<div className = "Profile_topbar" >
<div className="wrapper_container">
<h3>Good Evening, {apiData?.firstName || apiData?.username}!🥳</h3>
</div>
<div className="wrapper_container">
<button onClick={userLogout} className='btn' to="/">Logout</button>

</div>
</div>

<form className='py-1' onSubmit={formik.handleSubmit}>
<div className='profile flex justify-center py-4'>
<label htmlFor="profile">
<img src={apiData?.profile || file || avatar} className={`${styles.profile_img} ${extend.profile_img}`} alt="avatar" />
</label>

<input onChange={onUpload} type="file" id='profile' name='profile' />
</div>

<div className="textbox flex flex-col items-center gap-6">
<div className="name flex w-3/4 gap-10">
<input {...formik.getFieldProps('firstName')} className={`${styles.textbox} ${extend.textbox}`} type="text" placeholder='FirstName' />
<input {...formik.getFieldProps('lastName')} className={`${styles.textbox} ${extend.textbox}`} type="text" placeholder='LastName' />
<div className='profile_inner_wrapper'>
<form className='profile_info_form' onSubmit={formik.handleSubmit}>

<div className="form_wrapper_container_title">
<h3>Profile Details</h3>
<span className='py-4 text-xl w-2/3 text-center text-gray-500 custom-class-2'>
You can update the details.
</span>
</div>

<div className="name flex w-3/4 gap-10">
<input {...formik.getFieldProps('mobile')} className={`${styles.textbox} ${extend.textbox}`} type="text" placeholder='Mobile No.' />
<input {...formik.getFieldProps('email')} className={`${styles.textbox} ${extend.textbox}`} type="text" placeholder='Email*' />
<div className='form_wrapper'>
<div className='profile_image'>
<label htmlFor="profile">
<img src={apiData?.profile || file || avatar} className={`${styles.profile_img} ${extend.profile_img}`} alt="avatar" />
</label>

<input onChange={onUpload} type="file" id='profile' name='profile' />
</div>
</div>


<input {...formik.getFieldProps('address')} className={`${styles.textbox} ${extend.textbox}`} type="text" placeholder='Address' />
<button className={styles.btn} type='submit'>Update</button>

<div className="form_text_fields">
<div className="field_group">
<input {...formik.getFieldProps('firstName')} className='inputText' type="text" placeholder='First Name' />
<input {...formik.getFieldProps('lastName')} className='inputText' type="text" placeholder='Last Name' />

<input {...formik.getFieldProps('mobile')} className='inputText' type="tel" placeholder='Contact Number' />
<input {...formik.getFieldProps('email')} className='inputText' type="email" placeholder='Email' />

<textarea {...formik.getFieldProps('address')} className='inputText' row='5' type="Textarea" placeholder='Address' />
<button className='btn' type='submit'>Update</button>
<button className='btn delete-btn' type='delete'>Delete Account</button>
</div>
</div>

</div>
</form>
<div className='profile_info_form'>
<div className="form_wrapper_container_title">
<h3>Personal Reports</h3>
<span className='py-4 text-xl w-2/3 text-center text-gray-500 custom-class-2'>
Emotion Changing Frequency Over Months
</span>
</div>
<div className="App">
<BarChart />
</div>

<div className="text-center py-4">
<span className='text-gray-500'>come back later? <button onClick={userLogout} className='text-red-500' to="/">Logout</button></span>
</div>

</form>

</div>
</div>
</div>

</div>
</>

)
}
}
44 changes: 44 additions & 0 deletions frontend/src/components/chart.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
import React from 'react';
import { Chart } from 'react-google-charts';

const EmotionLineChart = () => {
const data = [
['Month', 'Joyful', 'Surprise', 'Anger', 'Sad', 'Happy'],
['January', 20, 15, 10, 5, 8],
['February', 18, 13, 11, 7, 10],
['March', 22, 17, 9, 4, 6],
['April', 25, 12, 15, 6, 9],
['May', 16, 20, 11, 8, 12],
['June', 19, 18, 8, 7, 11],
['July', 23, 16, 13, 5, 9],
['August', 17, 14, 12, 9, 7],
['September', 20, 19, 14, 4, 8],
['October', 18, 15, 10, 6, 10],
['November', 21, 17, 9, 5, 11],
['December', 24, 20, 11, 7, 6],
];

return (
<div className="chart-container" style={{ width: '100%', maxWidth: 800 }}>
<Chart
width={'100%'}
height={400}
chartType="LineChart"
loader={<div>Loading Chart</div>}
data={data}
options={{
title: '',
hAxis: {
title: 'Months',
},
vAxis: {
title: 'Emotion Frequency',
},
tooltip: { isHtml: true }, // Enable HTML content in tooltip
}}
/>
</div>
);
};

export default EmotionLineChart;
Loading

0 comments on commit 6a36c6e

Please sign in to comment.