mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-26 00:46:52 +00:00
Fix range widget for IE10/11 (#4534)
As detailed in #4519 the range widget currently does not save its value to the state tiddler on IE 10/11 as they do not support the input event, but rather the change event is fired instead of the input event. This has patch has been tested in IE11 and should work in IE10 as well. Note that on Chrome and Firefox, the change event will fire only once after the user stops dragging the range slider (In addition the input event). However this does lead to an extra refresh as the handleInputEvent method already checks to see if the current value of the slider is different from the saved value before saving to the store.
This commit is contained in:
parent
cf46b6b0ff
commit
21565f635e
@ -49,7 +49,8 @@ RangeWidget.prototype.render = function(parent,nextSibling) {
|
|||||||
this.inputDomNode.value = this.getValue();
|
this.inputDomNode.value = this.getValue();
|
||||||
// Add a click event handler
|
// Add a click event handler
|
||||||
$tw.utils.addEventListeners(this.inputDomNode,[
|
$tw.utils.addEventListeners(this.inputDomNode,[
|
||||||
{name: "input", handlerObject: this, handlerMethod: "handleInputEvent"}
|
{name: "input", handlerObject: this, handlerMethod: "handleInputEvent"},
|
||||||
|
{name: "change", handlerObject: this, handlerMethod: "handleInputEvent"}
|
||||||
]);
|
]);
|
||||||
// Insert the label into the DOM and render any children
|
// Insert the label into the DOM and render any children
|
||||||
parent.insertBefore(this.inputDomNode,nextSibling);
|
parent.insertBefore(this.inputDomNode,nextSibling);
|
||||||
@ -124,4 +125,4 @@ RangeWidget.prototype.refresh = function(changedTiddlers) {
|
|||||||
|
|
||||||
exports.range = RangeWidget;
|
exports.range = RangeWidget;
|
||||||
|
|
||||||
})();
|
})();
|
||||||
|
Loading…
Reference in New Issue
Block a user