195 lines
7.4 KiB
JavaScript
Raw Normal View History

2021-11-30 16:00:58 +02:00
import React, { useState } from 'react'
import { useSelector, useDispatch } from 'react-redux'
import { fetchPost } from '../../server/server'
2022-12-26 15:12:01 +03:00
import {useHistory, useParams, Redirect, Link} from 'react-router-dom'
2021-11-30 16:00:58 +02:00
import { Loader } from '../Loader/Loader'
2022-12-26 15:12:01 +03:00
import {auth} from '../../redux/outstaffingSlice'
import { getReportDate } from '../../redux/reportSlice'
2021-11-30 16:00:58 +02:00
import { getRole } from '../../redux/roleSlice'
import calendarIcon from '../../images/calendar_icon.png'
import ellipse from '../../images/ellipse.png'
import remove from '../../images/remove.png'
import addIcon from '../../images/addIcon.png'
2022-12-26 15:12:01 +03:00
import { currentMonthAndDay, getReports } from '../Calendar/calendarHelper'
2021-11-30 16:00:58 +02:00
import './reportForm.scss'
2022-12-26 15:12:01 +03:00
import arrow from "../../images/right-arrow.png";
2021-11-30 16:00:58 +02:00
2022-12-26 15:12:01 +03:00
const getCreatedDate = (day) => {
if (day) {
return `${new Date(day).getFullYear()}-${new Date(day).getMonth() + 1}-${new Date(day).getDate()}`
} else {
const date = new Date();
const dd = String(date.getDate()).padStart(2, '0')
const mm = String(date.getMonth() + 1).padStart(2, '0')
const yyyy = date.getFullYear()
return `${yyyy}-${mm}-${dd}`
}
2021-11-30 16:00:58 +02:00
}
2021-06-21 17:41:26 +03:00
const ReportForm = () => {
2021-11-30 16:00:58 +02:00
const dispatch = useDispatch()
const history = useHistory()
2022-12-26 15:12:01 +03:00
const reportDate = useSelector(getReportDate)
2021-11-30 16:00:58 +02:00
const role = useSelector(getRole)
2022-10-19 15:41:11 +03:00
2021-11-30 16:00:58 +02:00
const [isFetching, setIsFetching] = useState(false)
2022-10-19 15:41:11 +03:00
const [reportSuccess, setReportSuccess] = useState(false)
2021-06-22 18:00:52 +03:00
2021-11-30 16:00:58 +02:00
const [inputs, setInputs] = useState([ { task: '', hours_spent: '', minutes_spent: 0 } ]);
const [troublesInputValue, setTroublesInputValue] = useState('');
const [scheduledInputValue, setScheduledInputValue] = useState('');
2021-06-22 18:00:52 +03:00
2021-11-30 16:00:58 +02:00
const addInput = () => {
setInputs((prev) => [...prev, { task: '', hours_spent: '', minutes_spent: 0 }])
}
2021-06-22 18:00:52 +03:00
2022-10-19 15:41:11 +03:00
const totalHours = inputs.reduce((a,b) => a + b.hours_spent, 0)
2021-11-30 16:00:58 +02:00
const deleteInput = (indexRemove) => {
2022-10-19 15:41:11 +03:00
if (indexRemove !== 0) {
2021-11-30 16:00:58 +02:00
setInputs((prev) => prev.filter((el, index) => index !== indexRemove))
2021-06-29 17:58:15 +03:00
}
2021-11-30 16:00:58 +02:00
}
2021-06-22 18:00:52 +03:00
2021-06-21 17:41:26 +03:00
return (
2021-11-30 16:00:58 +02:00
<section className='report-form'>
<div className='row'>
2022-12-26 15:12:01 +03:00
<div className='col-xl-12 report__head'>
<Link className='calendar__back' to={`/ProfileCalendar`}>
<div><img src={arrow} alt=''/>Вернуться назад</div>
</Link>
2021-11-30 16:00:58 +02:00
<div className='report-form__block'>
<div className='report-form__block-title'>
<h2>Добавить отчет</h2>
<h3>Дата заполнения отчета:</h3>
</div>
<div className='report-form__block-img'>
<img
className='report-form__calendar-icon'
src={calendarIcon}
alt=''
/>
2022-12-26 15:12:01 +03:00
{/*{currentMonthAndDayReportPage()}*/}
{reportDate ? currentMonthAndDay(reportDate) : getCreatedDate()}
2021-11-30 16:00:58 +02:00
</div>
<div className='report-form__task-list'>
<img src={ellipse} alt='' />
<span>Какие задачи были выполнены?</span>
2021-06-21 17:41:26 +03:00
</div>
</div>
</div>
2021-11-30 16:00:58 +02:00
</div>
2021-06-22 18:00:52 +03:00
2021-11-30 16:00:58 +02:00
<div className='row'>
<div className='col-8'>
<div className='report-form__task-header'>
<p className='report-form__task-title--description'>
Краткое описание задачи
</p>
<p className='report-form__task-title--hours'>Количество часов</p>
</div>
{inputs.map((input, index) => {
return (
<form id={'input'} key={`input__${index}`} className='report-form__task-form'>
<div className='report-form__task-number'>
{index+1}.
</div>
<div className='report-form__task-input report-form__task-input--description'>
<input name='text' type='text' onChange={ e => setInputs(inputs.map( (input, inputIndex) => {
return index === inputIndex
? {
...input,
task: e.target.value
}
: input
}))} />
</div>
<div className='report-form__task-input report-form__task-input--hours'>
<input name='number' type='number' min='1' onChange={ e => setInputs(inputs.map( (input, inputIndex) => {
return index === inputIndex
? {
...input,
hours_spent: Number(e.target.value)
}
: input
}))} />
</div>
<div className='report-form__task-remove'>
<img onClick={() => deleteInput(index)} src={remove} alt='' />
</div>
</form>
)
})}
<div className='report-form__form-add'>
<img onClick={addInput} src={addIcon} alt='' />
<span>Добавить еще </span>
2021-06-22 18:00:52 +03:00
</div>
</div>
2021-11-30 16:00:58 +02:00
<div className='col-4'></div>
</div>
2021-06-22 18:00:52 +03:00
2021-11-30 16:00:58 +02:00
<div className='row'>
<div className='col-12'>
<div className='report-form__input-box'>
<div className='report-form__troubles'>
<img src={ellipse} alt='' />
<span>Какие сложности возникли?</span>
</div>
<input type='text' value={troublesInputValue} onChange={e => setTroublesInputValue(e.target.value)} />
<div className='report-form__scheduled'>
<img src={ellipse} alt='' />
<span>Что планируется сделать завтра?</span>
2021-06-22 18:00:52 +03:00
</div>
2021-11-30 16:00:58 +02:00
<input type='text' value={scheduledInputValue} onChange={e => setScheduledInputValue(e.target.value)} />
2021-06-22 18:00:52 +03:00
</div>
</div>
2021-11-30 16:00:58 +02:00
</div>
<div className='row'>
<div className='col-12'>
<div className='report-form__footer'>
<button className='report-form__footer-btn' onClick={() => {
fetchPost({
link: `${process.env.REACT_APP_API_URL}/api/reports/create`,
history,
role,
body: {
tasks: inputs,
difficulties: troublesInputValue,
tomorrow: scheduledInputValue,
2022-12-26 15:12:01 +03:00
created_at: getCreatedDate(reportDate),
2021-11-30 16:00:58 +02:00
status: 1,
},
logout: () => dispatch(auth(false))
}).then((res) =>
res.json().then((resJSON) => {
2022-10-19 15:41:11 +03:00
if(res.status === 200) {
setReportSuccess(true)
setTimeout(()=> setReportSuccess(false),2000)
}
2021-11-30 16:00:58 +02:00
setInputs( () => [] )
setTroublesInputValue('');
setScheduledInputValue('');
setIsFetching(false)
setInputs(() => [ { task: '', hours_spent: '', minutes_spent: 0 } ]);
})
)
}}>
{isFetching ? <Loader /> : 'Отправить'}
</button>
<p className='report-form__footer-text'>
2022-10-19 15:41:11 +03:00
Всего за день : <span>{totalHours} часов</span>
2021-11-30 16:00:58 +02:00
</p>
2022-10-19 15:41:11 +03:00
{reportSuccess &&
<p className='report-form__footer-done'>Отчет отправлен</p>
}
2021-06-22 18:00:52 +03:00
</div>
</div>
2021-11-30 16:00:58 +02:00
</div>
2021-06-21 17:41:26 +03:00
</section>
2021-11-30 16:00:58 +02:00
)
}
2021-06-21 17:41:26 +03:00
2021-11-30 16:00:58 +02:00
export default ReportForm