77 lines
2.7 KiB
JavaScript
Raw Normal View History

2022-12-26 15:12:01 +03:00
import React, { useEffect, useState } from 'react'
import {useSelector} from 'react-redux'
2022-12-26 15:12:01 +03:00
import { Link } from 'react-router-dom'
import moment from "moment";
2022-12-26 15:12:01 +03:00
import {currentMonth, getReports} from '../Calendar/calendarHelper'
import {ProfileCalendarComponent} from "./ProfileCalendarComponent";
import { Footer } from '../Footer/Footer'
import {ProfileHeader} from "../ProfileHeader/ProfileHeader";
2022-12-26 15:12:01 +03:00
import {useRequest} from "../../hooks/useRequest";
import { getProfileInfo } from '../../redux/outstaffingSlice'
import './profileCalendar.scss'
2022-12-26 15:12:01 +03:00
export const ProfileCalendar = () => {
const profileInfo = useSelector(getProfileInfo);
const [month, setMonth] = useState('');
const [reports, setReports] = useState([]);
const [totalHours, setTotalHours] = useState(0);
const [requestDates, setRequestDates] = useState('');
const {apiRequest} = useRequest();
2022-12-26 15:12:01 +03:00
useEffect(() => {
setRequestDates(getReports(moment()))
});
2022-12-26 15:12:01 +03:00
useEffect(async () => {
if (!requestDates) {
return
}
apiRequest(`/reports/reports-by-date?${requestDates}&user_id=${localStorage.getItem('id')}`)
.then((reports) => {
let spendTime = 0;
reports.map((report) => {
if (report.spendTime) {
spendTime += Number(report.spendTime)
}
});
setTotalHours(spendTime);
setReports(reports)
2022-12-26 15:12:01 +03:00
})
}, [requestDates]);
2022-12-26 15:12:01 +03:00
useEffect(() => {
setMonth(currentMonth)
}, [month]);
2022-12-26 15:12:01 +03:00
return (
2023-01-16 16:28:56 +03:00
<div className='profile__calendar'>
2023-01-13 15:53:07 +03:00
<ProfileHeader/>
<div className='container'>
<h2 className='summary__title'>Ваши отчеты</h2>
<div className='summary__info'>
<div className='summary__person'>
<img src={profileInfo.photo} className='summary__avatar' alt='avatar'/>
<p className='summary__name'>{profileInfo.fio} {profileInfo.specification}</p>
2022-12-26 15:12:01 +03:00
</div>
2023-01-13 15:53:07 +03:00
<Link to='/profile/report'>
<button className="calendar__btn">Заполнить отчет за день</button>
</Link>
2022-12-26 15:12:01 +03:00
</div>
2023-01-13 15:53:07 +03:00
<div className='row'>
<div className='col-12 col-xl-12'>
<ProfileCalendarComponent reportsDates={reports} />
<p className='calendar__hours'>
{month} : <span> {totalHours} часов </span>
</p>
</div>
2022-12-26 15:12:01 +03:00
</div>
</div>
<Footer />
2023-01-13 15:53:07 +03:00
</div>
2022-12-26 15:12:01 +03:00
)
};