Skip to content
This repository has been archived by the owner on Apr 4, 2019. It is now read-only.

Commit

Permalink
[BUGFIX] Fix text input cursor behavior
Browse files Browse the repository at this point in the history
  • Loading branch information
mmun committed Jan 29, 2016
1 parent 9e859d5 commit e48b981
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 2 deletions.
12 changes: 10 additions & 2 deletions packages/morph-attr/lib/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,16 @@ function getProperty() {

function updateProperty(value) {
if (this._renderedInitially === true || !isAttrRemovalValue(value)) {
// do not render if initial value is undefined or null
this.domHelper.setPropertyStrict(this.element, this.attrName, value);
let element = this.element;
let attrName = this.attrName;

if (attrName === 'value' && element.tagName === 'INPUT' && element.value === value) {
// Do nothing. Attempts to avoid accidently changing the input cursor location.
// See https://github.com/tildeio/htmlbars/pull/447 for more details.
} else {
// do not render if initial value is undefined or null
this.domHelper.setPropertyStrict(element, attrName, value);
}
}

this._renderedInitially = true;
Expand Down
25 changes: 25 additions & 0 deletions packages/morph-attr/tests/attr-morph-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import DOMHelper from "../dom-helper";
import SafeString from "htmlbars-util/safe-string";
import AttrMorph from "morph-attr";

var svgNamespace = "http://www.w3.org/2000/svg",
xlinkNamespace = "http://www.w3.org/1999/xlink";
Expand Down Expand Up @@ -249,3 +250,27 @@ test("embed src as data uri is sanitized", function() {
'unsafe:',
'attribute is escaped');
});

// Regression test for https://github.com/tildeio/htmlbars/pull/447.
test("the value property of an input element is not set if the value hasn't changed", function() {
let calls = 0;

let domHelperStub = {
setPropertyStrict() {
calls++;
}
};

let input = document.createElement('input');
let morph = AttrMorph.create(input, 'value', domHelperStub);

equal(calls, 0);
morph.setContent('one');
equal(calls, 1);
morph.setContent('one');
equal(calls, 1);
morph.setContent('two');
equal(calls, 2);
morph.setContent('two');
equal(calls, 2);
});

0 comments on commit e48b981

Please sign in to comment.