From 0780a87429593bda7abddb9172c07eacaf08604a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Wed, 13 Jan 2016 18:04:54 +0100 Subject: [PATCH] Remove unnecessary overrides of selectstart dragstart on view. And simplify DomEvent.add() / remove(), as we don't need support for multiple types in one entry anymore. --- src/dom/DomEvent.js | 16 ++++--------- src/view/View.js | 58 +++++++++++++++++++-------------------------- 2 files changed, 29 insertions(+), 45 deletions(-) diff --git a/src/dom/DomEvent.js b/src/dom/DomEvent.js index 8352e721..b83d3310 100644 --- a/src/dom/DomEvent.js +++ b/src/dom/DomEvent.js @@ -17,21 +17,13 @@ */ var DomEvent = /** @lends DomEvent */{ add: function(el, events) { - for (var type in events) { - var func = events[type], - parts = type.split(/[\s,]+/g); - for (var i = 0, l = parts.length; i < l; i++) - el.addEventListener(parts[i], func, false); - } + for (var type in events) + el.addEventListener(type, events[type], false); }, remove: function(el, events) { - for (var type in events) { - var func = events[type], - parts = type.split(/[\s,]+/g); - for (var i = 0, l = parts.length; i < l; i++) - el.removeEventListener(parts[i], func, false); - } + for (var type in events) + el.removeEventListener(type, events[type], false); }, getPoint: function(event) { diff --git a/src/view/View.js b/src/view/View.js index 27c83fd6..cff92879 100644 --- a/src/view/View.js +++ b/src/view/View.js @@ -43,10 +43,10 @@ var View = Base.extend(Emitter, /** @lends View# */{ // Borrowed from Hammer.js: var none = 'none'; DomElement.setPrefixed(element.style, { + userDrag: none, userSelect: none, touchCallout: none, contentZooming: none, - userDrag: none, tapHighlightColor: 'rgba(0,0,0,0)' }); @@ -786,39 +786,31 @@ new function() { // Injection scope for mouse events on the browser } } - var viewEvents = { - 'selectstart dragstart': function(event) { - // Only stop this even if we're mouseDown already, since otherwise - // no text whatsoever can be selected on the page. - if (mouseDown) - event.preventDefault(); - } - }; + var viewEvents = {}, + docEvents = { + // NOTE: mouseleave does not seem to work on document in IE: + mouseout: function(event) { + // When the moues leaves the document, fire one last mousemove + // event, to give items the change to receive a mouseleave, etc. + var view = View._focused, + target = DomEvent.getRelatedTarget(event); + if (view && (!target || target.nodeName === 'HTML')) { + // See #800 for this bizarre workaround for an issue of + // Chrome on Windows: + // TODO: Remove again after Dec 2016, once fixed in Chrome. + var offset = DomEvent.getOffset(event, view._element), + x = offset.x, + abs = Math.abs, + ax = abs(x), + max = 1 << 25, + diff = ax - max; + offset.x = abs(diff) < ax ? diff * (x < 0 ? -1 : 1) : x; + handleMouseMove(view, event, view.viewToProject(offset)); + } + }, - var docEvents = { - // NOTE: mouseleave does not seem to work on document in IE: - mouseout: function(event) { - // When the moues leaves the document, fire one last mousemove - // event, to give items the change to receive a mouseleave, etc. - var view = View._focused, - target = DomEvent.getRelatedTarget(event); - if (view && (!target || target.nodeName === 'HTML')) { - // See #800 for this bizarre workaround for an issue of Chrome - // on Windows: - // TODO: Remove again after Dec 2016 once it is fixed in Chrome. - var offset = DomEvent.getOffset(event, view._element), - x = offset.x, - abs = Math.abs, - ax = abs(x), - max = 1 << 25, - diff = ax - max; - offset.x = abs(diff) < ax ? diff * (x < 0 ? -1 : 1) : x; - handleMouseMove(view, event, view.viewToProject(offset)); - } - }, - - scroll: updateFocus - }; + scroll: updateFocus + }; // mousemove and mouseup events need to be installed on document, not the // view element, since we want to catch the end of drag events even outside