New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

lacuna-image-viewer

Package Overview
Dependencies
Maintainers
1
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

lacuna-image-viewer - npm Package Compare versions

Comparing version 1.0.13-beta.3 to 1.0.13-beta.4

68

bundles/lacuna-image-viewer.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/material'), require('screenfull')) :
typeof define === 'function' && define.amd ? define('lacuna-image-viewer', ['exports', '@angular/core', '@angular/common', '@angular/material', 'screenfull'], factory) :
(global = global || self, factory(global['lacuna-image-viewer'] = {}, global.ng.core, global.ng.common, global.ng.material, global.screenfull));
}(this, function (exports, core, common, material, screenfull) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/material'), require('angular-bigscreen')) :
typeof define === 'function' && define.amd ? define('lacuna-image-viewer', ['exports', '@angular/core', '@angular/common', '@angular/material', 'angular-bigscreen'], factory) :
(global = global || self, factory(global['lacuna-image-viewer'] = {}, global.ng.core, global.ng.common, global.ng.material, global.angularBigscreen));
}(this, function (exports, core, common, material, angularBigscreen) { 'use strict';

@@ -56,41 +56,2 @@ /*! *****************************************************************************

// [DEPRECATED] In LacunaImageViewer, this directive turned deprecated because it
// has a little bug: while in fullscreen mode, if we exit it by pressing "ESC", the
// "fullscreen" state, represented by the variable "isFullscreen", is not updated;
// consequently, the next time the user wants to get into fullscreen mode, it will
// be necessary to press the fullscreen button twice.
var ToggleFullscreenDirective = /** @class */ (function () {
function ToggleFullscreenDirective(el) {
this.el = el;
}
ToggleFullscreenDirective.prototype.ngOnChanges = function () {
if (isScreenFullAvailable(screenfull)) {
if (this.isFullscreen && screenfull.enabled) {
screenfull.request(this.el.nativeElement);
}
else if (screenfull.enabled) {
screenfull.exit();
}
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
}
};
__decorate([
core.Input('ngxToggleFullscreen'),
__metadata("design:type", Boolean)
], ToggleFullscreenDirective.prototype, "isFullscreen", void 0);
ToggleFullscreenDirective = __decorate([
core.Directive({
selector: '[ngxToggleFullscreen]'
}),
__metadata("design:paramtypes", [core.ElementRef])
], ToggleFullscreenDirective);
return ToggleFullscreenDirective;
}());
function isScreenFullAvailable(sf) {
return sf.enabled !== undefined;
}
var DEFAULT_CONFIG = {

@@ -123,4 +84,5 @@ btnClass: 'mat-mini-fab',

var ImageViewerComponent = /** @class */ (function () {
function ImageViewerComponent(moduleConfig) {
function ImageViewerComponent(moduleConfig, bigScreenService) {
this.moduleConfig = moduleConfig;
this.bigScreenService = bigScreenService;
this.index = 0;

@@ -209,13 +171,7 @@ this.indexChange = new core.EventEmitter();

ImageViewerComponent.prototype.toggleFullscreen = function () {
if (isScreenFullAvailable(screenfull)) {
if (screenfull.enabled && this.config.allowFullscreen) {
screenfull.toggle(this.fullscreenElement.nativeElement);
}
else {
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}
if (this.bigScreenService.isEnabled && this.config.allowFullscreen) {
this.bigScreenService.toggle(this.fullscreenElement.nativeElement);
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}

@@ -323,3 +279,3 @@ };

__param(0, core.Optional()), __param(0, core.Inject('config')),
__metadata("design:paramtypes", [Object])
__metadata("design:paramtypes", [Object, angularBigscreen.BigScreenService])
], ImageViewerComponent);

@@ -343,2 +299,3 @@ return ImageViewerComponent;

imports: [
angularBigscreen.BigScreenModule,
common.CommonModule,

@@ -350,7 +307,5 @@ material.MatButtonModule,

ImageViewerComponent,
ToggleFullscreenDirective
],
exports: [
ImageViewerComponent,
ToggleFullscreenDirective
]

@@ -365,3 +320,2 @@ })

exports.ImageViewerModule = ImageViewerModule;
exports.ɵa = ToggleFullscreenDirective;

@@ -368,0 +322,0 @@ Object.defineProperty(exports, '__esModule', { value: true });

2

bundles/lacuna-image-viewer.umd.min.js

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

!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports,require("@angular/core"),require("@angular/common"),require("@angular/material"),require("screenfull")):"function"==typeof define&&define.amd?define("lacuna-image-viewer",["exports","@angular/core","@angular/common","@angular/material","screenfull"],n):n((t=t||self)["lacuna-image-viewer"]={},t.ng.core,t.ng.common,t.ng.material,t.screenfull)}(this,function(t,n,e,o,i){"use strict";var r=function(){return(r=Object.assign||function(t){for(var n,e=1,o=arguments.length;e<o;e++)for(var i in n=arguments[e])Object.prototype.hasOwnProperty.call(n,i)&&(t[i]=n[i]);return t}).apply(this,arguments)};function a(t,n,e,o){var i,r=arguments.length,a=r<3?n:null===o?o=Object.getOwnPropertyDescriptor(n,e):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(t,n,e,o);else for(var s=t.length-1;s>=0;s--)(i=t[s])&&(a=(r<3?i(a):r>3?i(n,e,a):i(n,e))||a);return r>3&&a&&Object.defineProperty(n,e,a),a}function s(t,n){return function(e,o){n(e,o,t)}}function c(t,n){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(t,n)}var l=function(t,n){this.name=t,this.imageIndex=n},u=function(){function t(t){this.el=t}return t.prototype.ngOnChanges=function(){g(i)?this.isFullscreen&&i.enabled?i.request(this.el.nativeElement):i.enabled&&i.exit():console.log("[lacuna-image-viewer warning] Screenfull could not be used")},a([n.Input("ngxToggleFullscreen"),c("design:type",Boolean)],t.prototype,"isFullscreen",void 0),t=a([n.Directive({selector:"[ngxToggleFullscreen]"}),c("design:paramtypes",[n.ElementRef])],t)}();function g(t){return t.enabled!==undefined}var p={btnClass:"mat-mini-fab",zoomFactor:.1,containerBackgroundColor:"#ccc",allowCtrlWheelZoom:!0,allowFullscreen:!0,allowKeyboardNavigation:!0,allowDrag:!0,btnShow:{zoomIn:!0,zoomOut:!0,rotateClockwise:!0,rotateCounterClockwise:!0,next:!0,prev:!0},btnIcons:{zoomIn:"material-icons zoom-in",zoomOut:"material-icons zoom-out",rotateClockwise:"material-icons rotate-clockwise",rotateCounterClockwise:"material-icons rotate-counterclock",next:"material-icons next",prev:"material-icons prev",fullscreen:"material-icons fullscreen"}},f=function(){function t(t){this.moduleConfig=t,this.index=0,this.indexChange=new n.EventEmitter,this.configChange=new n.EventEmitter,this.customEvent=new n.EventEmitter,this.style={transform:"",msTransform:"",oTransform:"",webkitTransform:""},this.fullscreen=!1,this.loading=!0,this.scale=1,this.rotation=0,this.translateX=0,this.translateY=0,this.hovered=!1}return t.prototype.ngOnInit=function(){var t=this.mergeConfig(p,this.moduleConfig);this.config=this.mergeConfig(t,this.config),this.triggerConfigBinding()},t.prototype.nextImage=function(t){this.canNavigate(t)&&this.index<this.src.length-1&&(this.loading=!0,this.index++,this.triggerIndexBinding(),this.reset())},t.prototype.prevImage=function(t){this.canNavigate(t)&&this.index>0&&(this.loading=!0,this.index--,this.triggerIndexBinding(),this.reset())},t.prototype.zoomIn=function(){this.scale*=1+this.config.zoomFactor,this.updateStyle()},t.prototype.zoomOut=function(){this.scale>this.config.zoomFactor&&(this.scale/=1+this.config.zoomFactor),this.updateStyle()},t.prototype.scrollZoom=function(t){if(this.config.allowCtrlWheelZoom&&t.ctrlKey)return t.deltaY>0?this.zoomOut():this.zoomIn(),!1},t.prototype.rotateClockwise=function(){this.rotation+=90,this.updateStyle()},t.prototype.rotateCounterClockwise=function(){this.rotation-=90,this.updateStyle()},t.prototype.onLoad=function(){this.loading=!1},t.prototype.onLoadStart=function(){this.loading=!0},t.prototype.onDragOver=function(t){this.config.allowDrag&&(this.translateX+=t.clientX-this.prevX,this.translateY+=t.clientY-this.prevY,this.prevX=t.clientX,this.prevY=t.clientY,this.updateStyle())},t.prototype.onDragStart=function(t){this.config.allowDrag&&(t.dataTransfer&&t.dataTransfer.setDragImage&&t.dataTransfer.setDragImage(t.target.nextElementSibling,0,0),this.prevX=t.clientX,this.prevY=t.clientY)},t.prototype.toggleFullscreen=function(){g(i)?i.enabled&&this.config.allowFullscreen?i.toggle(this.fullscreenElement.nativeElement):console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled"):console.log("[lacuna-image-viewer warning] Screenfull could not be used")},t.prototype.triggerIndexBinding=function(){this.indexChange.emit(this.index)},t.prototype.triggerConfigBinding=function(){this.configChange.next(this.config)},t.prototype.fireCustomEvent=function(t,n){this.customEvent.emit(new l(t,n))},t.prototype.reset=function(){this.scale=1,this.rotation=0,this.translateX=0,this.translateY=0,this.updateStyle()},t.prototype.onMouseOver=function(){this.hovered=!0},t.prototype.onMouseLeave=function(){this.hovered=!1},t.prototype.canNavigate=function(t){return null==t||this.config.allowKeyboardNavigation&&this.hovered},t.prototype.updateStyle=function(){this.style.transform="translate("+this.translateX+"px, "+this.translateY+"px) rotate("+this.rotation+"deg) scale("+this.scale+")",this.style.msTransform=this.style.transform,this.style.webkitTransform=this.style.transform,this.style.oTransform=this.style.transform},t.prototype.mergeConfig=function(t,n){var e=r({},t);return n&&(e=r({},t,n),n.btnIcons&&(e.btnIcons=r({},t.btnIcons,n.btnIcons))),e},a([n.Input(),c("design:type",Array)],t.prototype,"src",void 0),a([n.Input(),c("design:type",Object)],t.prototype,"index",void 0),a([n.Input(),c("design:type",Object)],t.prototype,"config",void 0),a([n.Output(),c("design:type",n.EventEmitter)],t.prototype,"indexChange",void 0),a([n.Output(),c("design:type",n.EventEmitter)],t.prototype,"configChange",void 0),a([n.Output(),c("design:type",n.EventEmitter)],t.prototype,"customEvent",void 0),a([n.ViewChild("fullscreenElement"),c("design:type",n.ElementRef)],t.prototype,"fullscreenElement",void 0),a([n.HostListener("window:keyup.ArrowRight",["$event"]),c("design:type",Function),c("design:paramtypes",[Object]),c("design:returntype",void 0)],t.prototype,"nextImage",null),a([n.HostListener("window:keyup.ArrowLeft",["$event"]),c("design:type",Function),c("design:paramtypes",[Object]),c("design:returntype",void 0)],t.prototype,"prevImage",null),a([n.HostListener("mouseover"),c("design:type",Function),c("design:paramtypes",[]),c("design:returntype",void 0)],t.prototype,"onMouseOver",null),a([n.HostListener("mouseleave"),c("design:type",Function),c("design:paramtypes",[]),c("design:returntype",void 0)],t.prototype,"onMouseLeave",null),t=a([n.Component({selector:"ngx-image-viewer",template:'<div #fullscreenElement class="img-container" [style.backgroundColor]="config.containerBackgroundColor"\n\t(wheel)="scrollZoom($event)" (dragover)="onDragOver($event)">\n\t<img [src]="src[index]" [ngStyle]="style" alt="Image not found..." (dragstart)="onDragStart($event)"\n\t\t(load)="onLoad()" (loadstart)="onLoadStart()" />\n\t\x3c!-- Div below will be used to hide the \'ghost\' image when dragging --\x3e\n\t<div></div>\n\t<div class="spinner-container" *ngIf="loading">\n\t\t<div class="spinner"></div>\n\t</div>\n\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.rotateCounterClockwise"\n\t\t(click)="rotateCounterClockwise()">\n\t\t<span [class]="config.btnIcons.rotateCounterClockwise"></span>\n\t</button>\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.rotateClockwise" (click)="rotateClockwise()">\n\t\t<span [class]="config.btnIcons.rotateClockwise"></span>\n\t</button>\n\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.zoomOut" (click)="zoomOut()">\n\t\t<span [class]="config.btnIcons.zoomOut"></span>\n\t</button>\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.zoomIn" (click)="zoomIn()">\n\t\t<span [class]="config.btnIcons.zoomIn"></span>\n\t</button>\n\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngFor="let cBtn of config.customBtns"\n\t\t(click)="fireCustomEvent(cBtn.name, index)">\n\t\t<span [class]="cBtn.icon"></span>\n\t</button>\n\n\t<button type="button" id="ngx-fs-btn" mat-mini-fab [class]="config.btnClass" (click)="toggleFullscreen()"\n\t\t*ngIf="config.allowFullscreen">\n\t\t<span [class]="config.btnIcons.fullscreen"></span>\n\t</button>\n\n\t<div class="nav-button-container" *ngIf="src.length > 1">\n\t\t<button type="button" mat-mini-fab [class]="config.btnClass" (click)="prevImage($event)" [disabled]="index === 0">\n\t\t\t<span [class]="config.btnIcons.prev"></span>\n\t\t</button>\n\t\t<button type="button" mat-mini-fab [class]="config.btnClass" (click)="nextImage($event)"\n\t\t\t[disabled]="index === src.length - 1">\n\t\t\t<span [class]="config.btnIcons.next"></span>\n\t\t</button>\n\t</div>\n</div>\n',styles:['.img-container{height:100%;width:100%;overflow:hidden;position:relative}.img-container img{z-index:2;margin:0 auto;display:block;max-width:100%;max-height:100%}.img-container button{z-index:99;position:absolute;right:15px}.img-container button:not(:disabled){cursor:pointer}.img-container>button:nth-of-type(1):not(#ngx-fs-btn){bottom:15px}.img-container>button:nth-of-type(2):not(#ngx-fs-btn){bottom:65px}.img-container>button:nth-of-type(3):not(#ngx-fs-btn){bottom:115px}.img-container>button:nth-of-type(4):not(#ngx-fs-btn){bottom:165px}.img-container>button:nth-of-type(5):not(#ngx-fs-btn){bottom:215px}.img-container>button:nth-of-type(6):not(#ngx-fs-btn){bottom:265px}.img-container>button:nth-of-type(7):not(#ngx-fs-btn){bottom:315px}#ngx-fs-btn{top:15px}button.default{height:40px;width:40px;border:1px solid #555;border-radius:50%;background-color:#fff;opacity:.7;transition:opacity .2s}button.default:hover{opacity:1}button.default:disabled{opacity:.25}.nav-button-container>button{position:relative;right:0;margin:0 10px}.nav-button-container{text-align:center;position:absolute;z-index:98;bottom:10px;left:0;right:0}.spinner-container{position:absolute;left:0;right:0;top:0;bottom:0;width:60px;height:60px;margin:auto;padding:10px;background-color:rgba(0,0,0,.4);border-radius:25%}.spinner{border-width:7px;border-style:solid;border-color:#ccc #ccc #222;border-radius:50%;height:100%;width:100%;box-sizing:border-box;-webkit-animation:2s linear infinite rotation;animation:2s linear infinite rotation}@keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}@-webkit-keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}.zoom-in:after{content:"zoom_in"}.zoom-out:after{content:"zoom_out"}.rotate-clockwise:after{content:"rotate_right"}.rotate-counterclock:after{content:"rotate_left"}.next:after{content:"keyboard_arrow_right"}.prev:after{content:"keyboard_arrow_left"}.fullscreen:after{content:"fullscreen"}']}),s(0,n.Optional()),s(0,n.Inject("config")),c("design:paramtypes",[Object])],t)}(),d=function(){function t(){}var i;return i=t,t.forRoot=function(t){return{ngModule:i,providers:[{provide:"config",useValue:t}]}},t=i=a([n.NgModule({imports:[e.CommonModule,o.MatButtonModule,o.MatIconModule],declarations:[f,u],exports:[f,u]})],t)}();t.CustomEvent=l,t.ImageViewerComponent=f,t.ImageViewerModule=d,t.ɵa=u,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports,require("@angular/core"),require("@angular/common"),require("@angular/material"),require("angular-bigscreen")):"function"==typeof define&&define.amd?define("lacuna-image-viewer",["exports","@angular/core","@angular/common","@angular/material","angular-bigscreen"],n):n((t=t||self)["lacuna-image-viewer"]={},t.ng.core,t.ng.common,t.ng.material,t.angularBigscreen)}(this,function(t,n,e,o,i){"use strict";var r=function(){return(r=Object.assign||function(t){for(var n,e=1,o=arguments.length;e<o;e++)for(var i in n=arguments[e])Object.prototype.hasOwnProperty.call(n,i)&&(t[i]=n[i]);return t}).apply(this,arguments)};function a(t,n,e,o){var i,r=arguments.length,a=r<3?n:null===o?o=Object.getOwnPropertyDescriptor(n,e):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(t,n,e,o);else for(var s=t.length-1;s>=0;s--)(i=t[s])&&(a=(r<3?i(a):r>3?i(n,e,a):i(n,e))||a);return r>3&&a&&Object.defineProperty(n,e,a),a}function s(t,n){return function(e,o){n(e,o,t)}}function c(t,n){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(t,n)}var l=function(t,n){this.name=t,this.imageIndex=n},g={btnClass:"mat-mini-fab",zoomFactor:.1,containerBackgroundColor:"#ccc",allowCtrlWheelZoom:!0,allowFullscreen:!0,allowKeyboardNavigation:!0,allowDrag:!0,btnShow:{zoomIn:!0,zoomOut:!0,rotateClockwise:!0,rotateCounterClockwise:!0,next:!0,prev:!0},btnIcons:{zoomIn:"material-icons zoom-in",zoomOut:"material-icons zoom-out",rotateClockwise:"material-icons rotate-clockwise",rotateCounterClockwise:"material-icons rotate-counterclock",next:"material-icons next",prev:"material-icons prev",fullscreen:"material-icons fullscreen"}},u=function(){function t(t,e){this.moduleConfig=t,this.bigScreenService=e,this.index=0,this.indexChange=new n.EventEmitter,this.configChange=new n.EventEmitter,this.customEvent=new n.EventEmitter,this.style={transform:"",msTransform:"",oTransform:"",webkitTransform:""},this.fullscreen=!1,this.loading=!0,this.scale=1,this.rotation=0,this.translateX=0,this.translateY=0,this.hovered=!1}return t.prototype.ngOnInit=function(){var t=this.mergeConfig(g,this.moduleConfig);this.config=this.mergeConfig(t,this.config),this.triggerConfigBinding()},t.prototype.nextImage=function(t){this.canNavigate(t)&&this.index<this.src.length-1&&(this.loading=!0,this.index++,this.triggerIndexBinding(),this.reset())},t.prototype.prevImage=function(t){this.canNavigate(t)&&this.index>0&&(this.loading=!0,this.index--,this.triggerIndexBinding(),this.reset())},t.prototype.zoomIn=function(){this.scale*=1+this.config.zoomFactor,this.updateStyle()},t.prototype.zoomOut=function(){this.scale>this.config.zoomFactor&&(this.scale/=1+this.config.zoomFactor),this.updateStyle()},t.prototype.scrollZoom=function(t){if(this.config.allowCtrlWheelZoom&&t.ctrlKey)return t.deltaY>0?this.zoomOut():this.zoomIn(),!1},t.prototype.rotateClockwise=function(){this.rotation+=90,this.updateStyle()},t.prototype.rotateCounterClockwise=function(){this.rotation-=90,this.updateStyle()},t.prototype.onLoad=function(){this.loading=!1},t.prototype.onLoadStart=function(){this.loading=!0},t.prototype.onDragOver=function(t){this.config.allowDrag&&(this.translateX+=t.clientX-this.prevX,this.translateY+=t.clientY-this.prevY,this.prevX=t.clientX,this.prevY=t.clientY,this.updateStyle())},t.prototype.onDragStart=function(t){this.config.allowDrag&&(t.dataTransfer&&t.dataTransfer.setDragImage&&t.dataTransfer.setDragImage(t.target.nextElementSibling,0,0),this.prevX=t.clientX,this.prevY=t.clientY)},t.prototype.toggleFullscreen=function(){this.bigScreenService.isEnabled&&this.config.allowFullscreen?this.bigScreenService.toggle(this.fullscreenElement.nativeElement):console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled")},t.prototype.triggerIndexBinding=function(){this.indexChange.emit(this.index)},t.prototype.triggerConfigBinding=function(){this.configChange.next(this.config)},t.prototype.fireCustomEvent=function(t,n){this.customEvent.emit(new l(t,n))},t.prototype.reset=function(){this.scale=1,this.rotation=0,this.translateX=0,this.translateY=0,this.updateStyle()},t.prototype.onMouseOver=function(){this.hovered=!0},t.prototype.onMouseLeave=function(){this.hovered=!1},t.prototype.canNavigate=function(t){return null==t||this.config.allowKeyboardNavigation&&this.hovered},t.prototype.updateStyle=function(){this.style.transform="translate("+this.translateX+"px, "+this.translateY+"px) rotate("+this.rotation+"deg) scale("+this.scale+")",this.style.msTransform=this.style.transform,this.style.webkitTransform=this.style.transform,this.style.oTransform=this.style.transform},t.prototype.mergeConfig=function(t,n){var e=r({},t);return n&&(e=r({},t,n),n.btnIcons&&(e.btnIcons=r({},t.btnIcons,n.btnIcons))),e},a([n.Input(),c("design:type",Array)],t.prototype,"src",void 0),a([n.Input(),c("design:type",Object)],t.prototype,"index",void 0),a([n.Input(),c("design:type",Object)],t.prototype,"config",void 0),a([n.Output(),c("design:type",n.EventEmitter)],t.prototype,"indexChange",void 0),a([n.Output(),c("design:type",n.EventEmitter)],t.prototype,"configChange",void 0),a([n.Output(),c("design:type",n.EventEmitter)],t.prototype,"customEvent",void 0),a([n.ViewChild("fullscreenElement"),c("design:type",n.ElementRef)],t.prototype,"fullscreenElement",void 0),a([n.HostListener("window:keyup.ArrowRight",["$event"]),c("design:type",Function),c("design:paramtypes",[Object]),c("design:returntype",void 0)],t.prototype,"nextImage",null),a([n.HostListener("window:keyup.ArrowLeft",["$event"]),c("design:type",Function),c("design:paramtypes",[Object]),c("design:returntype",void 0)],t.prototype,"prevImage",null),a([n.HostListener("mouseover"),c("design:type",Function),c("design:paramtypes",[]),c("design:returntype",void 0)],t.prototype,"onMouseOver",null),a([n.HostListener("mouseleave"),c("design:type",Function),c("design:paramtypes",[]),c("design:returntype",void 0)],t.prototype,"onMouseLeave",null),t=a([n.Component({selector:"ngx-image-viewer",template:'<div #fullscreenElement class="img-container" [style.backgroundColor]="config.containerBackgroundColor"\n\t(wheel)="scrollZoom($event)" (dragover)="onDragOver($event)">\n\t<img [src]="src[index]" [ngStyle]="style" alt="Image not found..." (dragstart)="onDragStart($event)"\n\t\t(load)="onLoad()" (loadstart)="onLoadStart()" />\n\t\x3c!-- Div below will be used to hide the \'ghost\' image when dragging --\x3e\n\t<div></div>\n\t<div class="spinner-container" *ngIf="loading">\n\t\t<div class="spinner"></div>\n\t</div>\n\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.rotateCounterClockwise"\n\t\t(click)="rotateCounterClockwise()">\n\t\t<span [class]="config.btnIcons.rotateCounterClockwise"></span>\n\t</button>\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.rotateClockwise" (click)="rotateClockwise()">\n\t\t<span [class]="config.btnIcons.rotateClockwise"></span>\n\t</button>\n\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.zoomOut" (click)="zoomOut()">\n\t\t<span [class]="config.btnIcons.zoomOut"></span>\n\t</button>\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngIf="config.btnShow.zoomIn" (click)="zoomIn()">\n\t\t<span [class]="config.btnIcons.zoomIn"></span>\n\t</button>\n\n\t<button type="button" mat-mini-fab [class]="config.btnClass" *ngFor="let cBtn of config.customBtns"\n\t\t(click)="fireCustomEvent(cBtn.name, index)">\n\t\t<span [class]="cBtn.icon"></span>\n\t</button>\n\n\t<button type="button" id="ngx-fs-btn" mat-mini-fab [class]="config.btnClass" (click)="toggleFullscreen()"\n\t\t*ngIf="config.allowFullscreen">\n\t\t<span [class]="config.btnIcons.fullscreen"></span>\n\t</button>\n\n\t<div class="nav-button-container" *ngIf="src.length > 1">\n\t\t<button type="button" mat-mini-fab [class]="config.btnClass" (click)="prevImage($event)" [disabled]="index === 0">\n\t\t\t<span [class]="config.btnIcons.prev"></span>\n\t\t</button>\n\t\t<button type="button" mat-mini-fab [class]="config.btnClass" (click)="nextImage($event)"\n\t\t\t[disabled]="index === src.length - 1">\n\t\t\t<span [class]="config.btnIcons.next"></span>\n\t\t</button>\n\t</div>\n</div>\n',styles:['.img-container{height:100%;width:100%;overflow:hidden;position:relative}.img-container img{z-index:2;margin:0 auto;display:block;max-width:100%;max-height:100%}.img-container button{z-index:99;position:absolute;right:15px}.img-container button:not(:disabled){cursor:pointer}.img-container>button:nth-of-type(1):not(#ngx-fs-btn){bottom:15px}.img-container>button:nth-of-type(2):not(#ngx-fs-btn){bottom:65px}.img-container>button:nth-of-type(3):not(#ngx-fs-btn){bottom:115px}.img-container>button:nth-of-type(4):not(#ngx-fs-btn){bottom:165px}.img-container>button:nth-of-type(5):not(#ngx-fs-btn){bottom:215px}.img-container>button:nth-of-type(6):not(#ngx-fs-btn){bottom:265px}.img-container>button:nth-of-type(7):not(#ngx-fs-btn){bottom:315px}#ngx-fs-btn{top:15px}button.default{height:40px;width:40px;border:1px solid #555;border-radius:50%;background-color:#fff;opacity:.7;transition:opacity .2s}button.default:hover{opacity:1}button.default:disabled{opacity:.25}.nav-button-container>button{position:relative;right:0;margin:0 10px}.nav-button-container{text-align:center;position:absolute;z-index:98;bottom:10px;left:0;right:0}.spinner-container{position:absolute;left:0;right:0;top:0;bottom:0;width:60px;height:60px;margin:auto;padding:10px;background-color:rgba(0,0,0,.4);border-radius:25%}.spinner{border-width:7px;border-style:solid;border-color:#ccc #ccc #222;border-radius:50%;height:100%;width:100%;box-sizing:border-box;-webkit-animation:2s linear infinite rotation;animation:2s linear infinite rotation}@keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}@-webkit-keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}.zoom-in:after{content:"zoom_in"}.zoom-out:after{content:"zoom_out"}.rotate-clockwise:after{content:"rotate_right"}.rotate-counterclock:after{content:"rotate_left"}.next:after{content:"keyboard_arrow_right"}.prev:after{content:"keyboard_arrow_left"}.fullscreen:after{content:"fullscreen"}']}),s(0,n.Optional()),s(0,n.Inject("config")),c("design:paramtypes",[Object,i.BigScreenService])],t)}(),p=function(){function t(){}var r;return r=t,t.forRoot=function(t){return{ngModule:r,providers:[{provide:"config",useValue:t}]}},t=r=a([n.NgModule({imports:[i.BigScreenModule,e.CommonModule,o.MatButtonModule,o.MatIconModule],declarations:[u],exports:[u]})],t)}();t.CustomEvent=l,t.ImageViewerComponent=u,t.ImageViewerModule=p,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=lacuna-image-viewer.umd.min.js.map

@@ -5,3 +5,2 @@ /**

export * from './public_api';
export { ToggleFullscreenDirective as ɵa } from './src/app/image-viewer/fullscreen.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFjdW5hLWltYWdlLXZpZXdlci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJsYWN1bmEtaW1hZ2Utdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUM7QUFFN0IsT0FBTyxFQUFDLHlCQUF5QixJQUFJLEVBQUUsRUFBQyxNQUFNLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuXG5leHBvcnQge1RvZ2dsZUZ1bGxzY3JlZW5EaXJlY3RpdmUgYXMgybVhfSBmcm9tICcuL3NyYy9hcHAvaW1hZ2Utdmlld2VyL2Z1bGxzY3JlZW4uZGlyZWN0aXZlJzsiXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFjdW5hLWltYWdlLXZpZXdlci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJsYWN1bmEtaW1hZ2Utdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0=
import * as tslib_1 from "tslib";
import { Component, Input, Optional, Inject, Output, EventEmitter, HostListener, ElementRef, ViewChild } from '@angular/core';
import { CustomEvent } from './image-viewer-config.model';
import * as screenfull from 'screenfull';
import { isScreenFullAvailable } from './fullscreen.directive';
import { BigScreenService } from 'angular-bigscreen';
const DEFAULT_CONFIG = {

@@ -33,4 +32,5 @@ btnClass: 'mat-mini-fab',

let ImageViewerComponent = class ImageViewerComponent {
constructor(moduleConfig) {
constructor(moduleConfig, bigScreenService) {
this.moduleConfig = moduleConfig;
this.bigScreenService = bigScreenService;
this.index = 0;

@@ -119,13 +119,7 @@ this.indexChange = new EventEmitter();

toggleFullscreen() {
if (isScreenFullAvailable(screenfull)) {
if (screenfull.enabled && this.config.allowFullscreen) {
screenfull.toggle(this.fullscreenElement.nativeElement);
}
else {
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}
if (this.bigScreenService.isEnabled && this.config.allowFullscreen) {
this.bigScreenService.toggle(this.fullscreenElement.nativeElement);
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}

@@ -234,5 +228,5 @@ }

tslib_1.__param(0, Optional()), tslib_1.__param(0, Inject('config')),
tslib_1.__metadata("design:paramtypes", [Object])
tslib_1.__metadata("design:paramtypes", [Object, BigScreenService])
], ImageViewerComponent);
export { ImageViewerComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-viewer.component.js","sourceRoot":"ng://lacuna-image-viewer/","sources":["src/app/image-viewer/image-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Optional, Inject, Output, EventEmitter, HostListener, ElementRef, ViewChild } from '@angular/core';\nimport { ImageViewerConfig, CustomEvent } from './image-viewer-config.model';\nimport { SafeResourceUrl, SafeUrl } from '@angular/platform-browser';\nimport * as screenfull from 'screenfull';\nimport { isScreenFullAvailable } from './fullscreen.directive';\n\nconst DEFAULT_CONFIG: ImageViewerConfig = {\n\tbtnClass: 'mat-mini-fab', // we observed that it was tricky to override the browser button\n\tzoomFactor: 0.1,\n\tcontainerBackgroundColor: '#ccc',\n\tallowCtrlWheelZoom: true,\n\tallowFullscreen: true,\n\tallowKeyboardNavigation: true,\n\tallowDrag: true,\n\tbtnShow: {\n\t\tzoomIn: true,\n\t\tzoomOut: true,\n\t\trotateClockwise: true,\n\t\trotateCounterClockwise: true,\n\t\tnext: true,\n\t\tprev: true\n\t},\n\tbtnIcons: {\n\t\tzoomIn: 'material-icons zoom-in',\n\t\tzoomOut: 'material-icons zoom-out',\n\t\trotateClockwise: 'material-icons rotate-clockwise',\n\t\trotateCounterClockwise: 'material-icons rotate-counterclock',\n\t\tnext: 'material-icons next',\n\t\tprev: 'material-icons prev',\n\t\tfullscreen: 'material-icons fullscreen',\n\t}\n};\n\n@Component({\n\tselector: 'ngx-image-viewer',\n\ttemplateUrl: './image-viewer.component.html',\n\tstyleUrls: ['./image-viewer.component.scss']\n})\nexport class ImageViewerComponent implements OnInit {\n\n\t@Input()\n\tsrc: (string | SafeResourceUrl | SafeUrl)[];\n\n\t@Input()\n\tindex = 0;\n\n\t@Input()\n\tconfig: ImageViewerConfig;\n\n\t@Output()\n\tindexChange: EventEmitter<number> = new EventEmitter();\n\n\t@Output()\n\tconfigChange: EventEmitter<ImageViewerConfig> = new EventEmitter();\n\n\t@Output()\n\tcustomEvent: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t@ViewChild('fullscreenElement')\n\tfullscreenElement: ElementRef;\n\n\tpublic style = { transform: '', msTransform: '', oTransform: '', webkitTransform: '' };\n\tpublic fullscreen = false;\n\tpublic loading = true;\n\tprivate scale = 1;\n\tprivate rotation = 0;\n\tprivate translateX = 0;\n\tprivate translateY = 0;\n\tprivate prevX: number;\n\tprivate prevY: number;\n\tprivate hovered = false;\n\n\tconstructor(@Optional() @Inject('config') public moduleConfig: ImageViewerConfig) { }\n\n\tngOnInit() {\n\t\tconst merged = this.mergeConfig(DEFAULT_CONFIG, this.moduleConfig);\n\t\tthis.config = this.mergeConfig(merged, this.config);\n\t\tthis.triggerConfigBinding();\n\t}\n\n\t@HostListener('window:keyup.ArrowRight', ['$event'])\n\tnextImage(event) {\n\t\tif (this.canNavigate(event) && this.index < this.src.length - 1) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index++;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\t@HostListener('window:keyup.ArrowLeft', ['$event'])\n\tprevImage(event) {\n\t\tif (this.canNavigate(event) && this.index > 0) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index--;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\tzoomIn() {\n\t\tthis.scale *= (1 + this.config.zoomFactor);\n\t\tthis.updateStyle();\n\t}\n\n\tzoomOut() {\n\t\tif (this.scale > this.config.zoomFactor) {\n\t\t\tthis.scale /= (1 + this.config.zoomFactor);\n\t\t}\n\t\tthis.updateStyle();\n\t}\n\n\tscrollZoom(evt: WheelEvent) {\n\t\tif (this.config.allowCtrlWheelZoom && evt.ctrlKey) {\n\t\t\tevt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n\t\t\treturn false;\n\t\t}\n\t}\n\n\trotateClockwise() {\n\t\tthis.rotation += 90;\n\t\tthis.updateStyle();\n\t}\n\n\trotateCounterClockwise() {\n\t\tthis.rotation -= 90;\n\t\tthis.updateStyle();\n\t}\n\n\tonLoad() {\n\t\tthis.loading = false;\n\t}\n\n\tonLoadStart() {\n\t\tthis.loading = true;\n\t}\n\n\tonDragOver(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tthis.translateX += (evt.clientX - this.prevX);\n\t\t\tthis.translateY += (evt.clientY - this.prevY);\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t\tthis.updateStyle();\n\t\t}\n\t}\n\n\tonDragStart(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tif (evt.dataTransfer && evt.dataTransfer.setDragImage) {\n\t\t\t\tevt.dataTransfer.setDragImage(evt.target.nextElementSibling, 0, 0);\n\t\t\t}\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t}\n\t}\n\n\ttoggleFullscreen() {\n\t\tif(isScreenFullAvailable(screenfull)){\n\t\t\tif(screenfull.enabled && this.config.allowFullscreen){\n\t\t\t\tscreenfull.toggle(this.fullscreenElement.nativeElement);\n\t\t\t} else{\n\t\t\t\tconsole.log(\"[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled\");\n\t\t\t}\n\t\t} else{\n\t\t\t// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126\n\t\t\tconsole.log(\"[lacuna-image-viewer warning] Screenfull could not be used\");\n\t\t}\n\t}\n\n\ttriggerIndexBinding() {\n\t\tthis.indexChange.emit(this.index);\n\t}\n\n\ttriggerConfigBinding() {\n\t\tthis.configChange.next(this.config);\n\t}\n\n\tfireCustomEvent(name, imageIndex) {\n\t\tthis.customEvent.emit(new CustomEvent(name, imageIndex));\n\t}\n\n\treset() {\n\t\tthis.scale = 1;\n\t\tthis.rotation = 0;\n\t\tthis.translateX = 0;\n\t\tthis.translateY = 0;\n\t\tthis.updateStyle();\n\t}\n\n\t@HostListener('mouseover')\n\tonMouseOver() {\n\t\tthis.hovered = true;\n\t}\n\n\t@HostListener('mouseleave')\n\tonMouseLeave() {\n\t\tthis.hovered = false;\n\t}\n\n\tprivate canNavigate(event: any) {\n\t\treturn event == null || (this.config.allowKeyboardNavigation && this.hovered);\n\t}\n\n\tprivate updateStyle() {\n\t\tthis.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n\t\tthis.style.msTransform = this.style.transform;\n\t\tthis.style.webkitTransform = this.style.transform;\n\t\tthis.style.oTransform = this.style.transform;\n\t}\n\n\tprivate mergeConfig(defaultValues: ImageViewerConfig, overrideValues: ImageViewerConfig): ImageViewerConfig {\n\t\tlet result: ImageViewerConfig = { ...defaultValues };\n\t\tif (overrideValues) {\n\t\t\tresult = { ...defaultValues, ...overrideValues };\n\n\t\t\tif (overrideValues.btnIcons) {\n\t\t\t\tresult.btnIcons = { ...defaultValues.btnIcons, ...overrideValues.btnIcons };\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-viewer.component.js","sourceRoot":"ng://lacuna-image-viewer/","sources":["src/app/image-viewer/image-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Optional, Inject, Output, EventEmitter, HostListener, ElementRef, ViewChild } from '@angular/core';\nimport { ImageViewerConfig, CustomEvent } from './image-viewer-config.model';\nimport { SafeResourceUrl, SafeUrl } from '@angular/platform-browser';\nimport { BigScreenService } from 'angular-bigscreen';\n\nconst DEFAULT_CONFIG: ImageViewerConfig = {\n\tbtnClass: 'mat-mini-fab', // we observed that it was tricky to override the browser button\n\tzoomFactor: 0.1,\n\tcontainerBackgroundColor: '#ccc',\n\tallowCtrlWheelZoom: true,\n\tallowFullscreen: true,\n\tallowKeyboardNavigation: true,\n\tallowDrag: true,\n\tbtnShow: {\n\t\tzoomIn: true,\n\t\tzoomOut: true,\n\t\trotateClockwise: true,\n\t\trotateCounterClockwise: true,\n\t\tnext: true,\n\t\tprev: true\n\t},\n\tbtnIcons: {\n\t\tzoomIn: 'material-icons zoom-in',\n\t\tzoomOut: 'material-icons zoom-out',\n\t\trotateClockwise: 'material-icons rotate-clockwise',\n\t\trotateCounterClockwise: 'material-icons rotate-counterclock',\n\t\tnext: 'material-icons next',\n\t\tprev: 'material-icons prev',\n\t\tfullscreen: 'material-icons fullscreen',\n\t}\n};\n\n@Component({\n\tselector: 'ngx-image-viewer',\n\ttemplateUrl: './image-viewer.component.html',\n\tstyleUrls: ['./image-viewer.component.scss']\n})\nexport class ImageViewerComponent implements OnInit {\n\n\t@Input()\n\tsrc: (string | SafeResourceUrl | SafeUrl)[];\n\n\t@Input()\n\tindex = 0;\n\n\t@Input()\n\tconfig: ImageViewerConfig;\n\n\t@Output()\n\tindexChange: EventEmitter<number> = new EventEmitter();\n\n\t@Output()\n\tconfigChange: EventEmitter<ImageViewerConfig> = new EventEmitter();\n\n\t@Output()\n\tcustomEvent: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t@ViewChild('fullscreenElement')\n\tfullscreenElement: ElementRef;\n\n\tpublic style = { transform: '', msTransform: '', oTransform: '', webkitTransform: '' };\n\tpublic fullscreen = false;\n\tpublic loading = true;\n\tprivate scale = 1;\n\tprivate rotation = 0;\n\tprivate translateX = 0;\n\tprivate translateY = 0;\n\tprivate prevX: number;\n\tprivate prevY: number;\n\tprivate hovered = false;\n\n\tconstructor(\n\t\t@Optional() @Inject('config') public moduleConfig: ImageViewerConfig,\n\t\tprivate bigScreenService: BigScreenService\n\t) { }\n\n\tngOnInit() {\n\t\tconst merged = this.mergeConfig(DEFAULT_CONFIG, this.moduleConfig);\n\t\tthis.config = this.mergeConfig(merged, this.config);\n\t\tthis.triggerConfigBinding();\n\t}\n\n\t@HostListener('window:keyup.ArrowRight', ['$event'])\n\tnextImage(event) {\n\t\tif (this.canNavigate(event) && this.index < this.src.length - 1) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index++;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\t@HostListener('window:keyup.ArrowLeft', ['$event'])\n\tprevImage(event) {\n\t\tif (this.canNavigate(event) && this.index > 0) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index--;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\tzoomIn() {\n\t\tthis.scale *= (1 + this.config.zoomFactor);\n\t\tthis.updateStyle();\n\t}\n\n\tzoomOut() {\n\t\tif (this.scale > this.config.zoomFactor) {\n\t\t\tthis.scale /= (1 + this.config.zoomFactor);\n\t\t}\n\t\tthis.updateStyle();\n\t}\n\n\tscrollZoom(evt: WheelEvent) {\n\t\tif (this.config.allowCtrlWheelZoom && evt.ctrlKey) {\n\t\t\tevt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n\t\t\treturn false;\n\t\t}\n\t}\n\n\trotateClockwise() {\n\t\tthis.rotation += 90;\n\t\tthis.updateStyle();\n\t}\n\n\trotateCounterClockwise() {\n\t\tthis.rotation -= 90;\n\t\tthis.updateStyle();\n\t}\n\n\tonLoad() {\n\t\tthis.loading = false;\n\t}\n\n\tonLoadStart() {\n\t\tthis.loading = true;\n\t}\n\n\tonDragOver(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tthis.translateX += (evt.clientX - this.prevX);\n\t\t\tthis.translateY += (evt.clientY - this.prevY);\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t\tthis.updateStyle();\n\t\t}\n\t}\n\n\tonDragStart(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tif (evt.dataTransfer && evt.dataTransfer.setDragImage) {\n\t\t\t\tevt.dataTransfer.setDragImage(evt.target.nextElementSibling, 0, 0);\n\t\t\t}\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t}\n\t}\n\n\ttoggleFullscreen() {\n\t\tif(this.bigScreenService.isEnabled && this.config.allowFullscreen){\n\t\t\tthis.bigScreenService.toggle(this.fullscreenElement.nativeElement);\n\t\t} else {\n\t\t\tconsole.log(\"[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled\");\n\t\t}\n\t}\n\n\ttriggerIndexBinding() {\n\t\tthis.indexChange.emit(this.index);\n\t}\n\n\ttriggerConfigBinding() {\n\t\tthis.configChange.next(this.config);\n\t}\n\n\tfireCustomEvent(name, imageIndex) {\n\t\tthis.customEvent.emit(new CustomEvent(name, imageIndex));\n\t}\n\n\treset() {\n\t\tthis.scale = 1;\n\t\tthis.rotation = 0;\n\t\tthis.translateX = 0;\n\t\tthis.translateY = 0;\n\t\tthis.updateStyle();\n\t}\n\n\t@HostListener('mouseover')\n\tonMouseOver() {\n\t\tthis.hovered = true;\n\t}\n\n\t@HostListener('mouseleave')\n\tonMouseLeave() {\n\t\tthis.hovered = false;\n\t}\n\n\tprivate canNavigate(event: any) {\n\t\treturn event == null || (this.config.allowKeyboardNavigation && this.hovered);\n\t}\n\n\tprivate updateStyle() {\n\t\tthis.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n\t\tthis.style.msTransform = this.style.transform;\n\t\tthis.style.webkitTransform = this.style.transform;\n\t\tthis.style.oTransform = this.style.transform;\n\t}\n\n\tprivate mergeConfig(defaultValues: ImageViewerConfig, overrideValues: ImageViewerConfig): ImageViewerConfig {\n\t\tlet result: ImageViewerConfig = { ...defaultValues };\n\t\tif (overrideValues) {\n\t\t\tresult = { ...defaultValues, ...overrideValues };\n\n\t\t\tif (overrideValues.btnIcons) {\n\t\t\t\tresult.btnIcons = { ...defaultValues.btnIcons, ...overrideValues.btnIcons };\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n}\n"]}

@@ -6,4 +6,4 @@ import * as tslib_1 from "tslib";

import { MatButtonModule, MatIconModule } from '@angular/material';
import { BigScreenModule } from 'angular-bigscreen';
import { ImageViewerComponent } from './image-viewer.component';
import { ToggleFullscreenDirective } from './fullscreen.directive';
let ImageViewerModule = ImageViewerModule_1 = class ImageViewerModule {

@@ -20,2 +20,3 @@ static forRoot(config) {

imports: [
BigScreenModule,
CommonModule,

@@ -27,7 +28,5 @@ MatButtonModule,

ImageViewerComponent,
ToggleFullscreenDirective
],
exports: [
ImageViewerComponent,
ToggleFullscreenDirective
]

@@ -37,2 +36,2 @@ })

export { ImageViewerModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2Utdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJzcmMvYXBwL2ltYWdlLXZpZXdlci9pbWFnZS12aWV3ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbkUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFaEUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFpQm5FLElBQWEsaUJBQWlCLHlCQUE5QixNQUFhLGlCQUFpQjtJQUM3QixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQTBCO1FBQ3hDLE9BQU87WUFDTixRQUFRLEVBQUUsbUJBQWlCO1lBQzNCLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUM7U0FDcEQsQ0FBQztJQUNILENBQUM7Q0FDRCxDQUFBO0FBUFksaUJBQWlCO0lBZjdCLFFBQVEsQ0FBQztRQUNULE9BQU8sRUFBRTtZQUNSLFlBQVk7WUFDWixlQUFlO1lBQ2YsYUFBYTtTQUNiO1FBQ0QsWUFBWSxFQUFFO1lBQ2Isb0JBQW9CO1lBQ3BCLHlCQUF5QjtTQUN6QjtRQUNELE9BQU8sRUFBRTtZQUNSLG9CQUFvQjtZQUNwQix5QkFBeUI7U0FDekI7S0FDRCxDQUFDO0dBQ1csaUJBQWlCLENBTzdCO1NBUFksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbCc7XG5cbmltcG9ydCB7IEltYWdlVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9pbWFnZS12aWV3ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEltYWdlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi9pbWFnZS12aWV3ZXItY29uZmlnLm1vZGVsJztcbmltcG9ydCB7IFRvZ2dsZUZ1bGxzY3JlZW5EaXJlY3RpdmUgfSBmcm9tICcuL2Z1bGxzY3JlZW4uZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcblx0aW1wb3J0czogW1xuXHRcdENvbW1vbk1vZHVsZSxcblx0XHRNYXRCdXR0b25Nb2R1bGUsXG5cdFx0TWF0SWNvbk1vZHVsZSxcblx0XSxcblx0ZGVjbGFyYXRpb25zOiBbXG5cdFx0SW1hZ2VWaWV3ZXJDb21wb25lbnQsXG5cdFx0VG9nZ2xlRnVsbHNjcmVlbkRpcmVjdGl2ZVxuXHRdLFxuXHRleHBvcnRzOiBbXG5cdFx0SW1hZ2VWaWV3ZXJDb21wb25lbnQsXG5cdFx0VG9nZ2xlRnVsbHNjcmVlbkRpcmVjdGl2ZVxuXHRdXG59KVxuZXhwb3J0IGNsYXNzIEltYWdlVmlld2VyTW9kdWxlIHtcblx0c3RhdGljIGZvclJvb3QoY29uZmlnPzogSW1hZ2VWaWV3ZXJDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzIHtcblx0XHRyZXR1cm4ge1xuXHRcdFx0bmdNb2R1bGU6IEltYWdlVmlld2VyTW9kdWxlLFxuXHRcdFx0cHJvdmlkZXJzOiBbeyBwcm92aWRlOiAnY29uZmlnJywgdXNlVmFsdWU6IGNvbmZpZyB9XVxuXHRcdH07XG5cdH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2Utdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJzcmMvYXBwL2ltYWdlLXZpZXdlci9pbWFnZS12aWV3ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRXBELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBaUJoRSxJQUFhLGlCQUFpQix5QkFBOUIsTUFBYSxpQkFBaUI7SUFDN0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUEwQjtRQUN4QyxPQUFPO1lBQ04sUUFBUSxFQUFFLG1CQUFpQjtZQUMzQixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDO1NBQ3BELENBQUM7SUFDSCxDQUFDO0NBQ0QsQ0FBQTtBQVBZLGlCQUFpQjtJQWQ3QixRQUFRLENBQUM7UUFDVCxPQUFPLEVBQUU7WUFDUixlQUFlO1lBQ2YsWUFBWTtZQUNaLGVBQWU7WUFDZixhQUFhO1NBQ2I7UUFDRCxZQUFZLEVBQUU7WUFDYixvQkFBb0I7U0FDcEI7UUFDRCxPQUFPLEVBQUU7WUFDUixvQkFBb0I7U0FDcEI7S0FDRCxDQUFDO0dBQ1csaUJBQWlCLENBTzdCO1NBUFksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbCc7XG5pbXBvcnQgeyBCaWdTY3JlZW5Nb2R1bGUgfSBmcm9tICdhbmd1bGFyLWJpZ3NjcmVlbic7XG5cbmltcG9ydCB7IEltYWdlVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9pbWFnZS12aWV3ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEltYWdlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi9pbWFnZS12aWV3ZXItY29uZmlnLm1vZGVsJztcblxuQE5nTW9kdWxlKHtcblx0aW1wb3J0czogW1xuXHRcdEJpZ1NjcmVlbk1vZHVsZSxcblx0XHRDb21tb25Nb2R1bGUsXG5cdFx0TWF0QnV0dG9uTW9kdWxlLFxuXHRcdE1hdEljb25Nb2R1bGUsXG5cdF0sXG5cdGRlY2xhcmF0aW9uczogW1xuXHRcdEltYWdlVmlld2VyQ29tcG9uZW50LFxuXHRdLFxuXHRleHBvcnRzOiBbXG5cdFx0SW1hZ2VWaWV3ZXJDb21wb25lbnQsXG5cdF1cbn0pXG5leHBvcnQgY2xhc3MgSW1hZ2VWaWV3ZXJNb2R1bGUge1xuXHRzdGF0aWMgZm9yUm9vdChjb25maWc/OiBJbWFnZVZpZXdlckNvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnMge1xuXHRcdHJldHVybiB7XG5cdFx0XHRuZ01vZHVsZTogSW1hZ2VWaWV3ZXJNb2R1bGUsXG5cdFx0XHRwcm92aWRlcnM6IFt7IHByb3ZpZGU6ICdjb25maWcnLCB1c2VWYWx1ZTogY29uZmlnIH1dXG5cdFx0fTtcblx0fVxufVxuIl19

@@ -5,3 +5,2 @@ /**

export * from './public_api';
export { ToggleFullscreenDirective as ɵa } from './src/app/image-viewer/fullscreen.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFjdW5hLWltYWdlLXZpZXdlci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJsYWN1bmEtaW1hZ2Utdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUM7QUFFN0IsT0FBTyxFQUFDLHlCQUF5QixJQUFJLEVBQUUsRUFBQyxNQUFNLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuXG5leHBvcnQge1RvZ2dsZUZ1bGxzY3JlZW5EaXJlY3RpdmUgYXMgybVhfSBmcm9tICcuL3NyYy9hcHAvaW1hZ2Utdmlld2VyL2Z1bGxzY3JlZW4uZGlyZWN0aXZlJzsiXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFjdW5hLWltYWdlLXZpZXdlci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJsYWN1bmEtaW1hZ2Utdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0=
import * as tslib_1 from "tslib";
import { Component, Input, Optional, Inject, Output, EventEmitter, HostListener, ElementRef, ViewChild } from '@angular/core';
import { CustomEvent } from './image-viewer-config.model';
import * as screenfull from 'screenfull';
import { isScreenFullAvailable } from './fullscreen.directive';
import { BigScreenService } from 'angular-bigscreen';
var DEFAULT_CONFIG = {

@@ -33,4 +32,5 @@ btnClass: 'mat-mini-fab',

var ImageViewerComponent = /** @class */ (function () {
function ImageViewerComponent(moduleConfig) {
function ImageViewerComponent(moduleConfig, bigScreenService) {
this.moduleConfig = moduleConfig;
this.bigScreenService = bigScreenService;
this.index = 0;

@@ -119,13 +119,7 @@ this.indexChange = new EventEmitter();

ImageViewerComponent.prototype.toggleFullscreen = function () {
if (isScreenFullAvailable(screenfull)) {
if (screenfull.enabled && this.config.allowFullscreen) {
screenfull.toggle(this.fullscreenElement.nativeElement);
}
else {
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}
if (this.bigScreenService.isEnabled && this.config.allowFullscreen) {
this.bigScreenService.toggle(this.fullscreenElement.nativeElement);
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}

@@ -233,3 +227,3 @@ };

tslib_1.__param(0, Optional()), tslib_1.__param(0, Inject('config')),
tslib_1.__metadata("design:paramtypes", [Object])
tslib_1.__metadata("design:paramtypes", [Object, BigScreenService])
], ImageViewerComponent);

@@ -239,2 +233,2 @@ return ImageViewerComponent;

export { ImageViewerComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-viewer.component.js","sourceRoot":"ng://lacuna-image-viewer/","sources":["src/app/image-viewer/image-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Optional, Inject, Output, EventEmitter, HostListener, ElementRef, ViewChild } from '@angular/core';\nimport { ImageViewerConfig, CustomEvent } from './image-viewer-config.model';\nimport { SafeResourceUrl, SafeUrl } from '@angular/platform-browser';\nimport * as screenfull from 'screenfull';\nimport { isScreenFullAvailable } from './fullscreen.directive';\n\nconst DEFAULT_CONFIG: ImageViewerConfig = {\n\tbtnClass: 'mat-mini-fab', // we observed that it was tricky to override the browser button\n\tzoomFactor: 0.1,\n\tcontainerBackgroundColor: '#ccc',\n\tallowCtrlWheelZoom: true,\n\tallowFullscreen: true,\n\tallowKeyboardNavigation: true,\n\tallowDrag: true,\n\tbtnShow: {\n\t\tzoomIn: true,\n\t\tzoomOut: true,\n\t\trotateClockwise: true,\n\t\trotateCounterClockwise: true,\n\t\tnext: true,\n\t\tprev: true\n\t},\n\tbtnIcons: {\n\t\tzoomIn: 'material-icons zoom-in',\n\t\tzoomOut: 'material-icons zoom-out',\n\t\trotateClockwise: 'material-icons rotate-clockwise',\n\t\trotateCounterClockwise: 'material-icons rotate-counterclock',\n\t\tnext: 'material-icons next',\n\t\tprev: 'material-icons prev',\n\t\tfullscreen: 'material-icons fullscreen',\n\t}\n};\n\n@Component({\n\tselector: 'ngx-image-viewer',\n\ttemplateUrl: './image-viewer.component.html',\n\tstyleUrls: ['./image-viewer.component.scss']\n})\nexport class ImageViewerComponent implements OnInit {\n\n\t@Input()\n\tsrc: (string | SafeResourceUrl | SafeUrl)[];\n\n\t@Input()\n\tindex = 0;\n\n\t@Input()\n\tconfig: ImageViewerConfig;\n\n\t@Output()\n\tindexChange: EventEmitter<number> = new EventEmitter();\n\n\t@Output()\n\tconfigChange: EventEmitter<ImageViewerConfig> = new EventEmitter();\n\n\t@Output()\n\tcustomEvent: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t@ViewChild('fullscreenElement')\n\tfullscreenElement: ElementRef;\n\n\tpublic style = { transform: '', msTransform: '', oTransform: '', webkitTransform: '' };\n\tpublic fullscreen = false;\n\tpublic loading = true;\n\tprivate scale = 1;\n\tprivate rotation = 0;\n\tprivate translateX = 0;\n\tprivate translateY = 0;\n\tprivate prevX: number;\n\tprivate prevY: number;\n\tprivate hovered = false;\n\n\tconstructor(@Optional() @Inject('config') public moduleConfig: ImageViewerConfig) { }\n\n\tngOnInit() {\n\t\tconst merged = this.mergeConfig(DEFAULT_CONFIG, this.moduleConfig);\n\t\tthis.config = this.mergeConfig(merged, this.config);\n\t\tthis.triggerConfigBinding();\n\t}\n\n\t@HostListener('window:keyup.ArrowRight', ['$event'])\n\tnextImage(event) {\n\t\tif (this.canNavigate(event) && this.index < this.src.length - 1) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index++;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\t@HostListener('window:keyup.ArrowLeft', ['$event'])\n\tprevImage(event) {\n\t\tif (this.canNavigate(event) && this.index > 0) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index--;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\tzoomIn() {\n\t\tthis.scale *= (1 + this.config.zoomFactor);\n\t\tthis.updateStyle();\n\t}\n\n\tzoomOut() {\n\t\tif (this.scale > this.config.zoomFactor) {\n\t\t\tthis.scale /= (1 + this.config.zoomFactor);\n\t\t}\n\t\tthis.updateStyle();\n\t}\n\n\tscrollZoom(evt: WheelEvent) {\n\t\tif (this.config.allowCtrlWheelZoom && evt.ctrlKey) {\n\t\t\tevt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n\t\t\treturn false;\n\t\t}\n\t}\n\n\trotateClockwise() {\n\t\tthis.rotation += 90;\n\t\tthis.updateStyle();\n\t}\n\n\trotateCounterClockwise() {\n\t\tthis.rotation -= 90;\n\t\tthis.updateStyle();\n\t}\n\n\tonLoad() {\n\t\tthis.loading = false;\n\t}\n\n\tonLoadStart() {\n\t\tthis.loading = true;\n\t}\n\n\tonDragOver(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tthis.translateX += (evt.clientX - this.prevX);\n\t\t\tthis.translateY += (evt.clientY - this.prevY);\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t\tthis.updateStyle();\n\t\t}\n\t}\n\n\tonDragStart(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tif (evt.dataTransfer && evt.dataTransfer.setDragImage) {\n\t\t\t\tevt.dataTransfer.setDragImage(evt.target.nextElementSibling, 0, 0);\n\t\t\t}\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t}\n\t}\n\n\ttoggleFullscreen() {\n\t\tif(isScreenFullAvailable(screenfull)){\n\t\t\tif(screenfull.enabled && this.config.allowFullscreen){\n\t\t\t\tscreenfull.toggle(this.fullscreenElement.nativeElement);\n\t\t\t} else{\n\t\t\t\tconsole.log(\"[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled\");\n\t\t\t}\n\t\t} else{\n\t\t\t// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126\n\t\t\tconsole.log(\"[lacuna-image-viewer warning] Screenfull could not be used\");\n\t\t}\n\t}\n\n\ttriggerIndexBinding() {\n\t\tthis.indexChange.emit(this.index);\n\t}\n\n\ttriggerConfigBinding() {\n\t\tthis.configChange.next(this.config);\n\t}\n\n\tfireCustomEvent(name, imageIndex) {\n\t\tthis.customEvent.emit(new CustomEvent(name, imageIndex));\n\t}\n\n\treset() {\n\t\tthis.scale = 1;\n\t\tthis.rotation = 0;\n\t\tthis.translateX = 0;\n\t\tthis.translateY = 0;\n\t\tthis.updateStyle();\n\t}\n\n\t@HostListener('mouseover')\n\tonMouseOver() {\n\t\tthis.hovered = true;\n\t}\n\n\t@HostListener('mouseleave')\n\tonMouseLeave() {\n\t\tthis.hovered = false;\n\t}\n\n\tprivate canNavigate(event: any) {\n\t\treturn event == null || (this.config.allowKeyboardNavigation && this.hovered);\n\t}\n\n\tprivate updateStyle() {\n\t\tthis.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n\t\tthis.style.msTransform = this.style.transform;\n\t\tthis.style.webkitTransform = this.style.transform;\n\t\tthis.style.oTransform = this.style.transform;\n\t}\n\n\tprivate mergeConfig(defaultValues: ImageViewerConfig, overrideValues: ImageViewerConfig): ImageViewerConfig {\n\t\tlet result: ImageViewerConfig = { ...defaultValues };\n\t\tif (overrideValues) {\n\t\t\tresult = { ...defaultValues, ...overrideValues };\n\n\t\t\tif (overrideValues.btnIcons) {\n\t\t\t\tresult.btnIcons = { ...defaultValues.btnIcons, ...overrideValues.btnIcons };\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-viewer.component.js","sourceRoot":"ng://lacuna-image-viewer/","sources":["src/app/image-viewer/image-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Optional, Inject, Output, EventEmitter, HostListener, ElementRef, ViewChild } from '@angular/core';\nimport { ImageViewerConfig, CustomEvent } from './image-viewer-config.model';\nimport { SafeResourceUrl, SafeUrl } from '@angular/platform-browser';\nimport { BigScreenService } from 'angular-bigscreen';\n\nconst DEFAULT_CONFIG: ImageViewerConfig = {\n\tbtnClass: 'mat-mini-fab', // we observed that it was tricky to override the browser button\n\tzoomFactor: 0.1,\n\tcontainerBackgroundColor: '#ccc',\n\tallowCtrlWheelZoom: true,\n\tallowFullscreen: true,\n\tallowKeyboardNavigation: true,\n\tallowDrag: true,\n\tbtnShow: {\n\t\tzoomIn: true,\n\t\tzoomOut: true,\n\t\trotateClockwise: true,\n\t\trotateCounterClockwise: true,\n\t\tnext: true,\n\t\tprev: true\n\t},\n\tbtnIcons: {\n\t\tzoomIn: 'material-icons zoom-in',\n\t\tzoomOut: 'material-icons zoom-out',\n\t\trotateClockwise: 'material-icons rotate-clockwise',\n\t\trotateCounterClockwise: 'material-icons rotate-counterclock',\n\t\tnext: 'material-icons next',\n\t\tprev: 'material-icons prev',\n\t\tfullscreen: 'material-icons fullscreen',\n\t}\n};\n\n@Component({\n\tselector: 'ngx-image-viewer',\n\ttemplateUrl: './image-viewer.component.html',\n\tstyleUrls: ['./image-viewer.component.scss']\n})\nexport class ImageViewerComponent implements OnInit {\n\n\t@Input()\n\tsrc: (string | SafeResourceUrl | SafeUrl)[];\n\n\t@Input()\n\tindex = 0;\n\n\t@Input()\n\tconfig: ImageViewerConfig;\n\n\t@Output()\n\tindexChange: EventEmitter<number> = new EventEmitter();\n\n\t@Output()\n\tconfigChange: EventEmitter<ImageViewerConfig> = new EventEmitter();\n\n\t@Output()\n\tcustomEvent: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t@ViewChild('fullscreenElement')\n\tfullscreenElement: ElementRef;\n\n\tpublic style = { transform: '', msTransform: '', oTransform: '', webkitTransform: '' };\n\tpublic fullscreen = false;\n\tpublic loading = true;\n\tprivate scale = 1;\n\tprivate rotation = 0;\n\tprivate translateX = 0;\n\tprivate translateY = 0;\n\tprivate prevX: number;\n\tprivate prevY: number;\n\tprivate hovered = false;\n\n\tconstructor(\n\t\t@Optional() @Inject('config') public moduleConfig: ImageViewerConfig,\n\t\tprivate bigScreenService: BigScreenService\n\t) { }\n\n\tngOnInit() {\n\t\tconst merged = this.mergeConfig(DEFAULT_CONFIG, this.moduleConfig);\n\t\tthis.config = this.mergeConfig(merged, this.config);\n\t\tthis.triggerConfigBinding();\n\t}\n\n\t@HostListener('window:keyup.ArrowRight', ['$event'])\n\tnextImage(event) {\n\t\tif (this.canNavigate(event) && this.index < this.src.length - 1) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index++;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\t@HostListener('window:keyup.ArrowLeft', ['$event'])\n\tprevImage(event) {\n\t\tif (this.canNavigate(event) && this.index > 0) {\n\t\t\tthis.loading = true;\n\t\t\tthis.index--;\n\t\t\tthis.triggerIndexBinding();\n\t\t\tthis.reset();\n\t\t}\n\t}\n\n\tzoomIn() {\n\t\tthis.scale *= (1 + this.config.zoomFactor);\n\t\tthis.updateStyle();\n\t}\n\n\tzoomOut() {\n\t\tif (this.scale > this.config.zoomFactor) {\n\t\t\tthis.scale /= (1 + this.config.zoomFactor);\n\t\t}\n\t\tthis.updateStyle();\n\t}\n\n\tscrollZoom(evt: WheelEvent) {\n\t\tif (this.config.allowCtrlWheelZoom && evt.ctrlKey) {\n\t\t\tevt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n\t\t\treturn false;\n\t\t}\n\t}\n\n\trotateClockwise() {\n\t\tthis.rotation += 90;\n\t\tthis.updateStyle();\n\t}\n\n\trotateCounterClockwise() {\n\t\tthis.rotation -= 90;\n\t\tthis.updateStyle();\n\t}\n\n\tonLoad() {\n\t\tthis.loading = false;\n\t}\n\n\tonLoadStart() {\n\t\tthis.loading = true;\n\t}\n\n\tonDragOver(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tthis.translateX += (evt.clientX - this.prevX);\n\t\t\tthis.translateY += (evt.clientY - this.prevY);\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t\tthis.updateStyle();\n\t\t}\n\t}\n\n\tonDragStart(evt) {\n\t\tif(this.config.allowDrag){\n\t\t\tif (evt.dataTransfer && evt.dataTransfer.setDragImage) {\n\t\t\t\tevt.dataTransfer.setDragImage(evt.target.nextElementSibling, 0, 0);\n\t\t\t}\n\t\t\tthis.prevX = evt.clientX;\n\t\t\tthis.prevY = evt.clientY;\n\t\t}\n\t}\n\n\ttoggleFullscreen() {\n\t\tif(this.bigScreenService.isEnabled && this.config.allowFullscreen){\n\t\t\tthis.bigScreenService.toggle(this.fullscreenElement.nativeElement);\n\t\t} else {\n\t\t\tconsole.log(\"[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled\");\n\t\t}\n\t}\n\n\ttriggerIndexBinding() {\n\t\tthis.indexChange.emit(this.index);\n\t}\n\n\ttriggerConfigBinding() {\n\t\tthis.configChange.next(this.config);\n\t}\n\n\tfireCustomEvent(name, imageIndex) {\n\t\tthis.customEvent.emit(new CustomEvent(name, imageIndex));\n\t}\n\n\treset() {\n\t\tthis.scale = 1;\n\t\tthis.rotation = 0;\n\t\tthis.translateX = 0;\n\t\tthis.translateY = 0;\n\t\tthis.updateStyle();\n\t}\n\n\t@HostListener('mouseover')\n\tonMouseOver() {\n\t\tthis.hovered = true;\n\t}\n\n\t@HostListener('mouseleave')\n\tonMouseLeave() {\n\t\tthis.hovered = false;\n\t}\n\n\tprivate canNavigate(event: any) {\n\t\treturn event == null || (this.config.allowKeyboardNavigation && this.hovered);\n\t}\n\n\tprivate updateStyle() {\n\t\tthis.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n\t\tthis.style.msTransform = this.style.transform;\n\t\tthis.style.webkitTransform = this.style.transform;\n\t\tthis.style.oTransform = this.style.transform;\n\t}\n\n\tprivate mergeConfig(defaultValues: ImageViewerConfig, overrideValues: ImageViewerConfig): ImageViewerConfig {\n\t\tlet result: ImageViewerConfig = { ...defaultValues };\n\t\tif (overrideValues) {\n\t\t\tresult = { ...defaultValues, ...overrideValues };\n\n\t\t\tif (overrideValues.btnIcons) {\n\t\t\t\tresult.btnIcons = { ...defaultValues.btnIcons, ...overrideValues.btnIcons };\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n}\n"]}

@@ -5,4 +5,4 @@ import * as tslib_1 from "tslib";

import { MatButtonModule, MatIconModule } from '@angular/material';
import { BigScreenModule } from 'angular-bigscreen';
import { ImageViewerComponent } from './image-viewer.component';
import { ToggleFullscreenDirective } from './fullscreen.directive';
var ImageViewerModule = /** @class */ (function () {

@@ -22,2 +22,3 @@ function ImageViewerModule() {

imports: [
BigScreenModule,
CommonModule,

@@ -29,7 +30,5 @@ MatButtonModule,

ImageViewerComponent,
ToggleFullscreenDirective
],
exports: [
ImageViewerComponent,
ToggleFullscreenDirective
]

@@ -41,2 +40,2 @@ })

export { ImageViewerModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2Utdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJzcmMvYXBwL2ltYWdlLXZpZXdlci9pbWFnZS12aWV3ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVuRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUVoRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQWlCbkU7SUFBQTtJQU9BLENBQUM7MEJBUFksaUJBQWlCO0lBQ3RCLHlCQUFPLEdBQWQsVUFBZSxNQUEwQjtRQUN4QyxPQUFPO1lBQ04sUUFBUSxFQUFFLG1CQUFpQjtZQUMzQixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDO1NBQ3BELENBQUM7SUFDSCxDQUFDOztJQU5XLGlCQUFpQjtRQWY3QixRQUFRLENBQUM7WUFDVCxPQUFPLEVBQUU7Z0JBQ1IsWUFBWTtnQkFDWixlQUFlO2dCQUNmLGFBQWE7YUFDYjtZQUNELFlBQVksRUFBRTtnQkFDYixvQkFBb0I7Z0JBQ3BCLHlCQUF5QjthQUN6QjtZQUNELE9BQU8sRUFBRTtnQkFDUixvQkFBb0I7Z0JBQ3BCLHlCQUF5QjthQUN6QjtTQUNELENBQUM7T0FDVyxpQkFBaUIsQ0FPN0I7SUFBRCx3QkFBQztDQUFBLEFBUEQsSUFPQztTQVBZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlLCBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwnO1xuXG5pbXBvcnQgeyBJbWFnZVZpZXdlckNvbXBvbmVudCB9IGZyb20gJy4vaW1hZ2Utdmlld2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbWFnZVZpZXdlckNvbmZpZyB9IGZyb20gJy4vaW1hZ2Utdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5pbXBvcnQgeyBUb2dnbGVGdWxsc2NyZWVuRGlyZWN0aXZlIH0gZnJvbSAnLi9mdWxsc2NyZWVuLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG5cdGltcG9ydHM6IFtcblx0XHRDb21tb25Nb2R1bGUsXG5cdFx0TWF0QnV0dG9uTW9kdWxlLFxuXHRcdE1hdEljb25Nb2R1bGUsXG5cdF0sXG5cdGRlY2xhcmF0aW9uczogW1xuXHRcdEltYWdlVmlld2VyQ29tcG9uZW50LFxuXHRcdFRvZ2dsZUZ1bGxzY3JlZW5EaXJlY3RpdmVcblx0XSxcblx0ZXhwb3J0czogW1xuXHRcdEltYWdlVmlld2VyQ29tcG9uZW50LFxuXHRcdFRvZ2dsZUZ1bGxzY3JlZW5EaXJlY3RpdmVcblx0XVxufSlcbmV4cG9ydCBjbGFzcyBJbWFnZVZpZXdlck1vZHVsZSB7XG5cdHN0YXRpYyBmb3JSb290KGNvbmZpZz86IEltYWdlVmlld2VyQ29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG5cdFx0cmV0dXJuIHtcblx0XHRcdG5nTW9kdWxlOiBJbWFnZVZpZXdlck1vZHVsZSxcblx0XHRcdHByb3ZpZGVyczogW3sgcHJvdmlkZTogJ2NvbmZpZycsIHVzZVZhbHVlOiBjb25maWcgfV1cblx0XHR9O1xuXHR9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2Utdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2xhY3VuYS1pbWFnZS12aWV3ZXIvIiwic291cmNlcyI6WyJzcmMvYXBwL2ltYWdlLXZpZXdlci9pbWFnZS12aWV3ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFcEQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFpQmhFO0lBQUE7SUFPQSxDQUFDOzBCQVBZLGlCQUFpQjtJQUN0Qix5QkFBTyxHQUFkLFVBQWUsTUFBMEI7UUFDeEMsT0FBTztZQUNOLFFBQVEsRUFBRSxtQkFBaUI7WUFDM0IsU0FBUyxFQUFFLENBQUMsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsQ0FBQztTQUNwRCxDQUFDO0lBQ0gsQ0FBQzs7SUFOVyxpQkFBaUI7UUFkN0IsUUFBUSxDQUFDO1lBQ1QsT0FBTyxFQUFFO2dCQUNSLGVBQWU7Z0JBQ2YsWUFBWTtnQkFDWixlQUFlO2dCQUNmLGFBQWE7YUFDYjtZQUNELFlBQVksRUFBRTtnQkFDYixvQkFBb0I7YUFDcEI7WUFDRCxPQUFPLEVBQUU7Z0JBQ1Isb0JBQW9CO2FBQ3BCO1NBQ0QsQ0FBQztPQUNXLGlCQUFpQixDQU83QjtJQUFELHdCQUFDO0NBQUEsQUFQRCxJQU9DO1NBUFksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbCc7XG5pbXBvcnQgeyBCaWdTY3JlZW5Nb2R1bGUgfSBmcm9tICdhbmd1bGFyLWJpZ3NjcmVlbic7XG5cbmltcG9ydCB7IEltYWdlVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9pbWFnZS12aWV3ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEltYWdlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi9pbWFnZS12aWV3ZXItY29uZmlnLm1vZGVsJztcblxuQE5nTW9kdWxlKHtcblx0aW1wb3J0czogW1xuXHRcdEJpZ1NjcmVlbk1vZHVsZSxcblx0XHRDb21tb25Nb2R1bGUsXG5cdFx0TWF0QnV0dG9uTW9kdWxlLFxuXHRcdE1hdEljb25Nb2R1bGUsXG5cdF0sXG5cdGRlY2xhcmF0aW9uczogW1xuXHRcdEltYWdlVmlld2VyQ29tcG9uZW50LFxuXHRdLFxuXHRleHBvcnRzOiBbXG5cdFx0SW1hZ2VWaWV3ZXJDb21wb25lbnQsXG5cdF1cbn0pXG5leHBvcnQgY2xhc3MgSW1hZ2VWaWV3ZXJNb2R1bGUge1xuXHRzdGF0aWMgZm9yUm9vdChjb25maWc/OiBJbWFnZVZpZXdlckNvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnMge1xuXHRcdHJldHVybiB7XG5cdFx0XHRuZ01vZHVsZTogSW1hZ2VWaWV3ZXJNb2R1bGUsXG5cdFx0XHRwcm92aWRlcnM6IFt7IHByb3ZpZGU6ICdjb25maWcnLCB1c2VWYWx1ZTogY29uZmlnIH1dXG5cdFx0fTtcblx0fVxufVxuIl19
import { __decorate, __metadata, __param } from 'tslib';
import { Input, Directive, ElementRef, EventEmitter, Output, ViewChild, HostListener, Component, Optional, Inject, NgModule } from '@angular/core';
import { EventEmitter, Input, Output, ViewChild, ElementRef, HostListener, Component, Optional, Inject, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { MatButtonModule, MatIconModule } from '@angular/material';
import * as screenfull from 'screenfull';
import { enabled, request, exit, toggle } from 'screenfull';
import { BigScreenService, BigScreenModule } from 'angular-bigscreen';

@@ -15,40 +14,2 @@ class CustomEvent {

// [DEPRECATED] In LacunaImageViewer, this directive turned deprecated because it
// has a little bug: while in fullscreen mode, if we exit it by pressing "ESC", the
// "fullscreen" state, represented by the variable "isFullscreen", is not updated;
// consequently, the next time the user wants to get into fullscreen mode, it will
// be necessary to press the fullscreen button twice.
let ToggleFullscreenDirective = class ToggleFullscreenDirective {
constructor(el) {
this.el = el;
}
ngOnChanges() {
if (isScreenFullAvailable(screenfull)) {
if (this.isFullscreen && enabled) {
request(this.el.nativeElement);
}
else if (enabled) {
exit();
}
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
}
}
};
__decorate([
Input('ngxToggleFullscreen'),
__metadata("design:type", Boolean)
], ToggleFullscreenDirective.prototype, "isFullscreen", void 0);
ToggleFullscreenDirective = __decorate([
Directive({
selector: '[ngxToggleFullscreen]'
}),
__metadata("design:paramtypes", [ElementRef])
], ToggleFullscreenDirective);
function isScreenFullAvailable(sf) {
return sf.enabled !== undefined;
}
const DEFAULT_CONFIG = {

@@ -81,4 +42,5 @@ btnClass: 'mat-mini-fab',

let ImageViewerComponent = class ImageViewerComponent {
constructor(moduleConfig) {
constructor(moduleConfig, bigScreenService) {
this.moduleConfig = moduleConfig;
this.bigScreenService = bigScreenService;
this.index = 0;

@@ -167,13 +129,7 @@ this.indexChange = new EventEmitter();

toggleFullscreen() {
if (isScreenFullAvailable(screenfull)) {
if (enabled && this.config.allowFullscreen) {
toggle(this.fullscreenElement.nativeElement);
}
else {
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}
if (this.bigScreenService.isEnabled && this.config.allowFullscreen) {
this.bigScreenService.toggle(this.fullscreenElement.nativeElement);
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}

@@ -282,3 +238,3 @@ }

__param(0, Optional()), __param(0, Inject('config')),
__metadata("design:paramtypes", [Object])
__metadata("design:paramtypes", [Object, BigScreenService])
], ImageViewerComponent);

@@ -298,2 +254,3 @@

imports: [
BigScreenModule,
CommonModule,

@@ -305,7 +262,5 @@ MatButtonModule,

ImageViewerComponent,
ToggleFullscreenDirective
],
exports: [
ImageViewerComponent,
ToggleFullscreenDirective
]

@@ -315,3 +270,3 @@ })

export { CustomEvent, ImageViewerComponent, ImageViewerModule, ToggleFullscreenDirective as ɵa };
export { CustomEvent, ImageViewerComponent, ImageViewerModule };
//# sourceMappingURL=lacuna-image-viewer.js.map

@@ -1,7 +0,6 @@

import { __decorate, __metadata, __assign, __param } from 'tslib';
import { Input, Directive, ElementRef, Output, EventEmitter, ViewChild, HostListener, Component, Optional, Inject, NgModule } from '@angular/core';
import { __assign, __decorate, __metadata, __param } from 'tslib';
import { Input, Output, EventEmitter, ViewChild, ElementRef, HostListener, Component, Optional, Inject, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { MatButtonModule, MatIconModule } from '@angular/material';
import * as screenfull from 'screenfull';
import { enabled, request, exit, toggle } from 'screenfull';
import { BigScreenService, BigScreenModule } from 'angular-bigscreen';

@@ -16,41 +15,2 @@ var CustomEvent = /** @class */ (function () {

// [DEPRECATED] In LacunaImageViewer, this directive turned deprecated because it
// has a little bug: while in fullscreen mode, if we exit it by pressing "ESC", the
// "fullscreen" state, represented by the variable "isFullscreen", is not updated;
// consequently, the next time the user wants to get into fullscreen mode, it will
// be necessary to press the fullscreen button twice.
var ToggleFullscreenDirective = /** @class */ (function () {
function ToggleFullscreenDirective(el) {
this.el = el;
}
ToggleFullscreenDirective.prototype.ngOnChanges = function () {
if (isScreenFullAvailable(screenfull)) {
if (this.isFullscreen && enabled) {
request(this.el.nativeElement);
}
else if (enabled) {
exit();
}
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
}
};
__decorate([
Input('ngxToggleFullscreen'),
__metadata("design:type", Boolean)
], ToggleFullscreenDirective.prototype, "isFullscreen", void 0);
ToggleFullscreenDirective = __decorate([
Directive({
selector: '[ngxToggleFullscreen]'
}),
__metadata("design:paramtypes", [ElementRef])
], ToggleFullscreenDirective);
return ToggleFullscreenDirective;
}());
function isScreenFullAvailable(sf) {
return sf.enabled !== undefined;
}
var DEFAULT_CONFIG = {

@@ -83,4 +43,5 @@ btnClass: 'mat-mini-fab',

var ImageViewerComponent = /** @class */ (function () {
function ImageViewerComponent(moduleConfig) {
function ImageViewerComponent(moduleConfig, bigScreenService) {
this.moduleConfig = moduleConfig;
this.bigScreenService = bigScreenService;
this.index = 0;

@@ -169,13 +130,7 @@ this.indexChange = new EventEmitter();

ImageViewerComponent.prototype.toggleFullscreen = function () {
if (isScreenFullAvailable(screenfull)) {
if (enabled && this.config.allowFullscreen) {
toggle(this.fullscreenElement.nativeElement);
}
else {
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}
if (this.bigScreenService.isEnabled && this.config.allowFullscreen) {
this.bigScreenService.toggle(this.fullscreenElement.nativeElement);
}
else {
// Should not happen. See https://github.com/sindresorhus/screenfull.js/issues/126
console.log("[lacuna-image-viewer warning] Screenfull could not be used");
console.log("[lacuna-image-viewer warning] method toggleFullscreen() called, but fullscreen is disabled");
}

@@ -283,3 +238,3 @@ };

__param(0, Optional()), __param(0, Inject('config')),
__metadata("design:paramtypes", [Object])
__metadata("design:paramtypes", [Object, BigScreenService])
], ImageViewerComponent);

@@ -303,2 +258,3 @@ return ImageViewerComponent;

imports: [
BigScreenModule,
CommonModule,

@@ -310,7 +266,5 @@ MatButtonModule,

ImageViewerComponent,
ToggleFullscreenDirective
],
exports: [
ImageViewerComponent,
ToggleFullscreenDirective
]

@@ -322,3 +276,3 @@ })

export { CustomEvent, ImageViewerComponent, ImageViewerModule, ToggleFullscreenDirective as ɵa };
export { CustomEvent, ImageViewerComponent, ImageViewerModule };
//# sourceMappingURL=lacuna-image-viewer.js.map

@@ -5,2 +5,1 @@ /**

export * from './public_api';
export { ToggleFullscreenDirective as ɵa } from './src/app/image-viewer/fullscreen.directive';

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

{"__symbolic":"module","version":4,"metadata":{"ImageViewerModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":8,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":10,"character":2},{"__symbolic":"reference","module":"@angular/material","name":"MatButtonModule","line":11,"character":2},{"__symbolic":"reference","module":"@angular/material","name":"MatIconModule","line":12,"character":2}],"declarations":[{"__symbolic":"reference","name":"ImageViewerComponent"},{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ImageViewerComponent"},{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"ImageViewerModule"},"providers":[{"provide":"config","useValue":{"__symbolic":"reference","name":"config"}}]}}}},"ImageViewerComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":33,"character":1},"arguments":[{"selector":"ngx-image-viewer","template":"<div #fullscreenElement class=\"img-container\" [style.backgroundColor]=\"config.containerBackgroundColor\"\n\t(wheel)=\"scrollZoom($event)\" (dragover)=\"onDragOver($event)\">\n\t<img [src]=\"src[index]\" [ngStyle]=\"style\" alt=\"Image not found...\" (dragstart)=\"onDragStart($event)\"\n\t\t(load)=\"onLoad()\" (loadstart)=\"onLoadStart()\" />\n\t<!-- Div below will be used to hide the 'ghost' image when dragging -->\n\t<div></div>\n\t<div class=\"spinner-container\" *ngIf=\"loading\">\n\t\t<div class=\"spinner\"></div>\n\t</div>\n\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.rotateCounterClockwise\"\n\t\t(click)=\"rotateCounterClockwise()\">\n\t\t<span [class]=\"config.btnIcons.rotateCounterClockwise\"></span>\n\t</button>\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.rotateClockwise\" (click)=\"rotateClockwise()\">\n\t\t<span [class]=\"config.btnIcons.rotateClockwise\"></span>\n\t</button>\n\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.zoomOut\" (click)=\"zoomOut()\">\n\t\t<span [class]=\"config.btnIcons.zoomOut\"></span>\n\t</button>\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.zoomIn\" (click)=\"zoomIn()\">\n\t\t<span [class]=\"config.btnIcons.zoomIn\"></span>\n\t</button>\n\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngFor=\"let cBtn of config.customBtns\"\n\t\t(click)=\"fireCustomEvent(cBtn.name, index)\">\n\t\t<span [class]=\"cBtn.icon\"></span>\n\t</button>\n\n\t<button type=\"button\" id=\"ngx-fs-btn\" mat-mini-fab [class]=\"config.btnClass\" (click)=\"toggleFullscreen()\"\n\t\t*ngIf=\"config.allowFullscreen\">\n\t\t<span [class]=\"config.btnIcons.fullscreen\"></span>\n\t</button>\n\n\t<div class=\"nav-button-container\" *ngIf=\"src.length > 1\">\n\t\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" (click)=\"prevImage($event)\" [disabled]=\"index === 0\">\n\t\t\t<span [class]=\"config.btnIcons.prev\"></span>\n\t\t</button>\n\t\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" (click)=\"nextImage($event)\"\n\t\t\t[disabled]=\"index === src.length - 1\">\n\t\t\t<span [class]=\"config.btnIcons.next\"></span>\n\t\t</button>\n\t</div>\n</div>\n","styles":[".img-container{height:100%;width:100%;overflow:hidden;position:relative}.img-container img{z-index:2;margin:0 auto;display:block;max-width:100%;max-height:100%}.img-container button{z-index:99;position:absolute;right:15px}.img-container button:not(:disabled){cursor:pointer}.img-container>button:nth-of-type(1):not(#ngx-fs-btn){bottom:15px}.img-container>button:nth-of-type(2):not(#ngx-fs-btn){bottom:65px}.img-container>button:nth-of-type(3):not(#ngx-fs-btn){bottom:115px}.img-container>button:nth-of-type(4):not(#ngx-fs-btn){bottom:165px}.img-container>button:nth-of-type(5):not(#ngx-fs-btn){bottom:215px}.img-container>button:nth-of-type(6):not(#ngx-fs-btn){bottom:265px}.img-container>button:nth-of-type(7):not(#ngx-fs-btn){bottom:315px}#ngx-fs-btn{top:15px}button.default{height:40px;width:40px;border:1px solid #555;border-radius:50%;background-color:#fff;opacity:.7;transition:opacity .2s}button.default:hover{opacity:1}button.default:disabled{opacity:.25}.nav-button-container>button{position:relative;right:0;margin:0 10px}.nav-button-container{text-align:center;position:absolute;z-index:98;bottom:10px;left:0;right:0}.spinner-container{position:absolute;left:0;right:0;top:0;bottom:0;width:60px;height:60px;margin:auto;padding:10px;background-color:rgba(0,0,0,.4);border-radius:25%}.spinner{border-width:7px;border-style:solid;border-color:#ccc #ccc #222;border-radius:50%;height:100%;width:100%;box-sizing:border-box;-webkit-animation:2s linear infinite rotation;animation:2s linear infinite rotation}@keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}@-webkit-keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}.zoom-in:after{content:\"zoom_in\"}.zoom-out:after{content:\"zoom_out\"}.rotate-clockwise:after{content:\"rotate_right\"}.rotate-counterclock:after{content:\"rotate_left\"}.next:after{content:\"keyboard_arrow_right\"}.prev:after{content:\"keyboard_arrow_left\"}.fullscreen:after{content:\"fullscreen\"}"]}]}],"members":{"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":2}}]}],"index":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":2}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":2}}]}],"indexChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":49,"character":2}}]}],"configChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":52,"character":2}}]}],"customEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":55,"character":2}}]}],"fullscreenElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":58,"character":2},"arguments":["fullscreenElement"]}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":72,"character":14}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":72,"character":26},"arguments":["config"]}]],"parameters":[{"__symbolic":"reference","name":"ImageViewerConfig"}]}],"ngOnInit":[{"__symbolic":"method"}],"nextImage":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":80,"character":2},"arguments":["window:keyup.ArrowRight",["$event"]]}]}],"prevImage":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":90,"character":2},"arguments":["window:keyup.ArrowLeft",["$event"]]}]}],"zoomIn":[{"__symbolic":"method"}],"zoomOut":[{"__symbolic":"method"}],"scrollZoom":[{"__symbolic":"method"}],"rotateClockwise":[{"__symbolic":"method"}],"rotateCounterClockwise":[{"__symbolic":"method"}],"onLoad":[{"__symbolic":"method"}],"onLoadStart":[{"__symbolic":"method"}],"onDragOver":[{"__symbolic":"method"}],"onDragStart":[{"__symbolic":"method"}],"toggleFullscreen":[{"__symbolic":"method"}],"triggerIndexBinding":[{"__symbolic":"method"}],"triggerConfigBinding":[{"__symbolic":"method"}],"fireCustomEvent":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"onMouseOver":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":190,"character":2},"arguments":["mouseover"]}]}],"onMouseLeave":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":195,"character":2},"arguments":["mouseleave"]}]}],"canNavigate":[{"__symbolic":"method"}],"updateStyle":[{"__symbolic":"method"}],"mergeConfig":[{"__symbolic":"method"}]}},"ImageViewerConfig":{"__symbolic":"interface"},"CustomEvent":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[null,null]}]}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":9,"character":1},"arguments":[{"selector":"[ngxToggleFullscreen]"}]}],"members":{"isFullscreen":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":2},"arguments":["ngxToggleFullscreen"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":17,"character":25}]}],"ngOnChanges":[{"__symbolic":"method"}]}}},"origins":{"ImageViewerModule":"./src/app/image-viewer/image-viewer.module","ImageViewerComponent":"./src/app/image-viewer/image-viewer.component","ImageViewerConfig":"./src/app/image-viewer/image-viewer-config.model","CustomEvent":"./src/app/image-viewer/image-viewer-config.model","ɵa":"./src/app/image-viewer/fullscreen.directive"},"importAs":"lacuna-image-viewer"}
{"__symbolic":"module","version":4,"metadata":{"ImageViewerModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":8,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"angular-bigscreen","name":"BigScreenModule","line":10,"character":2},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":11,"character":2},{"__symbolic":"reference","module":"@angular/material","name":"MatButtonModule","line":12,"character":2},{"__symbolic":"reference","module":"@angular/material","name":"MatIconModule","line":13,"character":2}],"declarations":[{"__symbolic":"reference","name":"ImageViewerComponent"}],"exports":[{"__symbolic":"reference","name":"ImageViewerComponent"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"ImageViewerModule"},"providers":[{"provide":"config","useValue":{"__symbolic":"reference","name":"config"}}]}}}},"ImageViewerComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":32,"character":1},"arguments":[{"selector":"ngx-image-viewer","template":"<div #fullscreenElement class=\"img-container\" [style.backgroundColor]=\"config.containerBackgroundColor\"\n\t(wheel)=\"scrollZoom($event)\" (dragover)=\"onDragOver($event)\">\n\t<img [src]=\"src[index]\" [ngStyle]=\"style\" alt=\"Image not found...\" (dragstart)=\"onDragStart($event)\"\n\t\t(load)=\"onLoad()\" (loadstart)=\"onLoadStart()\" />\n\t<!-- Div below will be used to hide the 'ghost' image when dragging -->\n\t<div></div>\n\t<div class=\"spinner-container\" *ngIf=\"loading\">\n\t\t<div class=\"spinner\"></div>\n\t</div>\n\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.rotateCounterClockwise\"\n\t\t(click)=\"rotateCounterClockwise()\">\n\t\t<span [class]=\"config.btnIcons.rotateCounterClockwise\"></span>\n\t</button>\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.rotateClockwise\" (click)=\"rotateClockwise()\">\n\t\t<span [class]=\"config.btnIcons.rotateClockwise\"></span>\n\t</button>\n\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.zoomOut\" (click)=\"zoomOut()\">\n\t\t<span [class]=\"config.btnIcons.zoomOut\"></span>\n\t</button>\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngIf=\"config.btnShow.zoomIn\" (click)=\"zoomIn()\">\n\t\t<span [class]=\"config.btnIcons.zoomIn\"></span>\n\t</button>\n\n\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" *ngFor=\"let cBtn of config.customBtns\"\n\t\t(click)=\"fireCustomEvent(cBtn.name, index)\">\n\t\t<span [class]=\"cBtn.icon\"></span>\n\t</button>\n\n\t<button type=\"button\" id=\"ngx-fs-btn\" mat-mini-fab [class]=\"config.btnClass\" (click)=\"toggleFullscreen()\"\n\t\t*ngIf=\"config.allowFullscreen\">\n\t\t<span [class]=\"config.btnIcons.fullscreen\"></span>\n\t</button>\n\n\t<div class=\"nav-button-container\" *ngIf=\"src.length > 1\">\n\t\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" (click)=\"prevImage($event)\" [disabled]=\"index === 0\">\n\t\t\t<span [class]=\"config.btnIcons.prev\"></span>\n\t\t</button>\n\t\t<button type=\"button\" mat-mini-fab [class]=\"config.btnClass\" (click)=\"nextImage($event)\"\n\t\t\t[disabled]=\"index === src.length - 1\">\n\t\t\t<span [class]=\"config.btnIcons.next\"></span>\n\t\t</button>\n\t</div>\n</div>\n","styles":[".img-container{height:100%;width:100%;overflow:hidden;position:relative}.img-container img{z-index:2;margin:0 auto;display:block;max-width:100%;max-height:100%}.img-container button{z-index:99;position:absolute;right:15px}.img-container button:not(:disabled){cursor:pointer}.img-container>button:nth-of-type(1):not(#ngx-fs-btn){bottom:15px}.img-container>button:nth-of-type(2):not(#ngx-fs-btn){bottom:65px}.img-container>button:nth-of-type(3):not(#ngx-fs-btn){bottom:115px}.img-container>button:nth-of-type(4):not(#ngx-fs-btn){bottom:165px}.img-container>button:nth-of-type(5):not(#ngx-fs-btn){bottom:215px}.img-container>button:nth-of-type(6):not(#ngx-fs-btn){bottom:265px}.img-container>button:nth-of-type(7):not(#ngx-fs-btn){bottom:315px}#ngx-fs-btn{top:15px}button.default{height:40px;width:40px;border:1px solid #555;border-radius:50%;background-color:#fff;opacity:.7;transition:opacity .2s}button.default:hover{opacity:1}button.default:disabled{opacity:.25}.nav-button-container>button{position:relative;right:0;margin:0 10px}.nav-button-container{text-align:center;position:absolute;z-index:98;bottom:10px;left:0;right:0}.spinner-container{position:absolute;left:0;right:0;top:0;bottom:0;width:60px;height:60px;margin:auto;padding:10px;background-color:rgba(0,0,0,.4);border-radius:25%}.spinner{border-width:7px;border-style:solid;border-color:#ccc #ccc #222;border-radius:50%;height:100%;width:100%;box-sizing:border-box;-webkit-animation:2s linear infinite rotation;animation:2s linear infinite rotation}@keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}@-webkit-keyframes rotation{from{-webkit-transform:rotate(0)}to{-webkit-transform:rotate(359deg)}}.zoom-in:after{content:\"zoom_in\"}.zoom-out:after{content:\"zoom_out\"}.rotate-clockwise:after{content:\"rotate_right\"}.rotate-counterclock:after{content:\"rotate_left\"}.next:after{content:\"keyboard_arrow_right\"}.prev:after{content:\"keyboard_arrow_left\"}.fullscreen:after{content:\"fullscreen\"}"]}]}],"members":{"src":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":2}}]}],"index":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":2}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":2}}]}],"indexChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":48,"character":2}}]}],"configChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":51,"character":2}}]}],"customEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":54,"character":2}}]}],"fullscreenElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":57,"character":2},"arguments":["fullscreenElement"]}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":72,"character":3}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":72,"character":15},"arguments":["config"]}],null],"parameters":[{"__symbolic":"reference","name":"ImageViewerConfig"},{"__symbolic":"reference","module":"angular-bigscreen","name":"BigScreenService","line":73,"character":28}]}],"ngOnInit":[{"__symbolic":"method"}],"nextImage":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":82,"character":2},"arguments":["window:keyup.ArrowRight",["$event"]]}]}],"prevImage":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":92,"character":2},"arguments":["window:keyup.ArrowLeft",["$event"]]}]}],"zoomIn":[{"__symbolic":"method"}],"zoomOut":[{"__symbolic":"method"}],"scrollZoom":[{"__symbolic":"method"}],"rotateClockwise":[{"__symbolic":"method"}],"rotateCounterClockwise":[{"__symbolic":"method"}],"onLoad":[{"__symbolic":"method"}],"onLoadStart":[{"__symbolic":"method"}],"onDragOver":[{"__symbolic":"method"}],"onDragStart":[{"__symbolic":"method"}],"toggleFullscreen":[{"__symbolic":"method"}],"triggerIndexBinding":[{"__symbolic":"method"}],"triggerConfigBinding":[{"__symbolic":"method"}],"fireCustomEvent":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"onMouseOver":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":187,"character":2},"arguments":["mouseover"]}]}],"onMouseLeave":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":192,"character":2},"arguments":["mouseleave"]}]}],"canNavigate":[{"__symbolic":"method"}],"updateStyle":[{"__symbolic":"method"}],"mergeConfig":[{"__symbolic":"method"}]}},"ImageViewerConfig":{"__symbolic":"interface"},"CustomEvent":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[null,null]}]}}},"origins":{"ImageViewerModule":"./src/app/image-viewer/image-viewer.module","ImageViewerComponent":"./src/app/image-viewer/image-viewer.component","ImageViewerConfig":"./src/app/image-viewer/image-viewer-config.model","CustomEvent":"./src/app/image-viewer/image-viewer-config.model"},"importAs":"lacuna-image-viewer"}
{
"name": "lacuna-image-viewer",
"version": "1.0.13-beta.3",
"version": "1.0.13-beta.4",
"license": "MIT",

@@ -51,3 +51,3 @@ "private": false,

"dependencies": {
"screenfull": "^4.2.0",
"angular-bigscreen": "~3.2.0",
"tslib": "^1.9.0"

@@ -54,0 +54,0 @@ },

@@ -6,10 +6,10 @@ # LacunaImageViewer

What LacunaImageViewer has improved in NgxImageViewer:
* Updated Angular to 7.x (it was previously at version 5.x) and some other packages, such as ng-packagr;
* Started using Material as default for the buttons and icons, instead of Font-awesome;
* Made it possible to use SafeUrl and SafeResourceUrl as source;
* Updated `Angular` to 7.x (it was previously at version 5.x) and some other packages, such as `ng-packagr`;
* Started using `Material` as default for the buttons and icons, instead of `Font-awesome`;
* Made it possible to use `SafeUrl` and `SafeResourceUrl` as source;
* Made it possible to disable dragging (`allowDrag`);
* Made the wheel zoom work only when ctrl is pressed, to follow the way other viewers work, such as Adobe Reader (the config `wheelZoom` was renamed to `allowCtrlWheelZoom` as well);
* Fixed the runtime error caused by screenfull;
* Fixed some build errors that showed up after we updated ng-packagr (errors related to private properties that were being used in the template, and also to callbacks with the wrong signature);
* Fixed a bug that happened when a user was in fullscreen mode, and exited by pressing "ESC"; when doing so, the user would need to press the fullscreen button twice to activate it again.
* Since the package `screenfull` was causing some errors in runtime, we replaced it by the package `angular-bigscreen`, which is simpler to use, and, as `screenfull`, is a wrapper of the HTML5 fullscreen API;
* Fixed some build errors that showed up after we updated `ng-packagr` (errors related to private properties that were being used in the template, and also to callbacks with the wrong signature);
* Fixed a bug that happened when a user was in fullscreen mode, and exited by pressing "ESC"; when doing so, the user would need to press the fullscreen button twice to activate it again. We did it by deleting ToggleFullscreenDirective and simplifying the logic of the method toggleFullscreen, from ImageViewerComponent.

@@ -24,3 +24,3 @@ ## NgxImageViewer Features:

## DEMO
## NgxImageViewer DEMO

@@ -27,0 +27,0 @@ https://angular-2wrbwp.stackblitz.io/

import { OnInit, EventEmitter, ElementRef } from '@angular/core';
import { ImageViewerConfig, CustomEvent } from './image-viewer-config.model';
import { SafeResourceUrl, SafeUrl } from '@angular/platform-browser';
import { BigScreenService } from 'angular-bigscreen';
export declare class ImageViewerComponent implements OnInit {
moduleConfig: ImageViewerConfig;
private bigScreenService;
src: (string | SafeResourceUrl | SafeUrl)[];

@@ -28,3 +30,3 @@ index: number;

private hovered;
constructor(moduleConfig: ImageViewerConfig);
constructor(moduleConfig: ImageViewerConfig, bigScreenService: BigScreenService);
ngOnInit(): void;

@@ -31,0 +33,0 @@ nextImage(event: any): void;

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