summaryrefslogtreecommitdiff
path: root/web-ui
diff options
context:
space:
mode:
authorDuda Dornelles <dudassdornelles@gmail.com>2014-10-24 14:23:44 +0200
committerDuda Dornelles <dudassdornelles@gmail.com>2014-10-24 14:23:44 +0200
commitf6756ae2a53e3c6a8521c11dd406d8a9e9d0f515 (patch)
treed30922804f1f682f3de4dd8c857d3d0f55e428d0 /web-ui
parent7005b03934b2b666b56fb972cfad057a46d2fcbd (diff)
parent7bbc79dd46f8b23961d6abc9567dc66365d03398 (diff)
Merge pull request #123 from pedrovereza/issue-78
Issue #78 - Tokenize emails on blur
Diffstat (limited to 'web-ui')
-rw-r--r--web-ui/app/js/mail_view/ui/recipients/recipients_input.js17
-rw-r--r--web-ui/test/spec/mail_view/ui/recipients/recipients_input.spec.js13
2 files changed, 25 insertions, 5 deletions
diff --git a/web-ui/app/js/mail_view/ui/recipients/recipients_input.js b/web-ui/app/js/mail_view/ui/recipients/recipients_input.js
index e39ebf6a..a74e871e 100644
--- a/web-ui/app/js/mail_view/ui/recipients/recipients_input.js
+++ b/web-ui/app/js/mail_view/ui/recipients/recipients_input.js
@@ -102,10 +102,8 @@ define([
}
if (isEnterAddressKey(keyPressed)) {
- if (!_.isEmpty(this.$node.val())) {
- this.recipientSelected(null, { value: this.$node.val() });
- event.preventDefault();
- }
+ this.tokenizeRecipient(event);
+
if((keyPressed !== 9 /* tab */)) {
event.preventDefault();
}
@@ -113,6 +111,15 @@ define([
};
+ this.tokenizeRecipient = function (event) {
+ if (_.isEmpty(this.$node.val())) {
+ return;
+ }
+
+ this.recipientSelected(null, {value: this.$node.val() });
+ event.preventDefault();
+ }
+
this.recipientSelected = function (event, data) {
var value = (data && data.value) || this.$node.val();
@@ -141,11 +148,11 @@ define([
this.trigger(document, toTrigger, { name: this.attr.name });
};
-
this.after('initialize', function () {
self = this;
this.init();
this.on('typeahead:selected typeahead:autocompleted', this.recipientSelected);
+ this.on(this.$node, 'blur', this.tokenizeRecipient);
this.on(this.$node, 'keydown', this.processSpecialKey);
this.on(this.$node, 'keyup', this.warnSendButtonOfInputState);
diff --git a/web-ui/test/spec/mail_view/ui/recipients/recipients_input.spec.js b/web-ui/test/spec/mail_view/ui/recipients/recipients_input.spec.js
index 499065c2..6b486fa9 100644
--- a/web-ui/test/spec/mail_view/ui/recipients/recipients_input.spec.js
+++ b/web-ui/test/spec/mail_view/ui/recipients/recipients_input.spec.js
@@ -99,4 +99,17 @@ describeComponent('mail_view/ui/recipients/recipients_input',function () {
});
});
+ describe('on blur', function() {
+ it('tokenizes recipient email if there is an input val', function() {
+ var addressEnteredEvent = spyOnEvent(this.$node, Pixelated.events.ui.recipients.entered);
+ var blurEvent = $.Event('blur');
+ spyOn(blurEvent, 'preventDefault');
+
+ this.$node.val('a@b.c');
+ this.$node.trigger(blurEvent);
+
+ expect(blurEvent.preventDefault).toHaveBeenCalled();
+ expect(addressEnteredEvent).toHaveBeenTriggeredOnAndWith(this, {name: 'to', address: 'a@b.c'});
+ })
+ });
});