import React, { useEffect, useState } from "react"; import { useDispatch, useSelector } from "react-redux"; import { Link, Navigate } from "react-router-dom"; import { urlForLocal } from "@utils/helper"; import { apiRequest } from "@api/request"; import { getProfileInfo } from "@redux/outstaffingSlice"; import { getRequestDates, setReportDate, setRequestDate, } from "@redux/reportSlice"; import { getReports } from "@components/Calendar/calendarHelper"; import { ProfileCalendarComponent } from "./ProfileCalendarComponent"; import { Loader } from "@components/Loader/Loader"; import { ProfileHeader } from "@components/ProfileHeader/ProfileHeader"; import { ProfileBreadcrumbs } from "@components/ProfileBreadcrumbs/ProfileBreadcrumbs"; import { Footer } from "@components/Footer/Footer"; import { Navigation } from "@components/Navigation/Navigation"; import moment from "moment"; import "moment/locale/ru"; import "./profileCalendar.scss"; export const ProfileCalendar = () => { if (localStorage.getItem("role_status") === "18") { return ; } const dispatch = useDispatch(); const profileInfo = useSelector(getProfileInfo); const requestDates = useSelector(getRequestDates); const [value, setValue] = useState(moment()); const [reports, setReports] = useState([]); const [totalHours, setTotalHours] = useState(0); const [loader, setLoader] = useState(true); function setValueHandler(value) { setValue(value); } useEffect(() => { dispatch(setRequestDate(getReports(moment()))); }, []); useEffect(() => { setLoader(true); if (!requestDates) { return; } apiRequest( `/reports/reports-by-date?${requestDates}&user_card_id=${localStorage.getItem( "cardId" )}` ).then((reports) => { let spendTime = 0; for (const report of reports) { report.task.map((task) => { if (task.hours_spent) { spendTime += Number(task.hours_spent); } }); } setTotalHours(spendTime); setReports(reports); setLoader(false); }); }, [requestDates]); return (

Ваши отчеты

avatar

{profileInfo.fio}, {profileInfo.specification} разработчик

{loader ? (
) : (
)}
); };