Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ngx-pinch-zoom

Package Overview
Dependencies
Maintainers
1
Versions
37
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-pinch-zoom - npm Package Compare versions

Comparing version 2.0.1 to 2.0.2

14

bundles/ngx-pinch-zoom.umd.js

@@ -273,6 +273,16 @@ (function (global, factory) {

if (listener === 'mouseup' || listener === "mousemove") {
document[action](listener, this[handler], false);
if (action === 'addEventListener') {
document.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
document.removeEventListener(listener, this[handler], false);
}
}
else {
this.element[action](listener, this[handler], false);
if (action === 'addEventListener') {
this.element.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
this.element.removeEventListener(listener, this[handler], false);
}
}

@@ -279,0 +289,0 @@ }

2

bundles/ngx-pinch-zoom.umd.min.js

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-pinch-zoom",["exports","@angular/core","@angular/common"],e):e((t=t||self)["ngx-pinch-zoom"]={},t.ng.core,t.ng.common)}(this,(function(t,e,i){"use strict";var o={transitionDuration:200,doubleTap:!0,doubleTapScale:2,zoomButton:!0,zoomButtonScale:2,autoZoomOut:!1,limitZoom:3,disabled:!1},n={"transition-duration":"transitionDuration","double-tap":"doubleTap","double-tap-scale":"doubleTapScale","zoom-button":"zoomButton","auto-zoom-out":"autoZoomOut","limit-zoom":"limitZoom"};var s=function(){function t(t){var e=this;this.eventType=void 0,this.handlers={},this.startX=0,this.startY=0,this.lastTap=0,this.doubleTapMinTimeout=300,this.tapMinTimeout=200,this.touchstartTime=0,this.i=0,this.isMousedown=!1,this.touchListeners={touchstart:"handleTouchstart",touchmove:"handleTouchmove",touchend:"handleTouchend"},this.mouseListeners={mousedown:"handleMousedown",mousemove:"handleMousemove",mouseup:"handleMouseup"},this.handleTouchstart=function(t){e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getTouchstartPosition(t),e.runHandler("touchstart",t)},this.handleTouchmove=function(t){var i=t.touches;e.detectPan(i)&&e.runHandler("pan",t),e.detectPinch(t)&&e.runHandler("pinch",t)},this.handleTouchend=function(t){var i=t.touches;e.detectDoubleTap()&&e.runHandler("double-tap",t),e.detectTap(),e.runHandler("touchend",t),e.eventType="touchend",i&&0===i.length&&(e.eventType=void 0,e.i=0)},this.handleMousedown=function(t){e.isMousedown=!0,e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getMousedownPosition(t),e.runHandler("mousedown",t)},this.handleMousemove=function(t){if(t.preventDefault(),e.isMousedown){switch(e.runHandler("pan",t),e.detectLinearSwipe(t)){case"horizontal-swipe":t.swipeType="horizontal-swipe",e.runHandler("horizontal-swipe",t);break;case"vertical-swipe":t.swipeType="vertical-swipe",e.runHandler("vertical-swipe",t)}(e.detectLinearSwipe(t)||"horizontal-swipe"===e.eventType||"vertical-swipe"===e.eventType)&&e.handleLinearSwipe(t)}},this.handleMouseup=function(t){e.detectDoubleTap()&&e.runHandler("double-tap",t),e.detectTap(),e.isMousedown=!1,e.runHandler("mouseup",t),e.eventType=void 0,e.i=0},this.properties=t,this.element=this.properties.element,this.elementPosition=this.getElementPosition(),this.toggleEventListeners("addEventListener")}return t.prototype.destroy=function(){this.toggleEventListeners("removeEventListener")},t.prototype.toggleEventListeners=function(t){var e;for(var i in e="mouse and touch"===this.properties.listeners?Object.assign(this.touchListeners,this.mouseListeners):this.detectTouchScreen()?this.touchListeners:this.mouseListeners){var o=e[i];"mouseup"===i||"mousemove"===i?document[t](i,this[o],!1):this.element[t](i,this[o],!1)}},t.prototype.handleLinearSwipe=function(t){this.i++,this.i>3&&(this.eventType=this.getLinearSwipeType(t)),"horizontal-swipe"===this.eventType&&this.runHandler("horizontal-swipe",t),"vertical-swipe"===this.eventType&&this.runHandler("vertical-swipe",t)},t.prototype.runHandler=function(t,e){this.handlers[t]&&this.handlers[t](e)},t.prototype.detectPan=function(t){return 1===t.length&&!this.eventType||"pan"===this.eventType},t.prototype.detectDoubleTap=function(){var t=this;if(null==this.eventType){var e=(new Date).getTime(),i=e-this.lastTap;if(clearTimeout(this.doubleTapTimeout),i<this.doubleTapMinTimeout&&i>0)return!0;this.doubleTapTimeout=setTimeout((function(){clearTimeout(t.doubleTapTimeout)}),this.doubleTapMinTimeout),this.lastTap=e}},t.prototype.detectTap=function(){if(null==this.eventType){var t=(new Date).getTime()-this.touchstartTime;t>0&&(t<this.tapMinTimeout?this.runHandler("tap",event):this.runHandler("longtap",event))}},t.prototype.detectPinch=function(t){return 2===t.touches.length&&void 0===this.eventType||"pinch"===this.eventType},t.prototype.detectLinearSwipe=function(t){var e=t.touches;if(e){if(1===e.length&&!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)}else if(!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)},t.prototype.getLinearSwipeType=function(t){if("horizontal-swipe"!==this.eventType&&"vertical-swipe"!==this.eventType){var e=Math.abs(this.moveLeft(0,t)-this.startX);return 3*Math.abs(this.moveTop(0,t)-this.startY)>e?"vertical-swipe":"horizontal-swipe"}return this.eventType},t.prototype.getElementPosition=function(){return this.element.getBoundingClientRect()},t.prototype.getTouchstartPosition=function(t){this.startX=t.touches[0].clientX-this.elementPosition.left,this.startY=t.touches[0].clientY-this.elementPosition.top},t.prototype.getMousedownPosition=function(t){this.startX=t.clientX-this.elementPosition.left,this.startY=t.clientY-this.elementPosition.top},t.prototype.moveLeft=function(t,e){var i=e.touches;return i?i[t].clientX-this.elementPosition.left:e.clientX-this.elementPosition.left},t.prototype.moveTop=function(t,e){var i=e.touches;return i?i[t].clientY-this.elementPosition.top:e.clientY-this.elementPosition.top},t.prototype.detectTouchScreen=function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");return"ontouchstart"in window||function(t){return window.matchMedia(t).matches}(["(",t.join("touch-enabled),("),"heartz",")"].join(""))},t.prototype.on=function(t,e){t&&(this.handlers[t]=e)},t}();var a={doubleTap:!0,doubleTapScale:2,transitionDuration:200,limitZoom:3},r=function(){function t(t){var e=this;this.i=0,this.scale=1,this.initialScale=1,this.startX=0,this.startY=0,this.moveX=0,this.moveY=0,this.initialMoveX=0,this.initialMoveY=0,this.moveXC=0,this.moveYC=0,this.lastTap=0,this.draggingMode=!1,this.distance=0,this.doubleTapTimeout=0,this.initialDistance=0,this.events={},this.handleTouchstart=function(t){e.getElementPosition(),void 0===e.eventType&&e.getTouchstartPosition(t)},this.handleTouchend=function(t){if("touchend"===t.type){e.i=0,e.draggingMode=!1;var i=t.touches;e.scale<1&&(e.scale=1),e.properties.autoZoomOut&&"pinch"===e.eventType&&(e.scale=1),"pinch"!==e.eventType&&"pan"!==e.eventType||e.alignImage(),"pinch"!==e.eventType&&"pan"!==e.eventType&&"horizontal-swipe"!==e.eventType&&"vertical-swipe"!==e.eventType||e.updateInitialValues(),e.eventType="touchend",i&&0===i.length&&(e.eventType=void 0)}"mouseup"===t.type&&(e.draggingMode=!1,e.updateInitialValues(),e.eventType=void 0)},this.handlePan=function(t){if(!(e.scale<=1)){t.preventDefault();var i=e.getClientPosition(t),o=i.clientX,n=i.clientY;e.eventType||(e.startX=o-e.elementPosition.left,e.startY=n-e.elementPosition.top),e.eventType="pan",e.moveX=e.initialMoveX+(e.moveLeft(t,0)-e.startX),e.moveY=e.initialMoveY+(e.moveTop(t,0)-e.startY),"mousemove"===t.type&&e.centeringImage(),e.emitEvent({name:"pan",detail:{moveX:e.moveX,moveY:e.moveY}}),e.transformElement(0)}},this.handleDoubleTap=function(t){e.emitEvent({name:"double-tap"}),e.toggleZoom(t)},this.handlePinch=function(t){if(t.preventDefault(),void 0===e.eventType||"pinch"===e.eventType){var i=t.touches;if(!e.eventType){e.initialDistance=e.getDistance(i);var o=e.moveLeft(t,0),n=e.moveLeft(t,1),s=e.moveTop(t,0),a=e.moveTop(t,1);e.moveXC=(o+n)/2-e.initialMoveX,e.moveYC=(s+a)/2-e.initialMoveY}e.eventType="pinch",e.distance=e.getDistance(i),e.scale=e.initialScale*(e.distance/e.initialDistance),e.moveX=e.initialMoveX-(e.distance/e.initialDistance*e.moveXC-e.moveXC),e.moveY=e.initialMoveY-(e.distance/e.initialDistance*e.moveYC-e.moveYC),e.handleLimitZoom(),e.emitEvent({name:"pinch",detail:{scale:e.scale}}),e.transformElement(0)}},this.element=t.element,this.elementTarget=this.element.querySelector("*").tagName,this.parentElement=this.element.parentElement,this.properties=Object.assign({},a,t),this.touches=new s({element:t.element}),this.setBasicStyles(),this.touches.on("touchstart",this.handleTouchstart),this.touches.on("touchend",this.handleTouchend),this.touches.on("mousedown",this.handleTouchstart),this.touches.on("mouseup",this.handleTouchend),this.touches.on("pan",this.handlePan),this.touches.on("mousemove",this.handlePan),this.touches.on("pinch",this.handlePinch),this.properties.doubleTap&&this.touches.on("double-tap",this.handleDoubleTap)}return t.prototype.emitEvent=function(t){this.events[t.name]=new CustomEvent(t.name,{detail:t.detail}),this.element.dispatchEvent(this.events[t.name])},t.prototype.handleLimitZoom=function(){if(void 0!==this.properties.limitZoom&&this.scale>this.properties.limitZoom){var t=this.getImageWidth(),e=this.getImageHeight(),i=t*this.scale,o=e*this.scale,n=this.moveX/(i-t),s=this.moveY/(o-e);this.scale=this.properties.limitZoom;var a=t*this.scale,r=e*this.scale;this.moveX=-Math.abs(n*(a-t)),this.moveY=-Math.abs(-s*(r-e)),this.transformElement(this.properties.transitionDuration)}},t.prototype.moveLeft=function(t,e){return void 0===e&&(e=0),this.getClientPosition(t,e).clientX-this.elementPosition.left},t.prototype.moveTop=function(t,e){return void 0===e&&(e=0),this.getClientPosition(t,e).clientY-this.elementPosition.top},t.prototype.centeringImage=function(){var t=this.element.getElementsByTagName(this.elementTarget)[0],e=this.moveX,i=this.moveY;return this.moveY>0&&(this.moveY=0),this.moveX>0&&(this.moveX=0),t&&(this.transitionYRestriction(),this.transitionXRestriction()),t&&this.scale<1&&this.moveX<this.element.offsetWidth*(1-this.scale)&&(this.moveX=this.element.offsetWidth*(1-this.scale)),e!==this.moveX||i!==this.moveY},t.prototype.transitionYRestriction=function(){var t=this.getImageHeight();if(t*this.scale<this.parentElement.offsetHeight)this.moveY=(this.parentElement.offsetHeight-this.element.offsetHeight*this.scale)/2;else{var e=(t-this.element.offsetHeight)*this.scale/2;this.moveY>e?this.moveY=e:t*this.scale+Math.abs(e)-this.parentElement.offsetHeight+this.moveY<0&&(this.moveY=-(t*this.scale+Math.abs(e)-this.parentElement.offsetHeight))}},t.prototype.transitionXRestriction=function(){var t=this.getImageWidth();if(t*this.scale<this.parentElement.offsetWidth)this.moveX=(this.parentElement.offsetWidth-this.element.offsetWidth*this.scale)/2;else{var e=(t-this.element.offsetWidth)*this.scale/2;this.moveX>e?this.moveX=e:t*this.scale+Math.abs(e)-this.parentElement.offsetWidth+this.moveX<0&&(this.moveX=-(t*this.scale+Math.abs(e)-this.parentElement.offsetWidth))}},t.prototype.setBasicStyles=function(){this.element.style.display="flex",this.element.style.alignItems="center",this.element.style.justifyContent="center",this.element.style.transformOrigin="0 0",this.setImageWidth()},t.prototype.setImageWidth=function(){var t=this.element.getElementsByTagName(this.elementTarget);t.length&&(t[0].style.maxWidth="100%",t[0].style.maxHeight="100%")},t.prototype.getElementPosition=function(){this.elementPosition=this.element.parentElement.getBoundingClientRect()},t.prototype.getTouchstartPosition=function(t){var e=this.getClientPosition(t),i=e.clientX,o=e.clientY;this.startX=i-this.elementPosition.left,this.startY=o-this.elementPosition.top},t.prototype.getClientPosition=function(t,e){var i,o;return void 0===e&&(e=0),"touchstart"!==t.type&&"touchmove"!==t.type||(i=t.touches[e].clientX,o=t.touches[e].clientY),"mousedown"!==t.type&&"mousemove"!==t.type||(i=t.clientX,o=t.clientY),{clientX:i,clientY:o}},t.prototype.resetScale=function(){this.scale=1,this.moveX=0,this.moveY=0,this.updateInitialValues(),this.transformElement(this.properties.transitionDuration)},t.prototype.updateInitialValues=function(){this.initialScale=this.scale,this.initialMoveX=this.moveX,this.initialMoveY=this.moveY},t.prototype.getDistance=function(t){return Math.sqrt(Math.pow(t[0].pageX-t[1].pageX,2)+Math.pow(t[0].pageY-t[1].pageY,2))},t.prototype.getImageHeight=function(){return this.element.offsetHeight},t.prototype.getImageWidth=function(){return this.element.offsetWidth},t.prototype.transformElement=function(t){this.element.style.transition="all "+t+"ms",this.element.style.transform="matrix("+Number(this.scale)+", 0, 0, "+Number(this.scale)+", "+Number(this.moveX)+", "+Number(this.moveY)+")"},t.prototype.isTouchScreen=function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");if("ontouchstart"in window)return!0;var e=["(",t.join("touch-enabled),("),"heartz",")"].join("");return this.getMatchMedia(e)},t.prototype.getMatchMedia=function(t){return window.matchMedia(t).matches},t.prototype.isDragging=function(){var t=this.getImageHeight(),e=this.getImageWidth();return this.scale>1?t*this.scale>this.parentElement.offsetHeight||e*this.scale>this.parentElement.offsetWidth:1===this.scale?t>this.parentElement.offsetHeight||e>this.parentElement.offsetWidth:void 0},t.prototype.toggleZoom=function(t){if(void 0===t&&(t=!1),1===this.initialScale){if(t&&t.changedTouches){if(void 0===this.properties.doubleTapScale)return;var e=t.changedTouches;this.scale=this.initialScale*this.properties.doubleTapScale,this.moveX=this.initialMoveX-(e[0].clientX-this.elementPosition.left)*(this.properties.doubleTapScale-1),this.moveY=this.initialMoveY-(e[0].clientY-this.elementPosition.top)*(this.properties.doubleTapScale-1)}else this.scale=this.initialScale*this.properties.zoomButtonScale,this.moveX=this.initialMoveX-this.element.offsetWidth*(this.scale-1)/2,this.moveY=this.initialMoveY-this.element.offsetHeight*(this.scale-1)/2;this.centeringImage(),this.updateInitialValues(),this.emitEvent({name:"zoom-in"}),this.transformElement(this.properties.transitionDuration)}else this.emitEvent({name:"zoom-out"}),this.resetScale()},t.prototype.alignImage=function(){this.centeringImage()&&(this.updateInitialValues(),this.transformElement(this.properties.transitionDuration))},t}();var h=function(){function t(t){this.elementRef=t,this.transitionDuration=200,this.doubleTap=!0,this.doubleTapScale=2,this.zoomButton=!0,this.zoomButtonScale=2,this.autoZoomOut=!1,this.disabled=!1,this.allowScroll=!1,this.events=new e.EventEmitter,this.hostDisplay="block",this.hostOverflow="hidden",this.applyOptionsDefault(o,{})}return Object.defineProperty(t.prototype,"isZoomButton",{get:function(){return this.properties.zoomButton},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"properties",{get:function(){return this._properties},set:function(t){t&&(this._properties=t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isTouchScreen",{get:function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");return"ontouchstart"in window||function(t){return window.matchMedia(t).matches}(["(",t.join("touch-enabled),("),"heartz",")"].join(""))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isDragging",{get:function(){if(this.pinchZoom)return this.pinchZoom.isDragging()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isDisabled",{get:function(){if(this.properties)return this.properties.disabled},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"scale",{get:function(){if(this.pinchZoom)return this.pinchZoom.scale},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){this.initPinchZoom()},t.prototype.ngOnChanges=function(t){var e=this.getProperties(t);e=this.renameProperties(e),this.applyOptionsDefault(o,e)},t.prototype.ngOnDestroy=function(){},t.prototype.initPinchZoom=function(){this.properties.disabled||(this.properties.element=this.elementRef.nativeElement.querySelector(".pinch-zoom-content"),this.pinchZoom=new r(this.properties))},t.prototype.getProperties=function(t){var e={};for(var i in t)"properties"!==i&&(e[i]=t[i].currentValue),"properties"===i&&(e=t[i].currentValue);return e},t.prototype.renameProperties=function(t){for(var e in t)n[e]&&(t[n[e]]=t[e],delete t[e]);return t},t.prototype.applyOptionsDefault=function(t,e){this.properties=Object.assign({},t,e)},t.prototype.toggleZoom=function(){this.pinchZoom.toggleZoom()},t.decorators=[{type:e.Component,args:[{selector:"pinch-zoom",template:'<div class="pinch-zoom-content" \n\t[class.pz-dragging]="isDragging">\n\t<ng-content></ng-content>\n</div>\n\n<div class="pz-zoom-button"\n\t*ngIf="isZoomButton && !isTouchScreen && !isDisabled"\n\t(click)="toggleZoom()"\n\t[class.pz-zoom-out]="scale > 1">\n</div>',styles:[":host{position:relative;overflow:hidden;display:block}.pz-dragging{cursor:all-scroll}.pz-zoom-button{position:absolute;left:50%;bottom:16px;margin-left:-22px;z-index:1000;color:#fff;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABVUlEQVR4Ae3PAwxQXRgA0Pvbto1sW2NDts0x27atIdeQrakpY8i23cnGe5nn8epDeO1h+VgeVdRVRJLwsCQ101nX2aWJd8OD8a7Ozrkda6UJ8XnPUsBZy43S2Wz7rs8UDnEZCZjn5+tzb6jqCDgucYhDakAnb4Rb+MdmMCPEYSqYfH2cXfPr/ymcBalDFF84izN+uD7TnHCdXqB7iCI/WByuuy1QbrAiRFEL9L3WlObmc/l7uUHfgn0hivqg47VaXMfluQ/A6RBFeTDmnq39D7aEKNKBXfcMVBVMCtFsB0XvFshbVoBSIZqGYL8/wh10B/u8F6L52E6wU7ZwEx/oC6gV4pHVOXDeIPn95WOZ1bYRsD7EJ79D7m4nmO7dEI+fTHC7o7p6h+uh4pJJB0vscMwKQ+X13uXZ6RGh4vKeeQ8c6nWoJiFadCjRFUXzntbeDc/GaxcAotf7cicflKkAAAAASUVORK5CYII=),url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABS0lEQVR4Ae3UA8xWfQCG8afPNrNt240N2TbHbNu2hlxDtqamjCHbdr/s5905b9Z1fN/bdfyPfOZl8ZMSGmipggwvL8loqZsAOKaDb2Ir+UZ/t7zITjlio/nWRsBNm03T33KnHiflw4umAlaJ/ziLo6EL4LL04TTZAf3Eea5JYT9YEk60EMyP2mVxE2QP1vzuJm74P4Z+GBgcLCoN1sfYFwdbgkXNwMj7+4V1fnq6n/0DTgWLWoO+9/c7AwD3s+/B9WBRbTAjxj41OBAsygWOxdg3BPMiwTgMKkbtvrQFVAsjagtOSxKlGwxO+Tbc0HEUHFXomfx7IwHNIuFQ0C1w2zilJfOT/JrbC9gdCY/SzonOUbA49Mgknjme56KBvuaxKizy6WODIy7ZYqKSDx6xxUGq8MPeqlirPqs6RKljqwq6ovCq7r6JvBs+cwdLiOaEU9ek1AAAAABJRU5ErkJggg==),url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABVUlEQVR4Ae3PAwxQXRgA0Pvbto1sW2NDts0x27atIdeQrakpY8i23cnGe5nn8epDeO1h+VgeVdRVRJLwsCQ101nX2aWJd8OD8a7Ozrkda6UJ8XnPUsBZy43S2Wz7rs8UDnEZCZjn5+tzb6jqCDgucYhDakAnb4Rb+MdmMCPEYSqYfH2cXfPr/ymcBalDFF84izN+uD7TnHCdXqB7iCI/WByuuy1QbrAiRFEL9L3WlObmc/l7uUHfgn0hivqg47VaXMfluQ/A6RBFeTDmnq39D7aEKNKBXfcMVBVMCtFsB0XvFshbVoBSIZqGYL8/wh10B/u8F6L52E6wU7ZwEx/oC6gV4pHVOXDeIPn95WOZ1bYRsD7EJ79D7m4nmO7dEI+fTHC7o7p6h+uh4pJJB0vscMwKQ+X13uXZ6RGh4vKeeQ8c6nWoJiFadCjRFUXzntbeDc/GaxcAotf7cicflKkAAAAASUVORK5CYII=),url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABS0lEQVR4Ae3UA8xWfQCG8afPNrNt240N2TbHbNu2hlxDtqamjCHbdr/s5905b9Z1fN/bdfyPfOZl8ZMSGmipggwvL8loqZsAOKaDb2Ir+UZ/t7zITjlio/nWRsBNm03T33KnHiflw4umAlaJ/ziLo6EL4LL04TTZAf3Eea5JYT9YEk60EMyP2mVxE2QP1vzuJm74P4Z+GBgcLCoN1sfYFwdbgkXNwMj7+4V1fnq6n/0DTgWLWoO+9/c7AwD3s+/B9WBRbTAjxj41OBAsygWOxdg3BPMiwTgMKkbtvrQFVAsjagtOSxKlGwxO+Tbc0HEUHFXomfx7IwHNIuFQ0C1w2zilJfOT/JrbC9gdCY/SzonOUbA49Mgknjme56KBvuaxKizy6WODIy7ZYqKSDx6xxUGq8MPeqlirPqs6RKljqwq6ovCq7r6JvBs+cwdLiOaEU9ek1AAAAABJRU5ErkJggg==);background-color:rgba(0,0,0,.8);background-position:center,-1000px;background-repeat:no-repeat,no-repeat;width:56px;height:56px;border-radius:4px;opacity:.5;cursor:pointer;transition:opacity .1s;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.pz-zoom-button.pz-zoom-out{background-position:-1000px,center}.pz-zoom-button:hover{opacity:.7}"]}]}],t.ctorParameters=function(){return[{type:e.ElementRef}]},t.propDecorators={properties:[{type:e.Input,args:["properties"]}],transitionDuration:[{type:e.Input,args:["transition-duration"]}],doubleTap:[{type:e.Input,args:["double-tap"]}],doubleTapScale:[{type:e.Input,args:["double-tap-scale"]}],zoomButton:[{type:e.Input,args:["zoom-button"]}],zoomButtonScale:[{type:e.Input,args:["zoom-button-scale"]}],autoZoomOut:[{type:e.Input,args:["auto-zoom-out"]}],limitZoom:[{type:e.Input,args:["limit-zoom"]}],disabled:[{type:e.Input,args:["disabled"]}],allowScroll:[{type:e.Input,args:["allow-scroll"]}],events:[{type:e.Output}],hostDisplay:[{type:e.HostBinding,args:["style.display"]}],hostOverflow:[{type:e.HostBinding,args:["style.overflow"]}]},t}();var l=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{declarations:[h],imports:[i.CommonModule],exports:[h],providers:[],bootstrap:[],entryComponents:[h]}]}],t}();t.PinchZoomModule=l,t.ɵa=h,Object.defineProperty(t,"__esModule",{value:!0})}));
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-pinch-zoom",["exports","@angular/core","@angular/common"],e):e((t=t||self)["ngx-pinch-zoom"]={},t.ng.core,t.ng.common)}(this,(function(t,e,i){"use strict";var o={transitionDuration:200,doubleTap:!0,doubleTapScale:2,zoomButton:!0,zoomButtonScale:2,autoZoomOut:!1,limitZoom:3,disabled:!1},n={"transition-duration":"transitionDuration","double-tap":"doubleTap","double-tap-scale":"doubleTapScale","zoom-button":"zoomButton","auto-zoom-out":"autoZoomOut","limit-zoom":"limitZoom"};var s=function(){function t(t){var e=this;this.eventType=void 0,this.handlers={},this.startX=0,this.startY=0,this.lastTap=0,this.doubleTapMinTimeout=300,this.tapMinTimeout=200,this.touchstartTime=0,this.i=0,this.isMousedown=!1,this.touchListeners={touchstart:"handleTouchstart",touchmove:"handleTouchmove",touchend:"handleTouchend"},this.mouseListeners={mousedown:"handleMousedown",mousemove:"handleMousemove",mouseup:"handleMouseup"},this.handleTouchstart=function(t){e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getTouchstartPosition(t),e.runHandler("touchstart",t)},this.handleTouchmove=function(t){var i=t.touches;e.detectPan(i)&&e.runHandler("pan",t),e.detectPinch(t)&&e.runHandler("pinch",t)},this.handleTouchend=function(t){var i=t.touches;e.detectDoubleTap()&&e.runHandler("double-tap",t),e.detectTap(),e.runHandler("touchend",t),e.eventType="touchend",i&&0===i.length&&(e.eventType=void 0,e.i=0)},this.handleMousedown=function(t){e.isMousedown=!0,e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getMousedownPosition(t),e.runHandler("mousedown",t)},this.handleMousemove=function(t){if(t.preventDefault(),e.isMousedown){switch(e.runHandler("pan",t),e.detectLinearSwipe(t)){case"horizontal-swipe":t.swipeType="horizontal-swipe",e.runHandler("horizontal-swipe",t);break;case"vertical-swipe":t.swipeType="vertical-swipe",e.runHandler("vertical-swipe",t)}(e.detectLinearSwipe(t)||"horizontal-swipe"===e.eventType||"vertical-swipe"===e.eventType)&&e.handleLinearSwipe(t)}},this.handleMouseup=function(t){e.detectDoubleTap()&&e.runHandler("double-tap",t),e.detectTap(),e.isMousedown=!1,e.runHandler("mouseup",t),e.eventType=void 0,e.i=0},this.properties=t,this.element=this.properties.element,this.elementPosition=this.getElementPosition(),this.toggleEventListeners("addEventListener")}return t.prototype.destroy=function(){this.toggleEventListeners("removeEventListener")},t.prototype.toggleEventListeners=function(t){var e;for(var i in e="mouse and touch"===this.properties.listeners?Object.assign(this.touchListeners,this.mouseListeners):this.detectTouchScreen()?this.touchListeners:this.mouseListeners){var o=e[i];"mouseup"===i||"mousemove"===i?("addEventListener"===t&&document.addEventListener(i,this[o],!1),"removeEventListener"===t&&document.removeEventListener(i,this[o],!1)):("addEventListener"===t&&this.element.addEventListener(i,this[o],!1),"removeEventListener"===t&&this.element.removeEventListener(i,this[o],!1))}},t.prototype.handleLinearSwipe=function(t){this.i++,this.i>3&&(this.eventType=this.getLinearSwipeType(t)),"horizontal-swipe"===this.eventType&&this.runHandler("horizontal-swipe",t),"vertical-swipe"===this.eventType&&this.runHandler("vertical-swipe",t)},t.prototype.runHandler=function(t,e){this.handlers[t]&&this.handlers[t](e)},t.prototype.detectPan=function(t){return 1===t.length&&!this.eventType||"pan"===this.eventType},t.prototype.detectDoubleTap=function(){var t=this;if(null==this.eventType){var e=(new Date).getTime(),i=e-this.lastTap;if(clearTimeout(this.doubleTapTimeout),i<this.doubleTapMinTimeout&&i>0)return!0;this.doubleTapTimeout=setTimeout((function(){clearTimeout(t.doubleTapTimeout)}),this.doubleTapMinTimeout),this.lastTap=e}},t.prototype.detectTap=function(){if(null==this.eventType){var t=(new Date).getTime()-this.touchstartTime;t>0&&(t<this.tapMinTimeout?this.runHandler("tap",event):this.runHandler("longtap",event))}},t.prototype.detectPinch=function(t){return 2===t.touches.length&&void 0===this.eventType||"pinch"===this.eventType},t.prototype.detectLinearSwipe=function(t){var e=t.touches;if(e){if(1===e.length&&!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)}else if(!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)},t.prototype.getLinearSwipeType=function(t){if("horizontal-swipe"!==this.eventType&&"vertical-swipe"!==this.eventType){var e=Math.abs(this.moveLeft(0,t)-this.startX);return 3*Math.abs(this.moveTop(0,t)-this.startY)>e?"vertical-swipe":"horizontal-swipe"}return this.eventType},t.prototype.getElementPosition=function(){return this.element.getBoundingClientRect()},t.prototype.getTouchstartPosition=function(t){this.startX=t.touches[0].clientX-this.elementPosition.left,this.startY=t.touches[0].clientY-this.elementPosition.top},t.prototype.getMousedownPosition=function(t){this.startX=t.clientX-this.elementPosition.left,this.startY=t.clientY-this.elementPosition.top},t.prototype.moveLeft=function(t,e){var i=e.touches;return i?i[t].clientX-this.elementPosition.left:e.clientX-this.elementPosition.left},t.prototype.moveTop=function(t,e){var i=e.touches;return i?i[t].clientY-this.elementPosition.top:e.clientY-this.elementPosition.top},t.prototype.detectTouchScreen=function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");return"ontouchstart"in window||function(t){return window.matchMedia(t).matches}(["(",t.join("touch-enabled),("),"heartz",")"].join(""))},t.prototype.on=function(t,e){t&&(this.handlers[t]=e)},t}();var a={doubleTap:!0,doubleTapScale:2,transitionDuration:200,limitZoom:3},r=function(){function t(t){var e=this;this.i=0,this.scale=1,this.initialScale=1,this.startX=0,this.startY=0,this.moveX=0,this.moveY=0,this.initialMoveX=0,this.initialMoveY=0,this.moveXC=0,this.moveYC=0,this.lastTap=0,this.draggingMode=!1,this.distance=0,this.doubleTapTimeout=0,this.initialDistance=0,this.events={},this.handleTouchstart=function(t){e.getElementPosition(),void 0===e.eventType&&e.getTouchstartPosition(t)},this.handleTouchend=function(t){if("touchend"===t.type){e.i=0,e.draggingMode=!1;var i=t.touches;e.scale<1&&(e.scale=1),e.properties.autoZoomOut&&"pinch"===e.eventType&&(e.scale=1),"pinch"!==e.eventType&&"pan"!==e.eventType||e.alignImage(),"pinch"!==e.eventType&&"pan"!==e.eventType&&"horizontal-swipe"!==e.eventType&&"vertical-swipe"!==e.eventType||e.updateInitialValues(),e.eventType="touchend",i&&0===i.length&&(e.eventType=void 0)}"mouseup"===t.type&&(e.draggingMode=!1,e.updateInitialValues(),e.eventType=void 0)},this.handlePan=function(t){if(!(e.scale<=1)){t.preventDefault();var i=e.getClientPosition(t),o=i.clientX,n=i.clientY;e.eventType||(e.startX=o-e.elementPosition.left,e.startY=n-e.elementPosition.top),e.eventType="pan",e.moveX=e.initialMoveX+(e.moveLeft(t,0)-e.startX),e.moveY=e.initialMoveY+(e.moveTop(t,0)-e.startY),"mousemove"===t.type&&e.centeringImage(),e.emitEvent({name:"pan",detail:{moveX:e.moveX,moveY:e.moveY}}),e.transformElement(0)}},this.handleDoubleTap=function(t){e.emitEvent({name:"double-tap"}),e.toggleZoom(t)},this.handlePinch=function(t){if(t.preventDefault(),void 0===e.eventType||"pinch"===e.eventType){var i=t.touches;if(!e.eventType){e.initialDistance=e.getDistance(i);var o=e.moveLeft(t,0),n=e.moveLeft(t,1),s=e.moveTop(t,0),a=e.moveTop(t,1);e.moveXC=(o+n)/2-e.initialMoveX,e.moveYC=(s+a)/2-e.initialMoveY}e.eventType="pinch",e.distance=e.getDistance(i),e.scale=e.initialScale*(e.distance/e.initialDistance),e.moveX=e.initialMoveX-(e.distance/e.initialDistance*e.moveXC-e.moveXC),e.moveY=e.initialMoveY-(e.distance/e.initialDistance*e.moveYC-e.moveYC),e.handleLimitZoom(),e.emitEvent({name:"pinch",detail:{scale:e.scale}}),e.transformElement(0)}},this.element=t.element,this.elementTarget=this.element.querySelector("*").tagName,this.parentElement=this.element.parentElement,this.properties=Object.assign({},a,t),this.touches=new s({element:t.element}),this.setBasicStyles(),this.touches.on("touchstart",this.handleTouchstart),this.touches.on("touchend",this.handleTouchend),this.touches.on("mousedown",this.handleTouchstart),this.touches.on("mouseup",this.handleTouchend),this.touches.on("pan",this.handlePan),this.touches.on("mousemove",this.handlePan),this.touches.on("pinch",this.handlePinch),this.properties.doubleTap&&this.touches.on("double-tap",this.handleDoubleTap)}return t.prototype.emitEvent=function(t){this.events[t.name]=new CustomEvent(t.name,{detail:t.detail}),this.element.dispatchEvent(this.events[t.name])},t.prototype.handleLimitZoom=function(){if(void 0!==this.properties.limitZoom&&this.scale>this.properties.limitZoom){var t=this.getImageWidth(),e=this.getImageHeight(),i=t*this.scale,o=e*this.scale,n=this.moveX/(i-t),s=this.moveY/(o-e);this.scale=this.properties.limitZoom;var a=t*this.scale,r=e*this.scale;this.moveX=-Math.abs(n*(a-t)),this.moveY=-Math.abs(-s*(r-e)),this.transformElement(this.properties.transitionDuration)}},t.prototype.moveLeft=function(t,e){return void 0===e&&(e=0),this.getClientPosition(t,e).clientX-this.elementPosition.left},t.prototype.moveTop=function(t,e){return void 0===e&&(e=0),this.getClientPosition(t,e).clientY-this.elementPosition.top},t.prototype.centeringImage=function(){var t=this.element.getElementsByTagName(this.elementTarget)[0],e=this.moveX,i=this.moveY;return this.moveY>0&&(this.moveY=0),this.moveX>0&&(this.moveX=0),t&&(this.transitionYRestriction(),this.transitionXRestriction()),t&&this.scale<1&&this.moveX<this.element.offsetWidth*(1-this.scale)&&(this.moveX=this.element.offsetWidth*(1-this.scale)),e!==this.moveX||i!==this.moveY},t.prototype.transitionYRestriction=function(){var t=this.getImageHeight();if(t*this.scale<this.parentElement.offsetHeight)this.moveY=(this.parentElement.offsetHeight-this.element.offsetHeight*this.scale)/2;else{var e=(t-this.element.offsetHeight)*this.scale/2;this.moveY>e?this.moveY=e:t*this.scale+Math.abs(e)-this.parentElement.offsetHeight+this.moveY<0&&(this.moveY=-(t*this.scale+Math.abs(e)-this.parentElement.offsetHeight))}},t.prototype.transitionXRestriction=function(){var t=this.getImageWidth();if(t*this.scale<this.parentElement.offsetWidth)this.moveX=(this.parentElement.offsetWidth-this.element.offsetWidth*this.scale)/2;else{var e=(t-this.element.offsetWidth)*this.scale/2;this.moveX>e?this.moveX=e:t*this.scale+Math.abs(e)-this.parentElement.offsetWidth+this.moveX<0&&(this.moveX=-(t*this.scale+Math.abs(e)-this.parentElement.offsetWidth))}},t.prototype.setBasicStyles=function(){this.element.style.display="flex",this.element.style.alignItems="center",this.element.style.justifyContent="center",this.element.style.transformOrigin="0 0",this.setImageWidth()},t.prototype.setImageWidth=function(){var t=this.element.getElementsByTagName(this.elementTarget);t.length&&(t[0].style.maxWidth="100%",t[0].style.maxHeight="100%")},t.prototype.getElementPosition=function(){this.elementPosition=this.element.parentElement.getBoundingClientRect()},t.prototype.getTouchstartPosition=function(t){var e=this.getClientPosition(t),i=e.clientX,o=e.clientY;this.startX=i-this.elementPosition.left,this.startY=o-this.elementPosition.top},t.prototype.getClientPosition=function(t,e){var i,o;return void 0===e&&(e=0),"touchstart"!==t.type&&"touchmove"!==t.type||(i=t.touches[e].clientX,o=t.touches[e].clientY),"mousedown"!==t.type&&"mousemove"!==t.type||(i=t.clientX,o=t.clientY),{clientX:i,clientY:o}},t.prototype.resetScale=function(){this.scale=1,this.moveX=0,this.moveY=0,this.updateInitialValues(),this.transformElement(this.properties.transitionDuration)},t.prototype.updateInitialValues=function(){this.initialScale=this.scale,this.initialMoveX=this.moveX,this.initialMoveY=this.moveY},t.prototype.getDistance=function(t){return Math.sqrt(Math.pow(t[0].pageX-t[1].pageX,2)+Math.pow(t[0].pageY-t[1].pageY,2))},t.prototype.getImageHeight=function(){return this.element.offsetHeight},t.prototype.getImageWidth=function(){return this.element.offsetWidth},t.prototype.transformElement=function(t){this.element.style.transition="all "+t+"ms",this.element.style.transform="matrix("+Number(this.scale)+", 0, 0, "+Number(this.scale)+", "+Number(this.moveX)+", "+Number(this.moveY)+")"},t.prototype.isTouchScreen=function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");if("ontouchstart"in window)return!0;var e=["(",t.join("touch-enabled),("),"heartz",")"].join("");return this.getMatchMedia(e)},t.prototype.getMatchMedia=function(t){return window.matchMedia(t).matches},t.prototype.isDragging=function(){var t=this.getImageHeight(),e=this.getImageWidth();return this.scale>1?t*this.scale>this.parentElement.offsetHeight||e*this.scale>this.parentElement.offsetWidth:1===this.scale?t>this.parentElement.offsetHeight||e>this.parentElement.offsetWidth:void 0},t.prototype.toggleZoom=function(t){if(void 0===t&&(t=!1),1===this.initialScale){if(t&&t.changedTouches){if(void 0===this.properties.doubleTapScale)return;var e=t.changedTouches;this.scale=this.initialScale*this.properties.doubleTapScale,this.moveX=this.initialMoveX-(e[0].clientX-this.elementPosition.left)*(this.properties.doubleTapScale-1),this.moveY=this.initialMoveY-(e[0].clientY-this.elementPosition.top)*(this.properties.doubleTapScale-1)}else this.scale=this.initialScale*this.properties.zoomButtonScale,this.moveX=this.initialMoveX-this.element.offsetWidth*(this.scale-1)/2,this.moveY=this.initialMoveY-this.element.offsetHeight*(this.scale-1)/2;this.centeringImage(),this.updateInitialValues(),this.emitEvent({name:"zoom-in"}),this.transformElement(this.properties.transitionDuration)}else this.emitEvent({name:"zoom-out"}),this.resetScale()},t.prototype.alignImage=function(){this.centeringImage()&&(this.updateInitialValues(),this.transformElement(this.properties.transitionDuration))},t}();var h=function(){function t(t){this.elementRef=t,this.transitionDuration=200,this.doubleTap=!0,this.doubleTapScale=2,this.zoomButton=!0,this.zoomButtonScale=2,this.autoZoomOut=!1,this.disabled=!1,this.allowScroll=!1,this.events=new e.EventEmitter,this.hostDisplay="block",this.hostOverflow="hidden",this.applyOptionsDefault(o,{})}return Object.defineProperty(t.prototype,"isZoomButton",{get:function(){return this.properties.zoomButton},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"properties",{get:function(){return this._properties},set:function(t){t&&(this._properties=t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isTouchScreen",{get:function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");return"ontouchstart"in window||function(t){return window.matchMedia(t).matches}(["(",t.join("touch-enabled),("),"heartz",")"].join(""))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isDragging",{get:function(){if(this.pinchZoom)return this.pinchZoom.isDragging()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isDisabled",{get:function(){if(this.properties)return this.properties.disabled},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"scale",{get:function(){if(this.pinchZoom)return this.pinchZoom.scale},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){this.initPinchZoom()},t.prototype.ngOnChanges=function(t){var e=this.getProperties(t);e=this.renameProperties(e),this.applyOptionsDefault(o,e)},t.prototype.ngOnDestroy=function(){},t.prototype.initPinchZoom=function(){this.properties.disabled||(this.properties.element=this.elementRef.nativeElement.querySelector(".pinch-zoom-content"),this.pinchZoom=new r(this.properties))},t.prototype.getProperties=function(t){var e={};for(var i in t)"properties"!==i&&(e[i]=t[i].currentValue),"properties"===i&&(e=t[i].currentValue);return e},t.prototype.renameProperties=function(t){for(var e in t)n[e]&&(t[n[e]]=t[e],delete t[e]);return t},t.prototype.applyOptionsDefault=function(t,e){this.properties=Object.assign({},t,e)},t.prototype.toggleZoom=function(){this.pinchZoom.toggleZoom()},t.decorators=[{type:e.Component,args:[{selector:"pinch-zoom",template:'<div class="pinch-zoom-content" \n\t[class.pz-dragging]="isDragging">\n\t<ng-content></ng-content>\n</div>\n\n<div class="pz-zoom-button"\n\t*ngIf="isZoomButton && !isTouchScreen && !isDisabled"\n\t(click)="toggleZoom()"\n\t[class.pz-zoom-out]="scale > 1">\n</div>',styles:[":host{position:relative;overflow:hidden;display:block}.pz-dragging{cursor:all-scroll}.pz-zoom-button{position:absolute;left:50%;bottom:16px;margin-left:-22px;z-index:1000;color:#fff;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABVUlEQVR4Ae3PAwxQXRgA0Pvbto1sW2NDts0x27atIdeQrakpY8i23cnGe5nn8epDeO1h+VgeVdRVRJLwsCQ101nX2aWJd8OD8a7Ozrkda6UJ8XnPUsBZy43S2Wz7rs8UDnEZCZjn5+tzb6jqCDgucYhDakAnb4Rb+MdmMCPEYSqYfH2cXfPr/ymcBalDFF84izN+uD7TnHCdXqB7iCI/WByuuy1QbrAiRFEL9L3WlObmc/l7uUHfgn0hivqg47VaXMfluQ/A6RBFeTDmnq39D7aEKNKBXfcMVBVMCtFsB0XvFshbVoBSIZqGYL8/wh10B/u8F6L52E6wU7ZwEx/oC6gV4pHVOXDeIPn95WOZ1bYRsD7EJ79D7m4nmO7dEI+fTHC7o7p6h+uh4pJJB0vscMwKQ+X13uXZ6RGh4vKeeQ8c6nWoJiFadCjRFUXzntbeDc/GaxcAotf7cicflKkAAAAASUVORK5CYII=),url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABS0lEQVR4Ae3UA8xWfQCG8afPNrNt240N2TbHbNu2hlxDtqamjCHbdr/s5905b9Z1fN/bdfyPfOZl8ZMSGmipggwvL8loqZsAOKaDb2Ir+UZ/t7zITjlio/nWRsBNm03T33KnHiflw4umAlaJ/ziLo6EL4LL04TTZAf3Eea5JYT9YEk60EMyP2mVxE2QP1vzuJm74P4Z+GBgcLCoN1sfYFwdbgkXNwMj7+4V1fnq6n/0DTgWLWoO+9/c7AwD3s+/B9WBRbTAjxj41OBAsygWOxdg3BPMiwTgMKkbtvrQFVAsjagtOSxKlGwxO+Tbc0HEUHFXomfx7IwHNIuFQ0C1w2zilJfOT/JrbC9gdCY/SzonOUbA49Mgknjme56KBvuaxKizy6WODIy7ZYqKSDx6xxUGq8MPeqlirPqs6RKljqwq6ovCq7r6JvBs+cwdLiOaEU9ek1AAAAABJRU5ErkJggg==),url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABVUlEQVR4Ae3PAwxQXRgA0Pvbto1sW2NDts0x27atIdeQrakpY8i23cnGe5nn8epDeO1h+VgeVdRVRJLwsCQ101nX2aWJd8OD8a7Ozrkda6UJ8XnPUsBZy43S2Wz7rs8UDnEZCZjn5+tzb6jqCDgucYhDakAnb4Rb+MdmMCPEYSqYfH2cXfPr/ymcBalDFF84izN+uD7TnHCdXqB7iCI/WByuuy1QbrAiRFEL9L3WlObmc/l7uUHfgn0hivqg47VaXMfluQ/A6RBFeTDmnq39D7aEKNKBXfcMVBVMCtFsB0XvFshbVoBSIZqGYL8/wh10B/u8F6L52E6wU7ZwEx/oC6gV4pHVOXDeIPn95WOZ1bYRsD7EJ79D7m4nmO7dEI+fTHC7o7p6h+uh4pJJB0vscMwKQ+X13uXZ6RGh4vKeeQ8c6nWoJiFadCjRFUXzntbeDc/GaxcAotf7cicflKkAAAAASUVORK5CYII=),url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAkCAQAAABLCVATAAABS0lEQVR4Ae3UA8xWfQCG8afPNrNt240N2TbHbNu2hlxDtqamjCHbdr/s5905b9Z1fN/bdfyPfOZl8ZMSGmipggwvL8loqZsAOKaDb2Ir+UZ/t7zITjlio/nWRsBNm03T33KnHiflw4umAlaJ/ziLo6EL4LL04TTZAf3Eea5JYT9YEk60EMyP2mVxE2QP1vzuJm74P4Z+GBgcLCoN1sfYFwdbgkXNwMj7+4V1fnq6n/0DTgWLWoO+9/c7AwD3s+/B9WBRbTAjxj41OBAsygWOxdg3BPMiwTgMKkbtvrQFVAsjagtOSxKlGwxO+Tbc0HEUHFXomfx7IwHNIuFQ0C1w2zilJfOT/JrbC9gdCY/SzonOUbA49Mgknjme56KBvuaxKizy6WODIy7ZYqKSDx6xxUGq8MPeqlirPqs6RKljqwq6ovCq7r6JvBs+cwdLiOaEU9ek1AAAAABJRU5ErkJggg==);background-color:rgba(0,0,0,.8);background-position:center,-1000px;background-repeat:no-repeat,no-repeat;width:56px;height:56px;border-radius:4px;opacity:.5;cursor:pointer;transition:opacity .1s;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.pz-zoom-button.pz-zoom-out{background-position:-1000px,center}.pz-zoom-button:hover{opacity:.7}"]}]}],t.ctorParameters=function(){return[{type:e.ElementRef}]},t.propDecorators={properties:[{type:e.Input,args:["properties"]}],transitionDuration:[{type:e.Input,args:["transition-duration"]}],doubleTap:[{type:e.Input,args:["double-tap"]}],doubleTapScale:[{type:e.Input,args:["double-tap-scale"]}],zoomButton:[{type:e.Input,args:["zoom-button"]}],zoomButtonScale:[{type:e.Input,args:["zoom-button-scale"]}],autoZoomOut:[{type:e.Input,args:["auto-zoom-out"]}],limitZoom:[{type:e.Input,args:["limit-zoom"]}],disabled:[{type:e.Input,args:["disabled"]}],allowScroll:[{type:e.Input,args:["allow-scroll"]}],events:[{type:e.Output}],hostDisplay:[{type:e.HostBinding,args:["style.display"]}],hostOverflow:[{type:e.HostBinding,args:["style.overflow"]}]},t}();var l=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{declarations:[h],imports:[i.CommonModule],exports:[h],providers:[],bootstrap:[],entryComponents:[h]}]}],t}();t.PinchZoomModule=l,t.ɵa=h,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=ngx-pinch-zoom.umd.min.js.map

@@ -206,6 +206,16 @@ /**

if (listener === 'mouseup' || listener === "mousemove") {
document[action](listener, this[handler], false);
if (action === 'addEventListener') {
document.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
document.removeEventListener(listener, this[handler], false);
}
}
else {
this.element[action](listener, this[handler], false);
if (action === 'addEventListener') {
this.element.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
this.element.removeEventListener(listener, this[handler], false);
}
}

@@ -478,2 +488,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"touches.js","sourceRoot":"ng://ngx-pinch-zoom/","sources":["lib/touches.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nexport interface Properties {\r\n    element: HTMLElement;\r\n    listeners?: 'auto' | 'mouse and touch';\r\n}\r\n\r\nexport type EventType = undefined | 'touchend' | 'pan' | 'pinch' | 'horizontal-swipe' | 'vertical-swipe' | 'tap' | 'longtap';\r\nexport type TouchHandler = 'handleTouchstart' | 'handleTouchmove' | 'handleTouchend';\r\nexport type MouseHandler = 'handleMousedown' | 'handleMousemove' | 'handleMouseup';\r\n\r\nexport class Touches {\r\n    properties: Properties;\r\n    element: HTMLElement;\r\n    elementPosition: ClientRect;\r\n    eventType: EventType = undefined;\r\n    handlers: any = {};\r\n    startX = 0;\r\n    startY = 0;\r\n    lastTap = 0;\r\n    doubleTapTimeout: any;\r\n    doubleTapMinTimeout = 300;\r\n    tapMinTimeout = 200;\r\n    touchstartTime = 0;\r\n    i: number = 0;\r\n    isMousedown = false;\r\n\r\n    touchListeners: any = {\r\n        \"touchstart\": \"handleTouchstart\",\r\n        \"touchmove\": \"handleTouchmove\",\r\n        \"touchend\": \"handleTouchend\"\r\n    }\r\n    mouseListeners: any = {\r\n        \"mousedown\": \"handleMousedown\",\r\n        \"mousemove\": \"handleMousemove\",\r\n        \"mouseup\": \"handleMouseup\"\r\n    }\r\n\r\n    constructor(properties: Properties) {\r\n        this.properties = properties;\r\n        this.element = this.properties.element;\r\n        this.elementPosition = this.getElementPosition();\r\n\r\n        this.toggleEventListeners('addEventListener');\r\n    }\r\n\r\n    destroy() {\r\n        this.toggleEventListeners('removeEventListener');\r\n    }\r\n\r\n    toggleEventListeners(action: 'addEventListener' | 'removeEventListener') {\r\n        let listeners;\r\n\r\n        if (this.properties.listeners === 'mouse and touch') {\r\n            listeners = Object.assign(this.touchListeners, this.mouseListeners);\r\n        } else {\r\n            listeners = this.detectTouchScreen() ? this.touchListeners : this.mouseListeners;\r\n        }\r\n\r\n        for (var listener in listeners) {\r\n            const handler: MouseHandler = listeners[listener];\r\n            if (listener === 'mouseup' || listener === \"mousemove\") {\r\n                document[action](listener, this[handler], false);\r\n            } else {\r\n                this.element[action](listener, this[handler], false);\r\n            }\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Listeners\r\n     */\r\n\r\n    /* Touchstart */\r\n\r\n    handleTouchstart = (event: any) => {\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getTouchstartPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"touchstart\", event);\r\n    }\r\n\r\n\r\n    /* Touchmove */\r\n\r\n    handleTouchmove = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Pan\r\n        if (this.detectPan(touches)) {\r\n            this.runHandler(\"pan\", event);\r\n        }\r\n\r\n        // Linear swipe\r\n        /*\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n        */\r\n\r\n        // Linear swipe\r\n        /*\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n        */\r\n\r\n        // Pinch\r\n        if (this.detectPinch(event)) {\r\n            this.runHandler(\"pinch\", event);\r\n        }\r\n    }\r\n\r\n    handleLinearSwipe(event: any) {\r\n        //event.preventDefault();\r\n\r\n        this.i++;\r\n\r\n        if (this.i > 3) {\r\n            this.eventType = this.getLinearSwipeType(event);\r\n        }\r\n\r\n        if (this.eventType === 'horizontal-swipe') {\r\n            this.runHandler('horizontal-swipe', event);\r\n        }\r\n\r\n        if (this.eventType === 'vertical-swipe') {\r\n            this.runHandler('vertical-swipe', event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Touchend */\r\n\r\n    handleTouchend = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.runHandler(\"touchend\", event);\r\n        this.eventType = 'touchend';\r\n\r\n        if (touches && touches.length === 0) {\r\n            this.eventType = undefined;\r\n            this.i = 0;\r\n        }\r\n    }\r\n\r\n\r\n    /* Mousedown */\r\n\r\n    handleMousedown = (event: any) => {\r\n        this.isMousedown = true;\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getMousedownPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"mousedown\", event);\r\n    }\r\n\r\n\r\n    /* Mousemove */\r\n\r\n    handleMousemove = (event: any) => {\r\n        event.preventDefault();\r\n        \r\n        if (!this.isMousedown) {\r\n            return;\r\n        }\r\n\r\n        // Pan\r\n        this.runHandler(\"pan\", event);\r\n\r\n        // Linear swipe\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n\r\n        // Linear swipe\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Mouseup */\r\n\r\n    handleMouseup = (event: any) => {\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.isMousedown = false;\r\n        this.runHandler(\"mouseup\", event);\r\n        this.eventType = undefined;\r\n        this.i = 0;\r\n    }\r\n\r\n\r\n    runHandler(eventName: any, response: any) {\r\n        if (this.handlers[eventName]) {\r\n            this.handlers[eventName](response);\r\n        }\r\n    }\r\n\r\n\r\n    /*\r\n     * Detection\r\n     */\r\n\r\n    detectPan(touches: any) {\r\n        return touches.length === 1 && !this.eventType || this.eventType === 'pan';\r\n    }\r\n\r\n    detectDoubleTap() {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.lastTap;\r\n\r\n        clearTimeout(this.doubleTapTimeout);\r\n\r\n        if (tapLength < this.doubleTapMinTimeout && tapLength > 0) {\r\n            return true;\r\n        } else {\r\n            this.doubleTapTimeout = setTimeout(() => {\r\n                clearTimeout(this.doubleTapTimeout);\r\n            }, this.doubleTapMinTimeout);\r\n        }\r\n        this.lastTap = currentTime;\r\n    }\r\n\r\n    detectTap(): void {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.touchstartTime;\r\n\r\n        if (tapLength > 0) {\r\n            if (tapLength < this.tapMinTimeout) {\r\n                this.runHandler(\"tap\", event);\r\n            } else {\r\n                this.runHandler(\"longtap\", event);\r\n            }\r\n        }\r\n    }\r\n\r\n    detectPinch(event: any) {\r\n        const touches = event.touches;\r\n        return (touches.length === 2 && this.eventType === undefined) || this.eventType === 'pinch';\r\n    }\r\n\r\n    detectLinearSwipe(event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            if (touches.length === 1 && !this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        } else {\r\n            if (!this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        }\r\n    }\r\n\r\n    getLinearSwipeType(event: any) {\r\n        if (this.eventType !== 'horizontal-swipe' && this.eventType !== 'vertical-swipe') {\r\n            const movementX = Math.abs(this.moveLeft(0, event) - this.startX);\r\n            const movementY = Math.abs(this.moveTop(0, event) - this.startY);\r\n\r\n            if ((movementY * 3) > movementX) {\r\n                return 'vertical-swipe';\r\n            } else {\r\n                return 'horizontal-swipe';\r\n            }\r\n        } else {\r\n            return this.eventType;\r\n        }\r\n    }\r\n\r\n    getElementPosition() {\r\n        return this.element.getBoundingClientRect();\r\n    }\r\n\r\n    getTouchstartPosition(event: any) {\r\n        this.startX = event.touches[0].clientX - this.elementPosition.left;\r\n        this.startY = event.touches[0].clientY - this.elementPosition.top;\r\n    }\r\n\r\n    getMousedownPosition(event: any) {\r\n        this.startX = event.clientX - this.elementPosition.left;\r\n        this.startY = event.clientY - this.elementPosition.top;\r\n    }\r\n\r\n    moveLeft(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientX - this.elementPosition.left;\r\n        } else {\r\n            return event.clientX - this.elementPosition.left;\r\n        }\r\n    }\r\n\r\n    moveTop(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientY - this.elementPosition.top;\r\n        } else {\r\n            return event.clientY - this.elementPosition.top;\r\n        }\r\n    }\r\n\r\n    detectTouchScreen() {\r\n        var prefixes = ' -webkit- -moz- -o- -ms- '.split(' ');\r\n        var mq = function(query: any) {\r\n            return window.matchMedia(query).matches;\r\n        }\r\n\r\n        if (('ontouchstart' in window)) {\r\n            return true;\r\n        }\r\n\r\n        // include the 'heartz' as a way to have a non matching MQ to help terminate the join\r\n        // https://git.io/vznFH\r\n        var query = ['(', prefixes.join('touch-enabled),('), 'heartz', ')'].join('');\r\n        return mq(query);\r\n    }\r\n\r\n\r\n    /* Public properties and methods */\r\n\r\n    // Получаем список событий и функцию-обработчик\r\n    on(event: EventType, handler: Function) {\r\n        if (event) {\r\n            this.handlers[event] = handler;\r\n        }\r\n    }\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"touches.js","sourceRoot":"ng://ngx-pinch-zoom/","sources":["lib/touches.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nexport interface Properties {\r\n    element: HTMLElement;\r\n    listeners?: 'auto' | 'mouse and touch';\r\n}\r\n\r\nexport type EventType = undefined | 'touchend' | 'pan' | 'pinch' | 'horizontal-swipe' | 'vertical-swipe' | 'tap' | 'longtap';\r\nexport type TouchHandler = 'handleTouchstart' | 'handleTouchmove' | 'handleTouchend';\r\nexport type MouseHandler = 'handleMousedown' | 'handleMousemove' | 'handleMouseup';\r\n\r\nexport class Touches {\r\n    properties: Properties;\r\n    element: HTMLElement;\r\n    elementPosition: ClientRect;\r\n    eventType: EventType = undefined;\r\n    handlers: any = {};\r\n    startX = 0;\r\n    startY = 0;\r\n    lastTap = 0;\r\n    doubleTapTimeout: any;\r\n    doubleTapMinTimeout = 300;\r\n    tapMinTimeout = 200;\r\n    touchstartTime = 0;\r\n    i: number = 0;\r\n    isMousedown = false;\r\n\r\n    touchListeners: any = {\r\n        \"touchstart\": \"handleTouchstart\",\r\n        \"touchmove\": \"handleTouchmove\",\r\n        \"touchend\": \"handleTouchend\"\r\n    }\r\n    mouseListeners: any = {\r\n        \"mousedown\": \"handleMousedown\",\r\n        \"mousemove\": \"handleMousemove\",\r\n        \"mouseup\": \"handleMouseup\"\r\n    }\r\n\r\n    constructor(properties: Properties) {\r\n        this.properties = properties;\r\n        this.element = this.properties.element;\r\n        this.elementPosition = this.getElementPosition();\r\n\r\n        this.toggleEventListeners('addEventListener');\r\n    }\r\n\r\n    destroy() {\r\n        this.toggleEventListeners('removeEventListener');\r\n    }\r\n\r\n    toggleEventListeners(action: 'addEventListener' | 'removeEventListener') {\r\n        let listeners;\r\n\r\n        if (this.properties.listeners === 'mouse and touch') {\r\n            listeners = Object.assign(this.touchListeners, this.mouseListeners);\r\n        } else {\r\n            listeners = this.detectTouchScreen() ? this.touchListeners : this.mouseListeners;\r\n        }\r\n\r\n        for (var listener in listeners) {\r\n            const handler: MouseHandler = listeners[listener];\r\n            if (listener === 'mouseup' || listener === \"mousemove\") {\r\n                if (action === 'addEventListener') {\r\n                    document.addEventListener(listener, this[handler], false);\r\n                }\r\n                if (action === 'removeEventListener') {\r\n                    document.removeEventListener(listener, this[handler], false);\r\n                }\r\n            } else {\r\n                if (action === 'addEventListener') {\r\n                    this.element.addEventListener(listener, this[handler], false);\r\n                }\r\n                if (action === 'removeEventListener') {\r\n                    this.element.removeEventListener(listener, this[handler], false);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Listeners\r\n     */\r\n\r\n    /* Touchstart */\r\n\r\n    handleTouchstart = (event: any) => {\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getTouchstartPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"touchstart\", event);\r\n    }\r\n\r\n\r\n    /* Touchmove */\r\n\r\n    handleTouchmove = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Pan\r\n        if (this.detectPan(touches)) {\r\n            this.runHandler(\"pan\", event);\r\n        }\r\n\r\n        // Linear swipe\r\n        /*\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n        */\r\n\r\n        // Linear swipe\r\n        /*\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n        */\r\n\r\n        // Pinch\r\n        if (this.detectPinch(event)) {\r\n            this.runHandler(\"pinch\", event);\r\n        }\r\n    }\r\n\r\n    handleLinearSwipe(event: any) {\r\n        //event.preventDefault();\r\n\r\n        this.i++;\r\n\r\n        if (this.i > 3) {\r\n            this.eventType = this.getLinearSwipeType(event);\r\n        }\r\n\r\n        if (this.eventType === 'horizontal-swipe') {\r\n            this.runHandler('horizontal-swipe', event);\r\n        }\r\n\r\n        if (this.eventType === 'vertical-swipe') {\r\n            this.runHandler('vertical-swipe', event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Touchend */\r\n\r\n    handleTouchend = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.runHandler(\"touchend\", event);\r\n        this.eventType = 'touchend';\r\n\r\n        if (touches && touches.length === 0) {\r\n            this.eventType = undefined;\r\n            this.i = 0;\r\n        }\r\n    }\r\n\r\n\r\n    /* Mousedown */\r\n\r\n    handleMousedown = (event: any) => {\r\n        this.isMousedown = true;\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getMousedownPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"mousedown\", event);\r\n    }\r\n\r\n\r\n    /* Mousemove */\r\n\r\n    handleMousemove = (event: any) => {\r\n        event.preventDefault();\r\n        \r\n        if (!this.isMousedown) {\r\n            return;\r\n        }\r\n\r\n        // Pan\r\n        this.runHandler(\"pan\", event);\r\n\r\n        // Linear swipe\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n\r\n        // Linear swipe\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Mouseup */\r\n\r\n    handleMouseup = (event: any) => {\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.isMousedown = false;\r\n        this.runHandler(\"mouseup\", event);\r\n        this.eventType = undefined;\r\n        this.i = 0;\r\n    }\r\n\r\n\r\n    runHandler(eventName: any, response: any) {\r\n        if (this.handlers[eventName]) {\r\n            this.handlers[eventName](response);\r\n        }\r\n    }\r\n\r\n\r\n    /*\r\n     * Detection\r\n     */\r\n\r\n    detectPan(touches: any) {\r\n        return touches.length === 1 && !this.eventType || this.eventType === 'pan';\r\n    }\r\n\r\n    detectDoubleTap() {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.lastTap;\r\n\r\n        clearTimeout(this.doubleTapTimeout);\r\n\r\n        if (tapLength < this.doubleTapMinTimeout && tapLength > 0) {\r\n            return true;\r\n        } else {\r\n            this.doubleTapTimeout = setTimeout(() => {\r\n                clearTimeout(this.doubleTapTimeout);\r\n            }, this.doubleTapMinTimeout);\r\n        }\r\n        this.lastTap = currentTime;\r\n    }\r\n\r\n    detectTap(): void {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.touchstartTime;\r\n\r\n        if (tapLength > 0) {\r\n            if (tapLength < this.tapMinTimeout) {\r\n                this.runHandler(\"tap\", event);\r\n            } else {\r\n                this.runHandler(\"longtap\", event);\r\n            }\r\n        }\r\n    }\r\n\r\n    detectPinch(event: any) {\r\n        const touches = event.touches;\r\n        return (touches.length === 2 && this.eventType === undefined) || this.eventType === 'pinch';\r\n    }\r\n\r\n    detectLinearSwipe(event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            if (touches.length === 1 && !this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        } else {\r\n            if (!this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        }\r\n    }\r\n\r\n    getLinearSwipeType(event: any) {\r\n        if (this.eventType !== 'horizontal-swipe' && this.eventType !== 'vertical-swipe') {\r\n            const movementX = Math.abs(this.moveLeft(0, event) - this.startX);\r\n            const movementY = Math.abs(this.moveTop(0, event) - this.startY);\r\n\r\n            if ((movementY * 3) > movementX) {\r\n                return 'vertical-swipe';\r\n            } else {\r\n                return 'horizontal-swipe';\r\n            }\r\n        } else {\r\n            return this.eventType;\r\n        }\r\n    }\r\n\r\n    getElementPosition() {\r\n        return this.element.getBoundingClientRect();\r\n    }\r\n\r\n    getTouchstartPosition(event: any) {\r\n        this.startX = event.touches[0].clientX - this.elementPosition.left;\r\n        this.startY = event.touches[0].clientY - this.elementPosition.top;\r\n    }\r\n\r\n    getMousedownPosition(event: any) {\r\n        this.startX = event.clientX - this.elementPosition.left;\r\n        this.startY = event.clientY - this.elementPosition.top;\r\n    }\r\n\r\n    moveLeft(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientX - this.elementPosition.left;\r\n        } else {\r\n            return event.clientX - this.elementPosition.left;\r\n        }\r\n    }\r\n\r\n    moveTop(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientY - this.elementPosition.top;\r\n        } else {\r\n            return event.clientY - this.elementPosition.top;\r\n        }\r\n    }\r\n\r\n    detectTouchScreen() {\r\n        var prefixes = ' -webkit- -moz- -o- -ms- '.split(' ');\r\n        var mq = function(query: any) {\r\n            return window.matchMedia(query).matches;\r\n        }\r\n\r\n        if (('ontouchstart' in window)) {\r\n            return true;\r\n        }\r\n\r\n        // include the 'heartz' as a way to have a non matching MQ to help terminate the join\r\n        // https://git.io/vznFH\r\n        var query = ['(', prefixes.join('touch-enabled),('), 'heartz', ')'].join('');\r\n        return mq(query);\r\n    }\r\n\r\n\r\n    /* Public properties and methods */\r\n\r\n    // Получаем список событий и функцию-обработчик\r\n    on(event: EventType, handler: Function) {\r\n        if (event) {\r\n            this.handlers[event] = handler;\r\n        }\r\n    }\r\n}"]}

@@ -211,6 +211,16 @@ /**

if (listener === 'mouseup' || listener === "mousemove") {
document[action](listener, this[handler], false);
if (action === 'addEventListener') {
document.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
document.removeEventListener(listener, this[handler], false);
}
}
else {
this.element[action](listener, this[handler], false);
if (action === 'addEventListener') {
this.element.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
this.element.removeEventListener(listener, this[handler], false);
}
}

@@ -556,2 +566,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"touches.js","sourceRoot":"ng://ngx-pinch-zoom/","sources":["lib/touches.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nexport interface Properties {\r\n    element: HTMLElement;\r\n    listeners?: 'auto' | 'mouse and touch';\r\n}\r\n\r\nexport type EventType = undefined | 'touchend' | 'pan' | 'pinch' | 'horizontal-swipe' | 'vertical-swipe' | 'tap' | 'longtap';\r\nexport type TouchHandler = 'handleTouchstart' | 'handleTouchmove' | 'handleTouchend';\r\nexport type MouseHandler = 'handleMousedown' | 'handleMousemove' | 'handleMouseup';\r\n\r\nexport class Touches {\r\n    properties: Properties;\r\n    element: HTMLElement;\r\n    elementPosition: ClientRect;\r\n    eventType: EventType = undefined;\r\n    handlers: any = {};\r\n    startX = 0;\r\n    startY = 0;\r\n    lastTap = 0;\r\n    doubleTapTimeout: any;\r\n    doubleTapMinTimeout = 300;\r\n    tapMinTimeout = 200;\r\n    touchstartTime = 0;\r\n    i: number = 0;\r\n    isMousedown = false;\r\n\r\n    touchListeners: any = {\r\n        \"touchstart\": \"handleTouchstart\",\r\n        \"touchmove\": \"handleTouchmove\",\r\n        \"touchend\": \"handleTouchend\"\r\n    }\r\n    mouseListeners: any = {\r\n        \"mousedown\": \"handleMousedown\",\r\n        \"mousemove\": \"handleMousemove\",\r\n        \"mouseup\": \"handleMouseup\"\r\n    }\r\n\r\n    constructor(properties: Properties) {\r\n        this.properties = properties;\r\n        this.element = this.properties.element;\r\n        this.elementPosition = this.getElementPosition();\r\n\r\n        this.toggleEventListeners('addEventListener');\r\n    }\r\n\r\n    destroy() {\r\n        this.toggleEventListeners('removeEventListener');\r\n    }\r\n\r\n    toggleEventListeners(action: 'addEventListener' | 'removeEventListener') {\r\n        let listeners;\r\n\r\n        if (this.properties.listeners === 'mouse and touch') {\r\n            listeners = Object.assign(this.touchListeners, this.mouseListeners);\r\n        } else {\r\n            listeners = this.detectTouchScreen() ? this.touchListeners : this.mouseListeners;\r\n        }\r\n\r\n        for (var listener in listeners) {\r\n            const handler: MouseHandler = listeners[listener];\r\n            if (listener === 'mouseup' || listener === \"mousemove\") {\r\n                document[action](listener, this[handler], false);\r\n            } else {\r\n                this.element[action](listener, this[handler], false);\r\n            }\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Listeners\r\n     */\r\n\r\n    /* Touchstart */\r\n\r\n    handleTouchstart = (event: any) => {\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getTouchstartPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"touchstart\", event);\r\n    }\r\n\r\n\r\n    /* Touchmove */\r\n\r\n    handleTouchmove = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Pan\r\n        if (this.detectPan(touches)) {\r\n            this.runHandler(\"pan\", event);\r\n        }\r\n\r\n        // Linear swipe\r\n        /*\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n        */\r\n\r\n        // Linear swipe\r\n        /*\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n        */\r\n\r\n        // Pinch\r\n        if (this.detectPinch(event)) {\r\n            this.runHandler(\"pinch\", event);\r\n        }\r\n    }\r\n\r\n    handleLinearSwipe(event: any) {\r\n        //event.preventDefault();\r\n\r\n        this.i++;\r\n\r\n        if (this.i > 3) {\r\n            this.eventType = this.getLinearSwipeType(event);\r\n        }\r\n\r\n        if (this.eventType === 'horizontal-swipe') {\r\n            this.runHandler('horizontal-swipe', event);\r\n        }\r\n\r\n        if (this.eventType === 'vertical-swipe') {\r\n            this.runHandler('vertical-swipe', event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Touchend */\r\n\r\n    handleTouchend = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.runHandler(\"touchend\", event);\r\n        this.eventType = 'touchend';\r\n\r\n        if (touches && touches.length === 0) {\r\n            this.eventType = undefined;\r\n            this.i = 0;\r\n        }\r\n    }\r\n\r\n\r\n    /* Mousedown */\r\n\r\n    handleMousedown = (event: any) => {\r\n        this.isMousedown = true;\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getMousedownPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"mousedown\", event);\r\n    }\r\n\r\n\r\n    /* Mousemove */\r\n\r\n    handleMousemove = (event: any) => {\r\n        event.preventDefault();\r\n        \r\n        if (!this.isMousedown) {\r\n            return;\r\n        }\r\n\r\n        // Pan\r\n        this.runHandler(\"pan\", event);\r\n\r\n        // Linear swipe\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n\r\n        // Linear swipe\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Mouseup */\r\n\r\n    handleMouseup = (event: any) => {\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.isMousedown = false;\r\n        this.runHandler(\"mouseup\", event);\r\n        this.eventType = undefined;\r\n        this.i = 0;\r\n    }\r\n\r\n\r\n    runHandler(eventName: any, response: any) {\r\n        if (this.handlers[eventName]) {\r\n            this.handlers[eventName](response);\r\n        }\r\n    }\r\n\r\n\r\n    /*\r\n     * Detection\r\n     */\r\n\r\n    detectPan(touches: any) {\r\n        return touches.length === 1 && !this.eventType || this.eventType === 'pan';\r\n    }\r\n\r\n    detectDoubleTap() {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.lastTap;\r\n\r\n        clearTimeout(this.doubleTapTimeout);\r\n\r\n        if (tapLength < this.doubleTapMinTimeout && tapLength > 0) {\r\n            return true;\r\n        } else {\r\n            this.doubleTapTimeout = setTimeout(() => {\r\n                clearTimeout(this.doubleTapTimeout);\r\n            }, this.doubleTapMinTimeout);\r\n        }\r\n        this.lastTap = currentTime;\r\n    }\r\n\r\n    detectTap(): void {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.touchstartTime;\r\n\r\n        if (tapLength > 0) {\r\n            if (tapLength < this.tapMinTimeout) {\r\n                this.runHandler(\"tap\", event);\r\n            } else {\r\n                this.runHandler(\"longtap\", event);\r\n            }\r\n        }\r\n    }\r\n\r\n    detectPinch(event: any) {\r\n        const touches = event.touches;\r\n        return (touches.length === 2 && this.eventType === undefined) || this.eventType === 'pinch';\r\n    }\r\n\r\n    detectLinearSwipe(event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            if (touches.length === 1 && !this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        } else {\r\n            if (!this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        }\r\n    }\r\n\r\n    getLinearSwipeType(event: any) {\r\n        if (this.eventType !== 'horizontal-swipe' && this.eventType !== 'vertical-swipe') {\r\n            const movementX = Math.abs(this.moveLeft(0, event) - this.startX);\r\n            const movementY = Math.abs(this.moveTop(0, event) - this.startY);\r\n\r\n            if ((movementY * 3) > movementX) {\r\n                return 'vertical-swipe';\r\n            } else {\r\n                return 'horizontal-swipe';\r\n            }\r\n        } else {\r\n            return this.eventType;\r\n        }\r\n    }\r\n\r\n    getElementPosition() {\r\n        return this.element.getBoundingClientRect();\r\n    }\r\n\r\n    getTouchstartPosition(event: any) {\r\n        this.startX = event.touches[0].clientX - this.elementPosition.left;\r\n        this.startY = event.touches[0].clientY - this.elementPosition.top;\r\n    }\r\n\r\n    getMousedownPosition(event: any) {\r\n        this.startX = event.clientX - this.elementPosition.left;\r\n        this.startY = event.clientY - this.elementPosition.top;\r\n    }\r\n\r\n    moveLeft(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientX - this.elementPosition.left;\r\n        } else {\r\n            return event.clientX - this.elementPosition.left;\r\n        }\r\n    }\r\n\r\n    moveTop(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientY - this.elementPosition.top;\r\n        } else {\r\n            return event.clientY - this.elementPosition.top;\r\n        }\r\n    }\r\n\r\n    detectTouchScreen() {\r\n        var prefixes = ' -webkit- -moz- -o- -ms- '.split(' ');\r\n        var mq = function(query: any) {\r\n            return window.matchMedia(query).matches;\r\n        }\r\n\r\n        if (('ontouchstart' in window)) {\r\n            return true;\r\n        }\r\n\r\n        // include the 'heartz' as a way to have a non matching MQ to help terminate the join\r\n        // https://git.io/vznFH\r\n        var query = ['(', prefixes.join('touch-enabled),('), 'heartz', ')'].join('');\r\n        return mq(query);\r\n    }\r\n\r\n\r\n    /* Public properties and methods */\r\n\r\n    // Получаем список событий и функцию-обработчик\r\n    on(event: EventType, handler: Function) {\r\n        if (event) {\r\n            this.handlers[event] = handler;\r\n        }\r\n    }\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"touches.js","sourceRoot":"ng://ngx-pinch-zoom/","sources":["lib/touches.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nexport interface Properties {\r\n    element: HTMLElement;\r\n    listeners?: 'auto' | 'mouse and touch';\r\n}\r\n\r\nexport type EventType = undefined | 'touchend' | 'pan' | 'pinch' | 'horizontal-swipe' | 'vertical-swipe' | 'tap' | 'longtap';\r\nexport type TouchHandler = 'handleTouchstart' | 'handleTouchmove' | 'handleTouchend';\r\nexport type MouseHandler = 'handleMousedown' | 'handleMousemove' | 'handleMouseup';\r\n\r\nexport class Touches {\r\n    properties: Properties;\r\n    element: HTMLElement;\r\n    elementPosition: ClientRect;\r\n    eventType: EventType = undefined;\r\n    handlers: any = {};\r\n    startX = 0;\r\n    startY = 0;\r\n    lastTap = 0;\r\n    doubleTapTimeout: any;\r\n    doubleTapMinTimeout = 300;\r\n    tapMinTimeout = 200;\r\n    touchstartTime = 0;\r\n    i: number = 0;\r\n    isMousedown = false;\r\n\r\n    touchListeners: any = {\r\n        \"touchstart\": \"handleTouchstart\",\r\n        \"touchmove\": \"handleTouchmove\",\r\n        \"touchend\": \"handleTouchend\"\r\n    }\r\n    mouseListeners: any = {\r\n        \"mousedown\": \"handleMousedown\",\r\n        \"mousemove\": \"handleMousemove\",\r\n        \"mouseup\": \"handleMouseup\"\r\n    }\r\n\r\n    constructor(properties: Properties) {\r\n        this.properties = properties;\r\n        this.element = this.properties.element;\r\n        this.elementPosition = this.getElementPosition();\r\n\r\n        this.toggleEventListeners('addEventListener');\r\n    }\r\n\r\n    destroy() {\r\n        this.toggleEventListeners('removeEventListener');\r\n    }\r\n\r\n    toggleEventListeners(action: 'addEventListener' | 'removeEventListener') {\r\n        let listeners;\r\n\r\n        if (this.properties.listeners === 'mouse and touch') {\r\n            listeners = Object.assign(this.touchListeners, this.mouseListeners);\r\n        } else {\r\n            listeners = this.detectTouchScreen() ? this.touchListeners : this.mouseListeners;\r\n        }\r\n\r\n        for (var listener in listeners) {\r\n            const handler: MouseHandler = listeners[listener];\r\n            if (listener === 'mouseup' || listener === \"mousemove\") {\r\n                if (action === 'addEventListener') {\r\n                    document.addEventListener(listener, this[handler], false);\r\n                }\r\n                if (action === 'removeEventListener') {\r\n                    document.removeEventListener(listener, this[handler], false);\r\n                }\r\n            } else {\r\n                if (action === 'addEventListener') {\r\n                    this.element.addEventListener(listener, this[handler], false);\r\n                }\r\n                if (action === 'removeEventListener') {\r\n                    this.element.removeEventListener(listener, this[handler], false);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Listeners\r\n     */\r\n\r\n    /* Touchstart */\r\n\r\n    handleTouchstart = (event: any) => {\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getTouchstartPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"touchstart\", event);\r\n    }\r\n\r\n\r\n    /* Touchmove */\r\n\r\n    handleTouchmove = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Pan\r\n        if (this.detectPan(touches)) {\r\n            this.runHandler(\"pan\", event);\r\n        }\r\n\r\n        // Linear swipe\r\n        /*\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n        */\r\n\r\n        // Linear swipe\r\n        /*\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n        */\r\n\r\n        // Pinch\r\n        if (this.detectPinch(event)) {\r\n            this.runHandler(\"pinch\", event);\r\n        }\r\n    }\r\n\r\n    handleLinearSwipe(event: any) {\r\n        //event.preventDefault();\r\n\r\n        this.i++;\r\n\r\n        if (this.i > 3) {\r\n            this.eventType = this.getLinearSwipeType(event);\r\n        }\r\n\r\n        if (this.eventType === 'horizontal-swipe') {\r\n            this.runHandler('horizontal-swipe', event);\r\n        }\r\n\r\n        if (this.eventType === 'vertical-swipe') {\r\n            this.runHandler('vertical-swipe', event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Touchend */\r\n\r\n    handleTouchend = (event: any) => {\r\n        const touches = event.touches;\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.runHandler(\"touchend\", event);\r\n        this.eventType = 'touchend';\r\n\r\n        if (touches && touches.length === 0) {\r\n            this.eventType = undefined;\r\n            this.i = 0;\r\n        }\r\n    }\r\n\r\n\r\n    /* Mousedown */\r\n\r\n    handleMousedown = (event: any) => {\r\n        this.isMousedown = true;\r\n        this.elementPosition = this.getElementPosition();\r\n        this.touchstartTime = new Date().getTime();\r\n\r\n        if (this.eventType === undefined) {\r\n            this.getMousedownPosition(event);\r\n        }\r\n\r\n        this.runHandler(\"mousedown\", event);\r\n    }\r\n\r\n\r\n    /* Mousemove */\r\n\r\n    handleMousemove = (event: any) => {\r\n        event.preventDefault();\r\n        \r\n        if (!this.isMousedown) {\r\n            return;\r\n        }\r\n\r\n        // Pan\r\n        this.runHandler(\"pan\", event);\r\n\r\n        // Linear swipe\r\n        switch (this.detectLinearSwipe(event)) {\r\n            case \"horizontal-swipe\":\r\n                event.swipeType = \"horizontal-swipe\";\r\n                this.runHandler(\"horizontal-swipe\", event);\r\n                break;\r\n            case \"vertical-swipe\":\r\n                event.swipeType = \"vertical-swipe\";\r\n                this.runHandler(\"vertical-swipe\", event);\r\n                break;\r\n        }\r\n\r\n        // Linear swipe\r\n        if (this.detectLinearSwipe(event) ||\r\n            this.eventType === 'horizontal-swipe' ||\r\n            this.eventType === 'vertical-swipe') {\r\n\r\n            this.handleLinearSwipe(event);\r\n        }\r\n    }\r\n\r\n\r\n    /* Mouseup */\r\n\r\n    handleMouseup = (event: any) => {\r\n\r\n        // Double Tap\r\n        if (this.detectDoubleTap()) {\r\n            this.runHandler(\"double-tap\", event);\r\n        }\r\n\r\n        // Tap\r\n        this.detectTap();\r\n\r\n        this.isMousedown = false;\r\n        this.runHandler(\"mouseup\", event);\r\n        this.eventType = undefined;\r\n        this.i = 0;\r\n    }\r\n\r\n\r\n    runHandler(eventName: any, response: any) {\r\n        if (this.handlers[eventName]) {\r\n            this.handlers[eventName](response);\r\n        }\r\n    }\r\n\r\n\r\n    /*\r\n     * Detection\r\n     */\r\n\r\n    detectPan(touches: any) {\r\n        return touches.length === 1 && !this.eventType || this.eventType === 'pan';\r\n    }\r\n\r\n    detectDoubleTap() {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.lastTap;\r\n\r\n        clearTimeout(this.doubleTapTimeout);\r\n\r\n        if (tapLength < this.doubleTapMinTimeout && tapLength > 0) {\r\n            return true;\r\n        } else {\r\n            this.doubleTapTimeout = setTimeout(() => {\r\n                clearTimeout(this.doubleTapTimeout);\r\n            }, this.doubleTapMinTimeout);\r\n        }\r\n        this.lastTap = currentTime;\r\n    }\r\n\r\n    detectTap(): void {\r\n        if (this.eventType != undefined) {\r\n            return;\r\n        }\r\n\r\n        const currentTime = new Date().getTime();\r\n        const tapLength = currentTime - this.touchstartTime;\r\n\r\n        if (tapLength > 0) {\r\n            if (tapLength < this.tapMinTimeout) {\r\n                this.runHandler(\"tap\", event);\r\n            } else {\r\n                this.runHandler(\"longtap\", event);\r\n            }\r\n        }\r\n    }\r\n\r\n    detectPinch(event: any) {\r\n        const touches = event.touches;\r\n        return (touches.length === 2 && this.eventType === undefined) || this.eventType === 'pinch';\r\n    }\r\n\r\n    detectLinearSwipe(event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            if (touches.length === 1 && !this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        } else {\r\n            if (!this.eventType || this.eventType === 'horizontal-swipe' || this.eventType === 'vertical-swipe') {\r\n                return this.getLinearSwipeType(event);\r\n            }\r\n        }\r\n    }\r\n\r\n    getLinearSwipeType(event: any) {\r\n        if (this.eventType !== 'horizontal-swipe' && this.eventType !== 'vertical-swipe') {\r\n            const movementX = Math.abs(this.moveLeft(0, event) - this.startX);\r\n            const movementY = Math.abs(this.moveTop(0, event) - this.startY);\r\n\r\n            if ((movementY * 3) > movementX) {\r\n                return 'vertical-swipe';\r\n            } else {\r\n                return 'horizontal-swipe';\r\n            }\r\n        } else {\r\n            return this.eventType;\r\n        }\r\n    }\r\n\r\n    getElementPosition() {\r\n        return this.element.getBoundingClientRect();\r\n    }\r\n\r\n    getTouchstartPosition(event: any) {\r\n        this.startX = event.touches[0].clientX - this.elementPosition.left;\r\n        this.startY = event.touches[0].clientY - this.elementPosition.top;\r\n    }\r\n\r\n    getMousedownPosition(event: any) {\r\n        this.startX = event.clientX - this.elementPosition.left;\r\n        this.startY = event.clientY - this.elementPosition.top;\r\n    }\r\n\r\n    moveLeft(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientX - this.elementPosition.left;\r\n        } else {\r\n            return event.clientX - this.elementPosition.left;\r\n        }\r\n    }\r\n\r\n    moveTop(index: any, event: any) {\r\n        const touches = event.touches;\r\n\r\n        if (touches) {\r\n            return touches[index].clientY - this.elementPosition.top;\r\n        } else {\r\n            return event.clientY - this.elementPosition.top;\r\n        }\r\n    }\r\n\r\n    detectTouchScreen() {\r\n        var prefixes = ' -webkit- -moz- -o- -ms- '.split(' ');\r\n        var mq = function(query: any) {\r\n            return window.matchMedia(query).matches;\r\n        }\r\n\r\n        if (('ontouchstart' in window)) {\r\n            return true;\r\n        }\r\n\r\n        // include the 'heartz' as a way to have a non matching MQ to help terminate the join\r\n        // https://git.io/vznFH\r\n        var query = ['(', prefixes.join('touch-enabled),('), 'heartz', ')'].join('');\r\n        return mq(query);\r\n    }\r\n\r\n\r\n    /* Public properties and methods */\r\n\r\n    // Получаем список событий и функцию-обработчик\r\n    on(event: EventType, handler: Function) {\r\n        if (event) {\r\n            this.handlers[event] = handler;\r\n        }\r\n    }\r\n}"]}

@@ -265,6 +265,16 @@ import { EventEmitter, Component, ElementRef, Input, Output, HostBinding, NgModule } from '@angular/core';

if (listener === 'mouseup' || listener === "mousemove") {
document[action](listener, this[handler], false);
if (action === 'addEventListener') {
document.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
document.removeEventListener(listener, this[handler], false);
}
}
else {
this.element[action](listener, this[handler], false);
if (action === 'addEventListener') {
this.element.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
this.element.removeEventListener(listener, this[handler], false);
}
}

@@ -271,0 +281,0 @@ }

@@ -270,6 +270,16 @@ import { EventEmitter, Component, ElementRef, Input, Output, HostBinding, NgModule } from '@angular/core';

if (listener === 'mouseup' || listener === "mousemove") {
document[action](listener, this[handler], false);
if (action === 'addEventListener') {
document.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
document.removeEventListener(listener, this[handler], false);
}
}
else {
this.element[action](listener, this[handler], false);
if (action === 'addEventListener') {
this.element.addEventListener(listener, this[handler], false);
}
if (action === 'removeEventListener') {
this.element.removeEventListener(listener, this[handler], false);
}
}

@@ -276,0 +286,0 @@ }

{
"name": "ngx-pinch-zoom",
"version": "2.0.1",
"version": "2.0.2",
"description": "Pinch zoom component for Angular.",

@@ -5,0 +5,0 @@ "repository": {

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc