-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Create reservation rate report components
Create component ReservationRateReportModal. This modal lies in the /reservations page and can be unhidden/shown in the dropdown of <Lataa Raportti> -> Varausasteraportti. This modal will take the basic props the modal itself requires along with units and the action which downloads the report. Within the modal there are fields where the user can select/ input data: Units, Date range and Time range. Unit seletion field is a Typeahead component which is also a new package. Lastly there is the download button which when clicked, will call the api action to download the report. Create a container to wrap around the component in question.
- Loading branch information
Kevin Seestrand
committed
Mar 2, 2022
1 parent
580cabe
commit 6874a42
Showing
8 changed files
with
257 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
147 changes: 147 additions & 0 deletions
147
app/shared/modals/reservation-rate-report/ReservationsRateReport.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,147 @@ | ||
import React, { Component, PropTypes } from 'react'; | ||
import moment from 'moment'; | ||
import FontAwesome from 'react-fontawesome'; | ||
import Button from 'react-bootstrap/lib/Button'; | ||
import Modal from 'react-bootstrap/lib/Modal'; | ||
import Row from 'react-bootstrap/lib/Row'; | ||
import FormGroup from 'react-bootstrap/lib/FormGroup'; | ||
import ControlLabel from 'react-bootstrap/lib/ControlLabel'; | ||
import { Typeahead } from 'react-bootstrap-typeahead'; | ||
|
||
import DatePicker from 'shared/date-picker'; | ||
import DateTimeRange from 'shared/form-fields/DateTimeRange'; | ||
import 'react-bootstrap-typeahead/css/Typeahead.css'; | ||
import 'react-bootstrap-typeahead/css/Typeahead-bs4.css'; | ||
|
||
|
||
const initialState = { | ||
unitSelections: [], | ||
dateStart: moment().subtract(30, 'days').format('YYYY-MM-DD'), | ||
dateEnd: moment().format('YYYY-MM-DD'), | ||
times: { | ||
begin: { time: '08:00' }, | ||
end: { time: '16:00' }, | ||
}, | ||
loading: false, | ||
}; | ||
|
||
export default class ReservationsRateReportModal extends Component { | ||
static propTypes = { | ||
onHide: PropTypes.func.isRequired, | ||
show: PropTypes.bool.isRequired, | ||
units: PropTypes.object.isRequired, | ||
fetchReservationsRateReport: PropTypes.func.isRequired, | ||
}; | ||
|
||
constructor(props) { | ||
super(props); | ||
this.state = initialState; | ||
this.handleChange = this.handleDateChange.bind(this); | ||
this.handleTimeChange = this.handleTimeChange.bind(this); | ||
this.downloadReport = this.downloadReport.bind(this); | ||
} | ||
|
||
handleDateChange(date) { | ||
this.setState({ ...date }); | ||
} | ||
|
||
handleTimeChange(time) { | ||
this.setState({ times: time }); | ||
} | ||
|
||
downloadReport() { | ||
this.setState({ loading: true }); | ||
this.props.fetchReservationsRateReport({ | ||
start_date: this.state.dateStart, | ||
end_date: this.state.dateEnd, | ||
start_time: this.state.times.begin.time, | ||
end_time: this.state.times.end.time, | ||
units: this.state.unitSelections.map(selection => selection.value), | ||
}).then(() => { | ||
this.setState({ loading: false }); | ||
}).catch(() => { | ||
this.setState({ loading: false }); | ||
}); | ||
} | ||
|
||
render() { | ||
const unitOptions = Object.keys(this.props.units).map((id) => { | ||
const unit = this.props.units[id]; | ||
return { value: unit.id, label: unit.name.fi }; | ||
}); | ||
return ( | ||
<Modal | ||
onHide={this.props.onHide} | ||
show={this.props.show} | ||
> | ||
<div className="reservations-rate-report-modal"> | ||
<Modal.Header closeButton> | ||
<h2 className="modal-title">Varausaste raportti</h2> | ||
</Modal.Header> | ||
<Modal.Body> | ||
<div className="modal-body"> | ||
<Row> | ||
<FormGroup controlId="unit-select-control-group"> | ||
<Typeahead | ||
multiple | ||
options={unitOptions} | ||
placeholder="Valitse kiinteistö" | ||
id="unit-multi-select" | ||
onChange={(selected) => { | ||
this.setState({ unitSelections: selected }); | ||
}} | ||
className="unit-multi-select" | ||
/> | ||
</FormGroup> | ||
</Row> | ||
<Row> | ||
<FormGroup controlId="dates-control-group"> | ||
<div className="date-pickers-container"> | ||
<ControlLabel>Varaukset aikavälillä</ControlLabel> | ||
<DatePicker | ||
onChange={dateStart => this.handleDateChange({ dateStart })} | ||
value={this.state.dateStart} | ||
className="date-picker-field" | ||
/> | ||
<div className="delimiter"> | ||
<FontAwesome name="caret-right" /> | ||
</div> | ||
<DatePicker | ||
onChange={dateEnd => this.handleDateChange({ dateEnd })} | ||
value={this.state.dateEnd} | ||
className="date-picker-field" | ||
/> | ||
</div> | ||
</FormGroup> | ||
</Row> | ||
<Row> | ||
<FormGroup controlId="time-picker-control-group"> | ||
<div className="time-picker-container"> | ||
<DateTimeRange | ||
id="reservation-time-range" | ||
controlProps={{ | ||
renderDatePicker: false, | ||
onChange: time => this.handleTimeChange(time), | ||
value: this.state.times, | ||
}} | ||
/> | ||
</div> | ||
</FormGroup> | ||
</Row> | ||
</div> | ||
</Modal.Body> | ||
<Modal.Footer> | ||
<Button | ||
className="download-button" | ||
onClick={this.downloadReport} | ||
bsStyle="primary" | ||
disabled={this.state.loading} | ||
> | ||
Lataa | ||
</Button> | ||
</Modal.Footer> | ||
</div> | ||
</Modal> | ||
); | ||
} | ||
} |
34 changes: 34 additions & 0 deletions
34
app/shared/modals/reservation-rate-report/ReservationsRateReportContainer.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import React, { PropTypes } from 'react'; | ||
import { connect } from 'react-redux'; | ||
|
||
import uiActions from 'actions/uiActions'; | ||
import { fetchReservationsRateReport } from 'api/actions'; | ||
import ReservationsRateReportModal from './ReservationsRateReport'; | ||
import Selector from './ReservationsRateReportSelector'; | ||
|
||
UnconnectedReservationsRateReportModalContainer.propTypes = { | ||
onHide: PropTypes.func.isRequired, | ||
show: PropTypes.bool.isRequired, | ||
units: PropTypes.object.isRequired, | ||
fetchReservationsRateReport: PropTypes.func.isRequired, | ||
}; | ||
|
||
export function UnconnectedReservationsRateReportModalContainer(props) { | ||
return ( | ||
<ReservationsRateReportModal | ||
onHide={props.onHide} | ||
show={props.show} | ||
units={props.units} | ||
fetchReservationsRateReport={props.fetchReservationsRateReport} | ||
/> | ||
); | ||
} | ||
|
||
const actions = { | ||
onHide: uiActions.hideReservationsRateReportModal, | ||
fetchReservationsRateReport, | ||
}; | ||
|
||
export default connect(Selector, actions)( | ||
UnconnectedReservationsRateReportModalContainer | ||
); |
57 changes: 57 additions & 0 deletions
57
app/shared/modals/reservation-rate-report/_reservation-rate-report.scss
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
.reservations-rate-report-modal { | ||
.modal-title { | ||
color: $black; | ||
} | ||
.modal-body { | ||
box-sizing: border-box; | ||
padding: 15px; | ||
width: 100%; | ||
|
||
.date-pickers-container { | ||
display: flex; | ||
width: 100%; | ||
|
||
.delimiter { | ||
display: flex; | ||
align-items: center; | ||
padding: 0 8px; | ||
font-size: 32px; | ||
} | ||
} | ||
|
||
.unit-multi-select { | ||
.rbt-input-wrapper { | ||
padding: 0 5px 0 5px; | ||
} | ||
} | ||
|
||
.time-picker-container { | ||
display: flex; | ||
width: 100%; | ||
} | ||
|
||
@include input-size( | ||
'.date-picker', | ||
$input-height-base, | ||
$padding-base-vertical, | ||
$padding-base-horizontal, | ||
$font-size-base, | ||
$line-height-base, | ||
$input-border-radius | ||
); | ||
|
||
.date-picker { | ||
border: 2px solid $input-border; | ||
background-color: transparent; | ||
|
||
input { | ||
padding: 0; | ||
background-color: transparent; | ||
} | ||
} | ||
} | ||
|
||
.download-button { | ||
float: left; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
import ReservationsRateReportModalContainer from './ReservationsRateReportContainer'; | ||
|
||
export default ReservationsRateReportModalContainer; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters