From db693b50cbfc3e3adbe54f0ed207f155eb9fa0fe Mon Sep 17 00:00:00 2001 From: Jason Williams Date: Fri, 30 Jan 2015 22:18:26 +0000 Subject: [PATCH] Do not add autofocus attribute unless set to focus No Issue - Don't add the "autofocus" attribute to the input element unless the "focus" property is set to true. --- core/client/components/gh-trim-focus-input.js | 12 ++++++---- .../components/gh-trim-focus-input_test.js | 22 +++++++++++++++++++ 2 files changed, 30 insertions(+), 4 deletions(-) diff --git a/core/client/components/gh-trim-focus-input.js b/core/client/components/gh-trim-focus-input.js index 4e69b7c36b..c6873628eb 100644 --- a/core/client/components/gh-trim-focus-input.js +++ b/core/client/components/gh-trim-focus-input.js @@ -5,16 +5,20 @@ var TrimFocusInput = Ember.TextField.extend({ attributeBindings: ['autofocus'], autofocus: Ember.computed(function () { - return (device.ios()) ? false : 'autofocus'; + if (this.get('focus')) { + return (device.ios()) ? false : 'autofocus'; + } + + return false; }), - setFocus: function () { + didInsertElement: function () { // This fix is required until Mobile Safari has reliable // autofocus, select() or focus() support - if (this.focus && !device.ios()) { + if (this.get('focus') && !device.ios()) { this.$().val(this.$().val()).focus(); } - }.on('didInsertElement'), + }, focusOut: function () { var text = this.$().val(); diff --git a/core/test/client/unit/components/gh-trim-focus-input_test.js b/core/test/client/unit/components/gh-trim-focus-input_test.js index f707b9d6b5..a30e049eec 100644 --- a/core/test/client/unit/components/gh-trim-focus-input_test.js +++ b/core/test/client/unit/components/gh-trim-focus-input_test.js @@ -15,4 +15,26 @@ describeComponent('gh-trim-focus-input', function () { component.$().focusout(); expect(component.$().val()).to.equal('some random stuff'); }); + + it('does not have the autofocus attribute if not set to focus', function () { + var component = this.subject({ + value: 'some text', + focus: false + }); + + this.render(); + + expect(component.$().attr('autofocus')).to.not.be.ok; + }); + + it('has the autofocus attribute if set to focus', function () { + var component = this.subject({ + value: 'some text', + focus: true + }); + + this.render(); + + expect(component.$().attr('autofocus')).to.be.ok; + }); });