Compare commits

..

1 Commits

Author SHA1 Message Date
GotPPay
591d7be308 round time to the nearest 5 min 2018-05-11 17:24:40 +02:00
2 changed files with 29 additions and 85 deletions

View File

@@ -33,10 +33,8 @@ import Instance from '../../../../../../../components/Connection';
import Checkbox from 'material-ui/Checkbox'; import Checkbox from 'material-ui/Checkbox';
import Popover from 'material-ui/Popover'; import Popover from 'material-ui/Popover';
const ADDRESS_TYPE_HOME = "home";
let DateTimeFormat; let DateTimeFormat;
const roundingTime = 1000 * 60 * 5; //5 minutes
DateTimeFormat = global.Intl.DateTimeFormat; DateTimeFormat = global.Intl.DateTimeFormat;
@@ -46,8 +44,8 @@ export class ValidationErrorsInfoDialog extends React.Component {
open: this.props.open, open: this.props.open,
} }
componentWillReceiveProps(newProps){ componentWillReceiveProps(newProps) {
this.setState({open: newProps.open}); this.setState({ open: newProps.open });
} }
handleOpen = () => { handleOpen = () => {
@@ -78,13 +76,13 @@ export class ValidationErrorsInfoDialog extends React.Component {
modal={false} modal={false}
open={this.state.open} open={this.state.open}
onRequestClose={this.handleClose} onRequestClose={this.handleClose}
overlayStyle={{backgroundColor: 'transparent'}} overlayStyle={{ backgroundColor: 'transparent' }}
> >
{this.props.errorMessages.map(errorMessage => { {this.props.errorMessages.map(errorMessage => {
return ( return (
<div> <div>
<a>{errorMessage.message}</a> <a>{errorMessage.message}</a>
<br/> <br />
</div> </div>
); );
})} })}
@@ -418,16 +416,18 @@ class VerticalNonLinear extends React.Component {
constructor(props) { constructor(props) {
super(props); super(props);
let dateNow = new Date();
this.state = { this.state = {
stepIndex: 0, stepIndex: 0,
rideTypeValue: 0, rideTypeValue: 0,
providerID: 0, providerID: 0,
providerName: '', providerName: '',
visitDate: new Date(), visitDate: new Date(),
visitTime: new Date(), visitTime: new Date(Math.round(dateNow.getTime() / roundingTime) * roundingTime),
pickupLocation: null, pickupLocation: null,
pickupTime: new Date(), pickupTime: new Date(Math.round(dateNow.getTime() / roundingTime) * roundingTime),
pickupTimeReturn: new Date(), pickupTimeReturn: new Date(Math.round(dateNow.getTime() / roundingTime) * roundingTime),
pickupTimeReturnDisplayMode: 'none', pickupTimeReturnDisplayMode: 'none',
open: false, open: false,
message: 'Booking Ride', message: 'Booking Ride',
@@ -455,8 +455,8 @@ class VerticalNonLinear extends React.Component {
}, },
return_time: new Date(), return_time: new Date(),
pickupTimeHide: false, pickupTimeHide: false,
showValidationErrors:false, showValidationErrors: false,
validationErrors:[], validationErrors: [],
}; };
} }
@@ -471,16 +471,6 @@ class VerticalNonLinear extends React.Component {
if (user.useruuid !== loggedUser.useruuid) { if (user.useruuid !== loggedUser.useruuid) {
Instance.getRawConn().get(`/v1/nemt/users/member/${user.useruuid}`) Instance.getRawConn().get(`/v1/nemt/users/member/${user.useruuid}`)
.then(function (res) { .then(function (res) {
let userHomeAddress = null;
res.data.addresses.forEach(address => {
if (address.address_type === ADDRESS_TYPE_HOME) {
userHomeAddress = address;
}
});
if (userHomeAddress != null) {
userHomeAddress.name = "Home";
state.handlePickupChanged(userHomeAddress, state);
}
state.setState(Object.assign(state.state, { user: res.data, showUserSelection: true, userSelectionText: `${res.data.member} - ${res.data.name}` })); state.setState(Object.assign(state.state, { user: res.data, showUserSelection: true, userSelectionText: `${res.data.member} - ${res.data.name}` }));
}) })
.catch(err => { .catch(err => {
@@ -501,10 +491,10 @@ class VerticalNonLinear extends React.Component {
} }
}); });
let visitTime = new Date(new Date().getTime() + (1 * 60 * 60 * 1000)); let visitTime = new Date(Math.round((date.getTime() + (1 * 60 * 60 * 1000)) / roundingTime) * roundingTime);
let visitDate = visitTime; let visitDate = date;
let pickupTime = new Date(visitTime.getTime() - (0.5 * 60 * 60 * 1000)); let pickupTime = new Date(Math.round((visitTime.getTime() - (0.5 * 60 * 60 * 1000)) / roundingTime) * roundingTime);
let pickupTimeReturn = new Date(visitTime.getTime() - (0.5 * 60 * 60 * 1000)); let pickupTimeReturn = new Date(Math.round((visitTime.getTime() - (0.5 * 60 * 60 * 1000)) / roundingTime) * roundingTime);
this.setState(Object.assign(this.state, { this.setState(Object.assign(this.state, {
visitDate: visitDate, visitDate: visitDate,
@@ -568,11 +558,11 @@ class VerticalNonLinear extends React.Component {
self.handleRequestClose(self); self.handleRequestClose(self);
window.location.href = '/#/app/page/map/' + res.data.ride_uuid; window.location.href = '/#/app/page/map/' + res.data.ride_uuid;
}).catch(error => { }).catch(error => {
if (error.response.status === 422){ if (error.response.status === 422) {
//Unprocessable Entity (validation failed) //Unprocessable Entity (validation failed)
self.setState(Object.assign(self.state, { self.setState(Object.assign(self.state, {
showValidationErrors:true, showValidationErrors: true,
validationErrors:error.response.data.data validationErrors: error.response.data.data
})); }));
} }
}); });
@@ -612,10 +602,10 @@ class VerticalNonLinear extends React.Component {
handleDate(event, date, state) { handleDate(event, date, state) {
let self = state let self = state
let visitTime = new Date(date.getTime() + (1 * 60 * 60 * 1000)); let visitTime = new Date(Math.round((date.getTime() + (1 * 60 * 60 * 1000)) / roundingTime) * roundingTime);
let visitDate = date; let visitDate = date;
let pickupTime = new Date(visitTime.getTime() - (0.5 * 60 * 60 * 1000)); let pickupTime = new Date(Math.round((visitTime.getTime() - (0.5 * 60 * 60 * 1000)) / roundingTime) * roundingTime);
let pickupTimeReturn = new Date(visitTime.getTime() - (0.5 * 60 * 60 * 1000)); let pickupTimeReturn = new Date(Math.round((visitTime.getTime() - (0.5 * 60 * 60 * 1000)) / roundingTime) * roundingTime);
self.setState(Object.assign(self.state, { self.setState(Object.assign(self.state, {
visitDate: visitDate, visitDate: visitDate,
@@ -862,9 +852,9 @@ class VerticalNonLinear extends React.Component {
} }
handleValidationErrosDialogDismiss(){ handleValidationErrosDialogDismiss() {
this.setState(Object.assign(this.state, { this.setState(Object.assign(this.state, {
showValidationErrors:false showValidationErrors: false
})); }));
} }
@@ -906,17 +896,7 @@ class VerticalNonLinear extends React.Component {
if (this.state.showUserSelection && this.state.users.length > 0) { if (this.state.showUserSelection && this.state.users.length > 0) {
const handleAutocomplete = (u) => { const handleAutocomplete = (u) => {
let userHomeAddress = null; state.setState(Object.assign(state.state, { user: u, userSelectionText: u.userdata }));
u.addresses.forEach(address => {
if (address.address_type === ADDRESS_TYPE_HOME) {
userHomeAddress = address;
}
});
if (userHomeAddress != null) {
userHomeAddress.name = "Home";
state.handlePickupChanged(userHomeAddress,state);
}
state.setState(Object.assign(state.state, { user: u, userSelectionText: u.userdata }));
} }
const datasourceConfig = { text: 'userdata', value: 'useruuid' } const datasourceConfig = { text: 'userdata', value: 'useruuid' }
userSelection = ( userSelection = (
@@ -941,7 +921,7 @@ class VerticalNonLinear extends React.Component {
<div className="box-body padding-xs"> <div className="box-body padding-xs">
<div style={{ maxWidth: 380, margin: 'auto' }}> <div style={{ maxWidth: 380, margin: 'auto' }}>
<ValidationErrorsInfoDialog open = {this.state.showValidationErrors} errorMessages = {this.state.validationErrors} onDismiss={this.handleValidationErrosDialogDismiss.bind(this)}/> <ValidationErrorsInfoDialog open={this.state.showValidationErrors} errorMessages={this.state.validationErrors} onDismiss={this.handleValidationErrosDialogDismiss.bind(this)} />
<Stepper <Stepper
activeStep={this.state.stepIndex} activeStep={this.state.stepIndex}

View File

@@ -47,9 +47,7 @@ class SignUp extends React.Component {
"role": { name: "", key: "SP", desc: "" }, "role": { name: "", key: "SP", desc: "" },
"profiles": [], "profiles": [],
"types": [], "types": [],
"organizations": [], "organizations": []
showValidationErrors : false,
validationErrors: []
} }
this.buttonValidated = this.buttonValidated.bind(this); this.buttonValidated = this.buttonValidated.bind(this);
@@ -228,42 +226,12 @@ class SignUp extends React.Component {
localStorage.removeItem('loggedUser'); localStorage.removeItem('loggedUser');
location.href = '/#/login'; location.href = '/#/login';
}).catch(function (err) { }).catch(function (err) {
if (err.response.status === 422){ alert('Error to log in: ' + err.message);
//Unprocessable Entity (validation failed)
state.setState(Object.assign(state.state, {
showValidationErrors:true,
validationErrors:err.response.data.data
}));
}else{
alert('Error to log in: ' + err.message);
}
console.error(err); console.error(err);
}); });
} }
handleDismiss(){
this.setState(Object.assign(this.state, { showErrorMessage: false }));
}
render() { render() {
let validationErrors = null;
if (this.state.showValidationErrors){
validationErrors = (
<ul>
{this.state.validationErrors.map(errorMessage=>{
const oneValidationMessage = (<li>{errorMessage.message}</li>);
const oneValidationMessageWithTab = (<span><li style={{marginLeft:2 + "em"}}>{errorMessage.message}</li></span>);
if (errorMessage.field_name === "password-tab"){
return oneValidationMessageWithTab;
} else{
return oneValidationMessage;
}
})}
</ul>
);
}
return ( return (
<div className="body-inner"> <div className="body-inner">
@@ -366,10 +334,6 @@ class SignUp extends React.Component {
<div className="form-group"> <div className="form-group">
<p className="text-small">By clicking on sign up, you agree to <a href="javascript:;"><i>terms</i></a> and <a href="javascript:;"><i>privacy policy</i></a></p> <p className="text-small">By clicking on sign up, you agree to <a href="javascript:;"><i>terms</i></a> and <a href="javascript:;"><i>privacy policy</i></a></p>
</div> </div>
<div className="divider" />
<div className="form-group">
{validationErrors}
</div>
</fieldset> </fieldset>
</form> </form>
</div> </div>