diff --git a/core/client/app/controllers/reset.js b/core/client/app/controllers/reset.js
index 4f0a2d6307..30c0c27d82 100644
--- a/core/client/app/controllers/reset.js
+++ b/core/client/app/controllers/reset.js
@@ -7,6 +7,7 @@ export default Ember.Controller.extend(ValidationEngine, {
ne2Password: '',
token: '',
submitting: false,
+ flowErrors: '',
validationType: 'reset',
@@ -32,7 +33,7 @@ export default Ember.Controller.extend(ValidationEngine, {
submit: function () {
var credentials = this.getProperties('newPassword', 'ne2Password', 'token'),
self = this;
-
+ this.set('flowErrors', '');
this.validate().then(function () {
self.toggleProperty('submitting');
ajax({
@@ -52,6 +53,14 @@ export default Ember.Controller.extend(ValidationEngine, {
self.get('notifications').showAPIError(response);
self.toggleProperty('submitting');
});
+ }).catch(function () {
+ if (self.get('errors.newPassword')) {
+ self.set('flowErrors', self.get('errors.newPassword')[0].message);
+ }
+
+ if (self.get('errors.ne2Password')) {
+ self.set('flowErrors', self.get('errors.ne2Password')[0].message);
+ }
});
}
}
diff --git a/core/client/app/templates/reset.hbs b/core/client/app/templates/reset.hbs
index f7c112d740..f65736aeaf 100644
--- a/core/client/app/templates/reset.hbs
+++ b/core/client/app/templates/reset.hbs
@@ -3,22 +3,16 @@
diff --git a/core/client/app/templates/signin.hbs b/core/client/app/templates/signin.hbs
index 3e0ee1fba2..9a32d3d9c2 100644
--- a/core/client/app/templates/signin.hbs
+++ b/core/client/app/templates/signin.hbs
@@ -6,14 +6,12 @@
{{gh-trim-focus-input class="gh-input email" type="email" placeholder="Email Address" name="identification" autocapitalize="off" autocorrect="off" tabindex="1" value=model.identification}}
- {{gh-error-message errors=model.errors property="identification"}}
{{/gh-form-group}}
{{#gh-form-group errors=model.errors property="password"}}
{{input class="gh-input password" type="password" placeholder="Password" name="password" tabindex="2" value=model.password}}
- {{gh-error-message errors=model.errors property="password"}}
{{/gh-form-group}}
{{gh-spin-button class="login btn btn-blue btn-block" type="submit" tabindex="3" buttonText="Sign in" submitting=loggingIn autoWidth=false}}
diff --git a/core/client/app/validators/signin.js b/core/client/app/validators/signin.js
index 75e42a4ccb..8a75bd6a6f 100644
--- a/core/client/app/validators/signin.js
+++ b/core/client/app/validators/signin.js
@@ -19,12 +19,12 @@ var SigninValidator = BaseValidator.create({
model.get('errors').clear();
if (validator.empty(id)) {
- model.get('errors').add('identification', '');
+ model.get('errors').add('identification', 'Please enter an email');
this.invalidate();
}
if (validator.empty(password)) {
- model.get('errors').add('password', '');
+ model.get('errors').add('password', 'Please enter a password');
this.invalidate();
}
},
@@ -35,7 +35,7 @@ var SigninValidator = BaseValidator.create({
model.get('errors').clear();
if (validator.empty(id) || !validator.isEmail(id)) {
- model.get('errors').add('identification', '');
+ model.get('errors').add('identification', 'Invalid email');
this.invalidate();
}
}
diff --git a/core/test/functional/client/signin_test.js b/core/test/functional/client/signin_test.js
index 0cb83180e4..3d29d1d5dd 100644
--- a/core/test/functional/client/signin_test.js
+++ b/core/test/functional/client/signin_test.js
@@ -136,7 +136,7 @@ CasperTest.begin('Validates unknown email for sign-in', 5, function suite(test)
test.assert(true, 'Unknown email error was shown');
test.assertExists('.form-group.error input[name="identification"]', 'email field was not highlighted');
test.assertDoesntExist('.form-group.error input[name="password"]', 'password field was highlighted');
- }, casper.failOnTimeout(test, 'Uknown email error was not shown'));
+ }, casper.failOnTimeout(test, 'Unknown email error was not shown'));
}, true);
CasperTest.begin('Validates missing details for sign-in', 11, function suite(test) {
@@ -242,5 +242,5 @@ CasperTest.begin('Validates unknown email for forgotten password', 5, function s
test.assert(true, 'Unknown email error was shown');
test.assertExists('.form-group.error input[name="identification"]', 'email field was not highlighted');
test.assertDoesntExist('.form-group.error input[name="password"]', 'password field was highlighted');
- }, casper.failOnTimeout(test, 'Uknown email error was not shown'));
+ }, casper.failOnTimeout(test, 'Unknown email error was not shown'));
}, true);