aiber-martin/platforms/ios/www/tap-click-252af35a-js-es5.js
Martin Donnelly a4b8625d0f init
2020-12-17 16:23:12 +00:00

236 lines
7.1 KiB
JavaScript

(function () {
(window["webpackJsonp"] = window["webpackJsonp"] || []).push([["tap-click-252af35a-js"], {
/***/
"./node_modules/@ionic/core/dist/esm/tap-click-252af35a.js":
/*!*****************************************************************!*\
!*** ./node_modules/@ionic/core/dist/esm/tap-click-252af35a.js ***!
\*****************************************************************/
/*! exports provided: startTapClick */
/***/
function node_modulesIonicCoreDistEsmTapClick252af35aJs(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */
__webpack_require__.d(__webpack_exports__, "startTapClick", function () {
return startTapClick;
});
/* harmony import */
var _helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(
/*! ./helpers-5c745fbd.js */
"./node_modules/@ionic/core/dist/esm/helpers-5c745fbd.js");
var startTapClick = function startTapClick(config) {
var lastTouch = -MOUSE_WAIT * 10;
var lastActivated = 0;
var scrollingEl;
var activatableEle;
var activeRipple;
var activeDefer;
var useRippleEffect = config.getBoolean('animated', true) && config.getBoolean('rippleEffect', true);
var clearDefers = new WeakMap();
var isScrolling = function isScrolling() {
return scrollingEl !== undefined && scrollingEl.parentElement !== null;
}; // Touch Events
var onTouchStart = function onTouchStart(ev) {
lastTouch = Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_0__["n"])(ev);
pointerDown(ev);
};
var onTouchEnd = function onTouchEnd(ev) {
lastTouch = Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_0__["n"])(ev);
pointerUp(ev);
};
var onMouseDown = function onMouseDown(ev) {
var t = Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_0__["n"])(ev) - MOUSE_WAIT;
if (lastTouch < t) {
pointerDown(ev);
}
};
var onMouseUp = function onMouseUp(ev) {
var t = Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_0__["n"])(ev) - MOUSE_WAIT;
if (lastTouch < t) {
pointerUp(ev);
}
};
var cancelActive = function cancelActive() {
clearTimeout(activeDefer);
activeDefer = undefined;
if (activatableEle) {
removeActivated(false);
activatableEle = undefined;
}
};
var pointerDown = function pointerDown(ev) {
if (activatableEle || isScrolling()) {
return;
}
scrollingEl = undefined;
setActivatedElement(getActivatableTarget(ev), ev);
};
var pointerUp = function pointerUp(ev) {
setActivatedElement(undefined, ev);
};
var setActivatedElement = function setActivatedElement(el, ev) {
// do nothing
if (el && el === activatableEle) {
return;
}
clearTimeout(activeDefer);
activeDefer = undefined;
var _Object = Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_0__["p"])(ev),
x = _Object.x,
y = _Object.y; // deactivate selected
if (activatableEle) {
if (clearDefers.has(activatableEle)) {
throw new Error('internal error');
}
if (!activatableEle.classList.contains(ACTIVATED)) {
addActivated(activatableEle, x, y);
}
removeActivated(true);
} // activate
if (el) {
var deferId = clearDefers.get(el);
if (deferId) {
clearTimeout(deferId);
clearDefers["delete"](el);
}
var delay = isInstant(el) ? 0 : ADD_ACTIVATED_DEFERS;
el.classList.remove(ACTIVATED);
activeDefer = setTimeout(function () {
addActivated(el, x, y);
activeDefer = undefined;
}, delay);
}
activatableEle = el;
};
var addActivated = function addActivated(el, x, y) {
lastActivated = Date.now();
el.classList.add(ACTIVATED);
var rippleEffect = useRippleEffect && getRippleEffect(el);
if (rippleEffect && rippleEffect.addRipple) {
removeRipple();
activeRipple = rippleEffect.addRipple(x, y);
}
};
var removeRipple = function removeRipple() {
if (activeRipple !== undefined) {
activeRipple.then(function (remove) {
return remove();
});
activeRipple = undefined;
}
};
var removeActivated = function removeActivated(smooth) {
removeRipple();
var active = activatableEle;
if (!active) {
return;
}
var time = CLEAR_STATE_DEFERS - Date.now() + lastActivated;
if (smooth && time > 0 && !isInstant(active)) {
var deferId = setTimeout(function () {
active.classList.remove(ACTIVATED);
clearDefers["delete"](active);
}, CLEAR_STATE_DEFERS);
clearDefers.set(active, deferId);
} else {
active.classList.remove(ACTIVATED);
}
};
var doc = document;
doc.addEventListener('ionScrollStart', function (ev) {
scrollingEl = ev.target;
cancelActive();
});
doc.addEventListener('ionScrollEnd', function () {
scrollingEl = undefined;
});
doc.addEventListener('ionGestureCaptured', cancelActive);
doc.addEventListener('touchstart', onTouchStart, true);
doc.addEventListener('touchcancel', onTouchEnd, true);
doc.addEventListener('touchend', onTouchEnd, true);
doc.addEventListener('mousedown', onMouseDown, true);
doc.addEventListener('mouseup', onMouseUp, true);
};
var getActivatableTarget = function getActivatableTarget(ev) {
if (ev.composedPath) {
var path = ev.composedPath();
for (var i = 0; i < path.length - 2; i++) {
var el = path[i];
if (el.classList && el.classList.contains('ion-activatable')) {
return el;
}
}
} else {
return ev.target.closest('.ion-activatable');
}
};
var isInstant = function isInstant(el) {
return el.classList.contains('ion-activatable-instant');
};
var getRippleEffect = function getRippleEffect(el) {
if (el.shadowRoot) {
var ripple = el.shadowRoot.querySelector('ion-ripple-effect');
if (ripple) {
return ripple;
}
}
return el.querySelector('ion-ripple-effect');
};
var ACTIVATED = 'ion-activated';
var ADD_ACTIVATED_DEFERS = 200;
var CLEAR_STATE_DEFERS = 200;
var MOUSE_WAIT = 2500;
/***/
}
}]);
})();
//# sourceMappingURL=tap-click-252af35a-js-es5.js.map