client/views: reuse mutation observer

This commit is contained in:
rr- 2016-05-29 12:22:59 +02:00
parent 8591449508
commit 79f22d27cd
2 changed files with 21 additions and 15 deletions

View File

@ -61,18 +61,6 @@ class AutoCompleteControl {
this._results = []; this._results = [];
this._activeResult = -1; this._activeResult = -1;
this._mutationObserver = new MutationObserver(
mutations => {
for (let mutation of mutations) {
for (let node of mutation.removedNodes) {
if (node.contains(this._sourceInputNode)) {
this._uninstall();
return;
}
}
}
});
this._install(); this._install();
} }
@ -108,8 +96,6 @@ class AutoCompleteControl {
this._sourceInputNode.setAttribute('data-autocomplete', true); this._sourceInputNode.setAttribute('data-autocomplete', true);
this._sourceInputNode.setAttribute('autocomplete', 'off'); this._sourceInputNode.setAttribute('autocomplete', 'off');
this._mutationObserver.observe(
document.body, {childList: true, subtree: true});
this._sourceInputNode.addEventListener( this._sourceInputNode.addEventListener(
'keydown', e => this._evtKeyDown(e)); 'keydown', e => this._evtKeyDown(e));
this._sourceInputNode.addEventListener( this._sourceInputNode.addEventListener(
@ -119,11 +105,13 @@ class AutoCompleteControl {
'<div class="autocomplete"><ul></ul></div>'); '<div class="autocomplete"><ul></ul></div>');
this._suggestionList = this._suggestionDiv.querySelector('ul'); this._suggestionList = this._suggestionDiv.querySelector('ul');
document.body.appendChild(this._suggestionDiv); document.body.appendChild(this._suggestionDiv);
views.monitorNodeRemoval(
this._sourceInputNode, () => { this._uninstall(); });
} }
_uninstall() { _uninstall() {
window.clearTimeout(this._showTimeout); window.clearTimeout(this._showTimeout);
this._mutationObserver.disconnect();
document.body.removeChild(this._suggestionDiv); document.body.removeChild(this._suggestionDiv);
} }

View File

@ -354,6 +354,23 @@ function slideUp(element) {
}); });
} }
function monitorNodeRemoval(monitoredNode, callback) {
const mutationObserver = new MutationObserver(
mutations => {
for (let mutation of mutations) {
for (let node of mutation.removedNodes) {
if (node.contains(monitoredNode)) {
mutationObserver.disconnect();
callback();
return;
}
}
}
});
mutationObserver.observe(
document.body, {childList: true, subtree: true});
}
document.addEventListener('input', e => { document.addEventListener('input', e => {
const type = e.target.getAttribute('type'); const type = e.target.getAttribute('type');
if (type && type.toLowerCase() === 'color') { if (type && type.toLowerCase() === 'color') {
@ -378,4 +395,5 @@ module.exports = {
scrollToHash: scrollToHash, scrollToHash: scrollToHash,
slideDown: slideDown, slideDown: slideDown,
slideUp: slideUp, slideUp: slideUp,
monitorNodeRemoval: monitorNodeRemoval,
}; };