parent
de74c0cac8
commit
319e68ddb6
3 changed files with 52 additions and 18 deletions
|
@ -59,10 +59,26 @@ class SignupView extends React.Component {
|
|||
}
|
||||
}
|
||||
|
||||
function asyncErrorsSelector(formName, state) {
|
||||
const form = state.form[formName];
|
||||
if (!form) {
|
||||
return {};
|
||||
}
|
||||
|
||||
const fieldNames = Object.keys(form).filter(key => !key.startsWith('_'));
|
||||
return fieldNames.reduce((asyncErrors, fieldName) => {
|
||||
if (form[fieldName].asyncError) {
|
||||
return { ...asyncErrors, [fieldName]: form[fieldName].asyncError };
|
||||
}
|
||||
return asyncErrors;
|
||||
}, {});
|
||||
}
|
||||
|
||||
function mapStateToProps(state) {
|
||||
return {
|
||||
user: state.user,
|
||||
previousPath: state.ide.previousPath
|
||||
previousPath: state.ide.previousPath,
|
||||
asyncErrors: asyncErrorsSelector('signup', state)
|
||||
};
|
||||
}
|
||||
|
||||
|
@ -71,21 +87,29 @@ function mapDispatchToProps(dispatch) {
|
|||
}
|
||||
|
||||
function asyncValidate(formProps, dispatch, props) {
|
||||
const fieldToValidate = props.form._active;
|
||||
if (fieldToValidate) {
|
||||
const queryParams = {};
|
||||
queryParams[fieldToValidate] = formProps[fieldToValidate];
|
||||
queryParams.check_type = fieldToValidate;
|
||||
return axios.get('/api/signup/duplicate_check', { params: queryParams })
|
||||
.then((response) => {
|
||||
if (response.data.exists) {
|
||||
const error = {};
|
||||
error[fieldToValidate] = response.data.message;
|
||||
throw error;
|
||||
}
|
||||
});
|
||||
}
|
||||
return Promise.resolve(true).then(() => {});
|
||||
const errors = {};
|
||||
return Promise.resolve(true)
|
||||
.then(() => {
|
||||
const fieldToValidate = props.form._active;
|
||||
if (fieldToValidate) {
|
||||
const queryParams = {};
|
||||
queryParams[fieldToValidate] = formProps[fieldToValidate];
|
||||
queryParams.check_type = fieldToValidate;
|
||||
return axios.get('/api/signup/duplicate_check', { params: queryParams })
|
||||
.then((response) => {
|
||||
if (response.data.exists) {
|
||||
errors[fieldToValidate] = response.data.message;
|
||||
}
|
||||
});
|
||||
}
|
||||
return null;
|
||||
})
|
||||
.then(() => {
|
||||
const err = { ...errors, ...props.asyncErrors };
|
||||
if (Object.keys(err).length > 0) {
|
||||
throw err;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function onSubmitFail(errors) {
|
||||
|
|
|
@ -45,3 +45,7 @@
|
|||
.form input[type="submit"] {
|
||||
@extend %forms-button;
|
||||
}
|
||||
|
||||
.form input[type="submit"]:disabled {
|
||||
cursor: not-allowed;
|
||||
}
|
||||
|
|
|
@ -38,7 +38,12 @@ export function createUser(req, res, next) {
|
|||
});
|
||||
|
||||
User.findOne(
|
||||
{ email: req.body.email },
|
||||
{
|
||||
$or: [
|
||||
{ email: req.body.email },
|
||||
{ username: req.body.username }
|
||||
]
|
||||
},
|
||||
(err, existingUser) => {
|
||||
if (err) {
|
||||
res.status(404).send({ error: err });
|
||||
|
@ -46,7 +51,8 @@ export function createUser(req, res, next) {
|
|||
}
|
||||
|
||||
if (existingUser) {
|
||||
res.status(422).send({ error: 'Email is in use' });
|
||||
const fieldInUse = existingUser.email === req.body.email ? 'Email' : 'Username';
|
||||
res.status(422).send({ error: `${fieldInUse} is in use` });
|
||||
return;
|
||||
}
|
||||
user.save((saveErr) => {
|
||||
|
|
Loading…
Reference in a new issue