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

ngx-doe-gallery

Package Overview
Dependencies
Maintainers
1
Versions
19
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-doe-gallery - npm Package Compare versions

Comparing version 1.0.0-alpha.1 to 1.0.0-beta.0

esm2015/lib/directives/media.directive.js

4

bundles/ngx-doe-gallery.umd.min.js

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("@angular/animations"),require("rxjs/operators"),require("@angular/common"),require("@angular/platform-browser/animations"),require("@angular/platform-browser")):"function"==typeof define&&define.amd?define("ngx-doe-gallery",["exports","@angular/core","rxjs","@angular/animations","rxjs/operators","@angular/common","@angular/platform-browser/animations","@angular/platform-browser"],t):t((e=e||self)["ngx-doe-gallery"]={},e.ng.core,e.rxjs,e.ng.animations,e.rxjs.operators,e.ng.common,e.ng.platformBrowser.animations,e.ng.platformBrowser)}(this,(function(e,t,r,n,o,i,s,a){"use strict";
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("@angular/animations"),require("rxjs/operators"),require("@angular/common"),require("@angular/platform-browser/animations"),require("@angular/platform-browser")):"function"==typeof define&&define.amd?define("ngx-doe-gallery",["exports","@angular/core","rxjs","@angular/animations","rxjs/operators","@angular/common","@angular/platform-browser/animations","@angular/platform-browser"],t):t((e=e||self)["ngx-doe-gallery"]={},e.ng.core,e.rxjs,e.ng.animations,e.rxjs.operators,e.ng.common,e.ng.platformBrowser.animations,e.ng.platformBrowser)}(this,(function(e,t,n,o,i,r,s,a){"use strict";
/*! *****************************************************************************

@@ -15,3 +15,3 @@ Copyright (c) Microsoft Corporation. All rights reserved.

and limitations under the License.
***************************************************************************** */var l=function(e,t){return(l=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])})(e,t)};function c(e,t){function r(){this.constructor=e}l(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}function u(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,i=r.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(n=i.next()).done;)s.push(n.value)}catch(e){o={error:e}}finally{try{n&&!n.done&&(r=i.return)&&r.call(i)}finally{if(o)throw o.error}}return s}var h={galleryLabel:"Image Gallery",viewerLabel:"Displayed gallery image",thumbnailsLabel:"Gallery thumbnails"},d="undefined"!=typeof window,m={scrollBehavior:d&&"scrollBehavior"in document.body.style,nativeMediaLoading:d&&"loading"in Image.prototype,intersectionObserver:d&&"IntersectionObserver"in window},p={ios:d&&!!window.navigator.userAgent.match(/iP(ad|hone|od)/)},f=function(e,t,r,n,o){this.src=e,this.thumbSrc=t,this.alt=r,this.description=n,this.data=o};var g=function(e){function t(t,r,n,o,i,s){var a=e.call(this,t,r,n,o,s)||this;return a.pictureSources=i,a}return c(t,e),t}(f);var b=function(e){function t(t,r,n,o,i){return e.call(this,t,r,n,o,i)||this}return c(t,e),t}(f);var v=function(){function e(e,n){var o=this;this.cd=e,this.elRef=n,this.items=[],this.thumbClick=new t.EventEmitter,this.thumbHover=new t.EventEmitter,this.showStartArrow=!1,this.showEndArrow=!1,this.destroy$=new r.Subject,this.smoothScrollAllowed=!1,this.onArrowsObserved=function(e){var t=e[0].target,r=t===o.thumbsRef.first.nativeElement?e[0]:e[1],n=t===o.thumbsRef.last.nativeElement?e[0]:e[1];r&&(o.showStartArrow=r.intersectionRatio<1),n&&(o.showEndArrow=n.intersectionRatio<1),o.cd.detectChanges()}}return Object.defineProperty(e.prototype,"scrollBehavior",{get:function(){return this.smoothScrollAllowed?this._scrollBehavior:"auto"},set:function(e){this._scrollBehavior=e||"smooth"},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"cssClass",{get:function(){return"doe-thumbs--"+this.orientation},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"scrollKey",{get:function(){return this.vertical?"scrollTop":"scrollLeft"},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hostOffsetAxis",{get:function(){return this.vertical?this.elRef.nativeElement.offsetHeight:this.elRef.nativeElement.offsetWidth},enumerable:!0,configurable:!0}),e.prototype.ngOnChanges=function(e){var t=this,r=e.arrows,n=e.items,o=e.orientation;if(o&&null!=o.currentValue){var i=o.currentValue;this.vertical="left"===i||"right"===i}if(r&&(r.currentValue&&this.items&&this.items.length?this.observeArrows():r.currentValue||(this.showStartArrow=!1,this.showEndArrow=!1,this.unobserveArrows())),n&&n.currentValue){var s=n.currentValue||[],a=n.previousValue||[];if(s.length===a.length)return;this.arrows&&s.length&&this.observeArrows(),a.length||setTimeout((function(){t.centerThumbIfNeeded(t.selectedIndex),t.smoothScrollAllowed=!0}))}},e.prototype.ngOnDestroy=function(){this.destroy$.next(null),this.destroy$.complete(),this.arrowObserver&&this.arrowObserver.disconnect()},e.prototype.slide=function(e){var t;if(this.arrowSlideByLength)t=this.arrowSlideByLength;else{var r=this.thumbListRef.nativeElement,n=this.vertical?r.scrollHeight:r.scrollWidth,o=this.vertical?r.offsetHeight:r.offsetWidth;t=Math.min(o,n-o)}this.scroll(t*e)},e.prototype.centerThumbIfNeeded=function(e){if(this.items&&!(this.items.length<=1)){var t=this.thumbsRef.toArray()[e].nativeElement,r=t.offsetLeft,n=t.offsetTop,o=t.offsetWidth,i=t.offsetHeight,s=this.vertical?n:r,a=this.vertical?i:o,l=this.hostOffsetAxis,c=this.thumbListRef.nativeElement[this.scrollKey],u=s+a/2-l/2-c;(c+l<s+a||c>s)&&this.scroll(u)}},e.prototype.select=function(e){var t=this;this.selectedIndex=e,this.cd.detectChanges(),this.autoScroll&&setTimeout((function(){return t.centerThumbIfNeeded(e)}))},e.prototype.onItemErrored=function(e){e._thumbFailed=!0},e.prototype.emitEvent=function(e,t,r,n){n.emit({index:e,item:t,event:r})},e.prototype.scroll=function(e){var t=this;if(d)if(m.scrollBehavior||"auto"===this.scrollBehavior)this.thumbListRef.nativeElement[this.scrollKey]+=e;else{null!=this.scrollId&&cancelAnimationFrame(this.scrollId);var r=Math.abs(e),n=Date.now(),o=200*(Math.log10(r)-1.1);o<0&&(o=200);var i=0,s=function(){var a=Math.ceil((Date.now()-n)/o*r),l=Math.min(a-i,r-i);l*=Math.sign(e),i=a,t.thumbListRef.nativeElement[t.scrollKey]+=l,i<=r&&(t.scrollId=requestAnimationFrame(s))};this.scrollId=requestAnimationFrame(s)}},e.prototype.observeArrows=function(){var e=this;this.arrowObserver?this.arrowObserver.disconnect():this.arrowObserver=new IntersectionObserver(this.onArrowsObserved,{root:this.thumbListRef.nativeElement,threshold:1}),setTimeout((function(){e.arrowObserver.observe(e.thumbsRef.first.nativeElement),e.arrowObserver.observe(e.thumbsRef.last.nativeElement)}))},e.prototype.unobserveArrows=function(){this.arrowObserver&&this.arrowObserver.disconnect()},e.decorators=[{type:t.Component,args:[{selector:"doe-thumbs",template:'<div\r\n *ngIf="showStartArrow"\r\n class="doe-thumbs-arrow doe-thumbs-arrow-prev"\r\n (click)="slide(-1)"\r\n>\r\n <div *ngIf="!arrowTemplate; else arrowTemplate">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n\r\n<ul\r\n #thumbs\r\n [style.scrollBehavior]="scrollBehavior"\r\n tabindex="0"\r\n [attr.aria-label]="aria?.thumbnailsLabel"\r\n>\r\n <li *ngIf="!items || !items.length" class="doe-thumbs-initial-item"></li>\r\n <li\r\n #thumb\r\n *ngFor="let item of items; let i = index"\r\n [class.doe-thumbs-item--selected]="i === selectedIndex"\r\n aria-hidden="true"\r\n (click)="emitEvent(i, item, $event, thumbClick)"\r\n (mouseenter)="emitEvent(i, item, $event, thumbHover)"\r\n >\r\n <ng-container *ngIf="!thumbTemplate; else customThumbTemplate">\r\n <img\r\n [src]="item.thumbSrc || item.src"\r\n [alt]="item.alt"\r\n (error)="onItemErrored(item)"\r\n />\r\n\r\n <ng-container *ngIf="item._thumbFailed">\r\n <div\r\n *ngIf="!errorTemplate; else errorTemplate"\r\n class="doe-thumbs-error"\r\n >\r\n <div class="doe-thumbs-error-icon">⚠</div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #customThumbTemplate>\r\n <ng-container\r\n *ngTemplateOutlet="\r\n thumbTemplate;\r\n context: { index: i, selectedIndex: selectedIndex, item: item }\r\n "\r\n ></ng-container>\r\n </ng-template>\r\n </li>\r\n</ul>\r\n\r\n<div\r\n *ngIf="showEndArrow"\r\n class="doe-thumbs-arrow doe-thumbs-arrow-next"\r\n (click)="slide(1)"\r\n>\r\n <div *ngIf="!arrowTemplate; else arrowTemplate">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:[':host{flex:1 0 auto;position:relative}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;border:1px solid #252525;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:"";display:block;position:absolute;left:0;bottom:0;width:100%;height:10px;background-color:#ffffffab;box-shadow:0 0 1px #000}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#222}.doe-thumbs-error-icon{font-size:20px;color:#f5f5f5}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}']}]}],e.ctorParameters=function(){return[{type:t.ChangeDetectorRef},{type:t.ElementRef}]},e.propDecorators={items:[{type:t.Input}],selectedIndex:[{type:t.Input}],aria:[{type:t.Input}],orientation:[{type:t.Input}],arrows:[{type:t.Input}],arrowSlideByLength:[{type:t.Input}],autoScroll:[{type:t.Input}],thumbTemplate:[{type:t.Input}],arrowTemplate:[{type:t.Input}],errorTemplate:[{type:t.Input}],scrollBehavior:[{type:t.Input}],thumbClick:[{type:t.Output}],thumbHover:[{type:t.Output}],thumbListRef:[{type:t.ViewChild,args:["thumbs",{static:!0}]}],thumbsRef:[{type:t.ViewChildren,args:["thumb"]}],cssClass:[{type:t.HostBinding,args:["class"]}]},e}();var y=function(){function e(e,n,o){var i=this;this.hostRef=e,this.cd=n,this.zone=o,this.imageClick=new t.EventEmitter,this.descriptionClick=new t.EventEmitter,this.selection=new t.EventEmitter,this.UA=p,this._destroy$=new r.Subject,this._listX=0,this.onResize=function(){setTimeout((function(){var e=i.items;i.noAnimation=!0,e&&e.length?(i.readDimensions(),i._fringeCount=i.getFringeCount(),i.displayedItems=i.loop?function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(u(arguments[t]));return e}(e.slice(-i._fringeCount),e,e.slice(0,i._fringeCount)):e,i.cd.detectChanges(),i.center()):i.shift(0),setTimeout((function(){return i.noAnimation=!1}))}))},this.shiftByDelta=function(e){i.shift(i._listX-e)}}return Object.defineProperty(e.prototype,"itemWidth",{set:function(e){this.itemListRef.nativeElement.style.setProperty("--item-width",e||"")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lazyLoading",{get:function(){return"lazy"===this.loading},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"noAnimation",{set:function(e){this.itemListRef.nativeElement.style.transitionDuration=e?"0ms":""},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"showArrow",{get:function(){return this.arrows&&this.items&&this.items.length>1},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"showPrevArrow",{get:function(){return this.showArrow&&(this.selectedIndex>0||this.loop)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"showNextArrow",{get:function(){return this.showArrow&&(this.selectedIndex<this.items.length-1||this.loop)},enumerable:!0,configurable:!0}),e.prototype.ngOnChanges=function(e){var t=this,r=e.thumbsOrientation,n=e.items;if(r&&!r.firstChange&&(r.currentValue&r.previousValue||setTimeout((function(){t.readDimensions(),t.center(),t.cd.detectChanges()}))),n&&n.currentValue&&n.currentValue.length){this.onResize();var o=n.currentValue[this.selectedIndex];o&&(o._seen=!0)}},e.prototype.ngOnInit=function(){var e=this,t={passive:!0};d&&r.fromEvent(window,"resize",t).pipe(o.takeUntil(this._destroy$)).subscribe(this.onResize),d&&this.mouseGestures&&this.zone.runOutsideAngular((function(){var r,n=e.itemListRef.nativeElement,o=0,i=0,s=function(n){r=n,e.noAnimation=!0,document.addEventListener("mousemove",a,t),document.addEventListener("mouseup",l,t)},a=function(t){o=Math.max(Math.abs(r.x-t.x)),i=Math.max(Math.abs(r.y-t.y)),e.shiftByDelta(t.movementX)},l=function(t){var n=r.x-t.x;e.noAnimation=!1,e.zone.run((function(){return e.selectBySwipeStats(n)})),document.removeEventListener("mousemove",a),document.removeEventListener("mouseup",l)},c=function(e){(o>10||i>10)&&e.stopPropagation(),i=o=0},u=function(e){return e.preventDefault()};n.addEventListener("mousedown",s,t),n.addEventListener("click",c,{capture:!0}),n.addEventListener("dragstart",u),e._destroy$.subscribe((function(){n.removeEventListener("mousedown",s),n.removeEventListener("click",c),n.removeEventListener("dragstart",u)}))})),d&&this.touchGestures&&this.zone.runOutsideAngular((function(){var r,n,o=e.itemListRef.nativeElement,i=null,s=function(t){r=t,e.noAnimation=!0},a=function(t){if(r&&1===t.touches.length){var o=r.touches[0],s=t.touches[0];if(null==i){var a=Math.abs(s.clientX-o.clientX),l=Math.abs(s.clientY-o.clientY);(a||l)&&(i=1.2*a>=l)}i&&(e.shiftByDelta(s.clientX-(n||r).touches[0].clientX),n=t,p.ios&&(t.preventDefault(),t.stopPropagation()))}},l=function(){if(e.noAnimation=!1,n){var t=r.touches[0].clientX-n.touches[0].clientX;e.zone.run((function(){return e.selectBySwipeStats(t)}))}i=null,r=null,n=null};o.addEventListener("touchstart",s,t),document.addEventListener("touchmove",a,{passive:!p.ios}),document.addEventListener("touchend",l,t),e._destroy$.subscribe((function(){o.removeEventListener("touchstart",s),document.removeEventListener("touchmove",a),document.removeEventListener("touchend",l)}))}))},e.prototype.ngOnDestroy=function(){this._destroy$.next(null),this._destroy$.complete()},e.prototype.getSrc=function(e,t){var r=this.isInScrollportProximity(t);return!this.lazyLoading||e._seen||r?e.src:""},e.prototype.isInScrollportProximity=function(e){this.loop&&(e-=this._fringeCount);var t=Math.floor(Math.ceil(this._viewerWidth/(this._itemWidth+1))/2)+1||1,r=Math.abs(this.selectedIndex-e);return this.loop&&Math.abs(r-this.items.length)<=t||r<=t},e.prototype.isYoutube=function(e){return!!e.src.match(/youtube.*\/embed\//)},e.prototype.isVideo=function(e){return e instanceof b},e.prototype.selectByDelta=function(e){this.select(this.selectedIndex+e)},e.prototype.select=function(e){var t=this,r=!this.items[e];if(this.selectedIndex===e||!this.loop&&r)this.center();else{if(this.loop&&r){var n=e;e=n-Math.sign(e)*this.items.length,this.noAnimation=!0,setTimeout((function(){var e=t._listX-Math.sign(n)*t.items.length*t._itemWidth;t.shift(e),setTimeout((function(){t.noAnimation=!1,t.center()}))}))}if(this.isVideo(this.items[e])){var o=this.itemsRef.toArray()[this.selectedIndex].nativeElement.querySelector("video");o&&o.pause()}this.items[e]._seen=!0,this.selectedIndex=e,this.selection.emit(e),r||this.center()}},e.prototype.onImageClick=function(e,t){this.imageClick.emit({event:t,item:e,index:this.items.indexOf(e)})},e.prototype.onTab=function(e){var t=this;e>=0&&e<this.items.length&&(this.select(e),requestAnimationFrame((function(){return t.hostRef.nativeElement.scrollLeft=0})))},e.prototype.onItemLoaded=function(e,t){t.target.getAttribute("src")&&(e._loaded=!0,this.cd.detectChanges())},e.prototype.onItemErrored=function(e,t){t.target.getAttribute("src")&&(e._failed=!0,this.cd.detectChanges())},e.prototype.center=function(){var e=(this._viewerWidth-this._itemWidth)/2;this.shift((this.selectedIndex+this._fringeCount)*this._itemWidth-e)},e.prototype.getFringeCount=function(){return this.loop?Math.min(Math.ceil(this._viewerWidth/(this._itemWidth+1)),this.items.length):0},e.prototype.readDimensions=function(){this._viewerWidth=this.hostRef.nativeElement.offsetWidth,this._itemWidth=this.hostRef.nativeElement.querySelector("li").offsetWidth},e.prototype.selectBySwipeStats=function(e){var t=Math.ceil((Math.abs(e)-25)/this._itemWidth);t?this.selectByDelta(t*Math.sign(e)):this.center()},e.prototype.shift=function(e){this.itemListRef.nativeElement.style.transform="translate3d("+-(this._listX=e)+"px, 0, 0)"},e.decorators=[{type:t.Component,args:[{selector:"doe-viewer",template:'<div\r\n *ngIf="showPrevArrow"\r\n class="doe-viewer-arrow doe-viewer-arrow-prev"\r\n (click)="selectByDelta(-1)"\r\n>\r\n <doe-chevron-icon\r\n *ngIf="!arrowTemplate; else arrowTemplate"\r\n ></doe-chevron-icon>\r\n</div>\r\n\r\n<ul #itemList [attr.aria-label]="aria?.viewerLabel">\r\n <li *ngIf="!displayedItems?.length" class="doe-viewer-initial-item"></li>\r\n <li\r\n #items\r\n *ngFor="let item of displayedItems; let i = index"\r\n [class.doe-viewer-item--selected]="i === selectedIndex"\r\n tabindex="0"\r\n [attr.aria-label]="item.alt"\r\n [attr.aria-describedby]="\'doe-viewer-aria-description-\' + i"\r\n (click)="onImageClick(item, $event)"\r\n (keydown.Tab)="onTab(i + 1)"\r\n (keydown.shift.Tab)="onTab(i - 1)"\r\n >\r\n <ng-container *ngIf="!itemTemplate; else customTemplate">\r\n <ng-container *ngIf="isInScrollportProximity(i)">\r\n <ng-container *ngIf="getSrc(item, i); let src">\r\n <picture *ngIf="!isVideo(item)" @remove>\r\n <source\r\n *ngFor="let source of item.pictureSources"\r\n [srcset]="source.srcset"\r\n [attr.media]="source.media"\r\n [attr.sizes]="source.sizes"\r\n [attr.type]="source.type"\r\n />\r\n <img\r\n [src]="src"\r\n [alt]="item.alt"\r\n [class.doe-viewer-media-loading]="item._seen && !item._loaded"\r\n [style.objectFit]="objectFit"\r\n (load)="onItemLoaded(item, $event)"\r\n (error)="onItemErrored(item, $event)"\r\n />\r\n </picture>\r\n \x3c!-- Using loadedmetadata instead of loadeddata because iOS loads data lazily upon user\'s interaction --\x3e\r\n <video\r\n @remove\r\n *ngIf="!isYoutube(item) && isVideo(item)"\r\n [src]="src"\r\n [poster]="item.thumbSrc"\r\n [class.doe-viewer-media-loading]="item._seen && !item._loaded"\r\n [style.objectFit]="objectFit"\r\n controls\r\n playsinline\r\n (loadedmetadata)="onItemLoaded(item, $event)"\r\n (error)="onItemErrored(item, $event)"\r\n ></video>\r\n\r\n <iframe\r\n @remove\r\n *ngIf="isYoutube(item)"\r\n [src]="src | safe"\r\n frameborder="0"\r\n allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture"\r\n allowfullscreen\r\n (load)="onItemLoaded(item, $event)"\r\n ></iframe>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf="item._seen && !item._loaded && !item._failed">\r\n <ng-container *ngTemplateOutlet="loadingTemplate"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf="item._failed">\r\n <div\r\n *ngIf="!errorTemplate; else errorTemplate"\r\n class="doe-viewer-error"\r\n >\r\n <div class="doe-viewer-error-icon">⚠</div>\r\n <p class="doe-viewer-error-text">\r\n {{ errorText || \'Loading of this media failed\' }}\r\n </p>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <span\r\n [id]="\'doe-viewer-aria-description-\' + i"\r\n class="doe-viewer-aria-description"\r\n [innerHTML]="item.description"\r\n aria-hidden="true"\r\n ></span>\r\n\r\n <ng-template #customTemplate>\r\n <ng-container\r\n *ngTemplateOutlet="\r\n itemTemplate;\r\n context: {\r\n index: items.indexOf(item),\r\n selectedIndex: selectedIndex,\r\n item: item,\r\n seen: item._seen\r\n }\r\n "\r\n ></ng-container>\r\n </ng-template>\r\n </li>\r\n</ul>\r\n\r\n<ng-container *ngIf="items?.length <= 0">\r\n <ng-container *ngTemplateOutlet="loadingTemplate"></ng-container>\r\n</ng-container>\r\n\r\n<div\r\n *ngIf="showNextArrow"\r\n class="doe-viewer-arrow doe-viewer-arrow-next"\r\n (click)="selectByDelta(1)"\r\n>\r\n <doe-chevron-icon\r\n *ngIf="!arrowTemplate; else arrowTemplate"\r\n ></doe-chevron-icon>\r\n</div>\r\n\r\n<doe-counter\r\n *ngIf="imageCounter && items?.length"\r\n [itemQuantity]="items?.length"\r\n [selectedIndex]="selectedIndex"\r\n [orientation]="imageCounterOrientation"\r\n></doe-counter>\r\n\r\n<div\r\n *ngIf="descriptions && items"\r\n class="doe-viewer-description"\r\n [class.doe-viewer-description--above-counter]="\r\n imageCounter && imageCounterOrientation === \'bottom\'\r\n "\r\n aria-hidden="true"\r\n>\r\n <div\r\n *ngIf="items[selectedIndex]?.description as description"\r\n class="doe-viewer-description-inner"\r\n [innerHTML]="description"\r\n (click)="descriptionClick.emit($event)"\r\n ></div>\r\n</div>\r\n',changeDetection:t.ChangeDetectionStrategy.OnPush,animations:[n.trigger("remove",[n.transition(":leave",n.animate("0ms 100ms"))])],styles:[':host{display:block;position:relative;width:100%;height:100%;overflow:hidden;outline:0;background-color:#232323;z-index:1}ul{--item-width:calc(100% - 0.01px);display:flex;width:100%;height:100%;transition:transform .4s;scrollbar-width:none;-ms-overflow-style:none}ul::-webkit-scrollbar{width:0;height:0}li{display:flex;align-items:center;flex:none;position:relative;width:var(--item-width);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}picture{width:100%;height:100%}iframe,img,video{width:100%;height:100%;background-color:transparent;transition:opacity .3s ease-out;outline:0}iframe[src=""],img[src=""],video[src=""]{opacity:0}iframe.doe-viewer-media-loading,img.doe-viewer-media-loading,video.doe-viewer-media-loading{opacity:.5}img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.doe-viewer-description{position:absolute;bottom:5px;width:100%;display:flex;justify-content:center}.doe-viewer-description--above-counter{bottom:35px}.doe-viewer-description-inner{display:inline-block;background:#000;opacity:.8;color:#fff;padding:6px 15px;max-width:80%;font-size:.95em;text-align:center}.doe-viewer-aria-description{opacity:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:absolute;bottom:0;left:50%;transform:translateX(-50%)}.doe-viewer-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background-color:#f5f5f5;color:#424242}.doe-viewer-error-icon{font-size:40px}.doe-viewer-error-text{margin-top:20px;letter-spacing:.01em}.doe-viewer-arrow{display:flex;position:absolute;top:50%;transform:translateY(-50%);z-index:100;cursor:pointer}.doe-viewer-arrow-prev{left:0;transform:rotate(180deg) translateY(50%)}.doe-viewer-arrow-next{right:0}.doe-viewer-arrow doe-chevron-icon{margin:15px 6px;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-viewer-arrow doe-chevron-icon:hover{opacity:1}}.doe-viewer-arrow doe-chevron-icon::ng-deep svg{height:32px;width:32px}']}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.ChangeDetectorRef},{type:t.NgZone}]},e.propDecorators={items:[{type:t.Input}],arrows:[{type:t.Input}],selectedIndex:[{type:t.Input}],descriptions:[{type:t.Input}],errorText:[{type:t.Input}],mouseGestures:[{type:t.Input}],touchGestures:[{type:t.Input}],imageCounter:[{type:t.Input}],imageCounterOrientation:[{type:t.Input}],loading:[{type:t.Input}],loop:[{type:t.Input}],objectFit:[{type:t.Input}],itemTemplate:[{type:t.Input}],loadingTemplate:[{type:t.Input}],errorTemplate:[{type:t.Input}],arrowTemplate:[{type:t.Input}],thumbsOrientation:[{type:t.Input}],aria:[{type:t.Input}],itemWidth:[{type:t.Input}],imageClick:[{type:t.Output}],descriptionClick:[{type:t.Output}],selection:[{type:t.Output}],itemListRef:[{type:t.ViewChild,args:["itemList",{static:!0}]}],itemsRef:[{type:t.ViewChildren,args:["items"]}]},e}();var w=function(){function e(){this.selectedIndex=0,this.aria=h,this.arrows=!0,this.descriptions=!1,this.mouseGestures=!0,this.touchGestures=!0,this.imageCounter=!0,this.imageCounterOrientation="bottom",this.loading="auto",this.loop=!1,this.objectFit="cover",this.thumbs=!0,this.thumbsAutoScroll=!0,this.thumbsOrientation="bottom",this.thumbsArrows=!0,this.thumbsScrollBehavior="smooth",this.imageClick=new t.EventEmitter,this.thumbClick=new t.EventEmitter,this.thumbHover=new t.EventEmitter,this.descriptionClick=new t.EventEmitter,this.selection=new t.EventEmitter,this._tabindex=0}return Object.defineProperty(e.prototype,"ariaLabel",{get:function(){return this.aria&&this.aria.galleryLabel},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_galleryColumn",{get:function(){return"top"===this.thumbsOrientation||"bottom"===this.thumbsOrientation},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_thumbsOrientationFlag",{get:function(){return"top"===this.thumbsOrientation||"bottom"===this.thumbsOrientation?6:24},enumerable:!0,configurable:!0}),e.prototype.focus=function(){this.viewerElRef.nativeElement.focus()},e.prototype.next=function(){this.viewerRef.selectByDelta(1)},e.prototype.prev=function(){this.viewerRef.selectByDelta(-1)},e.prototype.select=function(e){this.viewerRef.select(e),this.thumbsRef.select(e),this._selectInternal(e)},e.prototype.slideThumbs=function(e){this.thumbsRef.slide(e)},e.prototype._onThumbClick=function(e){this.viewerRef.select(e.index),this.thumbClick.emit(e),this._selectInternal(e.index)},e.prototype._selectInternal=function(e){this.selectedIndex=e,this.selection.emit(this.items[e])},e.decorators=[{type:t.Component,args:[{selector:"doe-gallery",template:'<doe-thumbs\r\n *ngIf="thumbs"\r\n [items]="items"\r\n [selectedIndex]="selectedIndex"\r\n [orientation]="thumbsOrientation"\r\n [arrows]="thumbsArrows"\r\n [arrowSlideByLength]="thumbsArrowSlideByLength"\r\n [autoScroll]="thumbsAutoScroll"\r\n [scrollBehavior]="thumbsScrollBehavior"\r\n [thumbTemplate]="thumbTemplate"\r\n [arrowTemplate]="thumbsArrowTemplate"\r\n [errorTemplate]="thumbErrorTemplate"\r\n [aria]="aria"\r\n (thumbClick)="_onThumbClick($event)"\r\n (thumbHover)="thumbHover.emit($event)"\r\n></doe-thumbs>\r\n\r\n<doe-viewer\r\n tabindex="0"\r\n [items]="items"\r\n [selectedIndex]="selectedIndex"\r\n [arrows]="arrows"\r\n [descriptions]="descriptions"\r\n [errorText]="errorText"\r\n [mouseGestures]="mouseGestures"\r\n [touchGestures]="touchGestures"\r\n [imageCounter]="imageCounter"\r\n [imageCounterOrientation]="imageCounterOrientation"\r\n [itemWidth]="itemWidth"\r\n [objectFit]="objectFit"\r\n [loading]="loading"\r\n [itemTemplate]="itemTemplate"\r\n [loadingTemplate]="loadingTemplate || defaultLoadingTemplate"\r\n [errorTemplate]="errorTemplate"\r\n [loop]="loop"\r\n [thumbsOrientation]="_thumbsOrientationFlag"\r\n [arrowTemplate]="arrowTemplate"\r\n [aria]="aria"\r\n (imageClick)="imageClick.emit($event)"\r\n (descriptionClick)="descriptionClick.emit($event)"\r\n (selection)="_selectInternal($event); thumbsRef?.select($event)"\r\n></doe-viewer>\r\n\r\n<ng-template #defaultLoadingTemplate>\r\n <div class="doe-loading">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n</ng-template>\r\n',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:[":host{display:flex;height:600px;width:500px;outline:0;position:relative;background-color:#252525;border-radius:5px}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]}]}],e.propDecorators={items:[{type:t.Input}],selectedIndex:[{type:t.Input}],aria:[{type:t.Input}],arrows:[{type:t.Input}],descriptions:[{type:t.Input}],errorText:[{type:t.Input}],mouseGestures:[{type:t.Input}],touchGestures:[{type:t.Input}],imageCounter:[{type:t.Input}],imageCounterOrientation:[{type:t.Input}],itemWidth:[{type:t.Input}],loading:[{type:t.Input}],loop:[{type:t.Input}],objectFit:[{type:t.Input}],itemTemplate:[{type:t.Input}],loadingTemplate:[{type:t.Input}],errorTemplate:[{type:t.Input}],arrowTemplate:[{type:t.Input}],thumbs:[{type:t.Input}],thumbsAutoScroll:[{type:t.Input}],thumbsOrientation:[{type:t.Input}],thumbsArrows:[{type:t.Input}],thumbsArrowSlideByLength:[{type:t.Input}],thumbsScrollBehavior:[{type:t.Input}],thumbTemplate:[{type:t.Input}],thumbsArrowTemplate:[{type:t.Input}],thumbErrorTemplate:[{type:t.Input}],imageClick:[{type:t.Output}],thumbClick:[{type:t.Output}],thumbHover:[{type:t.Output}],descriptionClick:[{type:t.Output}],selection:[{type:t.Output}],viewerRef:[{type:t.ViewChild,args:[y,{static:!1}]}],thumbsRef:[{type:t.ViewChild,args:[v,{static:!1}]}],viewerElRef:[{type:t.ViewChild,args:[y,{static:!1,read:t.ElementRef}]}],_tabindex:[{type:t.HostBinding,args:["tabindex"]}],ariaLabel:[{type:t.HostBinding,args:["attr.aria-label"]}],_galleryColumn:[{type:t.HostBinding,args:["class.doe-gallery--column"]}],next:[{type:t.HostListener,args:["keydown.arrowright"]}],prev:[{type:t.HostListener,args:["keydown.arrowleft"]}]},e}();var x=function(){function e(){}return e.decorators=[{type:t.Component,args:[{selector:"doe-counter",template:'\n <span aria-hidden="true">\n {{ selectedIndex + 1 }}<span class="doe-counter-delimiter">/</span\n >{{ itemQuantity || 0 }}\n </span>\n ',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:[":host{position:absolute;left:50%;transform:translateX(-50%);background:#000;padding:4px 7px 3px;color:#fff;opacity:.7;font-size:14px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host.top{top:0}:host.bottom{bottom:0}.doe-counter-delimiter{padding:0 2px}"]}]}],e.propDecorators={itemQuantity:[{type:t.Input}],selectedIndex:[{type:t.Input}],orientation:[{type:t.HostBinding,args:["class"]},{type:t.Input}]},e}();var I=function(){function e(){}return e.decorators=[{type:t.Component,args:[{selector:"doe-chevron-icon",template:'\x3c!-- Icon made by Dave Gandy from www.flaticon.com --\x3e\r\n<svg\r\n version="1.1"\r\n xmlns="http://www.w3.org/2000/svg"\r\n xmlns:xlink="http://www.w3.org/1999/xlink"\r\n x="0px"\r\n y="0px"\r\n viewBox="0 0 407.436 407.436"\r\n xml:space="preserve"\r\n>\r\n <polygon\r\n points="112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 "\r\n />\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n</svg>\r\n',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:["svg{width:26px;height:26px;fill:#fff;-webkit-filter:drop-shadow(0 0 1px #000);filter:drop-shadow(0 0 1px #000);display:block}"]}]}],e}(),T=function(){function e(e){this.sanitizer=e}return e.prototype.transform=function(e){return this.sanitizer.bypassSecurityTrustResourceUrl(e)},e.decorators=[{type:t.Pipe,args:[{name:"safe"}]}],e.ctorParameters=function(){return[{type:a.DomSanitizer}]},e}();var O=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[w,v,y,I,x,T],imports:[i.CommonModule,s.BrowserAnimationsModule],exports:[w]}]}],e}();e.GalleryComponent=w,e.GalleryImage=g,e.GalleryItem=f,e.GalleryModule=O,e.GalleryVideo=b,e.SUPPORT=m,e.UA=p,e.isBrowser=d,e.orientations={left:2,right:4,top:8,bottom:16},e.ɵa=y,e.ɵb=v,e.ɵc=I,e.ɵd=x,e.ɵe=T,Object.defineProperty(e,"__esModule",{value:!0})}));
***************************************************************************** */var l=function(e,t){return(l=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])})(e,t)};function c(e,t){function n(){this.constructor=e}l(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}function d(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var o,i,r=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(o=r.next()).done;)s.push(o.value)}catch(e){i={error:e}}finally{try{o&&!o.done&&(n=r.return)&&n.call(r)}finally{if(i)throw i.error}}return s}var h={galleryLabel:"Image Gallery",viewerLabel:"Displayed gallery image",thumbnailsLabel:"Gallery thumbnails"},u="undefined"!=typeof window,m={scrollBehavior:u&&"scrollBehavior"in document.body.style,nativeMediaLoading:u&&"loading"in Image.prototype,intersectionObserver:u&&"IntersectionObserver"in window},p={ios:u&&!!window.navigator.userAgent.match(/iP(ad|hone|od)/)},f=function(e,t,n,o,i){this.src=e,this.thumbSrc=t,this.alt=n,this.description=o,this.data=i};var b=function(e){function t(t,n,o,i,r,s){var a=e.call(this,t,n,o,i,s)||this;return a.pictureSources=r,a}return c(t,e),t}(f);var g=function(e){function t(t,n,o,i,r){return e.call(this,t,n,o,i,r)||this}return c(t,e),t}(f);var v=function(e){return e instanceof g};var y=function(){function e(e,o){var i=this;this._cd=e,this._elRef=o,this.items=[],this.thumbClick=new t.EventEmitter,this.thumbHover=new t.EventEmitter,this.isVideo=v,this._showStartArrow=!1,this._showEndArrow=!1,this._destroy$=new n.Subject,this._smoothScrollAllowed=!1,this.onArrowsObserved=function(e){var t=e[0].target,n=t===i.thumbsRef.first.nativeElement?e[0]:e[1],o=t===i.thumbsRef.last.nativeElement?e[0]:e[1];n&&(i._showStartArrow=n.intersectionRatio<1),o&&(i._showEndArrow=o.intersectionRatio<1),i._cd.detectChanges()}}return Object.defineProperty(e.prototype,"scrollBehavior",{get:function(){return this._smoothScrollAllowed?this._scrollBehavior:"auto"},set:function(e){this._scrollBehavior=e||"smooth"},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"cssClass",{get:function(){return"doe-thumbs--"+this.orientation},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_hostOffsetAxis",{get:function(){return this._vertical?this._elRef.nativeElement.offsetHeight:this._elRef.nativeElement.offsetWidth},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_scrollKey",{get:function(){return this._vertical?"scrollTop":"scrollLeft"},enumerable:!0,configurable:!0}),e.prototype.ngOnChanges=function(e){var t=this,n=e.arrows,o=e.items,i=e.orientation;if(i&&null!=i.currentValue){var r=i.currentValue;this._vertical="left"===r||"right"===r}if(n&&(n.currentValue&&this.items&&this.items.length?this.observeArrows():n.currentValue||(this._showStartArrow=!1,this._showEndArrow=!1,this.unobserveArrows())),o&&o.currentValue){var s=o.currentValue||[],a=o.previousValue||[];if(s.length===a.length)return;this.arrows&&s.length&&this.observeArrows(),a.length||setTimeout((function(){t.centerThumbIfNeeded(t.selectedIndex),t._smoothScrollAllowed=!0}))}},e.prototype.ngOnDestroy=function(){this._destroy$.next(null),this._destroy$.complete(),this._arrowObserver&&this._arrowObserver.disconnect()},e.prototype.slide=function(e){var t;if(this.arrowSlideByLength)t=this.arrowSlideByLength;else{var n=this.thumbListRef.nativeElement,o=this._vertical?n.scrollHeight:n.scrollWidth,i=this._vertical?n.offsetHeight:n.offsetWidth;t=Math.min(i,o-i)}this.scroll(t*e)},e.prototype.centerThumbIfNeeded=function(e){if(this.items&&!(this.items.length<=1)){var t=this.thumbsRef.toArray()[e].nativeElement;if(t){var n=t.offsetLeft,o=t.offsetTop,i=t.offsetWidth,r=t.offsetHeight,s=this._vertical?o:n,a=this._vertical?r:i,l=this._hostOffsetAxis,c=this.thumbListRef.nativeElement[this._scrollKey],d=s+a/2-l/2-c;(c+l<s+a||c>s)&&this.scroll(d)}}},e.prototype.select=function(e){var t=this;this.selectedIndex=e,this._cd.detectChanges(),this.autoScroll&&setTimeout((function(){return t.centerThumbIfNeeded(e)}))},e.prototype._emitEvent=function(e,t,n,o){o.emit({index:e,item:t,event:n})},e.prototype._onLoadChange=function(e,t){e._thumbFailed=!t},e.prototype.scroll=function(e){var t=this;if(u)if(m.scrollBehavior||"auto"===this.scrollBehavior)this.thumbListRef.nativeElement[this._scrollKey]+=e;else{null!=this._scrollId&&cancelAnimationFrame(this._scrollId);var n=Math.abs(e),o=Date.now(),i=200*(Math.log10(n)-1.1);i<0&&(i=200);var r=0,s=function(){var a=Math.ceil((Date.now()-o)/i*n),l=Math.min(a-r,n-r);l*=Math.sign(e),r=a,t.thumbListRef.nativeElement[t._scrollKey]+=l,r<=n&&(t._scrollId=requestAnimationFrame(s))};this._scrollId=requestAnimationFrame(s)}},e.prototype.observeArrows=function(){var e=this;this._arrowObserver?this._arrowObserver.disconnect():this._arrowObserver=new IntersectionObserver(this.onArrowsObserved,{root:this.thumbListRef.nativeElement,threshold:1}),setTimeout((function(){e._arrowObserver.observe(e.thumbsRef.first.nativeElement),e._arrowObserver.observe(e.thumbsRef.last.nativeElement)}))},e.prototype.unobserveArrows=function(){this._arrowObserver&&this._arrowObserver.disconnect()},e.decorators=[{type:t.Component,args:[{selector:"doe-thumbs",template:'<div\n *ngIf="_showStartArrow"\n class="doe-thumbs-arrow doe-thumbs-arrow-prev"\n (click)="slide(-1)"\n>\n <div *ngIf="!arrowTemplate; else arrowTemplate">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n\n<ul\n #thumbs\n [style.scrollBehavior]="scrollBehavior"\n tabindex="0"\n [attr.aria-label]="aria?.thumbnailsLabel"\n>\n <li *ngIf="!items || !items.length" class="doe-thumbs-initial-item"></li>\n <li\n #thumb\n *ngFor="let item of items; let i = index"\n [class.doe-thumbs-item--selected]="i === selectedIndex"\n aria-hidden="true"\n (click)="_emitEvent(i, item, $event, thumbClick)"\n (mouseenter)="_emitEvent(i, item, $event, thumbHover)"\n >\n <ng-container *ngIf="!thumbTemplate; else customThumbTemplate">\n <img\n [src]="item.thumbSrc || \'\'"\n [alt]="item.alt"\n (load)="_onLoadChange(item, true)"\n (error)="_onLoadChange(item, false)"\n />\n\n <ng-container *ngIf="item._thumbFailed">\n <div\n *ngIf="!errorTemplate; else errorTemplate"\n class="doe-thumbs-error"\n >\n <div\n class="doe-thumbs-error-icon"\n [class.doe-thumbs-error-icon--video]="isVideo(item)"\n ></div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-template #customThumbTemplate>\n <ng-container\n *ngTemplateOutlet="\n thumbTemplate;\n context: { index: i, selectedIndex: selectedIndex, item: item }\n "\n ></ng-container>\n </ng-template>\n </li>\n</ul>\n\n<div\n *ngIf="_showEndArrow"\n class="doe-thumbs-arrow doe-thumbs-arrow-next"\n (click)="slide(1)"\n>\n <div *ngIf="!arrowTemplate; else arrowTemplate">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:[':host{flex:1 0 auto;position:relative;background-color:#f3f3f3}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--bottom .doe-thumbs-error,:host.doe-thumbs--top .doe-thumbs-error{border-right:1px solid #cecece}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--left .doe-thumbs-error,:host.doe-thumbs--right .doe-thumbs-error{border-bottom:1px solid #cecece}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:"";display:block;position:absolute;left:0;bottom:0;width:100%;height:100%;border:10px solid #ffffffcf;box-sizing:border-box}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#e8e8e8;box-sizing:border-box}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video){position:relative;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid #a5a5a5;margin-left:-8px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after,.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{content:"";position:absolute}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{height:10px;width:10px;background-color:#a5a5a5;border-radius:100%;left:14px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after{border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:17px solid #a5a5a5;top:11px}.doe-thumbs-error-icon--video{border-top:16px solid transparent;border-bottom:16px solid transparent;border-left:28px solid #a5a5a5;margin-left:9px}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}']}]}],e.ctorParameters=function(){return[{type:t.ChangeDetectorRef},{type:t.ElementRef}]},e.propDecorators={items:[{type:t.Input}],selectedIndex:[{type:t.Input}],aria:[{type:t.Input}],orientation:[{type:t.Input}],arrows:[{type:t.Input}],arrowSlideByLength:[{type:t.Input}],autoScroll:[{type:t.Input}],thumbTemplate:[{type:t.Input}],arrowTemplate:[{type:t.Input}],errorTemplate:[{type:t.Input}],scrollBehavior:[{type:t.Input}],thumbClick:[{type:t.Output}],thumbHover:[{type:t.Output}],thumbListRef:[{type:t.ViewChild,args:["thumbs",{static:!0}]}],thumbsRef:[{type:t.ViewChildren,args:["thumb"]}],cssClass:[{type:t.HostBinding,args:["class"]}]},e}();var w=function(){function e(e,o,i){var r=this;this._hostRef=e,this._cd=o,this._zone=i,this.imageClick=new t.EventEmitter,this.descriptionClick=new t.EventEmitter,this.selection=new t.EventEmitter,this.isVideo=v,this.UA=p,this._destroy$=new n.Subject,this._listX=0,this.onResize=function(){setTimeout((function(){var e=r.items;r._noAnimation=!0,e&&e.length?(r.readDimensions(),r._fringeCount=r.getFringeCount(),r._displayedItems=r.loop?function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(d(arguments[t]));return e}(e.slice(-r._fringeCount),e,e.slice(0,r._fringeCount)):e,r._cd.detectChanges(),r.center()):r.shift(0),setTimeout((function(){return r._noAnimation=!1}))}))},this.shiftByDelta=function(e){r.shift(r._listX-e)}}return Object.defineProperty(e.prototype,"loop",{get:function(){return this.items&&this.items.length>1&&this._loop},set:function(e){this._loop=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"itemWidth",{set:function(e){this.itemListRef.nativeElement.style.setProperty("--item-width",e||"")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_noAnimation",{set:function(e){this.itemListRef.nativeElement.style.transitionDuration=e?"0ms":""},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lazyLoading",{get:function(){return"lazy"===this.loading},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"showArrow",{get:function(){return this.arrows&&this.items&&this.items.length>1},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"showPrevArrow",{get:function(){return this.showArrow&&(this.selectedIndex>0||this.loop)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"showNextArrow",{get:function(){return this.showArrow&&(this.selectedIndex<this.items.length-1||this.loop)},enumerable:!0,configurable:!0}),e.prototype.ngOnChanges=function(e){var t=this,n=e.thumbsOrientation,o=e.items;n&&!n.firstChange&&(n.currentValue&n.previousValue||setTimeout((function(){t.readDimensions(),t.center(),t._cd.detectChanges()}))),o&&o.currentValue&&o.currentValue.length&&this.onResize()},e.prototype.ngOnInit=function(){var e=this,t={passive:!0};u&&n.fromEvent(window,"resize",t).pipe(i.takeUntil(this._destroy$)).subscribe(this.onResize),u&&this.mouseGestures&&this._zone.runOutsideAngular((function(){var n,o=e.itemListRef.nativeElement,i=0,r=0,s=function(o){n=o,e._noAnimation=!0,document.addEventListener("mousemove",a,t),document.addEventListener("mouseup",l,t)},a=function(t){i=Math.max(Math.abs(n.x-t.x)),r=Math.max(Math.abs(n.y-t.y)),e.shiftByDelta(t.movementX)},l=function(t){var o=n.x-t.x;e._noAnimation=!1,e._zone.run((function(){return e.selectBySwipeStats(o)})),document.removeEventListener("mousemove",a),document.removeEventListener("mouseup",l)},c=function(e){(i>10||r>10)&&(e.stopPropagation(),e.preventDefault()),r=i=0},d=function(e){return e.preventDefault()};o.addEventListener("mousedown",s,t),o.addEventListener("click",c,{capture:!0}),o.addEventListener("dragstart",d),e._destroy$.subscribe((function(){o.removeEventListener("mousedown",s),o.removeEventListener("click",c),o.removeEventListener("dragstart",d)}))})),u&&this.touchGestures&&this._zone.runOutsideAngular((function(){var n,o,i=e.itemListRef.nativeElement,r=null,s=function(t){n=t,e._noAnimation=!0},a=function(t){if(n&&1===t.touches.length){var i=n.touches[0],s=t.touches[0];if(null==r){var a=Math.abs(s.clientX-i.clientX),l=Math.abs(s.clientY-i.clientY);(a||l)&&(r=1.2*a>=l)}r&&(e.shiftByDelta(s.clientX-(o||n).touches[0].clientX),o=t,p.ios&&(t.preventDefault(),t.stopPropagation()))}},l=function(){if(e._noAnimation=!1,o){var t=n.touches[0].clientX-o.touches[0].clientX;e._zone.run((function(){return e.selectBySwipeStats(t)}))}r=null,n=null,o=null};i.addEventListener("touchstart",s,t),document.addEventListener("touchmove",a,{passive:!p.ios}),document.addEventListener("touchend",l,t),e._destroy$.subscribe((function(){i.removeEventListener("touchstart",s),document.removeEventListener("touchmove",a),document.removeEventListener("touchend",l)}))}))},e.prototype.ngOnDestroy=function(){this._destroy$.next(null),this._destroy$.complete()},e.prototype.isInScrollportProximity=function(e){this.loop&&(e-=this._fringeCount);var t=this.touched?Math.ceil(this._viewerWidth/(this._itemWidth+1))||1:Math.floor(Math.ceil(this._viewerWidth/this._itemWidth)/2),n=Math.abs(this.selectedIndex-e);return this.loop&&Math.abs(n-this.items.length)<=t||n<=t},e.prototype.isYoutube=function(e){return!!e.src.match(/youtube.*\/embed\//)},e.prototype.selectByDelta=function(e){this.select(this.selectedIndex+e)},e.prototype.select=function(e){var t=this,n=!this.items[e],o=this.loop&&n;if(this.selectedIndex===e)return this.center();if(!o&&n&&(e=e<0?0:this.items.length-1),o){var i=e;e=i-Math.sign(e)*this.items.length,this._noAnimation=!0,setTimeout((function(){var e=t._listX-Math.sign(i)*t.items.length*t._itemWidth;t.shift(e),setTimeout((function(){t._noAnimation=!1,t.center()}))}))}if(this.isVideo(this.items[e])){var r=this.itemsRef.toArray()[this.selectedIndex].nativeElement.querySelector("video");r&&r.pause()}this.selectedIndex=e,this.selection.emit(e),o||this.center()},e.prototype.onImageClick=function(e,t){this.imageClick.emit({event:t,item:e,index:this.items.indexOf(e)})},e.prototype.onTab=function(e){var t=this;e>=0&&e<this.items.length&&(this.select(e),requestAnimationFrame((function(){return t._hostRef.nativeElement.scrollLeft=0})))},e.prototype.onItemLoaded=function(e,t){t.target.getAttribute("src")&&(e._loaded=!0,e._failed=!1,this._cd.detectChanges())},e.prototype.onItemErrored=function(e,t){t.target.getAttribute("src")&&(e._failed=!0,this._cd.detectChanges())},e.prototype.center=function(){var e=(this._viewerWidth-this._itemWidth)/2;this.shift((this.selectedIndex+this._fringeCount)*this._itemWidth-e)},e.prototype.getFringeCount=function(){return this.loop?Math.min(Math.ceil(this._viewerWidth/(this._itemWidth+1)),this.items.length):0},e.prototype.readDimensions=function(){this._viewerWidth=this._hostRef.nativeElement.offsetWidth,this._itemWidth=this._hostRef.nativeElement.querySelector("li").offsetWidth},e.prototype.selectBySwipeStats=function(e){var t=Math.ceil((Math.abs(e)-25)/this._itemWidth);t?this.selectByDelta(t*Math.sign(e)):this.center()},e.prototype.shift=function(e){this.itemListRef.nativeElement.style.transform="translate3d("+-(this._listX=e)+"px, 0, 0)"},e.decorators=[{type:t.Component,args:[{selector:"doe-viewer",template:'<div\n *ngIf="showPrevArrow"\n class="doe-viewer-arrow doe-viewer-arrow-prev"\n (click)="selectByDelta(-1)"\n>\n <doe-chevron-icon\n *ngIf="!arrowTemplate; else arrowTemplate"\n ></doe-chevron-icon>\n</div>\n\n<ul #itemList [attr.aria-label]="aria?.viewerLabel">\n <li *ngIf="!_displayedItems?.length" class="doe-viewer-initial-item"></li>\n <li\n #itemsRef\n *ngFor="let item of _displayedItems; let i = index"\n [class.doe-viewer-item--selected]="i === selectedIndex"\n tabindex="0"\n [attr.aria-label]="item.alt"\n [attr.aria-describedby]="\'doe-viewer-aria-description-\' + i"\n (click)="onImageClick(item, $event)"\n (doe-media-load)="onItemLoaded(item, $event.detail)"\n (doe-media-error)="onItemErrored(item, $event.detail)"\n (keydown.Tab)="onTab(i + 1)"\n (keydown.shift.Tab)="onTab(i - 1)"\n >\n <ng-container *ngIf="!lazyLoading || isInScrollportProximity(i)">\n <ng-container *ngIf="!itemTemplate; else customTemplate">\n <picture *ngIf="!isVideo(item)" @remove>\n <source\n *ngFor="let source of item.pictureSources"\n [srcset]="source.srcset"\n [attr.media]="source.media"\n [attr.sizes]="source.sizes"\n [attr.type]="source.type"\n />\n <img\n [src]="item.src"\n [alt]="item.alt"\n [class.doe-viewer-media-loading]="!item._loaded"\n [style.objectFit]="objectFit"\n (load)="onItemLoaded(item, $event)"\n (error)="onItemErrored(item, $event)"\n />\n </picture>\n \x3c!-- Using loadedmetadata instead of loadeddata because iOS loads data lazily upon user\'s interaction --\x3e\n <video\n @remove\n *ngIf="!isYoutube(item) && isVideo(item)"\n [src]="item.src"\n [poster]="item.thumbSrc || \'\'"\n [class.doe-viewer-media-loading]="!item._loaded"\n [style.objectFit]="objectFit"\n controls\n playsinline\n (loadedmetadata)="onItemLoaded(item, $event)"\n (error)="onItemErrored(item, $event)"\n ></video>\n\n <iframe\n @remove\n *ngIf="isYoutube(item)"\n [src]="item.src | safe"\n frameborder="0"\n allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture"\n allowfullscreen\n (load)="onItemLoaded(item, $event)"\n ></iframe>\n </ng-container>\n\n <ng-container *ngIf="!item._loaded && !item._failed">\n <ng-container *ngTemplateOutlet="loadingTemplate"></ng-container>\n </ng-container>\n\n <ng-container *ngIf="item._failed">\n <div\n *ngIf="!errorTemplate; else errorTemplate"\n class="doe-viewer-error"\n >\n <div class="doe-viewer-error-icon">⚠</div>\n <p class="doe-viewer-error-text">\n {{ errorText || \'Loading of this media failed\' }}\n </p>\n </div>\n </ng-container>\n\n <span\n [id]="\'doe-viewer-aria-description-\' + i"\n class="doe-viewer-aria-description"\n [innerHTML]="item.description"\n aria-hidden="true"\n ></span>\n </ng-container>\n\n <ng-template #customTemplate>\n <ng-container\n *ngTemplateOutlet="\n itemTemplate;\n context: {\n index: items?.indexOf(item),\n selectedIndex: selectedIndex,\n item: item,\n video: isVideo(item)\n }\n "\n ></ng-container>\n </ng-template>\n </li>\n</ul>\n\n<ng-container *ngIf="items?.length <= 0">\n <ng-container *ngTemplateOutlet="loadingTemplate"></ng-container>\n</ng-container>\n\n<div\n *ngIf="showNextArrow"\n class="doe-viewer-arrow doe-viewer-arrow-next"\n (click)="selectByDelta(1)"\n>\n <doe-chevron-icon\n *ngIf="!arrowTemplate; else arrowTemplate"\n ></doe-chevron-icon>\n</div>\n\n<doe-counter\n *ngIf="counter && items?.length"\n [itemQuantity]="items?.length"\n [selectedIndex]="selectedIndex"\n [orientation]="counterOrientation"\n></doe-counter>\n\n<div\n *ngIf="descriptions && items"\n class="doe-viewer-description"\n [class.doe-viewer-description--above-counter]="\n counter && counterOrientation === \'bottom\'\n "\n aria-hidden="true"\n>\n <div\n *ngIf="items[selectedIndex]?.description as description"\n class="doe-viewer-description-inner"\n [innerHTML]="description"\n (click)="descriptionClick.emit($event)"\n ></div>\n</div>\n',changeDetection:t.ChangeDetectionStrategy.OnPush,animations:[o.trigger("remove",[o.transition(":leave",o.animate("0ms 100ms")),o.transition(":enter",[o.style({opacity:0}),o.animate("400ms",o.style({opacity:1}))])])],styles:[':host{display:block;position:relative;width:100%;height:100%;overflow:hidden;outline:0;background-color:#ececec;z-index:1}ul{--item-width:calc(100% - 0.01px);display:flex;width:100%;height:100%;transition:transform .4s;scrollbar-width:none;-ms-overflow-style:none}ul::-webkit-scrollbar{width:0;height:0}li{display:flex;align-items:center;flex:none;position:relative;width:var(--item-width);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}picture{width:100%;height:100%}iframe,img,video{width:100%;height:100%;background-color:transparent;transition:opacity .3s ease-out;outline:0}iframe[src=""],img[src=""],video[src=""]{opacity:0}iframe.doe-viewer-media-loading,img.doe-viewer-media-loading,video.doe-viewer-media-loading{opacity:.5}img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.doe-viewer-description{position:absolute;bottom:5px;width:100%;display:flex;justify-content:center}.doe-viewer-description--above-counter{bottom:35px}.doe-viewer-description-inner{display:inline-block;background:#000;opacity:.8;color:#fff;padding:6px 15px;max-width:80%;font-size:.95em;text-align:center}.doe-viewer-aria-description{opacity:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:absolute;bottom:0;left:50%;transform:translateX(-50%)}.doe-viewer-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background-color:#f5f5f5;color:#7d7d7d}.doe-viewer-error-icon{font-size:40px}.doe-viewer-error-text{margin-top:10px;letter-spacing:.01em}.doe-viewer-arrow{display:flex;position:absolute;top:50%;transform:translateY(-50%);z-index:100;cursor:pointer}.doe-viewer-arrow-prev{left:0;transform:rotate(180deg) translateY(50%)}.doe-viewer-arrow-next{right:0}.doe-viewer-arrow doe-chevron-icon{margin:15px 6px;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-viewer-arrow doe-chevron-icon:hover{opacity:1}}.doe-viewer-arrow doe-chevron-icon::ng-deep svg{height:32px;width:32px}']}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.ChangeDetectorRef},{type:t.NgZone}]},e.propDecorators={items:[{type:t.Input}],arrows:[{type:t.Input}],selectedIndex:[{type:t.Input}],descriptions:[{type:t.Input}],errorText:[{type:t.Input}],mouseGestures:[{type:t.Input}],touchGestures:[{type:t.Input}],counter:[{type:t.Input}],counterOrientation:[{type:t.Input}],loading:[{type:t.Input}],objectFit:[{type:t.Input}],itemTemplate:[{type:t.Input}],loadingTemplate:[{type:t.Input}],errorTemplate:[{type:t.Input}],arrowTemplate:[{type:t.Input}],thumbsOrientation:[{type:t.Input}],aria:[{type:t.Input}],loop:[{type:t.Input}],itemWidth:[{type:t.Input}],touched:[{type:t.Input}],imageClick:[{type:t.Output}],descriptionClick:[{type:t.Output}],selection:[{type:t.Output}],itemListRef:[{type:t.ViewChild,args:["itemList",{static:!0}]}],itemsRef:[{type:t.ViewChildren,args:["itemsRef"]}]},e}();var x=function(){function e(e,n){var o=this;this.cd=e,this.hostRef=n,this.selectedIndex=0,this.aria=h,this.arrows=!0,this.descriptions=!1,this.mouseGestures=!0,this.touchGestures=!0,this.counter=!0,this.counterOrientation="bottom",this.loading="auto",this.loop=!1,this.objectFit="cover",this.thumbs=!0,this.thumbsAutoScroll=!0,this.thumbsOrientation="bottom",this.thumbsArrows=!0,this.thumbsScrollBehavior="smooth",this.imageClick=new t.EventEmitter,this.thumbClick=new t.EventEmitter,this.thumbHover=new t.EventEmitter,this.descriptionClick=new t.EventEmitter,this.selection=new t.EventEmitter,this._tabindex=0,this._touched=!1,this.INIT_INTERACTIONS=["touchstart","mousedown","keydown"],this._onInitInteraction=function(){var e=o.hostRef.nativeElement;o._touched=!0,o.cd.detectChanges(),o.INIT_INTERACTIONS.forEach((function(t){return e.removeEventListener(t,o._onInitInteraction)}))},this.INIT_INTERACTIONS.forEach((function(e){return n.nativeElement.addEventListener(e,o._onInitInteraction,{passive:!0})}))}return Object.defineProperty(e.prototype,"ariaLabel",{get:function(){return this.aria&&this.aria.galleryLabel},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_galleryColumn",{get:function(){return"top"===this.thumbsOrientation||"bottom"===this.thumbsOrientation},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_thumbsOrientationFlag",{get:function(){return"top"===this.thumbsOrientation||"bottom"===this.thumbsOrientation?6:24},enumerable:!0,configurable:!0}),e.prototype.focus=function(){this._viewerElRef.nativeElement.focus()},e.prototype.next=function(){this._viewerRef.selectByDelta(1)},e.prototype.prev=function(){this._viewerRef.selectByDelta(-1)},e.prototype.select=function(e){this._viewerRef.select(e),this._thumbsRef.select(e),this._selectInternal(e)},e.prototype.slideThumbs=function(e){this._thumbsRef.slide(e)},e.prototype._onThumbClick=function(e){this._viewerRef.select(e.index),this.thumbClick.emit(e),this._selectInternal(e.index)},e.prototype._selectInternal=function(e){this.selectedIndex=e,this.selection.emit(this.items[e])},e.decorators=[{type:t.Component,args:[{selector:"doe-gallery",template:'<doe-thumbs\n *ngIf="thumbs"\n [items]="items"\n [selectedIndex]="selectedIndex"\n [orientation]="thumbsOrientation"\n [arrows]="thumbsArrows"\n [arrowSlideByLength]="thumbsArrowSlideByLength"\n [autoScroll]="thumbsAutoScroll"\n [scrollBehavior]="thumbsScrollBehavior"\n [thumbTemplate]="thumbTemplate"\n [arrowTemplate]="thumbsArrowTemplate"\n [errorTemplate]="thumbErrorTemplate"\n [aria]="aria"\n (thumbClick)="_onThumbClick($event)"\n (thumbHover)="thumbHover.emit($event)"\n></doe-thumbs>\n\n<doe-viewer\n tabindex="0"\n [items]="items"\n [selectedIndex]="selectedIndex"\n [arrows]="arrows"\n [descriptions]="descriptions"\n [errorText]="errorText"\n [mouseGestures]="mouseGestures"\n [touchGestures]="touchGestures"\n [counter]="counter"\n [counterOrientation]="counterOrientation"\n [itemWidth]="itemWidth"\n [objectFit]="objectFit"\n [loading]="loading"\n [itemTemplate]="itemTemplate"\n [loadingTemplate]="loadingTemplate || defaultLoadingTemplate"\n [errorTemplate]="errorTemplate"\n [loop]="loop"\n [thumbsOrientation]="_thumbsOrientationFlag"\n [arrowTemplate]="arrowTemplate"\n [aria]="aria"\n [touched]="_touched"\n (imageClick)="imageClick.emit($event)"\n (descriptionClick)="descriptionClick.emit($event)"\n (selection)="_selectInternal($event); _thumbsRef?.select($event)"\n></doe-viewer>\n\n<ng-template #defaultLoadingTemplate>\n <div class="doe-loading">\n <div></div>\n <div></div>\n <div></div>\n </div>\n</ng-template>\n',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:[":host{display:flex;height:600px;width:500px;outline:0;position:relative}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5,0 0 1px 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]}]}],e.ctorParameters=function(){return[{type:t.ChangeDetectorRef},{type:t.ElementRef}]},e.propDecorators={items:[{type:t.Input}],selectedIndex:[{type:t.Input}],aria:[{type:t.Input}],arrows:[{type:t.Input}],descriptions:[{type:t.Input}],errorText:[{type:t.Input}],mouseGestures:[{type:t.Input}],touchGestures:[{type:t.Input}],counter:[{type:t.Input}],counterOrientation:[{type:t.Input}],itemWidth:[{type:t.Input}],loading:[{type:t.Input}],loop:[{type:t.Input}],objectFit:[{type:t.Input}],itemTemplate:[{type:t.Input}],loadingTemplate:[{type:t.Input}],errorTemplate:[{type:t.Input}],arrowTemplate:[{type:t.Input}],thumbs:[{type:t.Input}],thumbsAutoScroll:[{type:t.Input}],thumbsOrientation:[{type:t.Input}],thumbsArrows:[{type:t.Input}],thumbsArrowSlideByLength:[{type:t.Input}],thumbsScrollBehavior:[{type:t.Input}],thumbTemplate:[{type:t.Input}],thumbsArrowTemplate:[{type:t.Input}],thumbErrorTemplate:[{type:t.Input}],imageClick:[{type:t.Output}],thumbClick:[{type:t.Output}],thumbHover:[{type:t.Output}],descriptionClick:[{type:t.Output}],selection:[{type:t.Output}],_viewerRef:[{type:t.ViewChild,args:[w,{static:!1}]}],_thumbsRef:[{type:t.ViewChild,args:[y,{static:!1}]}],_viewerElRef:[{type:t.ViewChild,args:[w,{static:!1,read:t.ElementRef}]}],_tabindex:[{type:t.HostBinding,args:["tabindex"]}],ariaLabel:[{type:t.HostBinding,args:["attr.aria-label"]}],_galleryColumn:[{type:t.HostBinding,args:["class.doe-gallery--column"]}],next:[{type:t.HostListener,args:["keydown.arrowright"]}],prev:[{type:t.HostListener,args:["keydown.arrowleft"]}]},e}();var I=function(){function e(){}return e.decorators=[{type:t.Component,args:[{selector:"doe-counter",template:'\n <span aria-hidden="true">\n {{ selectedIndex + 1 }}<span class="doe-counter-delimiter">/</span\n >{{ itemQuantity || 0 }}\n </span>\n ',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:[":host{position:absolute;left:50%;transform:translateX(-50%);background:#000;padding:4px 7px 3px;color:#fff;opacity:.7;font-size:14px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host.top{top:0}:host.bottom{bottom:0}.doe-counter-delimiter{padding:0 2px}"]}]}],e.propDecorators={itemQuantity:[{type:t.Input}],selectedIndex:[{type:t.Input}],orientation:[{type:t.HostBinding,args:["class"]},{type:t.Input}]},e}();var _=function(){function e(){}return e.decorators=[{type:t.Component,args:[{selector:"doe-chevron-icon",template:'\x3c!-- Icon made by Dave Gandy from www.flaticon.com --\x3e\n<svg\n version="1.1"\n xmlns="http://www.w3.org/2000/svg"\n xmlns:xlink="http://www.w3.org/1999/xlink"\n x="0px"\n y="0px"\n viewBox="0 0 407.436 407.436"\n xml:space="preserve"\n>\n <polygon\n points="112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 "\n />\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n</svg>\n',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:["svg{width:26px;height:26px;fill:#fff;-webkit-filter:drop-shadow(0 0 1px #000);filter:drop-shadow(0 0 1px #000);display:block}"]}]}],e}(),T=function(){function e(e){this.sanitizer=e}return e.prototype.transform=function(e){return this.sanitizer.bypassSecurityTrustResourceUrl(e)},e.decorators=[{type:t.Pipe,args:[{name:"safe"}]}],e.ctorParameters=function(){return[{type:a.DomSanitizer}]},e}();var E=function(){function e(e){this.hostRef=e}return e.prototype.onLoad=function(e){var t="error"===e.type?"doe-media-error":"doe-media-load";this.hostRef.nativeElement.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:e}))},e.decorators=[{type:t.Directive,args:[{selector:"[doeMedia]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef}]},e.propDecorators={onLoad:[{type:t.HostListener,args:["load",["$event"]]},{type:t.HostListener,args:["loadedmetadata",["$event"]]},{type:t.HostListener,args:["error",["$event"]]}]},e}();var O=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[x,y,w,_,I,T,E],imports:[r.CommonModule,s.BrowserAnimationsModule],exports:[x,E]}]}],e}();e.GalleryComponent=x,e.GalleryImage=b,e.GalleryItem=f,e.GalleryModule=O,e.GalleryVideo=g,e.SUPPORT=m,e.UA=p,e.isBrowser=u,e.orientations={left:2,right:4,top:8,bottom:16},e.ɵa=w,e.ɵb=y,e.ɵc=_,e.ɵd=I,e.ɵe=T,e.ɵf=E,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=ngx-doe-gallery.umd.min.js.map

@@ -35,2 +35,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsS0FBSyxFQUNMLFdBQVcsR0FDWixNQUFNLGVBQWUsQ0FBQztBQWV2QixNQUFNLE9BQU8sZ0JBQWdCOzs7WUFYNUIsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2QixRQUFRLEVBQUU7Ozs7O0dBS1Q7Z0JBRUQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O2FBQ2hEOzs7MkJBRUUsS0FBSzs0QkFHTCxLQUFLOzBCQUdMLFdBQVcsU0FBQyxPQUFPLGNBQ25CLEtBQUs7Ozs7SUFQTix3Q0FDcUI7O0lBRXJCLHlDQUNzQjs7SUFFdEIsdUNBRWlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb21wb25lbnQsXHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgSW5wdXQsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBWZXJ0aWNhbE9yaWVudGF0aW9uIH0gZnJvbSAnLi4vLi4vY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2RvZS1jb3VudGVyJyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPHNwYW4gYXJpYS1oaWRkZW49XCJ0cnVlXCI+XHJcbiAgICAgIHt7IHNlbGVjdGVkSW5kZXggKyAxIH19PHNwYW4gY2xhc3M9XCJkb2UtY291bnRlci1kZWxpbWl0ZXJcIj4vPC9zcGFuXHJcbiAgICAgID57eyBpdGVtUXVhbnRpdHkgfHwgMCB9fVxyXG4gICAgPC9zcGFuPlxyXG4gIGAsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY291bnRlci5jb21wb25lbnQuc2NzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ291bnRlckNvbXBvbmVudCB7XHJcbiAgQElucHV0KClcclxuICBpdGVtUXVhbnRpdHk6IG51bWJlcjtcclxuXHJcbiAgQElucHV0KClcclxuICBzZWxlY3RlZEluZGV4OiBudW1iZXI7XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxyXG4gIEBJbnB1dCgpXHJcbiAgb3JpZW50YXRpb246IFZlcnRpY2FsT3JpZW50YXRpb247XHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsS0FBSyxFQUNMLFdBQVcsR0FDWixNQUFNLGVBQWUsQ0FBQztBQWV2QixNQUFNLE9BQU8sZ0JBQWdCOzs7WUFYNUIsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2QixRQUFRLEVBQUU7Ozs7O0dBS1Q7Z0JBRUQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O2FBQ2hEOzs7MkJBRUUsS0FBSzs0QkFHTCxLQUFLOzBCQUdMLFdBQVcsU0FBQyxPQUFPLGNBQ25CLEtBQUs7Ozs7SUFQTix3Q0FDcUI7O0lBRXJCLHlDQUNzQjs7SUFFdEIsdUNBRWlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgSW5wdXQsXG4gIEhvc3RCaW5kaW5nLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgVmVydGljYWxPcmllbnRhdGlvbiB9IGZyb20gJy4uLy4uL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkb2UtY291bnRlcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHNwYW4gYXJpYS1oaWRkZW49XCJ0cnVlXCI+XG4gICAgICB7eyBzZWxlY3RlZEluZGV4ICsgMSB9fTxzcGFuIGNsYXNzPVwiZG9lLWNvdW50ZXItZGVsaW1pdGVyXCI+Lzwvc3BhblxuICAgICAgPnt7IGl0ZW1RdWFudGl0eSB8fCAwIH19XG4gICAgPC9zcGFuPlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9jb3VudGVyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBDb3VudGVyQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgaXRlbVF1YW50aXR5OiBudW1iZXI7XG5cbiAgQElucHV0KClcbiAgc2VsZWN0ZWRJbmRleDogbnVtYmVyO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBASW5wdXQoKVxuICBvcmllbnRhdGlvbjogVmVydGljYWxPcmllbnRhdGlvbjtcbn1cbiJdfQ==

@@ -6,3 +6,3 @@ /**

*/
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, TemplateRef, ViewChild, ChangeDetectorRef, } from '@angular/core';
import { defaultAria } from '../../core/aria';

@@ -12,3 +12,9 @@ import { ThumbsComponent } from '../thumbs/thumbs.component';

export class GalleryComponent {
constructor() {
/**
* @param {?} cd
* @param {?} hostRef
*/
constructor(cd, hostRef) {
this.cd = cd;
this.hostRef = hostRef;
this.selectedIndex = 0;

@@ -20,4 +26,4 @@ this.aria = defaultAria;

this.touchGestures = true;
this.imageCounter = true;
this.imageCounterOrientation = 'bottom';
this.counter = true;
this.counterOrientation = 'bottom';
this.loading = 'auto';

@@ -37,2 +43,25 @@ this.loop = false;

this._tabindex = 0;
this._touched = false;
this.INIT_INTERACTIONS = ['touchstart', 'mousedown', 'keydown'];
this._onInitInteraction = (/**
* @return {?}
*/
() => {
/** @type {?} */
const hostEl = this.hostRef.nativeElement;
this._touched = true;
this.cd.detectChanges();
this.INIT_INTERACTIONS.forEach((/**
* @param {?} ename
* @return {?}
*/
ename => hostEl.removeEventListener(ename, this._onInitInteraction)));
});
this.INIT_INTERACTIONS.forEach((/**
* @param {?} ename
* @return {?}
*/
ename => hostRef.nativeElement.addEventListener(ename, this._onInitInteraction, {
passive: true,
})));
}

@@ -65,3 +94,3 @@ /**

focus() {
this.viewerElRef.nativeElement.focus();
this._viewerElRef.nativeElement.focus();
}

@@ -72,3 +101,3 @@ /**

next() {
this.viewerRef.selectByDelta(1);
this._viewerRef.selectByDelta(1);
}

@@ -79,3 +108,3 @@ /**

prev() {
this.viewerRef.selectByDelta(-1);
this._viewerRef.selectByDelta(-1);
}

@@ -87,4 +116,4 @@ /**

select(index) {
this.viewerRef.select(index);
this.thumbsRef.select(index);
this._viewerRef.select(index);
this._thumbsRef.select(index);
this._selectInternal(index);

@@ -97,3 +126,3 @@ }

slideThumbs(direction) {
this.thumbsRef.slide(direction);
this._thumbsRef.slide(direction);
}

@@ -105,3 +134,3 @@ /**

_onThumbClick(event) {
this.viewerRef.select(event.index);
this._viewerRef.select(event.index);
this.thumbClick.emit(event);

@@ -122,7 +151,12 @@ this._selectInternal(event.index);

selector: 'doe-gallery',
template: "<doe-thumbs\r\n *ngIf=\"thumbs\"\r\n [items]=\"items\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [orientation]=\"thumbsOrientation\"\r\n [arrows]=\"thumbsArrows\"\r\n [arrowSlideByLength]=\"thumbsArrowSlideByLength\"\r\n [autoScroll]=\"thumbsAutoScroll\"\r\n [scrollBehavior]=\"thumbsScrollBehavior\"\r\n [thumbTemplate]=\"thumbTemplate\"\r\n [arrowTemplate]=\"thumbsArrowTemplate\"\r\n [errorTemplate]=\"thumbErrorTemplate\"\r\n [aria]=\"aria\"\r\n (thumbClick)=\"_onThumbClick($event)\"\r\n (thumbHover)=\"thumbHover.emit($event)\"\r\n></doe-thumbs>\r\n\r\n<doe-viewer\r\n tabindex=\"0\"\r\n [items]=\"items\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [arrows]=\"arrows\"\r\n [descriptions]=\"descriptions\"\r\n [errorText]=\"errorText\"\r\n [mouseGestures]=\"mouseGestures\"\r\n [touchGestures]=\"touchGestures\"\r\n [imageCounter]=\"imageCounter\"\r\n [imageCounterOrientation]=\"imageCounterOrientation\"\r\n [itemWidth]=\"itemWidth\"\r\n [objectFit]=\"objectFit\"\r\n [loading]=\"loading\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [loadingTemplate]=\"loadingTemplate || defaultLoadingTemplate\"\r\n [errorTemplate]=\"errorTemplate\"\r\n [loop]=\"loop\"\r\n [thumbsOrientation]=\"_thumbsOrientationFlag\"\r\n [arrowTemplate]=\"arrowTemplate\"\r\n [aria]=\"aria\"\r\n (imageClick)=\"imageClick.emit($event)\"\r\n (descriptionClick)=\"descriptionClick.emit($event)\"\r\n (selection)=\"_selectInternal($event); thumbsRef?.select($event)\"\r\n></doe-viewer>\r\n\r\n<ng-template #defaultLoadingTemplate>\r\n <div class=\"doe-loading\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n</ng-template>\r\n",
template: "<doe-thumbs\n *ngIf=\"thumbs\"\n [items]=\"items\"\n [selectedIndex]=\"selectedIndex\"\n [orientation]=\"thumbsOrientation\"\n [arrows]=\"thumbsArrows\"\n [arrowSlideByLength]=\"thumbsArrowSlideByLength\"\n [autoScroll]=\"thumbsAutoScroll\"\n [scrollBehavior]=\"thumbsScrollBehavior\"\n [thumbTemplate]=\"thumbTemplate\"\n [arrowTemplate]=\"thumbsArrowTemplate\"\n [errorTemplate]=\"thumbErrorTemplate\"\n [aria]=\"aria\"\n (thumbClick)=\"_onThumbClick($event)\"\n (thumbHover)=\"thumbHover.emit($event)\"\n></doe-thumbs>\n\n<doe-viewer\n tabindex=\"0\"\n [items]=\"items\"\n [selectedIndex]=\"selectedIndex\"\n [arrows]=\"arrows\"\n [descriptions]=\"descriptions\"\n [errorText]=\"errorText\"\n [mouseGestures]=\"mouseGestures\"\n [touchGestures]=\"touchGestures\"\n [counter]=\"counter\"\n [counterOrientation]=\"counterOrientation\"\n [itemWidth]=\"itemWidth\"\n [objectFit]=\"objectFit\"\n [loading]=\"loading\"\n [itemTemplate]=\"itemTemplate\"\n [loadingTemplate]=\"loadingTemplate || defaultLoadingTemplate\"\n [errorTemplate]=\"errorTemplate\"\n [loop]=\"loop\"\n [thumbsOrientation]=\"_thumbsOrientationFlag\"\n [arrowTemplate]=\"arrowTemplate\"\n [aria]=\"aria\"\n [touched]=\"_touched\"\n (imageClick)=\"imageClick.emit($event)\"\n (descriptionClick)=\"descriptionClick.emit($event)\"\n (selection)=\"_selectInternal($event); _thumbsRef?.select($event)\"\n></doe-viewer>\n\n<ng-template #defaultLoadingTemplate>\n <div class=\"doe-loading\">\n <div></div>\n <div></div>\n <div></div>\n </div>\n</ng-template>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [":host{display:flex;height:600px;width:500px;outline:0;position:relative;background-color:#252525;border-radius:5px}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]
styles: [":host{display:flex;height:600px;width:500px;outline:0;position:relative}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5,0 0 1px 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]
}] }
];
/** @nocollapse */
GalleryComponent.ctorParameters = () => [
{ type: ChangeDetectorRef },
{ type: ElementRef }
];
GalleryComponent.propDecorators = {

@@ -137,4 +171,4 @@ items: [{ type: Input }],

touchGestures: [{ type: Input }],
imageCounter: [{ type: Input }],
imageCounterOrientation: [{ type: Input }],
counter: [{ type: Input }],
counterOrientation: [{ type: Input }],
itemWidth: [{ type: Input }],

@@ -162,5 +196,5 @@ loading: [{ type: Input }],

selection: [{ type: Output }],
viewerRef: [{ type: ViewChild, args: [ViewerComponent, { static: false },] }],
thumbsRef: [{ type: ViewChild, args: [ThumbsComponent, { static: false },] }],
viewerElRef: [{ type: ViewChild, args: [ViewerComponent, { static: false, read: ElementRef },] }],
_viewerRef: [{ type: ViewChild, args: [ViewerComponent, { static: false },] }],
_thumbsRef: [{ type: ViewChild, args: [ThumbsComponent, { static: false },] }],
_viewerElRef: [{ type: ViewChild, args: [ViewerComponent, { static: false, read: ElementRef },] }],
_tabindex: [{ type: HostBinding, args: ['tabindex',] }],

@@ -190,5 +224,5 @@ ariaLabel: [{ type: HostBinding, args: ['attr.aria-label',] }],

/** @type {?} */
GalleryComponent.prototype.imageCounter;
GalleryComponent.prototype.counter;
/** @type {?} */
GalleryComponent.prototype.imageCounterOrientation;
GalleryComponent.prototype.counterOrientation;
/** @type {?} */

@@ -239,10 +273,29 @@ GalleryComponent.prototype.itemWidth;

/** @type {?} */
GalleryComponent.prototype.viewerRef;
GalleryComponent.prototype._viewerRef;
/** @type {?} */
GalleryComponent.prototype.thumbsRef;
GalleryComponent.prototype._thumbsRef;
/** @type {?} */
GalleryComponent.prototype.viewerElRef;
GalleryComponent.prototype._viewerElRef;
/** @type {?} */
GalleryComponent.prototype._tabindex;
/** @type {?} */
GalleryComponent.prototype._touched;
/** @type {?} */
GalleryComponent.prototype.INIT_INTERACTIONS;
/**
* @type {?}
* @private
*/
GalleryComponent.prototype._onInitInteraction;
/**
* @type {?}
* @private
*/
GalleryComponent.prototype.cd;
/**
* @type {?}
* @private
*/
GalleryComponent.prototype.hostRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gallery.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/gallery/gallery.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport {\r\n  Aria,\r\n  GalleryItem,\r\n  GalleryItemEvent,\r\n  ItemTemplateContext,\r\n  Loading,\r\n  ObjectFit,\r\n  Orientation,\r\n  OrientationFlag,\r\n  VerticalOrientation,\r\n  ThumbTemplateContext,\r\n} from '../../core';\r\nimport { defaultAria } from '../../core/aria';\r\nimport { ThumbsComponent } from '../thumbs/thumbs.component';\r\nimport { ViewerComponent } from '../viewer/viewer.component';\r\n\r\n@Component({\r\n  selector: 'doe-gallery',\r\n  templateUrl: './gallery.component.html',\r\n  styleUrls: ['./gallery.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class GalleryComponent {\r\n  @Input()\r\n  items: GalleryItem[];\r\n\r\n  @Input()\r\n  selectedIndex = 0;\r\n\r\n  @Input()\r\n  aria: Aria = defaultAria;\r\n\r\n  @Input()\r\n  arrows = true;\r\n\r\n  @Input()\r\n  descriptions = false;\r\n\r\n  @Input()\r\n  errorText: string;\r\n\r\n  @Input()\r\n  mouseGestures = true;\r\n\r\n  @Input()\r\n  touchGestures = true;\r\n\r\n  @Input()\r\n  imageCounter = true;\r\n\r\n  @Input()\r\n  imageCounterOrientation: VerticalOrientation = 'bottom';\r\n\r\n  @Input()\r\n  itemWidth: string;\r\n\r\n  @Input()\r\n  loading: Loading = 'auto';\r\n\r\n  @Input()\r\n  loop = false;\r\n\r\n  @Input()\r\n  objectFit: ObjectFit = 'cover';\r\n\r\n  @Input()\r\n  itemTemplate: TemplateRef<ItemTemplateContext>;\r\n\r\n  @Input()\r\n  loadingTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  errorTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  arrowTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  thumbs = true;\r\n\r\n  @Input()\r\n  thumbsAutoScroll = true;\r\n\r\n  @Input()\r\n  thumbsOrientation: Orientation = 'bottom';\r\n\r\n  @Input()\r\n  thumbsArrows = true;\r\n\r\n  @Input()\r\n  thumbsArrowSlideByLength: number;\r\n\r\n  @Input()\r\n  thumbsScrollBehavior: ScrollBehavior = 'smooth';\r\n\r\n  @Input()\r\n  thumbTemplate: TemplateRef<ThumbTemplateContext>;\r\n\r\n  @Input()\r\n  thumbsArrowTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  thumbErrorTemplate: TemplateRef<void>;\r\n\r\n  @Output()\r\n  imageClick = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @Output()\r\n  thumbClick = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @Output()\r\n  thumbHover = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @Output()\r\n  descriptionClick = new EventEmitter<Event>();\r\n\r\n  @Output()\r\n  selection = new EventEmitter<GalleryItem>();\r\n\r\n  @ViewChild(ViewerComponent, { static: false })\r\n  viewerRef: ViewerComponent;\r\n\r\n  @ViewChild(ThumbsComponent, { static: false })\r\n  thumbsRef: ThumbsComponent;\r\n\r\n  @ViewChild(ViewerComponent, { static: false, read: ElementRef })\r\n  viewerElRef: ElementRef<HTMLElement>;\r\n\r\n  @HostBinding('tabindex')\r\n  _tabindex = 0;\r\n\r\n  @HostBinding('attr.aria-label')\r\n  get ariaLabel() {\r\n    return this.aria && this.aria.galleryLabel;\r\n  }\r\n\r\n  @HostBinding('class.doe-gallery--column')\r\n  get _galleryColumn() {\r\n    return (\r\n      this.thumbsOrientation === 'top' || this.thumbsOrientation === 'bottom'\r\n    );\r\n  }\r\n\r\n  get _thumbsOrientationFlag(): OrientationFlag {\r\n    if (\r\n      this.thumbsOrientation === 'top' ||\r\n      this.thumbsOrientation === 'bottom'\r\n    ) {\r\n      return OrientationFlag.HORIZONTAL;\r\n    }\r\n    return OrientationFlag.VERTICAL;\r\n  }\r\n\r\n  focus() {\r\n    this.viewerElRef.nativeElement.focus();\r\n  }\r\n\r\n  @HostListener('keydown.arrowright')\r\n  next() {\r\n    this.viewerRef.selectByDelta(1);\r\n  }\r\n\r\n  @HostListener('keydown.arrowleft')\r\n  prev() {\r\n    this.viewerRef.selectByDelta(-1);\r\n  }\r\n\r\n  select(index: number) {\r\n    this.viewerRef.select(index);\r\n    this.thumbsRef.select(index);\r\n    this._selectInternal(index);\r\n  }\r\n\r\n  slideThumbs(direction: number) {\r\n    this.thumbsRef.slide(direction);\r\n  }\r\n\r\n  _onThumbClick(event: GalleryItemEvent) {\r\n    this.viewerRef.select(event.index);\r\n    this.thumbClick.emit(event);\r\n    this._selectInternal(event.index);\r\n  }\r\n\r\n  _selectInternal(index: number) {\r\n    this.selectedIndex = index;\r\n    this.selection.emit(this.items[index]);\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gallery.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/gallery/gallery.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ChangeDetectorRef,\n} from '@angular/core';\n\nimport {\n  Aria,\n  GalleryItem,\n  GalleryItemEvent,\n  ItemTemplateContext,\n  Loading,\n  ObjectFit,\n  Orientation,\n  OrientationFlag,\n  VerticalOrientation,\n  ThumbTemplateContext,\n} from '../../core';\nimport { defaultAria } from '../../core/aria';\nimport { ThumbsComponent } from '../thumbs/thumbs.component';\nimport { ViewerComponent } from '../viewer/viewer.component';\n\n@Component({\n  selector: 'doe-gallery',\n  templateUrl: './gallery.component.html',\n  styleUrls: ['./gallery.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class GalleryComponent {\n  @Input() items: GalleryItem[];\n  @Input() selectedIndex = 0;\n  @Input() aria: Aria = defaultAria;\n  @Input() arrows = true;\n  @Input() descriptions = false;\n  @Input() errorText: string;\n  @Input() mouseGestures = true;\n  @Input() touchGestures = true;\n  @Input() counter = true;\n  @Input() counterOrientation: VerticalOrientation = 'bottom';\n  @Input() itemWidth: string;\n  @Input() loading: Loading = 'auto';\n  @Input() loop = false;\n  @Input() objectFit: ObjectFit = 'cover';\n  @Input() itemTemplate: TemplateRef<ItemTemplateContext>;\n  @Input() loadingTemplate: TemplateRef<void>;\n  @Input() errorTemplate: TemplateRef<void>;\n  @Input() arrowTemplate: TemplateRef<void>;\n  @Input() thumbs = true;\n  @Input() thumbsAutoScroll = true;\n  @Input() thumbsOrientation: Orientation = 'bottom';\n  @Input() thumbsArrows = true;\n  @Input() thumbsArrowSlideByLength: number;\n  @Input() thumbsScrollBehavior: ScrollBehavior = 'smooth';\n  @Input() thumbTemplate: TemplateRef<ThumbTemplateContext>;\n  @Input() thumbsArrowTemplate: TemplateRef<void>;\n  @Input() thumbErrorTemplate: TemplateRef<void>;\n\n  @Output() imageClick = new EventEmitter<GalleryItemEvent>();\n  @Output() thumbClick = new EventEmitter<GalleryItemEvent>();\n  @Output() thumbHover = new EventEmitter<GalleryItemEvent>();\n  @Output() descriptionClick = new EventEmitter<Event>();\n  @Output() selection = new EventEmitter<GalleryItem>();\n\n  @ViewChild(ViewerComponent, { static: false }) _viewerRef: ViewerComponent;\n  @ViewChild(ThumbsComponent, { static: false }) _thumbsRef: ThumbsComponent;\n  @ViewChild(ViewerComponent, { static: false, read: ElementRef })\n  _viewerElRef: ElementRef<HTMLElement>;\n\n  @HostBinding('tabindex')\n  _tabindex = 0;\n  _touched = false;\n  INIT_INTERACTIONS = ['touchstart', 'mousedown', 'keydown'];\n\n  @HostBinding('attr.aria-label')\n  get ariaLabel() {\n    return this.aria && this.aria.galleryLabel;\n  }\n\n  @HostBinding('class.doe-gallery--column')\n  get _galleryColumn() {\n    return (\n      this.thumbsOrientation === 'top' || this.thumbsOrientation === 'bottom'\n    );\n  }\n\n  get _thumbsOrientationFlag(): OrientationFlag {\n    if (\n      this.thumbsOrientation === 'top' ||\n      this.thumbsOrientation === 'bottom'\n    ) {\n      return OrientationFlag.HORIZONTAL;\n    }\n    return OrientationFlag.VERTICAL;\n  }\n\n  constructor(\n    private cd: ChangeDetectorRef,\n    private hostRef: ElementRef<HTMLElement>\n  ) {\n    this.INIT_INTERACTIONS.forEach(ename =>\n      hostRef.nativeElement.addEventListener(ename, this._onInitInteraction, {\n        passive: true,\n      })\n    );\n  }\n\n  private _onInitInteraction = () => {\n    const hostEl = this.hostRef.nativeElement;\n    this._touched = true;\n    this.cd.detectChanges();\n    this.INIT_INTERACTIONS.forEach(ename =>\n      hostEl.removeEventListener(ename, this._onInitInteraction)\n    );\n  };\n\n  focus() {\n    this._viewerElRef.nativeElement.focus();\n  }\n\n  @HostListener('keydown.arrowright')\n  next() {\n    this._viewerRef.selectByDelta(1);\n  }\n\n  @HostListener('keydown.arrowleft')\n  prev() {\n    this._viewerRef.selectByDelta(-1);\n  }\n\n  select(index: number) {\n    this._viewerRef.select(index);\n    this._thumbsRef.select(index);\n    this._selectInternal(index);\n  }\n\n  slideThumbs(direction: number) {\n    this._thumbsRef.slide(direction);\n  }\n\n  _onThumbClick(event: GalleryItemEvent) {\n    this._viewerRef.select(event.index);\n    this.thumbClick.emit(event);\n    this._selectInternal(event.index);\n  }\n\n  _selectInternal(index: number) {\n    this.selectedIndex = index;\n    this.selection.emit(this.items[index]);\n  }\n}\n"]}

@@ -12,3 +12,3 @@ /**

selector: 'doe-chevron-icon',
template: "<!-- Icon made by Dave Gandy from www.flaticon.com -->\r\n<svg\r\n version=\"1.1\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n x=\"0px\"\r\n y=\"0px\"\r\n viewBox=\"0 0 407.436 407.436\"\r\n xml:space=\"preserve\"\r\n>\r\n <polygon\r\n points=\"112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 \"\r\n />\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n</svg>\r\n",
template: "<!-- Icon made by Dave Gandy from www.flaticon.com -->\n<svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 407.436 407.436\"\n xml:space=\"preserve\"\n>\n <polygon\n points=\"112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 \"\n />\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n</svg>\n",
changeDetection: ChangeDetectionStrategy.OnPush,

@@ -18,2 +18,2 @@ styles: ["svg{width:26px;height:26px;fill:#fff;-webkit-filter:drop-shadow(0 0 1px #000);filter:drop-shadow(0 0 1px #000);display:block}"]

];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hldnJvbi1pY29uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRbkUsTUFBTSxPQUFPLG9CQUFvQjs7O1lBTmhDLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixnbkJBQTRDO2dCQUU1QyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2RvZS1jaGV2cm9uLWljb24nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jaGV2cm9uLWljb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NoZXZyb24taWNvbi5jb21wb25lbnQuc2NzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaGV2cm9uSWNvbkNvbXBvbmVudCB7fVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hldnJvbi1pY29uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRbkUsTUFBTSxPQUFPLG9CQUFvQjs7O1lBTmhDLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixzakJBQTRDO2dCQUU1QyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RvZS1jaGV2cm9uLWljb24nLFxuICB0ZW1wbGF0ZVVybDogJy4vY2hldnJvbi1pY29uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hldnJvbi1pY29uLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIENoZXZyb25JY29uQ29tcG9uZW50IHt9XG4iXX0=

@@ -9,17 +9,19 @@ /**

import { isBrowser, SUPPORT, } from '../../core';
import { isVideo, } from '../../core/gallery-item';
export class ThumbsComponent {
/**
* @param {?} cd
* @param {?} elRef
* @param {?} _cd
* @param {?} _elRef
*/
constructor(cd, elRef) {
this.cd = cd;
this.elRef = elRef;
constructor(_cd, _elRef) {
this._cd = _cd;
this._elRef = _elRef;
this.items = [];
this.thumbClick = new EventEmitter();
this.thumbHover = new EventEmitter();
this.showStartArrow = false;
this.showEndArrow = false;
this.destroy$ = new Subject();
this.smoothScrollAllowed = false;
this.isVideo = isVideo;
this._showStartArrow = false;
this._showEndArrow = false;
this._destroy$ = new Subject();
this._smoothScrollAllowed = false;
this.onArrowsObserved = (/**

@@ -37,8 +39,8 @@ * @param {?} entries

if (firstThumbEntry) {
this.showStartArrow = firstThumbEntry.intersectionRatio < 1;
this._showStartArrow = firstThumbEntry.intersectionRatio < 1;
}
if (lastThumbEntry) {
this.showEndArrow = lastThumbEntry.intersectionRatio < 1;
this._showEndArrow = lastThumbEntry.intersectionRatio < 1;
}
this.cd.detectChanges();
this._cd.detectChanges();
});

@@ -57,3 +59,3 @@ }

get scrollBehavior() {
return this.smoothScrollAllowed ? this._scrollBehavior : 'auto';
return this._smoothScrollAllowed ? this._scrollBehavior : 'auto';
}

@@ -70,4 +72,6 @@ /**

*/
get scrollKey() {
return this.vertical ? 'scrollTop' : 'scrollLeft';
get _hostOffsetAxis() {
return this._vertical
? this._elRef.nativeElement.offsetHeight
: this._elRef.nativeElement.offsetWidth;
}

@@ -78,6 +82,4 @@ /**

*/
get hostOffsetAxis() {
return this.vertical
? this.elRef.nativeElement.offsetHeight
: this.elRef.nativeElement.offsetWidth;
get _scrollKey() {
return this._vertical ? 'scrollTop' : 'scrollLeft';
}

@@ -92,3 +94,3 @@ /**

const newOrientation = orientation.currentValue;
this.vertical = newOrientation === 'left' || newOrientation === 'right';
this._vertical = newOrientation === 'left' || newOrientation === 'right';
}

@@ -100,4 +102,4 @@ if (arrows) {

else if (!arrows.currentValue) {
this.showStartArrow = false;
this.showEndArrow = false;
this._showStartArrow = false;
this._showEndArrow = false;
this.unobserveArrows();

@@ -123,3 +125,3 @@ }

this.centerThumbIfNeeded(this.selectedIndex);
this.smoothScrollAllowed = true;
this._smoothScrollAllowed = true;
}));

@@ -133,5 +135,5 @@ }

ngOnDestroy() {
this.destroy$.next(null);
this.destroy$.complete();
this.arrowObserver && this.arrowObserver.disconnect();
this._destroy$.next(null);
this._destroy$.complete();
this._arrowObserver && this._arrowObserver.disconnect();
}

@@ -155,7 +157,7 @@ /**

/** @type {?} */
const thumbListScrollAxis = this.vertical
const thumbListScrollAxis = this._vertical
? thumbList.scrollHeight
: thumbList.scrollWidth;
/** @type {?} */
const thumbListOffsetAxis = this.vertical
const thumbListOffsetAxis = this._vertical
? thumbList.offsetHeight

@@ -177,11 +179,14 @@ : thumbList.offsetWidth;

const nextItemEl = this.thumbsRef.toArray()[index].nativeElement;
if (!nextItemEl) {
return;
}
const { offsetLeft, offsetTop, offsetWidth, offsetHeight } = nextItemEl;
/** @type {?} */
const itemOffset = this.vertical ? offsetTop : offsetLeft;
const itemOffset = this._vertical ? offsetTop : offsetLeft;
/** @type {?} */
const itemOffsetAxis = this.vertical ? offsetHeight : offsetWidth;
const itemOffsetAxis = this._vertical ? offsetHeight : offsetWidth;
/** @type {?} */
const hostScrollAxis = this.hostOffsetAxis;
const hostScrollAxis = this._hostOffsetAxis;
/** @type {?} */
const thumbListScroll = this.thumbListRef.nativeElement[this.scrollKey];
const thumbListScroll = this.thumbListRef.nativeElement[this._scrollKey];
/** @type {?} */

@@ -200,3 +205,3 @@ const nextScrollDelta = itemOffset + itemOffsetAxis / 2 - hostScrollAxis / 2 - thumbListScroll;

this.selectedIndex = index;
this.cd.detectChanges();
this._cd.detectChanges();
if (this.autoScroll) {

@@ -210,9 +215,2 @@ setTimeout((/**

/**
* @param {?} item
* @return {?}
*/
onItemErrored(item) {
item._thumbFailed = true;
}
/**
* @param {?} index

@@ -224,3 +222,3 @@ * @param {?} item

*/
emitEvent(index, item, event, emitter) {
_emitEvent(index, item, event, emitter) {
emitter.emit({

@@ -233,2 +231,10 @@ index,

/**
* @param {?} item
* @param {?} success
* @return {?}
*/
_onLoadChange(item, success) {
item._thumbFailed = !success;
}
/**
* @private

@@ -243,7 +249,7 @@ * @param {?} totalScrollDelta

if (SUPPORT.scrollBehavior || this.scrollBehavior === 'auto') {
this.thumbListRef.nativeElement[this.scrollKey] += totalScrollDelta;
this.thumbListRef.nativeElement[this._scrollKey] += totalScrollDelta;
return;
}
if (this.scrollId != null) {
cancelAnimationFrame(this.scrollId);
if (this._scrollId != null) {
cancelAnimationFrame(this._scrollId);
}

@@ -278,8 +284,8 @@ /** @type {?} */

currentScroll = suggestedScroll;
this.thumbListRef.nativeElement[this.scrollKey] += frameScroll;
this.thumbListRef.nativeElement[this._scrollKey] += frameScroll;
if (currentScroll <= totalDistance) {
this.scrollId = requestAnimationFrame(animate);
this._scrollId = requestAnimationFrame(animate);
}
});
this.scrollId = requestAnimationFrame(animate);
this._scrollId = requestAnimationFrame(animate);
}

@@ -291,4 +297,4 @@ /**

observeArrows() {
if (!this.arrowObserver) {
this.arrowObserver = new IntersectionObserver(this.onArrowsObserved, {
if (!this._arrowObserver) {
this._arrowObserver = new IntersectionObserver(this.onArrowsObserved, {
root: this.thumbListRef.nativeElement,

@@ -299,3 +305,3 @@ threshold: 1.0,

else {
this.arrowObserver.disconnect();
this._arrowObserver.disconnect();
}

@@ -306,4 +312,4 @@ setTimeout((/**

() => {
this.arrowObserver.observe(this.thumbsRef.first.nativeElement);
this.arrowObserver.observe(this.thumbsRef.last.nativeElement);
this._arrowObserver.observe(this.thumbsRef.first.nativeElement);
this._arrowObserver.observe(this.thumbsRef.last.nativeElement);
}));

@@ -316,3 +322,3 @@ }

unobserveArrows() {
this.arrowObserver && this.arrowObserver.disconnect();
this._arrowObserver && this._arrowObserver.disconnect();
}

@@ -323,5 +329,5 @@ }

selector: 'doe-thumbs',
template: "<div\r\n *ngIf=\"showStartArrow\"\r\n class=\"doe-thumbs-arrow doe-thumbs-arrow-prev\"\r\n (click)=\"slide(-1)\"\r\n>\r\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n\r\n<ul\r\n #thumbs\r\n [style.scrollBehavior]=\"scrollBehavior\"\r\n tabindex=\"0\"\r\n [attr.aria-label]=\"aria?.thumbnailsLabel\"\r\n>\r\n <li *ngIf=\"!items || !items.length\" class=\"doe-thumbs-initial-item\"></li>\r\n <li\r\n #thumb\r\n *ngFor=\"let item of items; let i = index\"\r\n [class.doe-thumbs-item--selected]=\"i === selectedIndex\"\r\n aria-hidden=\"true\"\r\n (click)=\"emitEvent(i, item, $event, thumbClick)\"\r\n (mouseenter)=\"emitEvent(i, item, $event, thumbHover)\"\r\n >\r\n <ng-container *ngIf=\"!thumbTemplate; else customThumbTemplate\">\r\n <img\r\n [src]=\"item.thumbSrc || item.src\"\r\n [alt]=\"item.alt\"\r\n (error)=\"onItemErrored(item)\"\r\n />\r\n\r\n <ng-container *ngIf=\"item._thumbFailed\">\r\n <div\r\n *ngIf=\"!errorTemplate; else errorTemplate\"\r\n class=\"doe-thumbs-error\"\r\n >\r\n <div class=\"doe-thumbs-error-icon\">\u26A0</div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #customThumbTemplate>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n thumbTemplate;\r\n context: { index: i, selectedIndex: selectedIndex, item: item }\r\n \"\r\n ></ng-container>\r\n </ng-template>\r\n </li>\r\n</ul>\r\n\r\n<div\r\n *ngIf=\"showEndArrow\"\r\n class=\"doe-thumbs-arrow doe-thumbs-arrow-next\"\r\n (click)=\"slide(1)\"\r\n>\r\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n",
template: "<div\n *ngIf=\"_showStartArrow\"\n class=\"doe-thumbs-arrow doe-thumbs-arrow-prev\"\n (click)=\"slide(-1)\"\n>\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n\n<ul\n #thumbs\n [style.scrollBehavior]=\"scrollBehavior\"\n tabindex=\"0\"\n [attr.aria-label]=\"aria?.thumbnailsLabel\"\n>\n <li *ngIf=\"!items || !items.length\" class=\"doe-thumbs-initial-item\"></li>\n <li\n #thumb\n *ngFor=\"let item of items; let i = index\"\n [class.doe-thumbs-item--selected]=\"i === selectedIndex\"\n aria-hidden=\"true\"\n (click)=\"_emitEvent(i, item, $event, thumbClick)\"\n (mouseenter)=\"_emitEvent(i, item, $event, thumbHover)\"\n >\n <ng-container *ngIf=\"!thumbTemplate; else customThumbTemplate\">\n <img\n [src]=\"item.thumbSrc || ''\"\n [alt]=\"item.alt\"\n (load)=\"_onLoadChange(item, true)\"\n (error)=\"_onLoadChange(item, false)\"\n />\n\n <ng-container *ngIf=\"item._thumbFailed\">\n <div\n *ngIf=\"!errorTemplate; else errorTemplate\"\n class=\"doe-thumbs-error\"\n >\n <div\n class=\"doe-thumbs-error-icon\"\n [class.doe-thumbs-error-icon--video]=\"isVideo(item)\"\n ></div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-template #customThumbTemplate>\n <ng-container\n *ngTemplateOutlet=\"\n thumbTemplate;\n context: { index: i, selectedIndex: selectedIndex, item: item }\n \"\n ></ng-container>\n </ng-template>\n </li>\n</ul>\n\n<div\n *ngIf=\"_showEndArrow\"\n class=\"doe-thumbs-arrow doe-thumbs-arrow-next\"\n (click)=\"slide(1)\"\n>\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [":host{flex:1 0 auto;position:relative}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;border:1px solid #252525;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:\"\";display:block;position:absolute;left:0;bottom:0;width:100%;height:10px;background-color:#ffffffab;box-shadow:0 0 1px #000}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#222}.doe-thumbs-error-icon{font-size:20px;color:#f5f5f5}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}"]
styles: [":host{flex:1 0 auto;position:relative;background-color:#f3f3f3}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--bottom .doe-thumbs-error,:host.doe-thumbs--top .doe-thumbs-error{border-right:1px solid #cecece}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--left .doe-thumbs-error,:host.doe-thumbs--right .doe-thumbs-error{border-bottom:1px solid #cecece}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:\"\";display:block;position:absolute;left:0;bottom:0;width:100%;height:100%;border:10px solid #ffffffcf;box-sizing:border-box}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#e8e8e8;box-sizing:border-box}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video){position:relative;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid #a5a5a5;margin-left:-8px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after,.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{content:\"\";position:absolute}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{height:10px;width:10px;background-color:#a5a5a5;border-radius:100%;left:14px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after{border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:17px solid #a5a5a5;top:11px}.doe-thumbs-error-icon--video{border-top:16px solid transparent;border-bottom:16px solid transparent;border-left:28px solid #a5a5a5;margin-left:9px}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}"]
}] }

@@ -382,7 +388,9 @@ ];

/** @type {?} */
ThumbsComponent.prototype.showStartArrow;
ThumbsComponent.prototype.isVideo;
/** @type {?} */
ThumbsComponent.prototype.showEndArrow;
ThumbsComponent.prototype._showStartArrow;
/** @type {?} */
ThumbsComponent.prototype.vertical;
ThumbsComponent.prototype._showEndArrow;
/** @type {?} */
ThumbsComponent.prototype._vertical;
/**

@@ -392,3 +400,3 @@ * @type {?}

*/
ThumbsComponent.prototype.destroy$;
ThumbsComponent.prototype._destroy$;
/**

@@ -398,3 +406,3 @@ * @type {?}

*/
ThumbsComponent.prototype.arrowObserver;
ThumbsComponent.prototype._arrowObserver;
/**

@@ -409,3 +417,3 @@ * @type {?}

*/
ThumbsComponent.prototype.smoothScrollAllowed;
ThumbsComponent.prototype._scrollId;
/**

@@ -415,3 +423,3 @@ * @type {?}

*/
ThumbsComponent.prototype.scrollId;
ThumbsComponent.prototype._smoothScrollAllowed;
/**

@@ -426,3 +434,3 @@ * @type {?}

*/
ThumbsComponent.prototype.cd;
ThumbsComponent.prototype._cd;
/**

@@ -432,4 +440,4 @@ * @type {?}

*/
ThumbsComponent.prototype.elRef;
ThumbsComponent.prototype._elRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thumbs.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/thumbs/thumbs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\n\r\nimport {\r\n  isBrowser,\r\n  Orientation,\r\n  SUPPORT,\r\n  ThumbTemplateContext,\r\n} from '../../core';\r\nimport { Aria } from '../../core/aria';\r\nimport { GalleryItemInternal, GalleryItemEvent } from '../../core/gallery-item';\r\n\r\n@Component({\r\n  selector: 'doe-thumbs',\r\n  templateUrl: './thumbs.component.html',\r\n  styleUrls: ['./thumbs.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ThumbsComponent implements OnChanges, OnDestroy {\r\n  @Input() items: GalleryItemInternal[] = [];\r\n  @Input() selectedIndex: number;\r\n  @Input() aria: Aria;\r\n  @Input() orientation: Orientation;\r\n  @Input() arrows: boolean;\r\n  @Input() arrowSlideByLength: number;\r\n  @Input() autoScroll: boolean;\r\n  @Input() thumbTemplate: TemplateRef<ThumbTemplateContext>;\r\n  @Input() arrowTemplate: TemplateRef<void>;\r\n  @Input() errorTemplate: TemplateRef<void>;\r\n  @Input()\r\n  set scrollBehavior(val: ScrollBehavior) {\r\n    this._scrollBehavior = val || 'smooth';\r\n  }\r\n  get scrollBehavior() {\r\n    return this.smoothScrollAllowed ? this._scrollBehavior : 'auto';\r\n  }\r\n\r\n  @Output() thumbClick = new EventEmitter<GalleryItemEvent>();\r\n  @Output() thumbHover = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @ViewChild('thumbs', { static: true }) thumbListRef: ElementRef<HTMLElement>;\r\n  @ViewChildren('thumb') thumbsRef: QueryList<ElementRef<HTMLElement>>;\r\n\r\n  showStartArrow = false;\r\n  showEndArrow = false;\r\n  vertical: boolean;\r\n\r\n  private destroy$ = new Subject();\r\n\r\n  private arrowObserver: IntersectionObserver;\r\n  private _scrollBehavior: ScrollBehavior;\r\n  private smoothScrollAllowed = false;\r\n\r\n  private scrollId: number;\r\n\r\n  @HostBinding('class')\r\n  get cssClass() {\r\n    return `doe-thumbs--${this.orientation}`;\r\n  }\r\n\r\n  private get scrollKey(): string {\r\n    return this.vertical ? 'scrollTop' : 'scrollLeft';\r\n  }\r\n\r\n  private get hostOffsetAxis(): number {\r\n    return this.vertical\r\n      ? this.elRef.nativeElement.offsetHeight\r\n      : this.elRef.nativeElement.offsetWidth;\r\n  }\r\n\r\n  constructor(\r\n    private cd: ChangeDetectorRef,\r\n    private elRef: ElementRef<HTMLElement>\r\n  ) {}\r\n\r\n  ngOnChanges({ arrows, items, orientation }: SimpleChanges) {\r\n    if (orientation && orientation.currentValue != null) {\r\n      const newOrientation: Orientation = orientation.currentValue;\r\n      this.vertical = newOrientation === 'left' || newOrientation === 'right';\r\n    }\r\n    if (arrows) {\r\n      if (arrows.currentValue && this.items && this.items.length) {\r\n        this.observeArrows();\r\n      } else if (!arrows.currentValue) {\r\n        this.showStartArrow = false;\r\n        this.showEndArrow = false;\r\n        this.unobserveArrows();\r\n      }\r\n    }\r\n\r\n    if (items && items.currentValue) {\r\n      const currItems = (items.currentValue || []) as GalleryItemInternal[];\r\n      const prevItems = (items.previousValue || []) as GalleryItemInternal[];\r\n\r\n      if (currItems.length === prevItems.length) {\r\n        return;\r\n      }\r\n\r\n      if (this.arrows && currItems.length) {\r\n        this.observeArrows();\r\n      }\r\n      if (!prevItems.length) {\r\n        setTimeout(() => {\r\n          this.centerThumbIfNeeded(this.selectedIndex);\r\n          this.smoothScrollAllowed = true;\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next(null);\r\n    this.destroy$.complete();\r\n    this.arrowObserver && this.arrowObserver.disconnect();\r\n  }\r\n\r\n  slide(direction: number) {\r\n    let delta: number;\r\n\r\n    if (this.arrowSlideByLength) {\r\n      delta = this.arrowSlideByLength;\r\n    } else {\r\n      // Note: Slide by the full height/width of the gallery\r\n      // or by the overflow of the thumbs - to prevent unnecessary requestAnimationFrame calls while trying to scroll\r\n      // outside of the min/max scroll of the thumbs\r\n      const thumbList = this.thumbListRef.nativeElement as HTMLElement;\r\n      const thumbListScrollAxis = this.vertical\r\n        ? thumbList.scrollHeight\r\n        : thumbList.scrollWidth;\r\n      const thumbListOffsetAxis = this.vertical\r\n        ? thumbList.offsetHeight\r\n        : thumbList.offsetWidth;\r\n\r\n      delta = Math.min(\r\n        thumbListOffsetAxis,\r\n        thumbListScrollAxis - thumbListOffsetAxis\r\n      );\r\n    }\r\n    this.scroll(delta * direction);\r\n  }\r\n\r\n  centerThumbIfNeeded(index: number) {\r\n    if (!this.items || this.items.length <= 1) {\r\n      return;\r\n    }\r\n\r\n    const nextItemEl = this.thumbsRef.toArray()[index].nativeElement;\r\n    const { offsetLeft, offsetTop, offsetWidth, offsetHeight } = nextItemEl;\r\n\r\n    const itemOffset = this.vertical ? offsetTop : offsetLeft;\r\n    const itemOffsetAxis = this.vertical ? offsetHeight : offsetWidth;\r\n\r\n    const hostScrollAxis = this.hostOffsetAxis;\r\n    const thumbListScroll = this.thumbListRef.nativeElement[this.scrollKey];\r\n\r\n    const nextScrollDelta =\r\n      itemOffset + itemOffsetAxis / 2 - hostScrollAxis / 2 - thumbListScroll;\r\n\r\n    if (\r\n      thumbListScroll + hostScrollAxis < itemOffset + itemOffsetAxis ||\r\n      thumbListScroll > itemOffset\r\n    ) {\r\n      this.scroll(nextScrollDelta);\r\n    }\r\n  }\r\n\r\n  select(index: number) {\r\n    this.selectedIndex = index;\r\n    this.cd.detectChanges();\r\n\r\n    if (this.autoScroll) {\r\n      setTimeout(() => this.centerThumbIfNeeded(index));\r\n    }\r\n  }\r\n\r\n  onItemErrored(item: GalleryItemInternal) {\r\n    item._thumbFailed = true;\r\n  }\r\n\r\n  emitEvent(\r\n    index: number,\r\n    item: GalleryItemInternal,\r\n    event: Event,\r\n    emitter: EventEmitter<GalleryItemEvent>\r\n  ) {\r\n    emitter.emit({\r\n      index,\r\n      item,\r\n      event,\r\n    });\r\n  }\r\n\r\n  private scroll(totalScrollDelta: number) {\r\n    if (!isBrowser) {\r\n      return;\r\n    }\r\n    if (SUPPORT.scrollBehavior || this.scrollBehavior === 'auto') {\r\n      this.thumbListRef.nativeElement[this.scrollKey] += totalScrollDelta;\r\n      return;\r\n    }\r\n    if (this.scrollId != null) {\r\n      cancelAnimationFrame(this.scrollId);\r\n    }\r\n\r\n    const totalDistance = Math.abs(totalScrollDelta);\r\n    const startTime = Date.now();\r\n    const baseArrowSlideTime = 200;\r\n    let totalTime = (Math.log10(totalDistance) - 1.1) * baseArrowSlideTime;\r\n    if (totalTime < 0) {\r\n      totalTime = baseArrowSlideTime;\r\n    }\r\n    let currentScroll = 0;\r\n\r\n    // Emulating native scroll-behavior: smooth\r\n    // NOTE: This function is called on per frame basis recursively to create smooth animation.\r\n    // The scroll value is updated proportionally to the time elapsed since the animation's start.\r\n    // The period of requested frames should match the display's refresh rate as recommended in W3C spec.\r\n    const animate = () => {\r\n      const suggestedScroll = Math.ceil(\r\n        ((Date.now() - startTime) / totalTime) * totalDistance\r\n      );\r\n      let frameScroll = Math.min(\r\n        suggestedScroll - currentScroll,\r\n        totalDistance - currentScroll\r\n      );\r\n      frameScroll *= Math.sign(totalScrollDelta);\r\n      currentScroll = suggestedScroll;\r\n\r\n      this.thumbListRef.nativeElement[this.scrollKey] += frameScroll;\r\n\r\n      if (currentScroll <= totalDistance) {\r\n        this.scrollId = requestAnimationFrame(animate);\r\n      }\r\n    };\r\n\r\n    this.scrollId = requestAnimationFrame(animate);\r\n  }\r\n\r\n  private onArrowsObserved: IntersectionObserverCallback = entries => {\r\n    const entryEl1 = entries[0].target as HTMLElement;\r\n    const firstThumbEntry =\r\n      entryEl1 === this.thumbsRef.first.nativeElement ? entries[0] : entries[1];\r\n    const lastThumbEntry =\r\n      entryEl1 === this.thumbsRef.last.nativeElement ? entries[0] : entries[1];\r\n\r\n    if (firstThumbEntry) {\r\n      this.showStartArrow = firstThumbEntry.intersectionRatio < 1;\r\n    }\r\n    if (lastThumbEntry) {\r\n      this.showEndArrow = lastThumbEntry.intersectionRatio < 1;\r\n    }\r\n\r\n    this.cd.detectChanges();\r\n  };\r\n\r\n  private observeArrows() {\r\n    if (!this.arrowObserver) {\r\n      this.arrowObserver = new IntersectionObserver(this.onArrowsObserved, {\r\n        root: this.thumbListRef.nativeElement,\r\n        threshold: 1.0,\r\n      });\r\n    } else {\r\n      this.arrowObserver.disconnect();\r\n    }\r\n    setTimeout(() => {\r\n      this.arrowObserver.observe(this.thumbsRef.first.nativeElement);\r\n      this.arrowObserver.observe(this.thumbsRef.last.nativeElement);\r\n    });\r\n  }\r\n\r\n  private unobserveArrows() {\r\n    this.arrowObserver && this.arrowObserver.disconnect();\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thumbs.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/thumbs/thumbs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\n\nimport {\n  isBrowser,\n  Orientation,\n  SUPPORT,\n  ThumbTemplateContext,\n} from '../../core';\nimport { Aria } from '../../core/aria';\nimport {\n  GalleryItemInternal,\n  GalleryItemEvent,\n  isVideo,\n} from '../../core/gallery-item';\n\n@Component({\n  selector: 'doe-thumbs',\n  templateUrl: './thumbs.component.html',\n  styleUrls: ['./thumbs.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ThumbsComponent implements OnChanges, OnDestroy {\n  @Input() items: GalleryItemInternal[] = [];\n  @Input() selectedIndex: number;\n  @Input() aria: Aria;\n  @Input() orientation: Orientation;\n  @Input() arrows: boolean;\n  @Input() arrowSlideByLength: number;\n  @Input() autoScroll: boolean;\n  @Input() thumbTemplate: TemplateRef<ThumbTemplateContext>;\n  @Input() arrowTemplate: TemplateRef<void>;\n  @Input() errorTemplate: TemplateRef<void>;\n  @Input()\n  set scrollBehavior(val: ScrollBehavior) {\n    this._scrollBehavior = val || 'smooth';\n  }\n  get scrollBehavior() {\n    return this._smoothScrollAllowed ? this._scrollBehavior : 'auto';\n  }\n\n  @Output() thumbClick = new EventEmitter<GalleryItemEvent>();\n  @Output() thumbHover = new EventEmitter<GalleryItemEvent>();\n\n  @ViewChild('thumbs', { static: true }) thumbListRef: ElementRef<HTMLElement>;\n  @ViewChildren('thumb') thumbsRef: QueryList<ElementRef<HTMLElement>>;\n\n  isVideo = isVideo;\n\n  _showStartArrow = false;\n  _showEndArrow = false;\n  _vertical: boolean;\n\n  private _destroy$ = new Subject();\n  private _arrowObserver: IntersectionObserver;\n  private _scrollBehavior: ScrollBehavior;\n  private _scrollId: number;\n  private _smoothScrollAllowed = false;\n\n  @HostBinding('class')\n  get cssClass() {\n    return `doe-thumbs--${this.orientation}`;\n  }\n\n  private get _hostOffsetAxis(): number {\n    return this._vertical\n      ? this._elRef.nativeElement.offsetHeight\n      : this._elRef.nativeElement.offsetWidth;\n  }\n\n  private get _scrollKey(): string {\n    return this._vertical ? 'scrollTop' : 'scrollLeft';\n  }\n\n  constructor(\n    private _cd: ChangeDetectorRef,\n    private _elRef: ElementRef<HTMLElement>\n  ) {}\n\n  ngOnChanges({ arrows, items, orientation }: SimpleChanges) {\n    if (orientation && orientation.currentValue != null) {\n      const newOrientation: Orientation = orientation.currentValue;\n      this._vertical = newOrientation === 'left' || newOrientation === 'right';\n    }\n    if (arrows) {\n      if (arrows.currentValue && this.items && this.items.length) {\n        this.observeArrows();\n      } else if (!arrows.currentValue) {\n        this._showStartArrow = false;\n        this._showEndArrow = false;\n        this.unobserveArrows();\n      }\n    }\n\n    if (items && items.currentValue) {\n      const currItems = (items.currentValue || []) as GalleryItemInternal[];\n      const prevItems = (items.previousValue || []) as GalleryItemInternal[];\n\n      if (currItems.length === prevItems.length) {\n        return;\n      }\n\n      if (this.arrows && currItems.length) {\n        this.observeArrows();\n      }\n      if (!prevItems.length) {\n        setTimeout(() => {\n          this.centerThumbIfNeeded(this.selectedIndex);\n          this._smoothScrollAllowed = true;\n        });\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n    this._arrowObserver && this._arrowObserver.disconnect();\n  }\n\n  slide(direction: number) {\n    let delta: number;\n\n    if (this.arrowSlideByLength) {\n      delta = this.arrowSlideByLength;\n    } else {\n      // Note: Slide by the full height/width of the gallery\n      // or by the overflow of the thumbs - to prevent unnecessary requestAnimationFrame calls while trying to scroll\n      // outside of the min/max scroll of the thumbs\n      const thumbList = this.thumbListRef.nativeElement as HTMLElement;\n      const thumbListScrollAxis = this._vertical\n        ? thumbList.scrollHeight\n        : thumbList.scrollWidth;\n      const thumbListOffsetAxis = this._vertical\n        ? thumbList.offsetHeight\n        : thumbList.offsetWidth;\n\n      delta = Math.min(\n        thumbListOffsetAxis,\n        thumbListScrollAxis - thumbListOffsetAxis\n      );\n    }\n    this.scroll(delta * direction);\n  }\n\n  centerThumbIfNeeded(index: number) {\n    if (!this.items || this.items.length <= 1) {\n      return;\n    }\n\n    const nextItemEl = this.thumbsRef.toArray()[index].nativeElement;\n\n    if (!nextItemEl) {\n      return;\n    }\n\n    const { offsetLeft, offsetTop, offsetWidth, offsetHeight } = nextItemEl;\n\n    const itemOffset = this._vertical ? offsetTop : offsetLeft;\n    const itemOffsetAxis = this._vertical ? offsetHeight : offsetWidth;\n\n    const hostScrollAxis = this._hostOffsetAxis;\n    const thumbListScroll = this.thumbListRef.nativeElement[this._scrollKey];\n\n    const nextScrollDelta =\n      itemOffset + itemOffsetAxis / 2 - hostScrollAxis / 2 - thumbListScroll;\n\n    if (\n      thumbListScroll + hostScrollAxis < itemOffset + itemOffsetAxis ||\n      thumbListScroll > itemOffset\n    ) {\n      this.scroll(nextScrollDelta);\n    }\n  }\n\n  select(index: number) {\n    this.selectedIndex = index;\n    this._cd.detectChanges();\n\n    if (this.autoScroll) {\n      setTimeout(() => this.centerThumbIfNeeded(index));\n    }\n  }\n\n  _emitEvent(\n    index: number,\n    item: GalleryItemInternal,\n    event: Event,\n    emitter: EventEmitter<GalleryItemEvent>\n  ) {\n    emitter.emit({\n      index,\n      item,\n      event,\n    });\n  }\n\n  _onLoadChange(item: GalleryItemInternal, success: boolean) {\n    item._thumbFailed = !success;\n  }\n\n  private scroll(totalScrollDelta: number) {\n    if (!isBrowser) {\n      return;\n    }\n    if (SUPPORT.scrollBehavior || this.scrollBehavior === 'auto') {\n      this.thumbListRef.nativeElement[this._scrollKey] += totalScrollDelta;\n      return;\n    }\n    if (this._scrollId != null) {\n      cancelAnimationFrame(this._scrollId);\n    }\n\n    const totalDistance = Math.abs(totalScrollDelta);\n    const startTime = Date.now();\n    const baseArrowSlideTime = 200;\n    let totalTime = (Math.log10(totalDistance) - 1.1) * baseArrowSlideTime;\n    if (totalTime < 0) {\n      totalTime = baseArrowSlideTime;\n    }\n    let currentScroll = 0;\n\n    // Emulating native scroll-behavior: smooth\n    // NOTE: This function is called on per frame basis recursively to create smooth animation.\n    // The scroll value is updated proportionally to the time elapsed since the animation's start.\n    // The period of requested frames should match the display's refresh rate as recommended in W3C spec.\n    const animate = () => {\n      const suggestedScroll = Math.ceil(\n        ((Date.now() - startTime) / totalTime) * totalDistance\n      );\n      let frameScroll = Math.min(\n        suggestedScroll - currentScroll,\n        totalDistance - currentScroll\n      );\n      frameScroll *= Math.sign(totalScrollDelta);\n      currentScroll = suggestedScroll;\n\n      this.thumbListRef.nativeElement[this._scrollKey] += frameScroll;\n\n      if (currentScroll <= totalDistance) {\n        this._scrollId = requestAnimationFrame(animate);\n      }\n    };\n\n    this._scrollId = requestAnimationFrame(animate);\n  }\n\n  private onArrowsObserved: IntersectionObserverCallback = entries => {\n    const entryEl1 = entries[0].target as HTMLElement;\n    const firstThumbEntry =\n      entryEl1 === this.thumbsRef.first.nativeElement ? entries[0] : entries[1];\n    const lastThumbEntry =\n      entryEl1 === this.thumbsRef.last.nativeElement ? entries[0] : entries[1];\n\n    if (firstThumbEntry) {\n      this._showStartArrow = firstThumbEntry.intersectionRatio < 1;\n    }\n    if (lastThumbEntry) {\n      this._showEndArrow = lastThumbEntry.intersectionRatio < 1;\n    }\n\n    this._cd.detectChanges();\n  };\n\n  private observeArrows() {\n    if (!this._arrowObserver) {\n      this._arrowObserver = new IntersectionObserver(this.onArrowsObserved, {\n        root: this.thumbListRef.nativeElement,\n        threshold: 1.0,\n      });\n    } else {\n      this._arrowObserver.disconnect();\n    }\n    setTimeout(() => {\n      this._arrowObserver.observe(this.thumbsRef.first.nativeElement);\n      this._arrowObserver.observe(this.thumbsRef.last.nativeElement);\n    });\n  }\n\n  private unobserveArrows() {\n    this._arrowObserver && this._arrowObserver.disconnect();\n  }\n}\n"]}

@@ -24,2 +24,2 @@ /**

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJpYS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2FyaWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSwwQkFJQzs7O0lBSEMsNEJBQXFCOztJQUNyQiwyQkFBb0I7O0lBQ3BCLCtCQUF3Qjs7O0FBRzFCLE1BQU0sT0FBTyxXQUFXLEdBQVM7SUFDL0IsWUFBWSxFQUFFLGVBQWU7SUFDN0IsV0FBVyxFQUFFLHlCQUF5QjtJQUN0QyxlQUFlLEVBQUUsb0JBQW9CO0NBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBcmlhIHtcclxuICBnYWxsZXJ5TGFiZWw6IHN0cmluZztcclxuICB2aWV3ZXJMYWJlbDogc3RyaW5nO1xyXG4gIHRodW1ibmFpbHNMYWJlbDogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZGVmYXVsdEFyaWE6IEFyaWEgPSB7XHJcbiAgZ2FsbGVyeUxhYmVsOiAnSW1hZ2UgR2FsbGVyeScsXHJcbiAgdmlld2VyTGFiZWw6ICdEaXNwbGF5ZWQgZ2FsbGVyeSBpbWFnZScsXHJcbiAgdGh1bWJuYWlsc0xhYmVsOiAnR2FsbGVyeSB0aHVtYm5haWxzJ1xyXG59O1xyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJpYS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2FyaWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSwwQkFJQzs7O0lBSEMsNEJBQXFCOztJQUNyQiwyQkFBb0I7O0lBQ3BCLCtCQUF3Qjs7O0FBRzFCLE1BQU0sT0FBTyxXQUFXLEdBQVM7SUFDL0IsWUFBWSxFQUFFLGVBQWU7SUFDN0IsV0FBVyxFQUFFLHlCQUF5QjtJQUN0QyxlQUFlLEVBQUUsb0JBQW9CO0NBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBcmlhIHtcbiAgZ2FsbGVyeUxhYmVsOiBzdHJpbmc7XG4gIHZpZXdlckxhYmVsOiBzdHJpbmc7XG4gIHRodW1ibmFpbHNMYWJlbDogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdEFyaWE6IEFyaWEgPSB7XG4gIGdhbGxlcnlMYWJlbDogJ0ltYWdlIEdhbGxlcnknLFxuICB2aWV3ZXJMYWJlbDogJ0Rpc3BsYXllZCBnYWxsZXJ5IGltYWdlJyxcbiAgdGh1bWJuYWlsc0xhYmVsOiAnR2FsbGVyeSB0aHVtYm5haWxzJ1xufTtcbiJdfQ==

@@ -141,7 +141,2 @@ /**

/**
* Marks item as seen at least once
* @type {?|undefined}
*/
GalleryItemInternal.prototype._seen;
/**
* `true` when media couldn't be loaded

@@ -157,2 +152,8 @@ * @type {?|undefined}

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS1pdGVtLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL2NvcmUvZ2FsbGVyeS1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsTUFBTSxPQUFnQixXQUFXOzs7Ozs7OztJQUMvQixZQUlTLEdBQVcsRUFLWCxRQUFnQixFQUtoQixHQUFXLEVBS1gsV0FBbUIsRUFLbkIsSUFBUztRQXBCVCxRQUFHLEdBQUgsR0FBRyxDQUFRO1FBS1gsYUFBUSxHQUFSLFFBQVEsQ0FBUTtRQUtoQixRQUFHLEdBQUgsR0FBRyxDQUFRO1FBS1gsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFLbkIsU0FBSSxHQUFKLElBQUksQ0FBSztJQUNmLENBQUM7Q0FDTDs7Ozs7O0lBdEJHLDBCQUFrQjs7Ozs7SUFLbEIsK0JBQXVCOzs7OztJQUt2QiwwQkFBa0I7Ozs7O0lBS2xCLGtDQUEwQjs7Ozs7SUFLMUIsMkJBQWdCOzs7Ozs7QUFPcEIsbUNBb0JDOzs7Ozs7SUFoQkMsK0JBQWU7Ozs7O0lBS2YsOEJBQWU7Ozs7O0lBS2YsOEJBQWU7Ozs7O0lBS2YsNkJBQWM7O0FBR2hCLE1BQU0sT0FBTyxZQUFhLFNBQVEsV0FBVzs7Ozs7Ozs7O0lBQzNDLFlBQ0UsR0FBRyxFQUNILFFBQVMsRUFDVCxHQUFJLEVBQ0osV0FBWSxFQUtMLGNBQWdDLEVBRXZDLElBQUs7UUFFTCxLQUFLLENBQUMsR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBSnRDLG1CQUFjLEdBQWQsY0FBYyxDQUFrQjtJQUt6QyxDQUFDO0NBQ0Y7Ozs7OztJQU5HLHNDQUF1Qzs7QUFRM0MsTUFBTSxPQUFPLFlBQWEsU0FBUSxXQUFXOzs7Ozs7OztJQUMzQyxZQUFZLEdBQUcsRUFBRSxRQUFTLEVBQUUsR0FBSSxFQUFFLFdBQVksRUFBRSxJQUFLO1FBQ25ELEtBQUssQ0FBQyxHQUFHLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDL0MsQ0FBQztDQUNGOzs7O0FBRUQsc0NBWUM7Ozs7OztJQVJDLGlDQUFjOztJQUVkLGdDQUFrQjs7Ozs7SUFLbEIsaUNBQWE7Ozs7O0FBR2YseUNBb0JDOzs7Ozs7SUFoQkMsc0NBQWtCOzs7OztJQUtsQixvQ0FBZ0I7Ozs7O0lBS2hCLHNDQUFrQjs7Ozs7SUFLbEIsMkNBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGFic3RyYWN0IGNsYXNzIEdhbGxlcnlJdGVtIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIC8qKlxyXG4gICAgICogTWVkaWEgdXJsXHJcbiAgICAgKi9cclxuICAgIHB1YmxpYyBzcmM6IHN0cmluZyxcclxuXHJcbiAgICAvKipcclxuICAgICAqIFVybCBvZiBtZWRpYSB0aHVtYm5haWxcclxuICAgICAqL1xyXG4gICAgcHVibGljIHRodW1iU3JjOiBzdHJpbmcsXHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBBbHQgdGV4dCBmb3Igbm90IHlldCBsb2FkZWQgaW1hZ2VcclxuICAgICAqL1xyXG4gICAgcHVibGljIGFsdDogc3RyaW5nLFxyXG5cclxuICAgIC8qKlxyXG4gICAgICogRGVzY3JpcHRpb24gdGhhdCBpcyB0byBiZSBzaG93biBvbiB0aGUgY3VycmVudGx5IGRpc3BsYXllZCBnYWxsZXJ5IGl0ZW1cclxuICAgICAqL1xyXG4gICAgcHVibGljIGRlc2NyaXB0aW9uOiBzdHJpbmcsXHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBDdXN0b20gZGF0YSB3aGVyZSB5b3UgY2FuIHB1dCB3aGF0ZXZlciB5b3Ugd2FudFxyXG4gICAgICovXHJcbiAgICBwdWJsaWMgZGF0YTogYW55XHJcbiAgKSB7fVxyXG59XHJcblxyXG4vKipcclxuICogVGhlIHdob2xlIGludGVyZmFjZSBtaXJyb3JzIDxzb3VyY2U+IGF0dHJpYnV0ZXMgZnJvbSB0aGUgV0hBVFdHIHNwZWMuXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFBpY3R1cmVTb3VyY2Uge1xyXG4gIC8qKlxyXG4gICAqIHNyYyBVUkxcclxuICAgKi9cclxuICBzcmNzZXQ6IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgICogQ1NTIG1lZGlhIHNlbGVjdG9yXHJcbiAgICovXHJcbiAgbWVkaWE/OiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIEdpdmUgaGludCB0byBicm93c2VyIHdoaWNoIHNyYyBmcm9tIHNyY3NldCB0byBwaWNrXHJcbiAgICovXHJcbiAgc2l6ZXM/OiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIE1JTUUgbWVkaWEgdHlwZVxyXG4gICAqL1xyXG4gIHR5cGU/OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBHYWxsZXJ5SW1hZ2UgZXh0ZW5kcyBHYWxsZXJ5SXRlbSB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBzcmMsXHJcbiAgICB0aHVtYlNyYz8sXHJcbiAgICBhbHQ/LFxyXG4gICAgZGVzY3JpcHRpb24/LFxyXG5cclxuICAgIC8qKlxyXG4gICAgICogU291cmNlcyBmb3IgPHBpY3R1cmU+XHJcbiAgICAgKi9cclxuICAgIHB1YmxpYyBwaWN0dXJlU291cmNlcz86IFBpY3R1cmVTb3VyY2VbXSxcclxuXHJcbiAgICBkYXRhP1xyXG4gICkge1xyXG4gICAgc3VwZXIoc3JjLCB0aHVtYlNyYywgYWx0LCBkZXNjcmlwdGlvbiwgZGF0YSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgR2FsbGVyeVZpZGVvIGV4dGVuZHMgR2FsbGVyeUl0ZW0ge1xyXG4gIGNvbnN0cnVjdG9yKHNyYywgdGh1bWJTcmM/LCBhbHQ/LCBkZXNjcmlwdGlvbj8sIGRhdGE/KSB7XHJcbiAgICBzdXBlcihzcmMsIHRodW1iU3JjLCBhbHQsIGRlc2NyaXB0aW9uLCBkYXRhKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR2FsbGVyeUl0ZW1FdmVudCB7XHJcbiAgLyoqXHJcbiAgICogSW5kZXggb2YgdGhlIGl0ZW1cclxuICAgKi9cclxuICBpbmRleDogbnVtYmVyO1xyXG5cclxuICBpdGVtOiBHYWxsZXJ5SXRlbTtcclxuXHJcbiAgLyoqXHJcbiAgICogRE9NIGV2ZW50XHJcbiAgICovXHJcbiAgZXZlbnQ6IEV2ZW50O1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEdhbGxlcnlJdGVtSW50ZXJuYWwgZXh0ZW5kcyBHYWxsZXJ5SW1hZ2UsIEdhbGxlcnlWaWRlbyB7XHJcbiAgLyoqXHJcbiAgICogTWFya3MgaXRlbSBhcyBsb2FkZWQgb25jZSBpdHMgbWVkaWEgZ2V0cyBsb2FkZWRcclxuICAgKi9cclxuICBfbG9hZGVkPzogYm9vbGVhbjtcclxuXHJcbiAgLyoqXHJcbiAgICogTWFya3MgaXRlbSBhcyBzZWVuIGF0IGxlYXN0IG9uY2VcclxuICAgKi9cclxuICBfc2Vlbj86IGJvb2xlYW47XHJcblxyXG4gIC8qKlxyXG4gICAqIGB0cnVlYCB3aGVuIG1lZGlhIGNvdWxkbid0IGJlIGxvYWRlZFxyXG4gICAqL1xyXG4gIF9mYWlsZWQ/OiBib29sZWFuO1xyXG5cclxuICAvKipcclxuICAgKiBgdHJ1ZWAgd2hlbiB0aHVtYm5haWwgY291bGRuJ3QgYmUgbG9hZGVkXHJcbiAgICovXHJcbiAgX3RodW1iRmFpbGVkPzogYm9vbGVhbjtcclxufVxyXG4iXX0=
/** @type {?} */
export const isVideo = (/**
* @param {?} item
* @return {?}
*/
(item) => item instanceof GalleryVideo);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS1pdGVtLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL2NvcmUvZ2FsbGVyeS1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsTUFBTSxPQUFnQixXQUFXOzs7Ozs7OztJQUMvQixZQUlTLEdBQVcsRUFLWCxRQUFnQixFQUtoQixHQUFXLEVBS1gsV0FBbUIsRUFLbkIsSUFBUztRQXBCVCxRQUFHLEdBQUgsR0FBRyxDQUFRO1FBS1gsYUFBUSxHQUFSLFFBQVEsQ0FBUTtRQUtoQixRQUFHLEdBQUgsR0FBRyxDQUFRO1FBS1gsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFLbkIsU0FBSSxHQUFKLElBQUksQ0FBSztJQUNmLENBQUM7Q0FDTDs7Ozs7O0lBdEJHLDBCQUFrQjs7Ozs7SUFLbEIsK0JBQXVCOzs7OztJQUt2QiwwQkFBa0I7Ozs7O0lBS2xCLGtDQUEwQjs7Ozs7SUFLMUIsMkJBQWdCOzs7Ozs7QUFPcEIsbUNBb0JDOzs7Ozs7SUFoQkMsK0JBQWU7Ozs7O0lBS2YsOEJBQWU7Ozs7O0lBS2YsOEJBQWU7Ozs7O0lBS2YsNkJBQWM7O0FBR2hCLE1BQU0sT0FBTyxZQUFhLFNBQVEsV0FBVzs7Ozs7Ozs7O0lBQzNDLFlBQ0UsR0FBRyxFQUNILFFBQVMsRUFDVCxHQUFJLEVBQ0osV0FBWSxFQUtMLGNBQWdDLEVBRXZDLElBQUs7UUFFTCxLQUFLLENBQUMsR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBSnRDLG1CQUFjLEdBQWQsY0FBYyxDQUFrQjtJQUt6QyxDQUFDO0NBQ0Y7Ozs7OztJQU5HLHNDQUF1Qzs7QUFRM0MsTUFBTSxPQUFPLFlBQWEsU0FBUSxXQUFXOzs7Ozs7OztJQUMzQyxZQUFZLEdBQUcsRUFBRSxRQUFTLEVBQUUsR0FBSSxFQUFFLFdBQVksRUFBRSxJQUFLO1FBQ25ELEtBQUssQ0FBQyxHQUFHLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDL0MsQ0FBQztDQUNGOzs7O0FBRUQsc0NBWUM7Ozs7OztJQVJDLGlDQUFjOztJQUVkLGdDQUFrQjs7Ozs7SUFLbEIsaUNBQWE7Ozs7O0FBR2YseUNBZUM7Ozs7OztJQVhDLHNDQUFrQjs7Ozs7SUFLbEIsc0NBQWtCOzs7OztJQUtsQiwyQ0FBdUI7OztBQUd6QixNQUFNLE9BQU8sT0FBTzs7OztBQUFHLENBQUMsSUFBaUIsRUFBRSxFQUFFLENBQUMsSUFBSSxZQUFZLFlBQVksQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBhYnN0cmFjdCBjbGFzcyBHYWxsZXJ5SXRlbSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIC8qKlxuICAgICAqIE1lZGlhIHVybFxuICAgICAqL1xuICAgIHB1YmxpYyBzcmM6IHN0cmluZyxcblxuICAgIC8qKlxuICAgICAqIFVybCBvZiBtZWRpYSB0aHVtYm5haWxcbiAgICAgKi9cbiAgICBwdWJsaWMgdGh1bWJTcmM6IHN0cmluZyxcblxuICAgIC8qKlxuICAgICAqIEFsdCB0ZXh0IGZvciBub3QgeWV0IGxvYWRlZCBpbWFnZVxuICAgICAqL1xuICAgIHB1YmxpYyBhbHQ6IHN0cmluZyxcblxuICAgIC8qKlxuICAgICAqIERlc2NyaXB0aW9uIHRoYXQgaXMgdG8gYmUgc2hvd24gb24gdGhlIGN1cnJlbnRseSBkaXNwbGF5ZWQgZ2FsbGVyeSBpdGVtXG4gICAgICovXG4gICAgcHVibGljIGRlc2NyaXB0aW9uOiBzdHJpbmcsXG5cbiAgICAvKipcbiAgICAgKiBDdXN0b20gZGF0YSB3aGVyZSB5b3UgY2FuIHB1dCB3aGF0ZXZlciB5b3Ugd2FudFxuICAgICAqL1xuICAgIHB1YmxpYyBkYXRhOiBhbnlcbiAgKSB7fVxufVxuXG4vKipcbiAqIFRoZSB3aG9sZSBpbnRlcmZhY2UgbWlycm9ycyA8c291cmNlPiBhdHRyaWJ1dGVzIGZyb20gdGhlIFdIQVRXRyBzcGVjLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBpY3R1cmVTb3VyY2Uge1xuICAvKipcbiAgICogc3JjIFVSTFxuICAgKi9cbiAgc3Jjc2V0OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIENTUyBtZWRpYSBzZWxlY3RvclxuICAgKi9cbiAgbWVkaWE/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEdpdmUgaGludCB0byBicm93c2VyIHdoaWNoIHNyYyBmcm9tIHNyY3NldCB0byBwaWNrXG4gICAqL1xuICBzaXplcz86IHN0cmluZztcblxuICAvKipcbiAgICogTUlNRSBtZWRpYSB0eXBlXG4gICAqL1xuICB0eXBlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgR2FsbGVyeUltYWdlIGV4dGVuZHMgR2FsbGVyeUl0ZW0ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBzcmMsXG4gICAgdGh1bWJTcmM/LFxuICAgIGFsdD8sXG4gICAgZGVzY3JpcHRpb24/LFxuXG4gICAgLyoqXG4gICAgICogU291cmNlcyBmb3IgPHBpY3R1cmU+XG4gICAgICovXG4gICAgcHVibGljIHBpY3R1cmVTb3VyY2VzPzogUGljdHVyZVNvdXJjZVtdLFxuXG4gICAgZGF0YT9cbiAgKSB7XG4gICAgc3VwZXIoc3JjLCB0aHVtYlNyYywgYWx0LCBkZXNjcmlwdGlvbiwgZGF0YSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEdhbGxlcnlWaWRlbyBleHRlbmRzIEdhbGxlcnlJdGVtIHtcbiAgY29uc3RydWN0b3Ioc3JjLCB0aHVtYlNyYz8sIGFsdD8sIGRlc2NyaXB0aW9uPywgZGF0YT8pIHtcbiAgICBzdXBlcihzcmMsIHRodW1iU3JjLCBhbHQsIGRlc2NyaXB0aW9uLCBkYXRhKTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdhbGxlcnlJdGVtRXZlbnQge1xuICAvKipcbiAgICogSW5kZXggb2YgdGhlIGl0ZW1cbiAgICovXG4gIGluZGV4OiBudW1iZXI7XG5cbiAgaXRlbTogR2FsbGVyeUl0ZW07XG5cbiAgLyoqXG4gICAqIERPTSBldmVudFxuICAgKi9cbiAgZXZlbnQ6IEV2ZW50O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdhbGxlcnlJdGVtSW50ZXJuYWwgZXh0ZW5kcyBHYWxsZXJ5SW1hZ2UsIEdhbGxlcnlWaWRlbyB7XG4gIC8qKlxuICAgKiBNYXJrcyBpdGVtIGFzIGxvYWRlZCBvbmNlIGl0cyBtZWRpYSBnZXRzIGxvYWRlZFxuICAgKi9cbiAgX2xvYWRlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIGB0cnVlYCB3aGVuIG1lZGlhIGNvdWxkbid0IGJlIGxvYWRlZFxuICAgKi9cbiAgX2ZhaWxlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIGB0cnVlYCB3aGVuIHRodW1ibmFpbCBjb3VsZG4ndCBiZSBsb2FkZWRcbiAgICovXG4gIF90aHVtYkZhaWxlZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBpc1ZpZGVvID0gKGl0ZW06IEdhbGxlcnlJdGVtKSA9PiBpdGVtIGluc3RhbmNlb2YgR2FsbGVyeVZpZGVvO1xuIl19

@@ -12,2 +12,2 @@ /**

export {} from './template-contexts';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHVDQUFjLFdBQVcsQ0FBQztBQUMxQixPQUFPLEVBQ0wsV0FBVyxFQUNYLFlBQVksRUFDWixZQUFZLEVBRWIsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixlQUFjLGNBQWMsQ0FBQztBQUM3QixlQUFjLFdBQVcsQ0FBQztBQUMxQiw2QkFBYyxlQUFlLENBQUM7QUFDOUIsZUFBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XHJcbmV4cG9ydCB7XHJcbiAgR2FsbGVyeUl0ZW0sXHJcbiAgR2FsbGVyeUltYWdlLFxyXG4gIEdhbGxlcnlWaWRlbyxcclxuICBHYWxsZXJ5SXRlbUV2ZW50XHJcbn0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xyXG5leHBvcnQgKiBmcm9tICcuL29iamVjdC1maXQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xvYWRpbmcnO1xyXG5leHBvcnQgKiBmcm9tICcuL29yaWVudGF0aW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi90ZW1wbGF0ZS1jb250ZXh0cyc7XHJcbmV4cG9ydCB7IEFyaWEgfSBmcm9tICcuL2FyaWEnO1xyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHVDQUFjLFdBQVcsQ0FBQztBQUMxQixPQUFPLEVBQ0wsV0FBVyxFQUNYLFlBQVksRUFDWixZQUFZLEVBRWIsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixlQUFjLGNBQWMsQ0FBQztBQUM3QixlQUFjLFdBQVcsQ0FBQztBQUMxQiw2QkFBYyxlQUFlLENBQUM7QUFDOUIsZUFBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XG5leHBvcnQge1xuICBHYWxsZXJ5SXRlbSxcbiAgR2FsbGVyeUltYWdlLFxuICBHYWxsZXJ5VmlkZW8sXG4gIEdhbGxlcnlJdGVtRXZlbnRcbn0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xuZXhwb3J0ICogZnJvbSAnLi9vYmplY3QtZml0JztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZyc7XG5leHBvcnQgKiBmcm9tICcuL29yaWVudGF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vdGVtcGxhdGUtY29udGV4dHMnO1xuZXhwb3J0IHsgQXJpYSB9IGZyb20gJy4vYXJpYSc7XG4iXX0=

@@ -6,2 +6,2 @@ /**

*/
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2xvYWRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIExvYWRpbmcgPSAnYXV0bycgfCAnbGF6eSc7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2xvYWRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIExvYWRpbmcgPSAnYXV0bycgfCAnbGF6eSc7XG4iXX0=

@@ -6,2 +6,2 @@ /**

*/
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWZpdC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL29iamVjdC1maXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE9iamVjdEZpdCA9ICdjb250YWluJyB8ICdjb3Zlcic7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWZpdC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL29iamVjdC1maXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE9iamVjdEZpdCA9ICdjb250YWluJyB8ICdjb3Zlcic7XG4iXX0=

@@ -23,2 +23,2 @@ /**

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JpZW50YXRpb24uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9vcmllbnRhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQSxNQUFrQixlQUFlO0lBQy9CLElBQUksR0FBSTtJQUNSLEtBQUssR0FBSTtJQUNULEdBQUcsR0FBSTtJQUNQLE1BQU0sSUFBSztJQUNYLFVBQVUsR0FBSTtJQUNkLFFBQVEsSUFBSztFQUNkOzs7QUFFRCxNQUFNLE9BQU8sWUFBWSxHQUFHO0lBQzFCLElBQUksY0FBc0I7SUFDMUIsS0FBSyxlQUF1QjtJQUM1QixHQUFHLGFBQXFCO0lBQ3hCLE1BQU0saUJBQXdCO0NBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgT3JpZW50YXRpb24gPSAndG9wJyB8ICdib3R0b20nIHwgJ2xlZnQnIHwgJ3JpZ2h0JztcclxuXHJcbmV4cG9ydCB0eXBlIFZlcnRpY2FsT3JpZW50YXRpb24gPSAndG9wJyB8ICdib3R0b20nO1xyXG5cclxuZXhwb3J0IGNvbnN0IGVudW0gT3JpZW50YXRpb25GbGFnIHtcclxuICBMRUZUID0gMixcclxuICBSSUdIVCA9IDQsXHJcbiAgVE9QID0gOCxcclxuICBCT1RUT00gPSAxNixcclxuICBIT1JJWk9OVEFMID0gNixcclxuICBWRVJUSUNBTCA9IDI0XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBvcmllbnRhdGlvbnMgPSB7XHJcbiAgbGVmdDogT3JpZW50YXRpb25GbGFnLkxFRlQsXHJcbiAgcmlnaHQ6IE9yaWVudGF0aW9uRmxhZy5SSUdIVCxcclxuICB0b3A6IE9yaWVudGF0aW9uRmxhZy5UT1AsXHJcbiAgYm90dG9tOiBPcmllbnRhdGlvbkZsYWcuQk9UVE9NXHJcbn07XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JpZW50YXRpb24uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9vcmllbnRhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQSxNQUFrQixlQUFlO0lBQy9CLElBQUksR0FBSTtJQUNSLEtBQUssR0FBSTtJQUNULEdBQUcsR0FBSTtJQUNQLE1BQU0sSUFBSztJQUNYLFVBQVUsR0FBSTtJQUNkLFFBQVEsSUFBSztFQUNkOzs7QUFFRCxNQUFNLE9BQU8sWUFBWSxHQUFHO0lBQzFCLElBQUksY0FBc0I7SUFDMUIsS0FBSyxlQUF1QjtJQUM1QixHQUFHLGFBQXFCO0lBQ3hCLE1BQU0saUJBQXdCO0NBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgT3JpZW50YXRpb24gPSAndG9wJyB8ICdib3R0b20nIHwgJ2xlZnQnIHwgJ3JpZ2h0JztcblxuZXhwb3J0IHR5cGUgVmVydGljYWxPcmllbnRhdGlvbiA9ICd0b3AnIHwgJ2JvdHRvbSc7XG5cbmV4cG9ydCBjb25zdCBlbnVtIE9yaWVudGF0aW9uRmxhZyB7XG4gIExFRlQgPSAyLFxuICBSSUdIVCA9IDQsXG4gIFRPUCA9IDgsXG4gIEJPVFRPTSA9IDE2LFxuICBIT1JJWk9OVEFMID0gNixcbiAgVkVSVElDQUwgPSAyNFxufVxuXG5leHBvcnQgY29uc3Qgb3JpZW50YXRpb25zID0ge1xuICBsZWZ0OiBPcmllbnRhdGlvbkZsYWcuTEVGVCxcbiAgcmlnaHQ6IE9yaWVudGF0aW9uRmxhZy5SSUdIVCxcbiAgdG9wOiBPcmllbnRhdGlvbkZsYWcuVE9QLFxuICBib3R0b206IE9yaWVudGF0aW9uRmxhZy5CT1RUT01cbn07XG4iXX0=

@@ -18,2 +18,2 @@ /**

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwcG9ydC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL3N1cHBvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsTUFBTSxPQUFPLFNBQVMsR0FBRyxPQUFPLE1BQU0sS0FBSyxXQUFXOztBQUV0RCxNQUFNLE9BQU8sT0FBTyxHQUFHO0lBQ3JCLGNBQWMsRUFBRSxTQUFTLElBQUksZ0JBQWdCLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLO0lBQ3BFLGtCQUFrQixFQUFFLFNBQVMsSUFBSSxTQUFTLElBQUksS0FBSyxDQUFDLFNBQVM7SUFDN0Qsb0JBQW9CLEVBQUUsU0FBUyxJQUFJLHNCQUFzQixJQUFJLE1BQU07Q0FDcEU7O0FBRUQsTUFBTSxPQUFPLEVBQUUsR0FBRztJQUNoQixHQUFHLEVBQUUsU0FBUyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUM7Q0FDdkUiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXNCcm93c2VyID0gdHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCc7XHJcblxyXG5leHBvcnQgY29uc3QgU1VQUE9SVCA9IHtcclxuICBzY3JvbGxCZWhhdmlvcjogaXNCcm93c2VyICYmICdzY3JvbGxCZWhhdmlvcicgaW4gZG9jdW1lbnQuYm9keS5zdHlsZSxcclxuICBuYXRpdmVNZWRpYUxvYWRpbmc6IGlzQnJvd3NlciAmJiAnbG9hZGluZycgaW4gSW1hZ2UucHJvdG90eXBlLFxyXG4gIGludGVyc2VjdGlvbk9ic2VydmVyOiBpc0Jyb3dzZXIgJiYgJ0ludGVyc2VjdGlvbk9ic2VydmVyJyBpbiB3aW5kb3dcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBVQSA9IHtcclxuICBpb3M6IGlzQnJvd3NlciAmJiAhIXdpbmRvdy5uYXZpZ2F0b3IudXNlckFnZW50Lm1hdGNoKC9pUChhZHxob25lfG9kKS8pXHJcbn07XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwcG9ydC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL3N1cHBvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsTUFBTSxPQUFPLFNBQVMsR0FBRyxPQUFPLE1BQU0sS0FBSyxXQUFXOztBQUV0RCxNQUFNLE9BQU8sT0FBTyxHQUFHO0lBQ3JCLGNBQWMsRUFBRSxTQUFTLElBQUksZ0JBQWdCLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLO0lBQ3BFLGtCQUFrQixFQUFFLFNBQVMsSUFBSSxTQUFTLElBQUksS0FBSyxDQUFDLFNBQVM7SUFDN0Qsb0JBQW9CLEVBQUUsU0FBUyxJQUFJLHNCQUFzQixJQUFJLE1BQU07Q0FDcEU7O0FBRUQsTUFBTSxPQUFPLEVBQUUsR0FBRztJQUNoQixHQUFHLEVBQUUsU0FBUyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUM7Q0FDdkUiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXNCcm93c2VyID0gdHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCc7XG5cbmV4cG9ydCBjb25zdCBTVVBQT1JUID0ge1xuICBzY3JvbGxCZWhhdmlvcjogaXNCcm93c2VyICYmICdzY3JvbGxCZWhhdmlvcicgaW4gZG9jdW1lbnQuYm9keS5zdHlsZSxcbiAgbmF0aXZlTWVkaWFMb2FkaW5nOiBpc0Jyb3dzZXIgJiYgJ2xvYWRpbmcnIGluIEltYWdlLnByb3RvdHlwZSxcbiAgaW50ZXJzZWN0aW9uT2JzZXJ2ZXI6IGlzQnJvd3NlciAmJiAnSW50ZXJzZWN0aW9uT2JzZXJ2ZXInIGluIHdpbmRvd1xufTtcblxuZXhwb3J0IGNvbnN0IFVBID0ge1xuICBpb3M6IGlzQnJvd3NlciAmJiAhIXdpbmRvdy5uYXZpZ2F0b3IudXNlckFnZW50Lm1hdGNoKC9pUChhZHxob25lfG9kKS8pXG59O1xuIl19

@@ -18,3 +18,3 @@ /**

/** @type {?} */
ItemTemplateContext.prototype.seen;
ItemTemplateContext.prototype.video;
}

@@ -33,2 +33,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS90ZW1wbGF0ZS1jb250ZXh0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUVBLHlDQUtDOzs7SUFKQyxvQ0FBYzs7SUFDZCw0Q0FBc0I7O0lBQ3RCLG1DQUFrQjs7SUFDbEIsbUNBQWM7Ozs7O0FBR2hCLDBDQUlDOzs7SUFIQyxxQ0FBYzs7SUFDZCw2Q0FBc0I7O0lBQ3RCLG9DQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdhbGxlcnlJdGVtIH0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJdGVtVGVtcGxhdGVDb250ZXh0IHtcclxuICBpbmRleDogbnVtYmVyO1xyXG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcclxuICBpdGVtOiBHYWxsZXJ5SXRlbTtcclxuICBzZWVuOiBib29sZWFuO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRodW1iVGVtcGxhdGVDb250ZXh0IHtcclxuICBpbmRleDogbnVtYmVyO1xyXG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcclxuICBpdGVtOiBHYWxsZXJ5SXRlbTtcclxufVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS90ZW1wbGF0ZS1jb250ZXh0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUVBLHlDQUtDOzs7SUFKQyxvQ0FBYzs7SUFDZCw0Q0FBc0I7O0lBQ3RCLG1DQUFrQjs7SUFDbEIsb0NBQWU7Ozs7O0FBR2pCLDBDQUlDOzs7SUFIQyxxQ0FBYzs7SUFDZCw2Q0FBc0I7O0lBQ3RCLG9DQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdhbGxlcnlJdGVtIH0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEl0ZW1UZW1wbGF0ZUNvbnRleHQge1xuICBpbmRleDogbnVtYmVyO1xuICBzZWxlY3RlZEluZGV4OiBudW1iZXI7XG4gIGl0ZW06IEdhbGxlcnlJdGVtO1xuICB2aWRlbzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUaHVtYlRlbXBsYXRlQ29udGV4dCB7XG4gIGluZGV4OiBudW1iZXI7XG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcbiAgaXRlbTogR2FsbGVyeUl0ZW07XG59XG4iXX0=

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

import { SafePipe } from './pipes/safe.pipe';
import { MediaDirective } from './directives/media.directive';
export class GalleryModule {

@@ -27,7 +28,8 @@ }

SafePipe,
MediaDirective,
],
imports: [CommonModule, BrowserAnimationsModule],
exports: [GalleryComponent],
exports: [GalleryComponent, MediaDirective],
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvZ2FsbGVyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUUvRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN6RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQWM3QyxNQUFNLE9BQU8sYUFBYTs7O1lBWnpCLFFBQVEsU0FBQztnQkFDUixZQUFZLEVBQUU7b0JBQ1osZ0JBQWdCO29CQUNoQixlQUFlO29CQUNmLGVBQWU7b0JBQ2Ysb0JBQW9CO29CQUNwQixnQkFBZ0I7b0JBQ2hCLFFBQVE7aUJBQ1Q7Z0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLHVCQUF1QixDQUFDO2dCQUNoRCxPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQzthQUM1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJyb3dzZXJBbmltYXRpb25zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zJztcclxuXHJcbmltcG9ydCB7IENvdW50ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY291bnRlci9jb3VudGVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEdhbGxlcnlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZ2FsbGVyeS9nYWxsZXJ5LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENoZXZyb25JY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFRodW1ic0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90aHVtYnMvdGh1bWJzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFZpZXdlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy92aWV3ZXIvdmlld2VyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFNhZmVQaXBlIH0gZnJvbSAnLi9waXBlcy9zYWZlLnBpcGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIEdhbGxlcnlDb21wb25lbnQsXHJcbiAgICBUaHVtYnNDb21wb25lbnQsXHJcbiAgICBWaWV3ZXJDb21wb25lbnQsXHJcbiAgICBDaGV2cm9uSWNvbkNvbXBvbmVudCxcclxuICAgIENvdW50ZXJDb21wb25lbnQsXHJcbiAgICBTYWZlUGlwZSxcclxuICBdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJyb3dzZXJBbmltYXRpb25zTW9kdWxlXSxcclxuICBleHBvcnRzOiBbR2FsbGVyeUNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBHYWxsZXJ5TW9kdWxlIHt9XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvZ2FsbGVyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUUvRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN6RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFlOUQsTUFBTSxPQUFPLGFBQWE7OztZQWJ6QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLGdCQUFnQjtvQkFDaEIsZUFBZTtvQkFDZixlQUFlO29CQUNmLG9CQUFvQjtvQkFDcEIsZ0JBQWdCO29CQUNoQixRQUFRO29CQUNSLGNBQWM7aUJBQ2Y7Z0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLHVCQUF1QixDQUFDO2dCQUNoRCxPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxjQUFjLENBQUM7YUFDNUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJyb3dzZXJBbmltYXRpb25zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zJztcblxuaW1wb3J0IHsgQ291bnRlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEdhbGxlcnlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZ2FsbGVyeS9nYWxsZXJ5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGV2cm9uSWNvbkNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9pY29ucy9jaGV2cm9uL2NoZXZyb24taWNvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGh1bWJzQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RodW1icy90aHVtYnMuY29tcG9uZW50JztcbmltcG9ydCB7IFZpZXdlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy92aWV3ZXIvdmlld2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTYWZlUGlwZSB9IGZyb20gJy4vcGlwZXMvc2FmZS5waXBlJztcbmltcG9ydCB7IE1lZGlhRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL21lZGlhLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEdhbGxlcnlDb21wb25lbnQsXG4gICAgVGh1bWJzQ29tcG9uZW50LFxuICAgIFZpZXdlckNvbXBvbmVudCxcbiAgICBDaGV2cm9uSWNvbkNvbXBvbmVudCxcbiAgICBDb3VudGVyQ29tcG9uZW50LFxuICAgIFNhZmVQaXBlLFxuICAgIE1lZGlhRGlyZWN0aXZlLFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBCcm93c2VyQW5pbWF0aW9uc01vZHVsZV0sXG4gIGV4cG9ydHM6IFtHYWxsZXJ5Q29tcG9uZW50LCBNZWRpYURpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIEdhbGxlcnlNb2R1bGUge31cbiJdfQ==

@@ -39,2 +39,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS5waXBlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL3BpcGVzL3NhZmUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUt6RCxNQUFNLE9BQU8sUUFBUTs7OztJQUNuQixZQUFvQixTQUF1QjtRQUF2QixjQUFTLEdBQVQsU0FBUyxDQUFjO0lBQUcsQ0FBQzs7Ozs7SUFFL0MsU0FBUyxDQUFDLEdBQVc7UUFDbkIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVELENBQUM7OztZQVJGLElBQUksU0FBQztnQkFDSixJQUFJLEVBQUUsTUFBTTthQUNiOzs7O1lBSlEsWUFBWTs7Ozs7OztJQU1QLDZCQUErQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRG9tU2FuaXRpemVyIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ3NhZmUnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTYWZlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2FuaXRpemVyOiBEb21TYW5pdGl6ZXIpIHt9XHJcblxyXG4gIHRyYW5zZm9ybSh1cmw6IHN0cmluZykge1xyXG4gICAgcmV0dXJuIHRoaXMuc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RSZXNvdXJjZVVybCh1cmwpO1xyXG4gIH1cclxufVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS5waXBlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL3BpcGVzL3NhZmUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUt6RCxNQUFNLE9BQU8sUUFBUTs7OztJQUNuQixZQUFvQixTQUF1QjtRQUF2QixjQUFTLEdBQVQsU0FBUyxDQUFjO0lBQUcsQ0FBQzs7Ozs7SUFFL0MsU0FBUyxDQUFDLEdBQVc7UUFDbkIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVELENBQUM7OztZQVJGLElBQUksU0FBQztnQkFDSixJQUFJLEVBQUUsTUFBTTthQUNiOzs7O1lBSlEsWUFBWTs7Ozs7OztJQU1QLDZCQUErQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERvbVNhbml0aXplciB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdzYWZlJ1xufSlcbmV4cG9ydCBjbGFzcyBTYWZlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHNhbml0aXplcjogRG9tU2FuaXRpemVyKSB7fVxuXG4gIHRyYW5zZm9ybSh1cmw6IHN0cmluZykge1xuICAgIHJldHVybiB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0UmVzb3VyY2VVcmwodXJsKTtcbiAgfVxufVxuIl19

@@ -14,3 +14,4 @@ /**

export { ViewerComponent as ɵa } from './lib/components/viewer/viewer.component';
export { MediaDirective as ɵf } from './lib/directives/media.directive';
export { SafePipe as ɵe } from './lib/pipes/safe.pipe';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRvZS1nYWxsZXJ5LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibmd4LWRvZS1nYWxsZXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsK0hBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNsRixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDakcsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxRQUFRLElBQUksRUFBRSxFQUFDLE1BQU0sdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG5cbmV4cG9ydCB7Q291bnRlckNvbXBvbmVudCBhcyDJtWR9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvY291bnRlci9jb3VudGVyLmNvbXBvbmVudCc7XG5leHBvcnQge0NoZXZyb25JY29uQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9saWIvY29tcG9uZW50cy9pY29ucy9jaGV2cm9uL2NoZXZyb24taWNvbi5jb21wb25lbnQnO1xuZXhwb3J0IHtUaHVtYnNDb21wb25lbnQgYXMgybVifSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RodW1icy90aHVtYnMuY29tcG9uZW50JztcbmV4cG9ydCB7Vmlld2VyQ29tcG9uZW50IGFzIMm1YX0gZnJvbSAnLi9saWIvY29tcG9uZW50cy92aWV3ZXIvdmlld2VyLmNvbXBvbmVudCc7XG5leHBvcnQge1NhZmVQaXBlIGFzIMm1ZX0gZnJvbSAnLi9saWIvcGlwZXMvc2FmZS5waXBlJzsiXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRvZS1nYWxsZXJ5LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibmd4LWRvZS1nYWxsZXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsK0hBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNsRixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDakcsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDdEUsT0FBTyxFQUFDLFFBQVEsSUFBSSxFQUFFLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtDb3VudGVyQ29tcG9uZW50IGFzIMm1ZH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7Q2hldnJvbkljb25Db21wb25lbnQgYXMgybVjfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQge1RodW1ic0NvbXBvbmVudCBhcyDJtWJ9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGh1bWJzL3RodW1icy5jb21wb25lbnQnO1xuZXhwb3J0IHtWaWV3ZXJDb21wb25lbnQgYXMgybVhfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3ZpZXdlci92aWV3ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7TWVkaWFEaXJlY3RpdmUgYXMgybVmfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL21lZGlhLmRpcmVjdGl2ZSc7XG5leHBvcnQge1NhZmVQaXBlIGFzIMm1ZX0gZnJvbSAnLi9saWIvcGlwZXMvc2FmZS5waXBlJzsiXX0=

@@ -12,2 +12,2 @@ /**

export { GalleryItem, GalleryImage, GalleryVideo, isBrowser, SUPPORT, UA, orientations } from './lib/core';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFJQSxpQ0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw4RkFBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZG9lLWdhbGxlcnlcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2dhbGxlcnkvZ2FsbGVyeS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9nYWxsZXJ5Lm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcmUnO1xyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFJQSxpQ0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw4RkFBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGRvZS1nYWxsZXJ5XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9nYWxsZXJ5L2dhbGxlcnkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dhbGxlcnkubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcmUnO1xuIl19

@@ -34,2 +34,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsS0FBSyxFQUNMLFdBQVcsR0FDWixNQUFNLGVBQWUsQ0FBQztBQUl2QjtJQUFBO0lBcUJBLENBQUM7O2dCQXJCQSxTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRSxnS0FLVDtvQkFFRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7aUJBQ2hEOzs7K0JBRUUsS0FBSztnQ0FHTCxLQUFLOzhCQUdMLFdBQVcsU0FBQyxPQUFPLGNBQ25CLEtBQUs7O0lBRVIsdUJBQUM7Q0FBQSxBQXJCRCxJQXFCQztTQVZZLGdCQUFnQjs7O0lBQzNCLHdDQUNxQjs7SUFFckIseUNBQ3NCOztJQUV0Qix1Q0FFaUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBJbnB1dCxcclxuICBIb3N0QmluZGluZyxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IFZlcnRpY2FsT3JpZW50YXRpb24gfSBmcm9tICcuLi8uLi9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZG9lLWNvdW50ZXInLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8c3BhbiBhcmlhLWhpZGRlbj1cInRydWVcIj5cclxuICAgICAge3sgc2VsZWN0ZWRJbmRleCArIDEgfX08c3BhbiBjbGFzcz1cImRvZS1jb3VudGVyLWRlbGltaXRlclwiPi88L3NwYW5cclxuICAgICAgPnt7IGl0ZW1RdWFudGl0eSB8fCAwIH19XHJcbiAgICA8L3NwYW4+XHJcbiAgYCxcclxuICBzdHlsZVVybHM6IFsnLi9jb3VudGVyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb3VudGVyQ29tcG9uZW50IHtcclxuICBASW5wdXQoKVxyXG4gIGl0ZW1RdWFudGl0eTogbnVtYmVyO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXHJcbiAgQElucHV0KClcclxuICBvcmllbnRhdGlvbjogVmVydGljYWxPcmllbnRhdGlvbjtcclxufVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsS0FBSyxFQUNMLFdBQVcsR0FDWixNQUFNLGVBQWUsQ0FBQztBQUl2QjtJQUFBO0lBcUJBLENBQUM7O2dCQXJCQSxTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRSxnS0FLVDtvQkFFRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7aUJBQ2hEOzs7K0JBRUUsS0FBSztnQ0FHTCxLQUFLOzhCQUdMLFdBQVcsU0FBQyxPQUFPLGNBQ25CLEtBQUs7O0lBRVIsdUJBQUM7Q0FBQSxBQXJCRCxJQXFCQztTQVZZLGdCQUFnQjs7O0lBQzNCLHdDQUNxQjs7SUFFckIseUNBQ3NCOztJQUV0Qix1Q0FFaUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBJbnB1dCxcbiAgSG9zdEJpbmRpbmcsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBWZXJ0aWNhbE9yaWVudGF0aW9uIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RvZS1jb3VudGVyJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8c3BhbiBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICAgIHt7IHNlbGVjdGVkSW5kZXggKyAxIH19PHNwYW4gY2xhc3M9XCJkb2UtY291bnRlci1kZWxpbWl0ZXJcIj4vPC9zcGFuXG4gICAgICA+e3sgaXRlbVF1YW50aXR5IHx8IDAgfX1cbiAgICA8L3NwYW4+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2NvdW50ZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIENvdW50ZXJDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBpdGVtUXVhbnRpdHk6IG51bWJlcjtcblxuICBASW5wdXQoKVxuICBzZWxlY3RlZEluZGV4OiBudW1iZXI7XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIEBJbnB1dCgpXG4gIG9yaWVudGF0aW9uOiBWZXJ0aWNhbE9yaWVudGF0aW9uO1xufVxuIl19

@@ -6,3 +6,3 @@ /**

*/
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, TemplateRef, ViewChild, ChangeDetectorRef, } from '@angular/core';
import { defaultAria } from '../../core/aria';

@@ -12,3 +12,6 @@ import { ThumbsComponent } from '../thumbs/thumbs.component';

var GalleryComponent = /** @class */ (function () {
function GalleryComponent() {
function GalleryComponent(cd, hostRef) {
var _this = this;
this.cd = cd;
this.hostRef = hostRef;
this.selectedIndex = 0;

@@ -20,4 +23,4 @@ this.aria = defaultAria;

this.touchGestures = true;
this.imageCounter = true;
this.imageCounterOrientation = 'bottom';
this.counter = true;
this.counterOrientation = 'bottom';
this.loading = 'auto';

@@ -37,2 +40,29 @@ this.loop = false;

this._tabindex = 0;
this._touched = false;
this.INIT_INTERACTIONS = ['touchstart', 'mousedown', 'keydown'];
this._onInitInteraction = (/**
* @return {?}
*/
function () {
/** @type {?} */
var hostEl = _this.hostRef.nativeElement;
_this._touched = true;
_this.cd.detectChanges();
_this.INIT_INTERACTIONS.forEach((/**
* @param {?} ename
* @return {?}
*/
function (ename) {
return hostEl.removeEventListener(ename, _this._onInitInteraction);
}));
});
this.INIT_INTERACTIONS.forEach((/**
* @param {?} ename
* @return {?}
*/
function (ename) {
return hostRef.nativeElement.addEventListener(ename, _this._onInitInteraction, {
passive: true,
});
}));
}

@@ -80,3 +110,3 @@ Object.defineProperty(GalleryComponent.prototype, "ariaLabel", {

function () {
this.viewerElRef.nativeElement.focus();
this._viewerElRef.nativeElement.focus();
};

@@ -90,3 +120,3 @@ /**

function () {
this.viewerRef.selectByDelta(1);
this._viewerRef.selectByDelta(1);
};

@@ -100,3 +130,3 @@ /**

function () {
this.viewerRef.selectByDelta(-1);
this._viewerRef.selectByDelta(-1);
};

@@ -112,4 +142,4 @@ /**

function (index) {
this.viewerRef.select(index);
this.thumbsRef.select(index);
this._viewerRef.select(index);
this._thumbsRef.select(index);
this._selectInternal(index);

@@ -126,3 +156,3 @@ };

function (direction) {
this.thumbsRef.slide(direction);
this._thumbsRef.slide(direction);
};

@@ -138,3 +168,3 @@ /**

function (event) {
this.viewerRef.select(event.index);
this._viewerRef.select(event.index);
this.thumbClick.emit(event);

@@ -158,7 +188,12 @@ this._selectInternal(event.index);

selector: 'doe-gallery',
template: "<doe-thumbs\r\n *ngIf=\"thumbs\"\r\n [items]=\"items\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [orientation]=\"thumbsOrientation\"\r\n [arrows]=\"thumbsArrows\"\r\n [arrowSlideByLength]=\"thumbsArrowSlideByLength\"\r\n [autoScroll]=\"thumbsAutoScroll\"\r\n [scrollBehavior]=\"thumbsScrollBehavior\"\r\n [thumbTemplate]=\"thumbTemplate\"\r\n [arrowTemplate]=\"thumbsArrowTemplate\"\r\n [errorTemplate]=\"thumbErrorTemplate\"\r\n [aria]=\"aria\"\r\n (thumbClick)=\"_onThumbClick($event)\"\r\n (thumbHover)=\"thumbHover.emit($event)\"\r\n></doe-thumbs>\r\n\r\n<doe-viewer\r\n tabindex=\"0\"\r\n [items]=\"items\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [arrows]=\"arrows\"\r\n [descriptions]=\"descriptions\"\r\n [errorText]=\"errorText\"\r\n [mouseGestures]=\"mouseGestures\"\r\n [touchGestures]=\"touchGestures\"\r\n [imageCounter]=\"imageCounter\"\r\n [imageCounterOrientation]=\"imageCounterOrientation\"\r\n [itemWidth]=\"itemWidth\"\r\n [objectFit]=\"objectFit\"\r\n [loading]=\"loading\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [loadingTemplate]=\"loadingTemplate || defaultLoadingTemplate\"\r\n [errorTemplate]=\"errorTemplate\"\r\n [loop]=\"loop\"\r\n [thumbsOrientation]=\"_thumbsOrientationFlag\"\r\n [arrowTemplate]=\"arrowTemplate\"\r\n [aria]=\"aria\"\r\n (imageClick)=\"imageClick.emit($event)\"\r\n (descriptionClick)=\"descriptionClick.emit($event)\"\r\n (selection)=\"_selectInternal($event); thumbsRef?.select($event)\"\r\n></doe-viewer>\r\n\r\n<ng-template #defaultLoadingTemplate>\r\n <div class=\"doe-loading\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n</ng-template>\r\n",
template: "<doe-thumbs\n *ngIf=\"thumbs\"\n [items]=\"items\"\n [selectedIndex]=\"selectedIndex\"\n [orientation]=\"thumbsOrientation\"\n [arrows]=\"thumbsArrows\"\n [arrowSlideByLength]=\"thumbsArrowSlideByLength\"\n [autoScroll]=\"thumbsAutoScroll\"\n [scrollBehavior]=\"thumbsScrollBehavior\"\n [thumbTemplate]=\"thumbTemplate\"\n [arrowTemplate]=\"thumbsArrowTemplate\"\n [errorTemplate]=\"thumbErrorTemplate\"\n [aria]=\"aria\"\n (thumbClick)=\"_onThumbClick($event)\"\n (thumbHover)=\"thumbHover.emit($event)\"\n></doe-thumbs>\n\n<doe-viewer\n tabindex=\"0\"\n [items]=\"items\"\n [selectedIndex]=\"selectedIndex\"\n [arrows]=\"arrows\"\n [descriptions]=\"descriptions\"\n [errorText]=\"errorText\"\n [mouseGestures]=\"mouseGestures\"\n [touchGestures]=\"touchGestures\"\n [counter]=\"counter\"\n [counterOrientation]=\"counterOrientation\"\n [itemWidth]=\"itemWidth\"\n [objectFit]=\"objectFit\"\n [loading]=\"loading\"\n [itemTemplate]=\"itemTemplate\"\n [loadingTemplate]=\"loadingTemplate || defaultLoadingTemplate\"\n [errorTemplate]=\"errorTemplate\"\n [loop]=\"loop\"\n [thumbsOrientation]=\"_thumbsOrientationFlag\"\n [arrowTemplate]=\"arrowTemplate\"\n [aria]=\"aria\"\n [touched]=\"_touched\"\n (imageClick)=\"imageClick.emit($event)\"\n (descriptionClick)=\"descriptionClick.emit($event)\"\n (selection)=\"_selectInternal($event); _thumbsRef?.select($event)\"\n></doe-viewer>\n\n<ng-template #defaultLoadingTemplate>\n <div class=\"doe-loading\">\n <div></div>\n <div></div>\n <div></div>\n </div>\n</ng-template>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [":host{display:flex;height:600px;width:500px;outline:0;position:relative;background-color:#252525;border-radius:5px}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]
styles: [":host{display:flex;height:600px;width:500px;outline:0;position:relative}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5,0 0 1px 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]
}] }
];
/** @nocollapse */
GalleryComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef },
{ type: ElementRef }
]; };
GalleryComponent.propDecorators = {

@@ -173,4 +208,4 @@ items: [{ type: Input }],

touchGestures: [{ type: Input }],
imageCounter: [{ type: Input }],
imageCounterOrientation: [{ type: Input }],
counter: [{ type: Input }],
counterOrientation: [{ type: Input }],
itemWidth: [{ type: Input }],

@@ -198,5 +233,5 @@ loading: [{ type: Input }],

selection: [{ type: Output }],
viewerRef: [{ type: ViewChild, args: [ViewerComponent, { static: false },] }],
thumbsRef: [{ type: ViewChild, args: [ThumbsComponent, { static: false },] }],
viewerElRef: [{ type: ViewChild, args: [ViewerComponent, { static: false, read: ElementRef },] }],
_viewerRef: [{ type: ViewChild, args: [ViewerComponent, { static: false },] }],
_thumbsRef: [{ type: ViewChild, args: [ThumbsComponent, { static: false },] }],
_viewerElRef: [{ type: ViewChild, args: [ViewerComponent, { static: false, read: ElementRef },] }],
_tabindex: [{ type: HostBinding, args: ['tabindex',] }],

@@ -229,5 +264,5 @@ ariaLabel: [{ type: HostBinding, args: ['attr.aria-label',] }],

/** @type {?} */
GalleryComponent.prototype.imageCounter;
GalleryComponent.prototype.counter;
/** @type {?} */
GalleryComponent.prototype.imageCounterOrientation;
GalleryComponent.prototype.counterOrientation;
/** @type {?} */

@@ -278,10 +313,29 @@ GalleryComponent.prototype.itemWidth;

/** @type {?} */
GalleryComponent.prototype.viewerRef;
GalleryComponent.prototype._viewerRef;
/** @type {?} */
GalleryComponent.prototype.thumbsRef;
GalleryComponent.prototype._thumbsRef;
/** @type {?} */
GalleryComponent.prototype.viewerElRef;
GalleryComponent.prototype._viewerElRef;
/** @type {?} */
GalleryComponent.prototype._tabindex;
/** @type {?} */
GalleryComponent.prototype._touched;
/** @type {?} */
GalleryComponent.prototype.INIT_INTERACTIONS;
/**
* @type {?}
* @private
*/
GalleryComponent.prototype._onInitInteraction;
/**
* @type {?}
* @private
*/
GalleryComponent.prototype.cd;
/**
* @type {?}
* @private
*/
GalleryComponent.prototype.hostRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gallery.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/gallery/gallery.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport {\r\n  Aria,\r\n  GalleryItem,\r\n  GalleryItemEvent,\r\n  ItemTemplateContext,\r\n  Loading,\r\n  ObjectFit,\r\n  Orientation,\r\n  OrientationFlag,\r\n  VerticalOrientation,\r\n  ThumbTemplateContext,\r\n} from '../../core';\r\nimport { defaultAria } from '../../core/aria';\r\nimport { ThumbsComponent } from '../thumbs/thumbs.component';\r\nimport { ViewerComponent } from '../viewer/viewer.component';\r\n\r\n@Component({\r\n  selector: 'doe-gallery',\r\n  templateUrl: './gallery.component.html',\r\n  styleUrls: ['./gallery.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class GalleryComponent {\r\n  @Input()\r\n  items: GalleryItem[];\r\n\r\n  @Input()\r\n  selectedIndex = 0;\r\n\r\n  @Input()\r\n  aria: Aria = defaultAria;\r\n\r\n  @Input()\r\n  arrows = true;\r\n\r\n  @Input()\r\n  descriptions = false;\r\n\r\n  @Input()\r\n  errorText: string;\r\n\r\n  @Input()\r\n  mouseGestures = true;\r\n\r\n  @Input()\r\n  touchGestures = true;\r\n\r\n  @Input()\r\n  imageCounter = true;\r\n\r\n  @Input()\r\n  imageCounterOrientation: VerticalOrientation = 'bottom';\r\n\r\n  @Input()\r\n  itemWidth: string;\r\n\r\n  @Input()\r\n  loading: Loading = 'auto';\r\n\r\n  @Input()\r\n  loop = false;\r\n\r\n  @Input()\r\n  objectFit: ObjectFit = 'cover';\r\n\r\n  @Input()\r\n  itemTemplate: TemplateRef<ItemTemplateContext>;\r\n\r\n  @Input()\r\n  loadingTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  errorTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  arrowTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  thumbs = true;\r\n\r\n  @Input()\r\n  thumbsAutoScroll = true;\r\n\r\n  @Input()\r\n  thumbsOrientation: Orientation = 'bottom';\r\n\r\n  @Input()\r\n  thumbsArrows = true;\r\n\r\n  @Input()\r\n  thumbsArrowSlideByLength: number;\r\n\r\n  @Input()\r\n  thumbsScrollBehavior: ScrollBehavior = 'smooth';\r\n\r\n  @Input()\r\n  thumbTemplate: TemplateRef<ThumbTemplateContext>;\r\n\r\n  @Input()\r\n  thumbsArrowTemplate: TemplateRef<void>;\r\n\r\n  @Input()\r\n  thumbErrorTemplate: TemplateRef<void>;\r\n\r\n  @Output()\r\n  imageClick = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @Output()\r\n  thumbClick = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @Output()\r\n  thumbHover = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @Output()\r\n  descriptionClick = new EventEmitter<Event>();\r\n\r\n  @Output()\r\n  selection = new EventEmitter<GalleryItem>();\r\n\r\n  @ViewChild(ViewerComponent, { static: false })\r\n  viewerRef: ViewerComponent;\r\n\r\n  @ViewChild(ThumbsComponent, { static: false })\r\n  thumbsRef: ThumbsComponent;\r\n\r\n  @ViewChild(ViewerComponent, { static: false, read: ElementRef })\r\n  viewerElRef: ElementRef<HTMLElement>;\r\n\r\n  @HostBinding('tabindex')\r\n  _tabindex = 0;\r\n\r\n  @HostBinding('attr.aria-label')\r\n  get ariaLabel() {\r\n    return this.aria && this.aria.galleryLabel;\r\n  }\r\n\r\n  @HostBinding('class.doe-gallery--column')\r\n  get _galleryColumn() {\r\n    return (\r\n      this.thumbsOrientation === 'top' || this.thumbsOrientation === 'bottom'\r\n    );\r\n  }\r\n\r\n  get _thumbsOrientationFlag(): OrientationFlag {\r\n    if (\r\n      this.thumbsOrientation === 'top' ||\r\n      this.thumbsOrientation === 'bottom'\r\n    ) {\r\n      return OrientationFlag.HORIZONTAL;\r\n    }\r\n    return OrientationFlag.VERTICAL;\r\n  }\r\n\r\n  focus() {\r\n    this.viewerElRef.nativeElement.focus();\r\n  }\r\n\r\n  @HostListener('keydown.arrowright')\r\n  next() {\r\n    this.viewerRef.selectByDelta(1);\r\n  }\r\n\r\n  @HostListener('keydown.arrowleft')\r\n  prev() {\r\n    this.viewerRef.selectByDelta(-1);\r\n  }\r\n\r\n  select(index: number) {\r\n    this.viewerRef.select(index);\r\n    this.thumbsRef.select(index);\r\n    this._selectInternal(index);\r\n  }\r\n\r\n  slideThumbs(direction: number) {\r\n    this.thumbsRef.slide(direction);\r\n  }\r\n\r\n  _onThumbClick(event: GalleryItemEvent) {\r\n    this.viewerRef.select(event.index);\r\n    this.thumbClick.emit(event);\r\n    this._selectInternal(event.index);\r\n  }\r\n\r\n  _selectInternal(index: number) {\r\n    this.selectedIndex = index;\r\n    this.selection.emit(this.items[index]);\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gallery.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/gallery/gallery.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ChangeDetectorRef,\n} from '@angular/core';\n\nimport {\n  Aria,\n  GalleryItem,\n  GalleryItemEvent,\n  ItemTemplateContext,\n  Loading,\n  ObjectFit,\n  Orientation,\n  OrientationFlag,\n  VerticalOrientation,\n  ThumbTemplateContext,\n} from '../../core';\nimport { defaultAria } from '../../core/aria';\nimport { ThumbsComponent } from '../thumbs/thumbs.component';\nimport { ViewerComponent } from '../viewer/viewer.component';\n\n@Component({\n  selector: 'doe-gallery',\n  templateUrl: './gallery.component.html',\n  styleUrls: ['./gallery.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class GalleryComponent {\n  @Input() items: GalleryItem[];\n  @Input() selectedIndex = 0;\n  @Input() aria: Aria = defaultAria;\n  @Input() arrows = true;\n  @Input() descriptions = false;\n  @Input() errorText: string;\n  @Input() mouseGestures = true;\n  @Input() touchGestures = true;\n  @Input() counter = true;\n  @Input() counterOrientation: VerticalOrientation = 'bottom';\n  @Input() itemWidth: string;\n  @Input() loading: Loading = 'auto';\n  @Input() loop = false;\n  @Input() objectFit: ObjectFit = 'cover';\n  @Input() itemTemplate: TemplateRef<ItemTemplateContext>;\n  @Input() loadingTemplate: TemplateRef<void>;\n  @Input() errorTemplate: TemplateRef<void>;\n  @Input() arrowTemplate: TemplateRef<void>;\n  @Input() thumbs = true;\n  @Input() thumbsAutoScroll = true;\n  @Input() thumbsOrientation: Orientation = 'bottom';\n  @Input() thumbsArrows = true;\n  @Input() thumbsArrowSlideByLength: number;\n  @Input() thumbsScrollBehavior: ScrollBehavior = 'smooth';\n  @Input() thumbTemplate: TemplateRef<ThumbTemplateContext>;\n  @Input() thumbsArrowTemplate: TemplateRef<void>;\n  @Input() thumbErrorTemplate: TemplateRef<void>;\n\n  @Output() imageClick = new EventEmitter<GalleryItemEvent>();\n  @Output() thumbClick = new EventEmitter<GalleryItemEvent>();\n  @Output() thumbHover = new EventEmitter<GalleryItemEvent>();\n  @Output() descriptionClick = new EventEmitter<Event>();\n  @Output() selection = new EventEmitter<GalleryItem>();\n\n  @ViewChild(ViewerComponent, { static: false }) _viewerRef: ViewerComponent;\n  @ViewChild(ThumbsComponent, { static: false }) _thumbsRef: ThumbsComponent;\n  @ViewChild(ViewerComponent, { static: false, read: ElementRef })\n  _viewerElRef: ElementRef<HTMLElement>;\n\n  @HostBinding('tabindex')\n  _tabindex = 0;\n  _touched = false;\n  INIT_INTERACTIONS = ['touchstart', 'mousedown', 'keydown'];\n\n  @HostBinding('attr.aria-label')\n  get ariaLabel() {\n    return this.aria && this.aria.galleryLabel;\n  }\n\n  @HostBinding('class.doe-gallery--column')\n  get _galleryColumn() {\n    return (\n      this.thumbsOrientation === 'top' || this.thumbsOrientation === 'bottom'\n    );\n  }\n\n  get _thumbsOrientationFlag(): OrientationFlag {\n    if (\n      this.thumbsOrientation === 'top' ||\n      this.thumbsOrientation === 'bottom'\n    ) {\n      return OrientationFlag.HORIZONTAL;\n    }\n    return OrientationFlag.VERTICAL;\n  }\n\n  constructor(\n    private cd: ChangeDetectorRef,\n    private hostRef: ElementRef<HTMLElement>\n  ) {\n    this.INIT_INTERACTIONS.forEach(ename =>\n      hostRef.nativeElement.addEventListener(ename, this._onInitInteraction, {\n        passive: true,\n      })\n    );\n  }\n\n  private _onInitInteraction = () => {\n    const hostEl = this.hostRef.nativeElement;\n    this._touched = true;\n    this.cd.detectChanges();\n    this.INIT_INTERACTIONS.forEach(ename =>\n      hostEl.removeEventListener(ename, this._onInitInteraction)\n    );\n  };\n\n  focus() {\n    this._viewerElRef.nativeElement.focus();\n  }\n\n  @HostListener('keydown.arrowright')\n  next() {\n    this._viewerRef.selectByDelta(1);\n  }\n\n  @HostListener('keydown.arrowleft')\n  prev() {\n    this._viewerRef.selectByDelta(-1);\n  }\n\n  select(index: number) {\n    this._viewerRef.select(index);\n    this._thumbsRef.select(index);\n    this._selectInternal(index);\n  }\n\n  slideThumbs(direction: number) {\n    this._thumbsRef.slide(direction);\n  }\n\n  _onThumbClick(event: GalleryItemEvent) {\n    this._viewerRef.select(event.index);\n    this.thumbClick.emit(event);\n    this._selectInternal(event.index);\n  }\n\n  _selectInternal(index: number) {\n    this.selectedIndex = index;\n    this.selection.emit(this.items[index]);\n  }\n}\n"]}

@@ -13,3 +13,3 @@ /**

selector: 'doe-chevron-icon',
template: "<!-- Icon made by Dave Gandy from www.flaticon.com -->\r\n<svg\r\n version=\"1.1\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n x=\"0px\"\r\n y=\"0px\"\r\n viewBox=\"0 0 407.436 407.436\"\r\n xml:space=\"preserve\"\r\n>\r\n <polygon\r\n points=\"112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 \"\r\n />\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n</svg>\r\n",
template: "<!-- Icon made by Dave Gandy from www.flaticon.com -->\n<svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 407.436 407.436\"\n xml:space=\"preserve\"\n>\n <polygon\n points=\"112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 \"\n />\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n</svg>\n",
changeDetection: ChangeDetectionStrategy.OnPush,

@@ -22,2 +22,2 @@ styles: ["svg{width:26px;height:26px;fill:#fff;-webkit-filter:drop-shadow(0 0 1px #000);filter:drop-shadow(0 0 1px #000);display:block}"]

export { ChevronIconComponent };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hldnJvbi1pY29uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkU7SUFBQTtJQU1tQyxDQUFDOztnQkFObkMsU0FBUyxTQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLGduQkFBNEM7b0JBRTVDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNOztpQkFDaEQ7O0lBQ2tDLDJCQUFDO0NBQUEsQUFOcEMsSUFNb0M7U0FBdkIsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkb2UtY2hldnJvbi1pY29uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hldnJvbi1pY29uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jaGV2cm9uLWljb24uY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hldnJvbkljb25Db21wb25lbnQge31cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hldnJvbi1pY29uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkU7SUFBQTtJQU1tQyxDQUFDOztnQkFObkMsU0FBUyxTQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLHNqQkFBNEM7b0JBRTVDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNOztpQkFDaEQ7O0lBQ2tDLDJCQUFDO0NBQUEsQUFOcEMsSUFNb0M7U0FBdkIsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkb2UtY2hldnJvbi1pY29uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZXZyb24taWNvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NoZXZyb24taWNvbi5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBDaGV2cm9uSWNvbkNvbXBvbmVudCB7fVxuIl19

@@ -9,14 +9,16 @@ /**

import { isBrowser, SUPPORT, } from '../../core';
import { isVideo, } from '../../core/gallery-item';
var ThumbsComponent = /** @class */ (function () {
function ThumbsComponent(cd, elRef) {
function ThumbsComponent(_cd, _elRef) {
var _this = this;
this.cd = cd;
this.elRef = elRef;
this._cd = _cd;
this._elRef = _elRef;
this.items = [];
this.thumbClick = new EventEmitter();
this.thumbHover = new EventEmitter();
this.showStartArrow = false;
this.showEndArrow = false;
this.destroy$ = new Subject();
this.smoothScrollAllowed = false;
this.isVideo = isVideo;
this._showStartArrow = false;
this._showEndArrow = false;
this._destroy$ = new Subject();
this._smoothScrollAllowed = false;
this.onArrowsObserved = (/**

@@ -34,8 +36,8 @@ * @param {?} entries

if (firstThumbEntry) {
_this.showStartArrow = firstThumbEntry.intersectionRatio < 1;
_this._showStartArrow = firstThumbEntry.intersectionRatio < 1;
}
if (lastThumbEntry) {
_this.showEndArrow = lastThumbEntry.intersectionRatio < 1;
_this._showEndArrow = lastThumbEntry.intersectionRatio < 1;
}
_this.cd.detectChanges();
_this._cd.detectChanges();
});

@@ -48,3 +50,3 @@ }

function () {
return this.smoothScrollAllowed ? this._scrollBehavior : 'auto';
return this._smoothScrollAllowed ? this._scrollBehavior : 'auto';
},

@@ -71,3 +73,3 @@ set: /**

});
Object.defineProperty(ThumbsComponent.prototype, "scrollKey", {
Object.defineProperty(ThumbsComponent.prototype, "_hostOffsetAxis", {
get: /**

@@ -78,3 +80,5 @@ * @private

function () {
return this.vertical ? 'scrollTop' : 'scrollLeft';
return this._vertical
? this._elRef.nativeElement.offsetHeight
: this._elRef.nativeElement.offsetWidth;
},

@@ -84,3 +88,3 @@ enumerable: true,

});
Object.defineProperty(ThumbsComponent.prototype, "hostOffsetAxis", {
Object.defineProperty(ThumbsComponent.prototype, "_scrollKey", {
get: /**

@@ -91,5 +95,3 @@ * @private

function () {
return this.vertical
? this.elRef.nativeElement.offsetHeight
: this.elRef.nativeElement.offsetWidth;
return this._vertical ? 'scrollTop' : 'scrollLeft';
},

@@ -113,3 +115,3 @@ enumerable: true,

var newOrientation = orientation.currentValue;
this.vertical = newOrientation === 'left' || newOrientation === 'right';
this._vertical = newOrientation === 'left' || newOrientation === 'right';
}

@@ -121,4 +123,4 @@ if (arrows) {

else if (!arrows.currentValue) {
this.showStartArrow = false;
this.showEndArrow = false;
this._showStartArrow = false;
this._showEndArrow = false;
this.unobserveArrows();

@@ -144,3 +146,3 @@ }

_this.centerThumbIfNeeded(_this.selectedIndex);
_this.smoothScrollAllowed = true;
_this._smoothScrollAllowed = true;
}));

@@ -157,5 +159,5 @@ }

function () {
this.destroy$.next(null);
this.destroy$.complete();
this.arrowObserver && this.arrowObserver.disconnect();
this._destroy$.next(null);
this._destroy$.complete();
this._arrowObserver && this._arrowObserver.disconnect();
};

@@ -183,7 +185,7 @@ /**

/** @type {?} */
var thumbListScrollAxis = this.vertical
var thumbListScrollAxis = this._vertical
? thumbList.scrollHeight
: thumbList.scrollWidth;
/** @type {?} */
var thumbListOffsetAxis = this.vertical
var thumbListOffsetAxis = this._vertical
? thumbList.offsetHeight

@@ -209,11 +211,14 @@ : thumbList.offsetWidth;

var nextItemEl = this.thumbsRef.toArray()[index].nativeElement;
if (!nextItemEl) {
return;
}
var offsetLeft = nextItemEl.offsetLeft, offsetTop = nextItemEl.offsetTop, offsetWidth = nextItemEl.offsetWidth, offsetHeight = nextItemEl.offsetHeight;
/** @type {?} */
var itemOffset = this.vertical ? offsetTop : offsetLeft;
var itemOffset = this._vertical ? offsetTop : offsetLeft;
/** @type {?} */
var itemOffsetAxis = this.vertical ? offsetHeight : offsetWidth;
var itemOffsetAxis = this._vertical ? offsetHeight : offsetWidth;
/** @type {?} */
var hostScrollAxis = this.hostOffsetAxis;
var hostScrollAxis = this._hostOffsetAxis;
/** @type {?} */
var thumbListScroll = this.thumbListRef.nativeElement[this.scrollKey];
var thumbListScroll = this.thumbListRef.nativeElement[this._scrollKey];
/** @type {?} */

@@ -237,3 +242,3 @@ var nextScrollDelta = itemOffset + itemOffsetAxis / 2 - hostScrollAxis / 2 - thumbListScroll;

this.selectedIndex = index;
this.cd.detectChanges();
this._cd.detectChanges();
if (this.autoScroll) {

@@ -247,13 +252,2 @@ setTimeout((/**

/**
* @param {?} item
* @return {?}
*/
ThumbsComponent.prototype.onItemErrored = /**
* @param {?} item
* @return {?}
*/
function (item) {
item._thumbFailed = true;
};
/**
* @param {?} index

@@ -265,3 +259,3 @@ * @param {?} item

*/
ThumbsComponent.prototype.emitEvent = /**
ThumbsComponent.prototype._emitEvent = /**
* @param {?} index

@@ -281,2 +275,15 @@ * @param {?} item

/**
* @param {?} item
* @param {?} success
* @return {?}
*/
ThumbsComponent.prototype._onLoadChange = /**
* @param {?} item
* @param {?} success
* @return {?}
*/
function (item, success) {
item._thumbFailed = !success;
};
/**
* @private

@@ -297,7 +304,7 @@ * @param {?} totalScrollDelta

if (SUPPORT.scrollBehavior || this.scrollBehavior === 'auto') {
this.thumbListRef.nativeElement[this.scrollKey] += totalScrollDelta;
this.thumbListRef.nativeElement[this._scrollKey] += totalScrollDelta;
return;
}
if (this.scrollId != null) {
cancelAnimationFrame(this.scrollId);
if (this._scrollId != null) {
cancelAnimationFrame(this._scrollId);
}

@@ -332,8 +339,8 @@ /** @type {?} */

currentScroll = suggestedScroll;
_this.thumbListRef.nativeElement[_this.scrollKey] += frameScroll;
_this.thumbListRef.nativeElement[_this._scrollKey] += frameScroll;
if (currentScroll <= totalDistance) {
_this.scrollId = requestAnimationFrame(animate);
_this._scrollId = requestAnimationFrame(animate);
}
});
this.scrollId = requestAnimationFrame(animate);
this._scrollId = requestAnimationFrame(animate);
};

@@ -350,4 +357,4 @@ /**

var _this = this;
if (!this.arrowObserver) {
this.arrowObserver = new IntersectionObserver(this.onArrowsObserved, {
if (!this._arrowObserver) {
this._arrowObserver = new IntersectionObserver(this.onArrowsObserved, {
root: this.thumbListRef.nativeElement,

@@ -358,3 +365,3 @@ threshold: 1.0,

else {
this.arrowObserver.disconnect();
this._arrowObserver.disconnect();
}

@@ -365,4 +372,4 @@ setTimeout((/**

function () {
_this.arrowObserver.observe(_this.thumbsRef.first.nativeElement);
_this.arrowObserver.observe(_this.thumbsRef.last.nativeElement);
_this._arrowObserver.observe(_this.thumbsRef.first.nativeElement);
_this._arrowObserver.observe(_this.thumbsRef.last.nativeElement);
}));

@@ -379,3 +386,3 @@ };

function () {
this.arrowObserver && this.arrowObserver.disconnect();
this._arrowObserver && this._arrowObserver.disconnect();
};

@@ -385,5 +392,5 @@ ThumbsComponent.decorators = [

selector: 'doe-thumbs',
template: "<div\r\n *ngIf=\"showStartArrow\"\r\n class=\"doe-thumbs-arrow doe-thumbs-arrow-prev\"\r\n (click)=\"slide(-1)\"\r\n>\r\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n\r\n<ul\r\n #thumbs\r\n [style.scrollBehavior]=\"scrollBehavior\"\r\n tabindex=\"0\"\r\n [attr.aria-label]=\"aria?.thumbnailsLabel\"\r\n>\r\n <li *ngIf=\"!items || !items.length\" class=\"doe-thumbs-initial-item\"></li>\r\n <li\r\n #thumb\r\n *ngFor=\"let item of items; let i = index\"\r\n [class.doe-thumbs-item--selected]=\"i === selectedIndex\"\r\n aria-hidden=\"true\"\r\n (click)=\"emitEvent(i, item, $event, thumbClick)\"\r\n (mouseenter)=\"emitEvent(i, item, $event, thumbHover)\"\r\n >\r\n <ng-container *ngIf=\"!thumbTemplate; else customThumbTemplate\">\r\n <img\r\n [src]=\"item.thumbSrc || item.src\"\r\n [alt]=\"item.alt\"\r\n (error)=\"onItemErrored(item)\"\r\n />\r\n\r\n <ng-container *ngIf=\"item._thumbFailed\">\r\n <div\r\n *ngIf=\"!errorTemplate; else errorTemplate\"\r\n class=\"doe-thumbs-error\"\r\n >\r\n <div class=\"doe-thumbs-error-icon\">\u26A0</div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #customThumbTemplate>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n thumbTemplate;\r\n context: { index: i, selectedIndex: selectedIndex, item: item }\r\n \"\r\n ></ng-container>\r\n </ng-template>\r\n </li>\r\n</ul>\r\n\r\n<div\r\n *ngIf=\"showEndArrow\"\r\n class=\"doe-thumbs-arrow doe-thumbs-arrow-next\"\r\n (click)=\"slide(1)\"\r\n>\r\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n",
template: "<div\n *ngIf=\"_showStartArrow\"\n class=\"doe-thumbs-arrow doe-thumbs-arrow-prev\"\n (click)=\"slide(-1)\"\n>\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n\n<ul\n #thumbs\n [style.scrollBehavior]=\"scrollBehavior\"\n tabindex=\"0\"\n [attr.aria-label]=\"aria?.thumbnailsLabel\"\n>\n <li *ngIf=\"!items || !items.length\" class=\"doe-thumbs-initial-item\"></li>\n <li\n #thumb\n *ngFor=\"let item of items; let i = index\"\n [class.doe-thumbs-item--selected]=\"i === selectedIndex\"\n aria-hidden=\"true\"\n (click)=\"_emitEvent(i, item, $event, thumbClick)\"\n (mouseenter)=\"_emitEvent(i, item, $event, thumbHover)\"\n >\n <ng-container *ngIf=\"!thumbTemplate; else customThumbTemplate\">\n <img\n [src]=\"item.thumbSrc || ''\"\n [alt]=\"item.alt\"\n (load)=\"_onLoadChange(item, true)\"\n (error)=\"_onLoadChange(item, false)\"\n />\n\n <ng-container *ngIf=\"item._thumbFailed\">\n <div\n *ngIf=\"!errorTemplate; else errorTemplate\"\n class=\"doe-thumbs-error\"\n >\n <div\n class=\"doe-thumbs-error-icon\"\n [class.doe-thumbs-error-icon--video]=\"isVideo(item)\"\n ></div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-template #customThumbTemplate>\n <ng-container\n *ngTemplateOutlet=\"\n thumbTemplate;\n context: { index: i, selectedIndex: selectedIndex, item: item }\n \"\n ></ng-container>\n </ng-template>\n </li>\n</ul>\n\n<div\n *ngIf=\"_showEndArrow\"\n class=\"doe-thumbs-arrow doe-thumbs-arrow-next\"\n (click)=\"slide(1)\"\n>\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [":host{flex:1 0 auto;position:relative}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;border:1px solid #252525;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:\"\";display:block;position:absolute;left:0;bottom:0;width:100%;height:10px;background-color:#ffffffab;box-shadow:0 0 1px #000}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#222}.doe-thumbs-error-icon{font-size:20px;color:#f5f5f5}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}"]
styles: [":host{flex:1 0 auto;position:relative;background-color:#f3f3f3}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--bottom .doe-thumbs-error,:host.doe-thumbs--top .doe-thumbs-error{border-right:1px solid #cecece}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--left .doe-thumbs-error,:host.doe-thumbs--right .doe-thumbs-error{border-bottom:1px solid #cecece}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:\"\";display:block;position:absolute;left:0;bottom:0;width:100%;height:100%;border:10px solid #ffffffcf;box-sizing:border-box}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#e8e8e8;box-sizing:border-box}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video){position:relative;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid #a5a5a5;margin-left:-8px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after,.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{content:\"\";position:absolute}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{height:10px;width:10px;background-color:#a5a5a5;border-radius:100%;left:14px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after{border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:17px solid #a5a5a5;top:11px}.doe-thumbs-error-icon--video{border-top:16px solid transparent;border-bottom:16px solid transparent;border-left:28px solid #a5a5a5;margin-left:9px}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}"]
}] }

@@ -447,7 +454,9 @@ ];

/** @type {?} */
ThumbsComponent.prototype.showStartArrow;
ThumbsComponent.prototype.isVideo;
/** @type {?} */
ThumbsComponent.prototype.showEndArrow;
ThumbsComponent.prototype._showStartArrow;
/** @type {?} */
ThumbsComponent.prototype.vertical;
ThumbsComponent.prototype._showEndArrow;
/** @type {?} */
ThumbsComponent.prototype._vertical;
/**

@@ -457,3 +466,3 @@ * @type {?}

*/
ThumbsComponent.prototype.destroy$;
ThumbsComponent.prototype._destroy$;
/**

@@ -463,3 +472,3 @@ * @type {?}

*/
ThumbsComponent.prototype.arrowObserver;
ThumbsComponent.prototype._arrowObserver;
/**

@@ -474,3 +483,3 @@ * @type {?}

*/
ThumbsComponent.prototype.smoothScrollAllowed;
ThumbsComponent.prototype._scrollId;
/**

@@ -480,3 +489,3 @@ * @type {?}

*/
ThumbsComponent.prototype.scrollId;
ThumbsComponent.prototype._smoothScrollAllowed;
/**

@@ -491,3 +500,3 @@ * @type {?}

*/
ThumbsComponent.prototype.cd;
ThumbsComponent.prototype._cd;
/**

@@ -497,4 +506,4 @@ * @type {?}

*/
ThumbsComponent.prototype.elRef;
ThumbsComponent.prototype._elRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thumbs.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/thumbs/thumbs.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EAGL,MAAM,EACN,SAAS,EAET,WAAW,EACX,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,OAAO,EACL,SAAS,EAET,OAAO,GAER,MAAM,YAAY,CAAC;AAIpB;IA0DE,yBACU,EAAqB,EACrB,KAA8B;QAFxC,iBAGI;QAFM,OAAE,GAAF,EAAE,CAAmB;QACrB,UAAK,GAAL,KAAK,CAAyB;QArD/B,UAAK,GAA0B,EAAE,CAAC;QAkBjC,eAAU,GAAG,IAAI,YAAY,EAAoB,CAAC;QAClD,eAAU,GAAG,IAAI,YAAY,EAAoB,CAAC;QAK5D,mBAAc,GAAG,KAAK,CAAC;QACvB,iBAAY,GAAG,KAAK,CAAC;QAGb,aAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;QAIzB,wBAAmB,GAAG,KAAK,CAAC;QA2L5B,qBAAgB;;;;QAAiC,UAAA,OAAO;;gBACxD,QAAQ,GAAG,mBAAA,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,EAAe;;gBAC3C,eAAe,GACnB,QAAQ,KAAK,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;;gBACrE,cAAc,GAClB,QAAQ,KAAK,KAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;YAE1E,IAAI,eAAe,EAAE;gBACnB,KAAI,CAAC,cAAc,GAAG,eAAe,CAAC,iBAAiB,GAAG,CAAC,CAAC;aAC7D;YACD,IAAI,cAAc,EAAE;gBAClB,KAAI,CAAC,YAAY,GAAG,cAAc,CAAC,iBAAiB,GAAG,CAAC,CAAC;aAC1D;YAED,KAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC1B,CAAC,EAAC;IApLC,CAAC;IA5CJ,sBACI,2CAAc;;;;QAGlB;YACE,OAAO,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC;QAClE,CAAC;;;;;QAND,UACmB,GAAmB;YACpC,IAAI,CAAC,eAAe,GAAG,GAAG,IAAI,QAAQ,CAAC;QACzC,CAAC;;;OAAA;IAuBD,sBACI,qCAAQ;;;;QADZ;YAEE,OAAO,iBAAe,IAAI,CAAC,WAAa,CAAC;QAC3C,CAAC;;;OAAA;IAED,sBAAY,sCAAS;;;;;QAArB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,YAAY,CAAC;QACpD,CAAC;;;OAAA;IAED,sBAAY,2CAAc;;;;;QAA1B;YACE,OAAO,IAAI,CAAC,QAAQ;gBAClB,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,YAAY;gBACvC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC;QAC3C,CAAC;;;OAAA;;;;;IAOD,qCAAW;;;;IAAX,UAAY,EAA6C;QAAzD,iBAiCC;YAjCa,kBAAM,EAAE,gBAAK,EAAE,4BAAW;QACtC,IAAI,WAAW,IAAI,WAAW,CAAC,YAAY,IAAI,IAAI,EAAE;;gBAC7C,cAAc,GAAgB,WAAW,CAAC,YAAY;YAC5D,IAAI,CAAC,QAAQ,GAAG,cAAc,KAAK,MAAM,IAAI,cAAc,KAAK,OAAO,CAAC;SACzE;QACD,IAAI,MAAM,EAAE;YACV,IAAI,MAAM,CAAC,YAAY,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;gBAC1D,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;iBAAM,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE;gBAC/B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;SACF;QAED,IAAI,KAAK,IAAI,KAAK,CAAC,YAAY,EAAE;;gBACzB,SAAS,GAAG,mBAAA,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC,EAAyB;;gBAC/D,SAAS,GAAG,mBAAA,CAAC,KAAK,CAAC,aAAa,IAAI,EAAE,CAAC,EAAyB;YAEtE,IAAI,SAAS,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,EAAE;gBACzC,OAAO;aACR;YAED,IAAI,IAAI,CAAC,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE;gBACnC,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;YACD,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;gBACrB,UAAU;;;gBAAC;oBACT,KAAI,CAAC,mBAAmB,CAAC,KAAI,CAAC,aAAa,CAAC,CAAC;oBAC7C,KAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;gBAClC,CAAC,EAAC,CAAC;aACJ;SACF;IACH,CAAC;;;;IAED,qCAAW;;;IAAX;QACE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC;IACxD,CAAC;;;;;IAED,+BAAK;;;;IAAL,UAAM,SAAiB;;YACjB,KAAa;QAEjB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC;SACjC;aAAM;;;;;gBAIC,SAAS,GAAG,mBAAA,IAAI,CAAC,YAAY,CAAC,aAAa,EAAe;;gBAC1D,mBAAmB,GAAG,IAAI,CAAC,QAAQ;gBACvC,CAAC,CAAC,SAAS,CAAC,YAAY;gBACxB,CAAC,CAAC,SAAS,CAAC,WAAW;;gBACnB,mBAAmB,GAAG,IAAI,CAAC,QAAQ;gBACvC,CAAC,CAAC,SAAS,CAAC,YAAY;gBACxB,CAAC,CAAC,SAAS,CAAC,WAAW;YAEzB,KAAK,GAAG,IAAI,CAAC,GAAG,CACd,mBAAmB,EACnB,mBAAmB,GAAG,mBAAmB,CAC1C,CAAC;SACH;QACD,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC;IACjC,CAAC;;;;;IAED,6CAAmB;;;;IAAnB,UAAoB,KAAa;QAC/B,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE;YACzC,OAAO;SACR;;YAEK,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,aAAa;QACxD,IAAA,kCAAU,EAAE,gCAAS,EAAE,oCAAW,EAAE,sCAAY;;YAElD,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU;;YACnD,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW;;YAE3D,cAAc,GAAG,IAAI,CAAC,cAAc;;YACpC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC;;YAEjE,eAAe,GACnB,UAAU,GAAG,cAAc,GAAG,CAAC,GAAG,cAAc,GAAG,CAAC,GAAG,eAAe;QAExE,IACE,eAAe,GAAG,cAAc,GAAG,UAAU,GAAG,cAAc;YAC9D,eAAe,GAAG,UAAU,EAC5B;YACA,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;SAC9B;IACH,CAAC;;;;;IAED,gCAAM;;;;IAAN,UAAO,KAAa;QAApB,iBAOC;QANC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,UAAU;;;YAAC,cAAM,OAAA,KAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAA/B,CAA+B,EAAC,CAAC;SACnD;IACH,CAAC;;;;;IAED,uCAAa;;;;IAAb,UAAc,IAAyB;QACrC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;;;;;;;;IAED,mCAAS;;;;;;;IAAT,UACE,KAAa,EACb,IAAyB,EACzB,KAAY,EACZ,OAAuC;QAEvC,OAAO,CAAC,IAAI,CAAC;YACX,KAAK,OAAA;YACL,IAAI,MAAA;YACJ,KAAK,OAAA;SACN,CAAC,CAAC;IACL,CAAC;;;;;;IAEO,gCAAM;;;;;IAAd,UAAe,gBAAwB;QAAvC,iBA4CC;QA3CC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;SACR;QACD,IAAI,OAAO,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,KAAK,MAAM,EAAE;YAC5D,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,gBAAgB,CAAC;YACpE,OAAO;SACR;QACD,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;YACzB,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACrC;;YAEK,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC;;YAC1C,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE;;YACtB,kBAAkB,GAAG,GAAG;;YAC1B,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,GAAG,CAAC,GAAG,kBAAkB;QACtE,IAAI,SAAS,GAAG,CAAC,EAAE;YACjB,SAAS,GAAG,kBAAkB,CAAC;SAChC;;YACG,aAAa,GAAG,CAAC;;;;;;YAMf,OAAO;;;QAAG;;gBACR,eAAe,GAAG,IAAI,CAAC,IAAI,CAC/B,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC,GAAG,SAAS,CAAC,GAAG,aAAa,CACvD;;gBACG,WAAW,GAAG,IAAI,CAAC,GAAG,CACxB,eAAe,GAAG,aAAa,EAC/B,aAAa,GAAG,aAAa,CAC9B;YACD,WAAW,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAC3C,aAAa,GAAG,eAAe,CAAC;YAEhC,KAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAI,CAAC,SAAS,CAAC,IAAI,WAAW,CAAC;YAE/D,IAAI,aAAa,IAAI,aAAa,EAAE;gBAClC,KAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAC;aAChD;QACH,CAAC,CAAA;QAED,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAC;IACjD,CAAC;;;;;IAmBO,uCAAa;;;;IAArB;QAAA,iBAaC;QAZC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,IAAI,oBAAoB,CAAC,IAAI,CAAC,gBAAgB,EAAE;gBACnE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa;gBACrC,SAAS,EAAE,GAAG;aACf,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC;SACjC;QACD,UAAU;;;QAAC;YACT,KAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YAC/D,KAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAChE,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAEO,yCAAe;;;;IAAvB;QACE,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC;IACxD,CAAC;;gBApQF,SAAS,SAAC;oBACT,QAAQ,EAAE,YAAY;oBACtB,yzDAAsC;oBAEtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;iBAChD;;;;gBA/BC,iBAAiB;gBAEjB,UAAU;;;wBA+BT,KAAK;gCACL,KAAK;uBACL,KAAK;8BACL,KAAK;yBACL,KAAK;qCACL,KAAK;6BACL,KAAK;gCACL,KAAK;gCACL,KAAK;gCACL,KAAK;iCACL,KAAK;6BAQL,MAAM;6BACN,MAAM;+BAEN,SAAS,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;4BACpC,YAAY,SAAC,OAAO;2BAcpB,WAAW,SAAC,OAAO;;IA0NtB,sBAAC;CAAA,AArQD,IAqQC;SA/PY,eAAe;;;IAC1B,gCAA2C;;IAC3C,wCAA+B;;IAC/B,+BAAoB;;IACpB,sCAAkC;;IAClC,iCAAyB;;IACzB,6CAAoC;;IACpC,qCAA6B;;IAC7B,wCAA0D;;IAC1D,wCAA0C;;IAC1C,wCAA0C;;IAS1C,qCAA4D;;IAC5D,qCAA4D;;IAE5D,uCAA6E;;IAC7E,oCAAqE;;IAErE,yCAAuB;;IACvB,uCAAqB;;IACrB,mCAAkB;;;;;IAElB,mCAAiC;;;;;IAEjC,wCAA4C;;;;;IAC5C,0CAAwC;;;;;IACxC,8CAAoC;;;;;IAEpC,mCAAyB;;;;;IAyLzB,2CAeE;;;;;IAtLA,6BAA6B;;;;;IAC7B,gCAAsC","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\n\r\nimport {\r\n  isBrowser,\r\n  Orientation,\r\n  SUPPORT,\r\n  ThumbTemplateContext,\r\n} from '../../core';\r\nimport { Aria } from '../../core/aria';\r\nimport { GalleryItemInternal, GalleryItemEvent } from '../../core/gallery-item';\r\n\r\n@Component({\r\n  selector: 'doe-thumbs',\r\n  templateUrl: './thumbs.component.html',\r\n  styleUrls: ['./thumbs.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ThumbsComponent implements OnChanges, OnDestroy {\r\n  @Input() items: GalleryItemInternal[] = [];\r\n  @Input() selectedIndex: number;\r\n  @Input() aria: Aria;\r\n  @Input() orientation: Orientation;\r\n  @Input() arrows: boolean;\r\n  @Input() arrowSlideByLength: number;\r\n  @Input() autoScroll: boolean;\r\n  @Input() thumbTemplate: TemplateRef<ThumbTemplateContext>;\r\n  @Input() arrowTemplate: TemplateRef<void>;\r\n  @Input() errorTemplate: TemplateRef<void>;\r\n  @Input()\r\n  set scrollBehavior(val: ScrollBehavior) {\r\n    this._scrollBehavior = val || 'smooth';\r\n  }\r\n  get scrollBehavior() {\r\n    return this.smoothScrollAllowed ? this._scrollBehavior : 'auto';\r\n  }\r\n\r\n  @Output() thumbClick = new EventEmitter<GalleryItemEvent>();\r\n  @Output() thumbHover = new EventEmitter<GalleryItemEvent>();\r\n\r\n  @ViewChild('thumbs', { static: true }) thumbListRef: ElementRef<HTMLElement>;\r\n  @ViewChildren('thumb') thumbsRef: QueryList<ElementRef<HTMLElement>>;\r\n\r\n  showStartArrow = false;\r\n  showEndArrow = false;\r\n  vertical: boolean;\r\n\r\n  private destroy$ = new Subject();\r\n\r\n  private arrowObserver: IntersectionObserver;\r\n  private _scrollBehavior: ScrollBehavior;\r\n  private smoothScrollAllowed = false;\r\n\r\n  private scrollId: number;\r\n\r\n  @HostBinding('class')\r\n  get cssClass() {\r\n    return `doe-thumbs--${this.orientation}`;\r\n  }\r\n\r\n  private get scrollKey(): string {\r\n    return this.vertical ? 'scrollTop' : 'scrollLeft';\r\n  }\r\n\r\n  private get hostOffsetAxis(): number {\r\n    return this.vertical\r\n      ? this.elRef.nativeElement.offsetHeight\r\n      : this.elRef.nativeElement.offsetWidth;\r\n  }\r\n\r\n  constructor(\r\n    private cd: ChangeDetectorRef,\r\n    private elRef: ElementRef<HTMLElement>\r\n  ) {}\r\n\r\n  ngOnChanges({ arrows, items, orientation }: SimpleChanges) {\r\n    if (orientation && orientation.currentValue != null) {\r\n      const newOrientation: Orientation = orientation.currentValue;\r\n      this.vertical = newOrientation === 'left' || newOrientation === 'right';\r\n    }\r\n    if (arrows) {\r\n      if (arrows.currentValue && this.items && this.items.length) {\r\n        this.observeArrows();\r\n      } else if (!arrows.currentValue) {\r\n        this.showStartArrow = false;\r\n        this.showEndArrow = false;\r\n        this.unobserveArrows();\r\n      }\r\n    }\r\n\r\n    if (items && items.currentValue) {\r\n      const currItems = (items.currentValue || []) as GalleryItemInternal[];\r\n      const prevItems = (items.previousValue || []) as GalleryItemInternal[];\r\n\r\n      if (currItems.length === prevItems.length) {\r\n        return;\r\n      }\r\n\r\n      if (this.arrows && currItems.length) {\r\n        this.observeArrows();\r\n      }\r\n      if (!prevItems.length) {\r\n        setTimeout(() => {\r\n          this.centerThumbIfNeeded(this.selectedIndex);\r\n          this.smoothScrollAllowed = true;\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next(null);\r\n    this.destroy$.complete();\r\n    this.arrowObserver && this.arrowObserver.disconnect();\r\n  }\r\n\r\n  slide(direction: number) {\r\n    let delta: number;\r\n\r\n    if (this.arrowSlideByLength) {\r\n      delta = this.arrowSlideByLength;\r\n    } else {\r\n      // Note: Slide by the full height/width of the gallery\r\n      // or by the overflow of the thumbs - to prevent unnecessary requestAnimationFrame calls while trying to scroll\r\n      // outside of the min/max scroll of the thumbs\r\n      const thumbList = this.thumbListRef.nativeElement as HTMLElement;\r\n      const thumbListScrollAxis = this.vertical\r\n        ? thumbList.scrollHeight\r\n        : thumbList.scrollWidth;\r\n      const thumbListOffsetAxis = this.vertical\r\n        ? thumbList.offsetHeight\r\n        : thumbList.offsetWidth;\r\n\r\n      delta = Math.min(\r\n        thumbListOffsetAxis,\r\n        thumbListScrollAxis - thumbListOffsetAxis\r\n      );\r\n    }\r\n    this.scroll(delta * direction);\r\n  }\r\n\r\n  centerThumbIfNeeded(index: number) {\r\n    if (!this.items || this.items.length <= 1) {\r\n      return;\r\n    }\r\n\r\n    const nextItemEl = this.thumbsRef.toArray()[index].nativeElement;\r\n    const { offsetLeft, offsetTop, offsetWidth, offsetHeight } = nextItemEl;\r\n\r\n    const itemOffset = this.vertical ? offsetTop : offsetLeft;\r\n    const itemOffsetAxis = this.vertical ? offsetHeight : offsetWidth;\r\n\r\n    const hostScrollAxis = this.hostOffsetAxis;\r\n    const thumbListScroll = this.thumbListRef.nativeElement[this.scrollKey];\r\n\r\n    const nextScrollDelta =\r\n      itemOffset + itemOffsetAxis / 2 - hostScrollAxis / 2 - thumbListScroll;\r\n\r\n    if (\r\n      thumbListScroll + hostScrollAxis < itemOffset + itemOffsetAxis ||\r\n      thumbListScroll > itemOffset\r\n    ) {\r\n      this.scroll(nextScrollDelta);\r\n    }\r\n  }\r\n\r\n  select(index: number) {\r\n    this.selectedIndex = index;\r\n    this.cd.detectChanges();\r\n\r\n    if (this.autoScroll) {\r\n      setTimeout(() => this.centerThumbIfNeeded(index));\r\n    }\r\n  }\r\n\r\n  onItemErrored(item: GalleryItemInternal) {\r\n    item._thumbFailed = true;\r\n  }\r\n\r\n  emitEvent(\r\n    index: number,\r\n    item: GalleryItemInternal,\r\n    event: Event,\r\n    emitter: EventEmitter<GalleryItemEvent>\r\n  ) {\r\n    emitter.emit({\r\n      index,\r\n      item,\r\n      event,\r\n    });\r\n  }\r\n\r\n  private scroll(totalScrollDelta: number) {\r\n    if (!isBrowser) {\r\n      return;\r\n    }\r\n    if (SUPPORT.scrollBehavior || this.scrollBehavior === 'auto') {\r\n      this.thumbListRef.nativeElement[this.scrollKey] += totalScrollDelta;\r\n      return;\r\n    }\r\n    if (this.scrollId != null) {\r\n      cancelAnimationFrame(this.scrollId);\r\n    }\r\n\r\n    const totalDistance = Math.abs(totalScrollDelta);\r\n    const startTime = Date.now();\r\n    const baseArrowSlideTime = 200;\r\n    let totalTime = (Math.log10(totalDistance) - 1.1) * baseArrowSlideTime;\r\n    if (totalTime < 0) {\r\n      totalTime = baseArrowSlideTime;\r\n    }\r\n    let currentScroll = 0;\r\n\r\n    // Emulating native scroll-behavior: smooth\r\n    // NOTE: This function is called on per frame basis recursively to create smooth animation.\r\n    // The scroll value is updated proportionally to the time elapsed since the animation's start.\r\n    // The period of requested frames should match the display's refresh rate as recommended in W3C spec.\r\n    const animate = () => {\r\n      const suggestedScroll = Math.ceil(\r\n        ((Date.now() - startTime) / totalTime) * totalDistance\r\n      );\r\n      let frameScroll = Math.min(\r\n        suggestedScroll - currentScroll,\r\n        totalDistance - currentScroll\r\n      );\r\n      frameScroll *= Math.sign(totalScrollDelta);\r\n      currentScroll = suggestedScroll;\r\n\r\n      this.thumbListRef.nativeElement[this.scrollKey] += frameScroll;\r\n\r\n      if (currentScroll <= totalDistance) {\r\n        this.scrollId = requestAnimationFrame(animate);\r\n      }\r\n    };\r\n\r\n    this.scrollId = requestAnimationFrame(animate);\r\n  }\r\n\r\n  private onArrowsObserved: IntersectionObserverCallback = entries => {\r\n    const entryEl1 = entries[0].target as HTMLElement;\r\n    const firstThumbEntry =\r\n      entryEl1 === this.thumbsRef.first.nativeElement ? entries[0] : entries[1];\r\n    const lastThumbEntry =\r\n      entryEl1 === this.thumbsRef.last.nativeElement ? entries[0] : entries[1];\r\n\r\n    if (firstThumbEntry) {\r\n      this.showStartArrow = firstThumbEntry.intersectionRatio < 1;\r\n    }\r\n    if (lastThumbEntry) {\r\n      this.showEndArrow = lastThumbEntry.intersectionRatio < 1;\r\n    }\r\n\r\n    this.cd.detectChanges();\r\n  };\r\n\r\n  private observeArrows() {\r\n    if (!this.arrowObserver) {\r\n      this.arrowObserver = new IntersectionObserver(this.onArrowsObserved, {\r\n        root: this.thumbListRef.nativeElement,\r\n        threshold: 1.0,\r\n      });\r\n    } else {\r\n      this.arrowObserver.disconnect();\r\n    }\r\n    setTimeout(() => {\r\n      this.arrowObserver.observe(this.thumbsRef.first.nativeElement);\r\n      this.arrowObserver.observe(this.thumbsRef.last.nativeElement);\r\n    });\r\n  }\r\n\r\n  private unobserveArrows() {\r\n    this.arrowObserver && this.arrowObserver.disconnect();\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thumbs.component.js","sourceRoot":"ng://ngx-doe-gallery/","sources":["lib/components/thumbs/thumbs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\n\nimport {\n  isBrowser,\n  Orientation,\n  SUPPORT,\n  ThumbTemplateContext,\n} from '../../core';\nimport { Aria } from '../../core/aria';\nimport {\n  GalleryItemInternal,\n  GalleryItemEvent,\n  isVideo,\n} from '../../core/gallery-item';\n\n@Component({\n  selector: 'doe-thumbs',\n  templateUrl: './thumbs.component.html',\n  styleUrls: ['./thumbs.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ThumbsComponent implements OnChanges, OnDestroy {\n  @Input() items: GalleryItemInternal[] = [];\n  @Input() selectedIndex: number;\n  @Input() aria: Aria;\n  @Input() orientation: Orientation;\n  @Input() arrows: boolean;\n  @Input() arrowSlideByLength: number;\n  @Input() autoScroll: boolean;\n  @Input() thumbTemplate: TemplateRef<ThumbTemplateContext>;\n  @Input() arrowTemplate: TemplateRef<void>;\n  @Input() errorTemplate: TemplateRef<void>;\n  @Input()\n  set scrollBehavior(val: ScrollBehavior) {\n    this._scrollBehavior = val || 'smooth';\n  }\n  get scrollBehavior() {\n    return this._smoothScrollAllowed ? this._scrollBehavior : 'auto';\n  }\n\n  @Output() thumbClick = new EventEmitter<GalleryItemEvent>();\n  @Output() thumbHover = new EventEmitter<GalleryItemEvent>();\n\n  @ViewChild('thumbs', { static: true }) thumbListRef: ElementRef<HTMLElement>;\n  @ViewChildren('thumb') thumbsRef: QueryList<ElementRef<HTMLElement>>;\n\n  isVideo = isVideo;\n\n  _showStartArrow = false;\n  _showEndArrow = false;\n  _vertical: boolean;\n\n  private _destroy$ = new Subject();\n  private _arrowObserver: IntersectionObserver;\n  private _scrollBehavior: ScrollBehavior;\n  private _scrollId: number;\n  private _smoothScrollAllowed = false;\n\n  @HostBinding('class')\n  get cssClass() {\n    return `doe-thumbs--${this.orientation}`;\n  }\n\n  private get _hostOffsetAxis(): number {\n    return this._vertical\n      ? this._elRef.nativeElement.offsetHeight\n      : this._elRef.nativeElement.offsetWidth;\n  }\n\n  private get _scrollKey(): string {\n    return this._vertical ? 'scrollTop' : 'scrollLeft';\n  }\n\n  constructor(\n    private _cd: ChangeDetectorRef,\n    private _elRef: ElementRef<HTMLElement>\n  ) {}\n\n  ngOnChanges({ arrows, items, orientation }: SimpleChanges) {\n    if (orientation && orientation.currentValue != null) {\n      const newOrientation: Orientation = orientation.currentValue;\n      this._vertical = newOrientation === 'left' || newOrientation === 'right';\n    }\n    if (arrows) {\n      if (arrows.currentValue && this.items && this.items.length) {\n        this.observeArrows();\n      } else if (!arrows.currentValue) {\n        this._showStartArrow = false;\n        this._showEndArrow = false;\n        this.unobserveArrows();\n      }\n    }\n\n    if (items && items.currentValue) {\n      const currItems = (items.currentValue || []) as GalleryItemInternal[];\n      const prevItems = (items.previousValue || []) as GalleryItemInternal[];\n\n      if (currItems.length === prevItems.length) {\n        return;\n      }\n\n      if (this.arrows && currItems.length) {\n        this.observeArrows();\n      }\n      if (!prevItems.length) {\n        setTimeout(() => {\n          this.centerThumbIfNeeded(this.selectedIndex);\n          this._smoothScrollAllowed = true;\n        });\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n    this._arrowObserver && this._arrowObserver.disconnect();\n  }\n\n  slide(direction: number) {\n    let delta: number;\n\n    if (this.arrowSlideByLength) {\n      delta = this.arrowSlideByLength;\n    } else {\n      // Note: Slide by the full height/width of the gallery\n      // or by the overflow of the thumbs - to prevent unnecessary requestAnimationFrame calls while trying to scroll\n      // outside of the min/max scroll of the thumbs\n      const thumbList = this.thumbListRef.nativeElement as HTMLElement;\n      const thumbListScrollAxis = this._vertical\n        ? thumbList.scrollHeight\n        : thumbList.scrollWidth;\n      const thumbListOffsetAxis = this._vertical\n        ? thumbList.offsetHeight\n        : thumbList.offsetWidth;\n\n      delta = Math.min(\n        thumbListOffsetAxis,\n        thumbListScrollAxis - thumbListOffsetAxis\n      );\n    }\n    this.scroll(delta * direction);\n  }\n\n  centerThumbIfNeeded(index: number) {\n    if (!this.items || this.items.length <= 1) {\n      return;\n    }\n\n    const nextItemEl = this.thumbsRef.toArray()[index].nativeElement;\n\n    if (!nextItemEl) {\n      return;\n    }\n\n    const { offsetLeft, offsetTop, offsetWidth, offsetHeight } = nextItemEl;\n\n    const itemOffset = this._vertical ? offsetTop : offsetLeft;\n    const itemOffsetAxis = this._vertical ? offsetHeight : offsetWidth;\n\n    const hostScrollAxis = this._hostOffsetAxis;\n    const thumbListScroll = this.thumbListRef.nativeElement[this._scrollKey];\n\n    const nextScrollDelta =\n      itemOffset + itemOffsetAxis / 2 - hostScrollAxis / 2 - thumbListScroll;\n\n    if (\n      thumbListScroll + hostScrollAxis < itemOffset + itemOffsetAxis ||\n      thumbListScroll > itemOffset\n    ) {\n      this.scroll(nextScrollDelta);\n    }\n  }\n\n  select(index: number) {\n    this.selectedIndex = index;\n    this._cd.detectChanges();\n\n    if (this.autoScroll) {\n      setTimeout(() => this.centerThumbIfNeeded(index));\n    }\n  }\n\n  _emitEvent(\n    index: number,\n    item: GalleryItemInternal,\n    event: Event,\n    emitter: EventEmitter<GalleryItemEvent>\n  ) {\n    emitter.emit({\n      index,\n      item,\n      event,\n    });\n  }\n\n  _onLoadChange(item: GalleryItemInternal, success: boolean) {\n    item._thumbFailed = !success;\n  }\n\n  private scroll(totalScrollDelta: number) {\n    if (!isBrowser) {\n      return;\n    }\n    if (SUPPORT.scrollBehavior || this.scrollBehavior === 'auto') {\n      this.thumbListRef.nativeElement[this._scrollKey] += totalScrollDelta;\n      return;\n    }\n    if (this._scrollId != null) {\n      cancelAnimationFrame(this._scrollId);\n    }\n\n    const totalDistance = Math.abs(totalScrollDelta);\n    const startTime = Date.now();\n    const baseArrowSlideTime = 200;\n    let totalTime = (Math.log10(totalDistance) - 1.1) * baseArrowSlideTime;\n    if (totalTime < 0) {\n      totalTime = baseArrowSlideTime;\n    }\n    let currentScroll = 0;\n\n    // Emulating native scroll-behavior: smooth\n    // NOTE: This function is called on per frame basis recursively to create smooth animation.\n    // The scroll value is updated proportionally to the time elapsed since the animation's start.\n    // The period of requested frames should match the display's refresh rate as recommended in W3C spec.\n    const animate = () => {\n      const suggestedScroll = Math.ceil(\n        ((Date.now() - startTime) / totalTime) * totalDistance\n      );\n      let frameScroll = Math.min(\n        suggestedScroll - currentScroll,\n        totalDistance - currentScroll\n      );\n      frameScroll *= Math.sign(totalScrollDelta);\n      currentScroll = suggestedScroll;\n\n      this.thumbListRef.nativeElement[this._scrollKey] += frameScroll;\n\n      if (currentScroll <= totalDistance) {\n        this._scrollId = requestAnimationFrame(animate);\n      }\n    };\n\n    this._scrollId = requestAnimationFrame(animate);\n  }\n\n  private onArrowsObserved: IntersectionObserverCallback = entries => {\n    const entryEl1 = entries[0].target as HTMLElement;\n    const firstThumbEntry =\n      entryEl1 === this.thumbsRef.first.nativeElement ? entries[0] : entries[1];\n    const lastThumbEntry =\n      entryEl1 === this.thumbsRef.last.nativeElement ? entries[0] : entries[1];\n\n    if (firstThumbEntry) {\n      this._showStartArrow = firstThumbEntry.intersectionRatio < 1;\n    }\n    if (lastThumbEntry) {\n      this._showEndArrow = lastThumbEntry.intersectionRatio < 1;\n    }\n\n    this._cd.detectChanges();\n  };\n\n  private observeArrows() {\n    if (!this._arrowObserver) {\n      this._arrowObserver = new IntersectionObserver(this.onArrowsObserved, {\n        root: this.thumbListRef.nativeElement,\n        threshold: 1.0,\n      });\n    } else {\n      this._arrowObserver.disconnect();\n    }\n    setTimeout(() => {\n      this._arrowObserver.observe(this.thumbsRef.first.nativeElement);\n      this._arrowObserver.observe(this.thumbsRef.last.nativeElement);\n    });\n  }\n\n  private unobserveArrows() {\n    this._arrowObserver && this._arrowObserver.disconnect();\n  }\n}\n"]}

@@ -24,2 +24,2 @@ /**

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJpYS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2FyaWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSwwQkFJQzs7O0lBSEMsNEJBQXFCOztJQUNyQiwyQkFBb0I7O0lBQ3BCLCtCQUF3Qjs7O0FBRzFCLE1BQU0sS0FBTyxXQUFXLEdBQVM7SUFDL0IsWUFBWSxFQUFFLGVBQWU7SUFDN0IsV0FBVyxFQUFFLHlCQUF5QjtJQUN0QyxlQUFlLEVBQUUsb0JBQW9CO0NBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBcmlhIHtcclxuICBnYWxsZXJ5TGFiZWw6IHN0cmluZztcclxuICB2aWV3ZXJMYWJlbDogc3RyaW5nO1xyXG4gIHRodW1ibmFpbHNMYWJlbDogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZGVmYXVsdEFyaWE6IEFyaWEgPSB7XHJcbiAgZ2FsbGVyeUxhYmVsOiAnSW1hZ2UgR2FsbGVyeScsXHJcbiAgdmlld2VyTGFiZWw6ICdEaXNwbGF5ZWQgZ2FsbGVyeSBpbWFnZScsXHJcbiAgdGh1bWJuYWlsc0xhYmVsOiAnR2FsbGVyeSB0aHVtYm5haWxzJ1xyXG59O1xyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJpYS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2FyaWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSwwQkFJQzs7O0lBSEMsNEJBQXFCOztJQUNyQiwyQkFBb0I7O0lBQ3BCLCtCQUF3Qjs7O0FBRzFCLE1BQU0sS0FBTyxXQUFXLEdBQVM7SUFDL0IsWUFBWSxFQUFFLGVBQWU7SUFDN0IsV0FBVyxFQUFFLHlCQUF5QjtJQUN0QyxlQUFlLEVBQUUsb0JBQW9CO0NBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBcmlhIHtcbiAgZ2FsbGVyeUxhYmVsOiBzdHJpbmc7XG4gIHZpZXdlckxhYmVsOiBzdHJpbmc7XG4gIHRodW1ibmFpbHNMYWJlbDogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdEFyaWE6IEFyaWEgPSB7XG4gIGdhbGxlcnlMYWJlbDogJ0ltYWdlIEdhbGxlcnknLFxuICB2aWV3ZXJMYWJlbDogJ0Rpc3BsYXllZCBnYWxsZXJ5IGltYWdlJyxcbiAgdGh1bWJuYWlsc0xhYmVsOiAnR2FsbGVyeSB0aHVtYm5haWxzJ1xufTtcbiJdfQ==

@@ -135,7 +135,2 @@ /**

/**
* Marks item as seen at least once
* @type {?|undefined}
*/
GalleryItemInternal.prototype._seen;
/**
* `true` when media couldn't be loaded

@@ -151,2 +146,8 @@ * @type {?|undefined}

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS1pdGVtLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL2NvcmUvZ2FsbGVyeS1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOzs7O0lBQ0UscUJBSVMsR0FBVyxFQUtYLFFBQWdCLEVBS2hCLEdBQVcsRUFLWCxXQUFtQixFQUtuQixJQUFTO1FBcEJULFFBQUcsR0FBSCxHQUFHLENBQVE7UUFLWCxhQUFRLEdBQVIsUUFBUSxDQUFRO1FBS2hCLFFBQUcsR0FBSCxHQUFHLENBQVE7UUFLWCxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUtuQixTQUFJLEdBQUosSUFBSSxDQUFLO0lBQ2YsQ0FBQztJQUNOLGtCQUFDO0FBQUQsQ0FBQyxBQTNCRCxJQTJCQzs7Ozs7Ozs7OztJQXRCRywwQkFBa0I7Ozs7O0lBS2xCLCtCQUF1Qjs7Ozs7SUFLdkIsMEJBQWtCOzs7OztJQUtsQixrQ0FBMEI7Ozs7O0lBSzFCLDJCQUFnQjs7Ozs7O0FBT3BCLG1DQW9CQzs7Ozs7O0lBaEJDLCtCQUFlOzs7OztJQUtmLDhCQUFlOzs7OztJQUtmLDhCQUFlOzs7OztJQUtmLDZCQUFjOztBQUdoQjtJQUFrQyx3Q0FBVztJQUMzQyxzQkFDRSxHQUFHLEVBQ0gsUUFBUyxFQUNULEdBQUksRUFDSixXQUFZLEVBS0wsY0FBZ0MsRUFFdkMsSUFBSztRQVhQLFlBYUUsa0JBQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQyxTQUM3QztRQUxRLG9CQUFjLEdBQWQsY0FBYyxDQUFrQjs7SUFLekMsQ0FBQztJQUNILG1CQUFDO0FBQUQsQ0FBQyxBQWhCRCxDQUFrQyxXQUFXLEdBZ0I1Qzs7Ozs7OztJQU5HLHNDQUF1Qzs7QUFRM0M7SUFBa0Msd0NBQVc7SUFDM0Msc0JBQVksR0FBRyxFQUFFLFFBQVMsRUFBRSxHQUFJLEVBQUUsV0FBWSxFQUFFLElBQUs7ZUFDbkQsa0JBQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQztJQUM5QyxDQUFDO0lBQ0gsbUJBQUM7QUFBRCxDQUFDLEFBSkQsQ0FBa0MsV0FBVyxHQUk1Qzs7Ozs7QUFFRCxzQ0FZQzs7Ozs7O0lBUkMsaUNBQWM7O0lBRWQsZ0NBQWtCOzs7OztJQUtsQixpQ0FBYTs7Ozs7QUFHZix5Q0FvQkM7Ozs7OztJQWhCQyxzQ0FBa0I7Ozs7O0lBS2xCLG9DQUFnQjs7Ozs7SUFLaEIsc0NBQWtCOzs7OztJQUtsQiwyQ0FBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgYWJzdHJhY3QgY2xhc3MgR2FsbGVyeUl0ZW0ge1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgLyoqXHJcbiAgICAgKiBNZWRpYSB1cmxcclxuICAgICAqL1xyXG4gICAgcHVibGljIHNyYzogc3RyaW5nLFxyXG5cclxuICAgIC8qKlxyXG4gICAgICogVXJsIG9mIG1lZGlhIHRodW1ibmFpbFxyXG4gICAgICovXHJcbiAgICBwdWJsaWMgdGh1bWJTcmM6IHN0cmluZyxcclxuXHJcbiAgICAvKipcclxuICAgICAqIEFsdCB0ZXh0IGZvciBub3QgeWV0IGxvYWRlZCBpbWFnZVxyXG4gICAgICovXHJcbiAgICBwdWJsaWMgYWx0OiBzdHJpbmcsXHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBEZXNjcmlwdGlvbiB0aGF0IGlzIHRvIGJlIHNob3duIG9uIHRoZSBjdXJyZW50bHkgZGlzcGxheWVkIGdhbGxlcnkgaXRlbVxyXG4gICAgICovXHJcbiAgICBwdWJsaWMgZGVzY3JpcHRpb246IHN0cmluZyxcclxuXHJcbiAgICAvKipcclxuICAgICAqIEN1c3RvbSBkYXRhIHdoZXJlIHlvdSBjYW4gcHV0IHdoYXRldmVyIHlvdSB3YW50XHJcbiAgICAgKi9cclxuICAgIHB1YmxpYyBkYXRhOiBhbnlcclxuICApIHt9XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGUgd2hvbGUgaW50ZXJmYWNlIG1pcnJvcnMgPHNvdXJjZT4gYXR0cmlidXRlcyBmcm9tIHRoZSBXSEFUV0cgc3BlYy5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgUGljdHVyZVNvdXJjZSB7XHJcbiAgLyoqXHJcbiAgICogc3JjIFVSTFxyXG4gICAqL1xyXG4gIHNyY3NldDogc3RyaW5nO1xyXG5cclxuICAvKipcclxuICAgKiBDU1MgbWVkaWEgc2VsZWN0b3JcclxuICAgKi9cclxuICBtZWRpYT86IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgICogR2l2ZSBoaW50IHRvIGJyb3dzZXIgd2hpY2ggc3JjIGZyb20gc3Jjc2V0IHRvIHBpY2tcclxuICAgKi9cclxuICBzaXplcz86IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgICogTUlNRSBtZWRpYSB0eXBlXHJcbiAgICovXHJcbiAgdHlwZT86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIEdhbGxlcnlJbWFnZSBleHRlbmRzIEdhbGxlcnlJdGVtIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHNyYyxcclxuICAgIHRodW1iU3JjPyxcclxuICAgIGFsdD8sXHJcbiAgICBkZXNjcmlwdGlvbj8sXHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBTb3VyY2VzIGZvciA8cGljdHVyZT5cclxuICAgICAqL1xyXG4gICAgcHVibGljIHBpY3R1cmVTb3VyY2VzPzogUGljdHVyZVNvdXJjZVtdLFxyXG5cclxuICAgIGRhdGE/XHJcbiAgKSB7XHJcbiAgICBzdXBlcihzcmMsIHRodW1iU3JjLCBhbHQsIGRlc2NyaXB0aW9uLCBkYXRhKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBHYWxsZXJ5VmlkZW8gZXh0ZW5kcyBHYWxsZXJ5SXRlbSB7XHJcbiAgY29uc3RydWN0b3Ioc3JjLCB0aHVtYlNyYz8sIGFsdD8sIGRlc2NyaXB0aW9uPywgZGF0YT8pIHtcclxuICAgIHN1cGVyKHNyYywgdGh1bWJTcmMsIGFsdCwgZGVzY3JpcHRpb24sIGRhdGEpO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBHYWxsZXJ5SXRlbUV2ZW50IHtcclxuICAvKipcclxuICAgKiBJbmRleCBvZiB0aGUgaXRlbVxyXG4gICAqL1xyXG4gIGluZGV4OiBudW1iZXI7XHJcblxyXG4gIGl0ZW06IEdhbGxlcnlJdGVtO1xyXG5cclxuICAvKipcclxuICAgKiBET00gZXZlbnRcclxuICAgKi9cclxuICBldmVudDogRXZlbnQ7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR2FsbGVyeUl0ZW1JbnRlcm5hbCBleHRlbmRzIEdhbGxlcnlJbWFnZSwgR2FsbGVyeVZpZGVvIHtcclxuICAvKipcclxuICAgKiBNYXJrcyBpdGVtIGFzIGxvYWRlZCBvbmNlIGl0cyBtZWRpYSBnZXRzIGxvYWRlZFxyXG4gICAqL1xyXG4gIF9sb2FkZWQ/OiBib29sZWFuO1xyXG5cclxuICAvKipcclxuICAgKiBNYXJrcyBpdGVtIGFzIHNlZW4gYXQgbGVhc3Qgb25jZVxyXG4gICAqL1xyXG4gIF9zZWVuPzogYm9vbGVhbjtcclxuXHJcbiAgLyoqXHJcbiAgICogYHRydWVgIHdoZW4gbWVkaWEgY291bGRuJ3QgYmUgbG9hZGVkXHJcbiAgICovXHJcbiAgX2ZhaWxlZD86IGJvb2xlYW47XHJcblxyXG4gIC8qKlxyXG4gICAqIGB0cnVlYCB3aGVuIHRodW1ibmFpbCBjb3VsZG4ndCBiZSBsb2FkZWRcclxuICAgKi9cclxuICBfdGh1bWJGYWlsZWQ/OiBib29sZWFuO1xyXG59XHJcbiJdfQ==
/** @type {?} */
export var isVideo = (/**
* @param {?} item
* @return {?}
*/
function (item) { return item instanceof GalleryVideo; });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS1pdGVtLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL2NvcmUvZ2FsbGVyeS1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOzs7O0lBQ0UscUJBSVMsR0FBVyxFQUtYLFFBQWdCLEVBS2hCLEdBQVcsRUFLWCxXQUFtQixFQUtuQixJQUFTO1FBcEJULFFBQUcsR0FBSCxHQUFHLENBQVE7UUFLWCxhQUFRLEdBQVIsUUFBUSxDQUFRO1FBS2hCLFFBQUcsR0FBSCxHQUFHLENBQVE7UUFLWCxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUtuQixTQUFJLEdBQUosSUFBSSxDQUFLO0lBQ2YsQ0FBQztJQUNOLGtCQUFDO0FBQUQsQ0FBQyxBQTNCRCxJQTJCQzs7Ozs7Ozs7OztJQXRCRywwQkFBa0I7Ozs7O0lBS2xCLCtCQUF1Qjs7Ozs7SUFLdkIsMEJBQWtCOzs7OztJQUtsQixrQ0FBMEI7Ozs7O0lBSzFCLDJCQUFnQjs7Ozs7O0FBT3BCLG1DQW9CQzs7Ozs7O0lBaEJDLCtCQUFlOzs7OztJQUtmLDhCQUFlOzs7OztJQUtmLDhCQUFlOzs7OztJQUtmLDZCQUFjOztBQUdoQjtJQUFrQyx3Q0FBVztJQUMzQyxzQkFDRSxHQUFHLEVBQ0gsUUFBUyxFQUNULEdBQUksRUFDSixXQUFZLEVBS0wsY0FBZ0MsRUFFdkMsSUFBSztRQVhQLFlBYUUsa0JBQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQyxTQUM3QztRQUxRLG9CQUFjLEdBQWQsY0FBYyxDQUFrQjs7SUFLekMsQ0FBQztJQUNILG1CQUFDO0FBQUQsQ0FBQyxBQWhCRCxDQUFrQyxXQUFXLEdBZ0I1Qzs7Ozs7OztJQU5HLHNDQUF1Qzs7QUFRM0M7SUFBa0Msd0NBQVc7SUFDM0Msc0JBQVksR0FBRyxFQUFFLFFBQVMsRUFBRSxHQUFJLEVBQUUsV0FBWSxFQUFFLElBQUs7ZUFDbkQsa0JBQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQztJQUM5QyxDQUFDO0lBQ0gsbUJBQUM7QUFBRCxDQUFDLEFBSkQsQ0FBa0MsV0FBVyxHQUk1Qzs7Ozs7QUFFRCxzQ0FZQzs7Ozs7O0lBUkMsaUNBQWM7O0lBRWQsZ0NBQWtCOzs7OztJQUtsQixpQ0FBYTs7Ozs7QUFHZix5Q0FlQzs7Ozs7O0lBWEMsc0NBQWtCOzs7OztJQUtsQixzQ0FBa0I7Ozs7O0lBS2xCLDJDQUF1Qjs7O0FBR3pCLE1BQU0sS0FBTyxPQUFPOzs7O0FBQUcsVUFBQyxJQUFpQixJQUFLLE9BQUEsSUFBSSxZQUFZLFlBQVksRUFBNUIsQ0FBNEIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBhYnN0cmFjdCBjbGFzcyBHYWxsZXJ5SXRlbSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIC8qKlxuICAgICAqIE1lZGlhIHVybFxuICAgICAqL1xuICAgIHB1YmxpYyBzcmM6IHN0cmluZyxcblxuICAgIC8qKlxuICAgICAqIFVybCBvZiBtZWRpYSB0aHVtYm5haWxcbiAgICAgKi9cbiAgICBwdWJsaWMgdGh1bWJTcmM6IHN0cmluZyxcblxuICAgIC8qKlxuICAgICAqIEFsdCB0ZXh0IGZvciBub3QgeWV0IGxvYWRlZCBpbWFnZVxuICAgICAqL1xuICAgIHB1YmxpYyBhbHQ6IHN0cmluZyxcblxuICAgIC8qKlxuICAgICAqIERlc2NyaXB0aW9uIHRoYXQgaXMgdG8gYmUgc2hvd24gb24gdGhlIGN1cnJlbnRseSBkaXNwbGF5ZWQgZ2FsbGVyeSBpdGVtXG4gICAgICovXG4gICAgcHVibGljIGRlc2NyaXB0aW9uOiBzdHJpbmcsXG5cbiAgICAvKipcbiAgICAgKiBDdXN0b20gZGF0YSB3aGVyZSB5b3UgY2FuIHB1dCB3aGF0ZXZlciB5b3Ugd2FudFxuICAgICAqL1xuICAgIHB1YmxpYyBkYXRhOiBhbnlcbiAgKSB7fVxufVxuXG4vKipcbiAqIFRoZSB3aG9sZSBpbnRlcmZhY2UgbWlycm9ycyA8c291cmNlPiBhdHRyaWJ1dGVzIGZyb20gdGhlIFdIQVRXRyBzcGVjLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBpY3R1cmVTb3VyY2Uge1xuICAvKipcbiAgICogc3JjIFVSTFxuICAgKi9cbiAgc3Jjc2V0OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIENTUyBtZWRpYSBzZWxlY3RvclxuICAgKi9cbiAgbWVkaWE/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEdpdmUgaGludCB0byBicm93c2VyIHdoaWNoIHNyYyBmcm9tIHNyY3NldCB0byBwaWNrXG4gICAqL1xuICBzaXplcz86IHN0cmluZztcblxuICAvKipcbiAgICogTUlNRSBtZWRpYSB0eXBlXG4gICAqL1xuICB0eXBlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgR2FsbGVyeUltYWdlIGV4dGVuZHMgR2FsbGVyeUl0ZW0ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBzcmMsXG4gICAgdGh1bWJTcmM/LFxuICAgIGFsdD8sXG4gICAgZGVzY3JpcHRpb24/LFxuXG4gICAgLyoqXG4gICAgICogU291cmNlcyBmb3IgPHBpY3R1cmU+XG4gICAgICovXG4gICAgcHVibGljIHBpY3R1cmVTb3VyY2VzPzogUGljdHVyZVNvdXJjZVtdLFxuXG4gICAgZGF0YT9cbiAgKSB7XG4gICAgc3VwZXIoc3JjLCB0aHVtYlNyYywgYWx0LCBkZXNjcmlwdGlvbiwgZGF0YSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEdhbGxlcnlWaWRlbyBleHRlbmRzIEdhbGxlcnlJdGVtIHtcbiAgY29uc3RydWN0b3Ioc3JjLCB0aHVtYlNyYz8sIGFsdD8sIGRlc2NyaXB0aW9uPywgZGF0YT8pIHtcbiAgICBzdXBlcihzcmMsIHRodW1iU3JjLCBhbHQsIGRlc2NyaXB0aW9uLCBkYXRhKTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdhbGxlcnlJdGVtRXZlbnQge1xuICAvKipcbiAgICogSW5kZXggb2YgdGhlIGl0ZW1cbiAgICovXG4gIGluZGV4OiBudW1iZXI7XG5cbiAgaXRlbTogR2FsbGVyeUl0ZW07XG5cbiAgLyoqXG4gICAqIERPTSBldmVudFxuICAgKi9cbiAgZXZlbnQ6IEV2ZW50O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdhbGxlcnlJdGVtSW50ZXJuYWwgZXh0ZW5kcyBHYWxsZXJ5SW1hZ2UsIEdhbGxlcnlWaWRlbyB7XG4gIC8qKlxuICAgKiBNYXJrcyBpdGVtIGFzIGxvYWRlZCBvbmNlIGl0cyBtZWRpYSBnZXRzIGxvYWRlZFxuICAgKi9cbiAgX2xvYWRlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIGB0cnVlYCB3aGVuIG1lZGlhIGNvdWxkbid0IGJlIGxvYWRlZFxuICAgKi9cbiAgX2ZhaWxlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIGB0cnVlYCB3aGVuIHRodW1ibmFpbCBjb3VsZG4ndCBiZSBsb2FkZWRcbiAgICovXG4gIF90aHVtYkZhaWxlZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBpc1ZpZGVvID0gKGl0ZW06IEdhbGxlcnlJdGVtKSA9PiBpdGVtIGluc3RhbmNlb2YgR2FsbGVyeVZpZGVvO1xuIl19

@@ -12,2 +12,2 @@ /**

export {} from './template-contexts';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHVDQUFjLFdBQVcsQ0FBQztBQUMxQixPQUFPLEVBQ0wsV0FBVyxFQUNYLFlBQVksRUFDWixZQUFZLEVBRWIsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixlQUFjLGNBQWMsQ0FBQztBQUM3QixlQUFjLFdBQVcsQ0FBQztBQUMxQiw2QkFBYyxlQUFlLENBQUM7QUFDOUIsZUFBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XHJcbmV4cG9ydCB7XHJcbiAgR2FsbGVyeUl0ZW0sXHJcbiAgR2FsbGVyeUltYWdlLFxyXG4gIEdhbGxlcnlWaWRlbyxcclxuICBHYWxsZXJ5SXRlbUV2ZW50XHJcbn0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xyXG5leHBvcnQgKiBmcm9tICcuL29iamVjdC1maXQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xvYWRpbmcnO1xyXG5leHBvcnQgKiBmcm9tICcuL29yaWVudGF0aW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi90ZW1wbGF0ZS1jb250ZXh0cyc7XHJcbmV4cG9ydCB7IEFyaWEgfSBmcm9tICcuL2FyaWEnO1xyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHVDQUFjLFdBQVcsQ0FBQztBQUMxQixPQUFPLEVBQ0wsV0FBVyxFQUNYLFlBQVksRUFDWixZQUFZLEVBRWIsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixlQUFjLGNBQWMsQ0FBQztBQUM3QixlQUFjLFdBQVcsQ0FBQztBQUMxQiw2QkFBYyxlQUFlLENBQUM7QUFDOUIsZUFBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XG5leHBvcnQge1xuICBHYWxsZXJ5SXRlbSxcbiAgR2FsbGVyeUltYWdlLFxuICBHYWxsZXJ5VmlkZW8sXG4gIEdhbGxlcnlJdGVtRXZlbnRcbn0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xuZXhwb3J0ICogZnJvbSAnLi9vYmplY3QtZml0JztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZyc7XG5leHBvcnQgKiBmcm9tICcuL29yaWVudGF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vdGVtcGxhdGUtY29udGV4dHMnO1xuZXhwb3J0IHsgQXJpYSB9IGZyb20gJy4vYXJpYSc7XG4iXX0=

@@ -6,2 +6,2 @@ /**

*/
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2xvYWRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIExvYWRpbmcgPSAnYXV0bycgfCAnbGF6eSc7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL2xvYWRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIExvYWRpbmcgPSAnYXV0bycgfCAnbGF6eSc7XG4iXX0=

@@ -6,2 +6,2 @@ /**

*/
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWZpdC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL29iamVjdC1maXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE9iamVjdEZpdCA9ICdjb250YWluJyB8ICdjb3Zlcic7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWZpdC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL29iamVjdC1maXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE9iamVjdEZpdCA9ICdjb250YWluJyB8ICdjb3Zlcic7XG4iXX0=

@@ -23,2 +23,2 @@ /**

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JpZW50YXRpb24uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9vcmllbnRhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQSxJQUFrQixlQUFlO0lBQy9CLElBQUksR0FBSTtJQUNSLEtBQUssR0FBSTtJQUNULEdBQUcsR0FBSTtJQUNQLE1BQU0sSUFBSztJQUNYLFVBQVUsR0FBSTtJQUNkLFFBQVEsSUFBSztFQUNkOzs7QUFFRCxNQUFNLEtBQU8sWUFBWSxHQUFHO0lBQzFCLElBQUksY0FBc0I7SUFDMUIsS0FBSyxlQUF1QjtJQUM1QixHQUFHLGFBQXFCO0lBQ3hCLE1BQU0saUJBQXdCO0NBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgT3JpZW50YXRpb24gPSAndG9wJyB8ICdib3R0b20nIHwgJ2xlZnQnIHwgJ3JpZ2h0JztcclxuXHJcbmV4cG9ydCB0eXBlIFZlcnRpY2FsT3JpZW50YXRpb24gPSAndG9wJyB8ICdib3R0b20nO1xyXG5cclxuZXhwb3J0IGNvbnN0IGVudW0gT3JpZW50YXRpb25GbGFnIHtcclxuICBMRUZUID0gMixcclxuICBSSUdIVCA9IDQsXHJcbiAgVE9QID0gOCxcclxuICBCT1RUT00gPSAxNixcclxuICBIT1JJWk9OVEFMID0gNixcclxuICBWRVJUSUNBTCA9IDI0XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBvcmllbnRhdGlvbnMgPSB7XHJcbiAgbGVmdDogT3JpZW50YXRpb25GbGFnLkxFRlQsXHJcbiAgcmlnaHQ6IE9yaWVudGF0aW9uRmxhZy5SSUdIVCxcclxuICB0b3A6IE9yaWVudGF0aW9uRmxhZy5UT1AsXHJcbiAgYm90dG9tOiBPcmllbnRhdGlvbkZsYWcuQk9UVE9NXHJcbn07XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JpZW50YXRpb24uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS9vcmllbnRhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQSxJQUFrQixlQUFlO0lBQy9CLElBQUksR0FBSTtJQUNSLEtBQUssR0FBSTtJQUNULEdBQUcsR0FBSTtJQUNQLE1BQU0sSUFBSztJQUNYLFVBQVUsR0FBSTtJQUNkLFFBQVEsSUFBSztFQUNkOzs7QUFFRCxNQUFNLEtBQU8sWUFBWSxHQUFHO0lBQzFCLElBQUksY0FBc0I7SUFDMUIsS0FBSyxlQUF1QjtJQUM1QixHQUFHLGFBQXFCO0lBQ3hCLE1BQU0saUJBQXdCO0NBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgT3JpZW50YXRpb24gPSAndG9wJyB8ICdib3R0b20nIHwgJ2xlZnQnIHwgJ3JpZ2h0JztcblxuZXhwb3J0IHR5cGUgVmVydGljYWxPcmllbnRhdGlvbiA9ICd0b3AnIHwgJ2JvdHRvbSc7XG5cbmV4cG9ydCBjb25zdCBlbnVtIE9yaWVudGF0aW9uRmxhZyB7XG4gIExFRlQgPSAyLFxuICBSSUdIVCA9IDQsXG4gIFRPUCA9IDgsXG4gIEJPVFRPTSA9IDE2LFxuICBIT1JJWk9OVEFMID0gNixcbiAgVkVSVElDQUwgPSAyNFxufVxuXG5leHBvcnQgY29uc3Qgb3JpZW50YXRpb25zID0ge1xuICBsZWZ0OiBPcmllbnRhdGlvbkZsYWcuTEVGVCxcbiAgcmlnaHQ6IE9yaWVudGF0aW9uRmxhZy5SSUdIVCxcbiAgdG9wOiBPcmllbnRhdGlvbkZsYWcuVE9QLFxuICBib3R0b206IE9yaWVudGF0aW9uRmxhZy5CT1RUT01cbn07XG4iXX0=

@@ -18,2 +18,2 @@ /**

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwcG9ydC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL3N1cHBvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsTUFBTSxLQUFPLFNBQVMsR0FBRyxPQUFPLE1BQU0sS0FBSyxXQUFXOztBQUV0RCxNQUFNLEtBQU8sT0FBTyxHQUFHO0lBQ3JCLGNBQWMsRUFBRSxTQUFTLElBQUksZ0JBQWdCLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLO0lBQ3BFLGtCQUFrQixFQUFFLFNBQVMsSUFBSSxTQUFTLElBQUksS0FBSyxDQUFDLFNBQVM7SUFDN0Qsb0JBQW9CLEVBQUUsU0FBUyxJQUFJLHNCQUFzQixJQUFJLE1BQU07Q0FDcEU7O0FBRUQsTUFBTSxLQUFPLEVBQUUsR0FBRztJQUNoQixHQUFHLEVBQUUsU0FBUyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUM7Q0FDdkUiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXNCcm93c2VyID0gdHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCc7XHJcblxyXG5leHBvcnQgY29uc3QgU1VQUE9SVCA9IHtcclxuICBzY3JvbGxCZWhhdmlvcjogaXNCcm93c2VyICYmICdzY3JvbGxCZWhhdmlvcicgaW4gZG9jdW1lbnQuYm9keS5zdHlsZSxcclxuICBuYXRpdmVNZWRpYUxvYWRpbmc6IGlzQnJvd3NlciAmJiAnbG9hZGluZycgaW4gSW1hZ2UucHJvdG90eXBlLFxyXG4gIGludGVyc2VjdGlvbk9ic2VydmVyOiBpc0Jyb3dzZXIgJiYgJ0ludGVyc2VjdGlvbk9ic2VydmVyJyBpbiB3aW5kb3dcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBVQSA9IHtcclxuICBpb3M6IGlzQnJvd3NlciAmJiAhIXdpbmRvdy5uYXZpZ2F0b3IudXNlckFnZW50Lm1hdGNoKC9pUChhZHxob25lfG9kKS8pXHJcbn07XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwcG9ydC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbImxpYi9jb3JlL3N1cHBvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsTUFBTSxLQUFPLFNBQVMsR0FBRyxPQUFPLE1BQU0sS0FBSyxXQUFXOztBQUV0RCxNQUFNLEtBQU8sT0FBTyxHQUFHO0lBQ3JCLGNBQWMsRUFBRSxTQUFTLElBQUksZ0JBQWdCLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLO0lBQ3BFLGtCQUFrQixFQUFFLFNBQVMsSUFBSSxTQUFTLElBQUksS0FBSyxDQUFDLFNBQVM7SUFDN0Qsb0JBQW9CLEVBQUUsU0FBUyxJQUFJLHNCQUFzQixJQUFJLE1BQU07Q0FDcEU7O0FBRUQsTUFBTSxLQUFPLEVBQUUsR0FBRztJQUNoQixHQUFHLEVBQUUsU0FBUyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUM7Q0FDdkUiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXNCcm93c2VyID0gdHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCc7XG5cbmV4cG9ydCBjb25zdCBTVVBQT1JUID0ge1xuICBzY3JvbGxCZWhhdmlvcjogaXNCcm93c2VyICYmICdzY3JvbGxCZWhhdmlvcicgaW4gZG9jdW1lbnQuYm9keS5zdHlsZSxcbiAgbmF0aXZlTWVkaWFMb2FkaW5nOiBpc0Jyb3dzZXIgJiYgJ2xvYWRpbmcnIGluIEltYWdlLnByb3RvdHlwZSxcbiAgaW50ZXJzZWN0aW9uT2JzZXJ2ZXI6IGlzQnJvd3NlciAmJiAnSW50ZXJzZWN0aW9uT2JzZXJ2ZXInIGluIHdpbmRvd1xufTtcblxuZXhwb3J0IGNvbnN0IFVBID0ge1xuICBpb3M6IGlzQnJvd3NlciAmJiAhIXdpbmRvdy5uYXZpZ2F0b3IudXNlckFnZW50Lm1hdGNoKC9pUChhZHxob25lfG9kKS8pXG59O1xuIl19

@@ -18,3 +18,3 @@ /**

/** @type {?} */
ItemTemplateContext.prototype.seen;
ItemTemplateContext.prototype.video;
}

@@ -33,2 +33,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS90ZW1wbGF0ZS1jb250ZXh0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUVBLHlDQUtDOzs7SUFKQyxvQ0FBYzs7SUFDZCw0Q0FBc0I7O0lBQ3RCLG1DQUFrQjs7SUFDbEIsbUNBQWM7Ozs7O0FBR2hCLDBDQUlDOzs7SUFIQyxxQ0FBYzs7SUFDZCw2Q0FBc0I7O0lBQ3RCLG9DQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdhbGxlcnlJdGVtIH0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJdGVtVGVtcGxhdGVDb250ZXh0IHtcclxuICBpbmRleDogbnVtYmVyO1xyXG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcclxuICBpdGVtOiBHYWxsZXJ5SXRlbTtcclxuICBzZWVuOiBib29sZWFuO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRodW1iVGVtcGxhdGVDb250ZXh0IHtcclxuICBpbmRleDogbnVtYmVyO1xyXG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcclxuICBpdGVtOiBHYWxsZXJ5SXRlbTtcclxufVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvY29yZS90ZW1wbGF0ZS1jb250ZXh0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUVBLHlDQUtDOzs7SUFKQyxvQ0FBYzs7SUFDZCw0Q0FBc0I7O0lBQ3RCLG1DQUFrQjs7SUFDbEIsb0NBQWU7Ozs7O0FBR2pCLDBDQUlDOzs7SUFIQyxxQ0FBYzs7SUFDZCw2Q0FBc0I7O0lBQ3RCLG9DQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdhbGxlcnlJdGVtIH0gZnJvbSAnLi9nYWxsZXJ5LWl0ZW0nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEl0ZW1UZW1wbGF0ZUNvbnRleHQge1xuICBpbmRleDogbnVtYmVyO1xuICBzZWxlY3RlZEluZGV4OiBudW1iZXI7XG4gIGl0ZW06IEdhbGxlcnlJdGVtO1xuICB2aWRlbzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUaHVtYlRlbXBsYXRlQ29udGV4dCB7XG4gIGluZGV4OiBudW1iZXI7XG4gIHNlbGVjdGVkSW5kZXg6IG51bWJlcjtcbiAgaXRlbTogR2FsbGVyeUl0ZW07XG59XG4iXX0=

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

import { SafePipe } from './pipes/safe.pipe';
import { MediaDirective } from './directives/media.directive';
var GalleryModule = /** @class */ (function () {

@@ -28,5 +29,6 @@ function GalleryModule() {

SafePipe,
MediaDirective,
],
imports: [CommonModule, BrowserAnimationsModule],
exports: [GalleryComponent],
exports: [GalleryComponent, MediaDirective],
},] }

@@ -37,2 +39,2 @@ ];

export { GalleryModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvZ2FsbGVyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUUvRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN6RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUU3QztJQUFBO0lBWTRCLENBQUM7O2dCQVo1QixRQUFRLFNBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGdCQUFnQjt3QkFDaEIsZUFBZTt3QkFDZixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsZ0JBQWdCO3dCQUNoQixRQUFRO3FCQUNUO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSx1QkFBdUIsQ0FBQztvQkFDaEQsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQzVCOztJQUMyQixvQkFBQztDQUFBLEFBWjdCLElBWTZCO1NBQWhCLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyQW5pbWF0aW9uc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9ucyc7XHJcblxyXG5pbXBvcnQgeyBDb3VudGVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2NvdW50ZXIvY291bnRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBHYWxsZXJ5Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2dhbGxlcnkvZ2FsbGVyeS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDaGV2cm9uSWNvbkNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9pY29ucy9jaGV2cm9uL2NoZXZyb24taWNvbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBUaHVtYnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGh1bWJzL3RodW1icy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBWaWV3ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdmlld2VyL3ZpZXdlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTYWZlUGlwZSB9IGZyb20gJy4vcGlwZXMvc2FmZS5waXBlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBHYWxsZXJ5Q29tcG9uZW50LFxyXG4gICAgVGh1bWJzQ29tcG9uZW50LFxyXG4gICAgVmlld2VyQ29tcG9uZW50LFxyXG4gICAgQ2hldnJvbkljb25Db21wb25lbnQsXHJcbiAgICBDb3VudGVyQ29tcG9uZW50LFxyXG4gICAgU2FmZVBpcGUsXHJcbiAgXSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBCcm93c2VyQW5pbWF0aW9uc01vZHVsZV0sXHJcbiAgZXhwb3J0czogW0dhbGxlcnlDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgR2FsbGVyeU1vZHVsZSB7fVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FsbGVyeS5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtZG9lLWdhbGxlcnkvIiwic291cmNlcyI6WyJsaWIvZ2FsbGVyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUUvRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN6RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFOUQ7SUFBQTtJQWE0QixDQUFDOztnQkFiNUIsUUFBUSxTQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixnQkFBZ0I7d0JBQ2hCLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixvQkFBb0I7d0JBQ3BCLGdCQUFnQjt3QkFDaEIsUUFBUTt3QkFDUixjQUFjO3FCQUNmO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSx1QkFBdUIsQ0FBQztvQkFDaEQsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLEVBQUUsY0FBYyxDQUFDO2lCQUM1Qzs7SUFDMkIsb0JBQUM7Q0FBQSxBQWI3QixJQWE2QjtTQUFoQixhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCcm93c2VyQW5pbWF0aW9uc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9ucyc7XG5cbmltcG9ydCB7IENvdW50ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY291bnRlci9jb3VudGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBHYWxsZXJ5Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2dhbGxlcnkvZ2FsbGVyeS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2hldnJvbkljb25Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvaWNvbnMvY2hldnJvbi9jaGV2cm9uLWljb24uY29tcG9uZW50JztcbmltcG9ydCB7IFRodW1ic0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90aHVtYnMvdGh1bWJzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBWaWV3ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdmlld2VyL3ZpZXdlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2FmZVBpcGUgfSBmcm9tICcuL3BpcGVzL3NhZmUucGlwZSc7XG5pbXBvcnQgeyBNZWRpYURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9tZWRpYS5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBHYWxsZXJ5Q29tcG9uZW50LFxuICAgIFRodW1ic0NvbXBvbmVudCxcbiAgICBWaWV3ZXJDb21wb25lbnQsXG4gICAgQ2hldnJvbkljb25Db21wb25lbnQsXG4gICAgQ291bnRlckNvbXBvbmVudCxcbiAgICBTYWZlUGlwZSxcbiAgICBNZWRpYURpcmVjdGl2ZSxcbiAgXSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQnJvd3NlckFuaW1hdGlvbnNNb2R1bGVdLFxuICBleHBvcnRzOiBbR2FsbGVyeUNvbXBvbmVudCwgTWVkaWFEaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBHYWxsZXJ5TW9kdWxlIHt9XG4iXX0=

@@ -42,2 +42,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS5waXBlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL3BpcGVzL3NhZmUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV6RDtJQUlFLGtCQUFvQixTQUF1QjtRQUF2QixjQUFTLEdBQVQsU0FBUyxDQUFjO0lBQUcsQ0FBQzs7Ozs7SUFFL0MsNEJBQVM7Ozs7SUFBVCxVQUFVLEdBQVc7UUFDbkIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVELENBQUM7O2dCQVJGLElBQUksU0FBQztvQkFDSixJQUFJLEVBQUUsTUFBTTtpQkFDYjs7OztnQkFKUSxZQUFZOztJQVdyQixlQUFDO0NBQUEsQUFURCxJQVNDO1NBTlksUUFBUTs7Ozs7O0lBQ1AsNkJBQStCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnc2FmZSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFNhZmVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzYW5pdGl6ZXI6IERvbVNhbml0aXplcikge31cclxuXHJcbiAgdHJhbnNmb3JtKHVybDogc3RyaW5nKSB7XHJcbiAgICByZXR1cm4gdGhpcy5zYW5pdGl6ZXIuYnlwYXNzU2VjdXJpdHlUcnVzdFJlc291cmNlVXJsKHVybCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS5waXBlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibGliL3BpcGVzL3NhZmUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV6RDtJQUlFLGtCQUFvQixTQUF1QjtRQUF2QixjQUFTLEdBQVQsU0FBUyxDQUFjO0lBQUcsQ0FBQzs7Ozs7SUFFL0MsNEJBQVM7Ozs7SUFBVCxVQUFVLEdBQVc7UUFDbkIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVELENBQUM7O2dCQVJGLElBQUksU0FBQztvQkFDSixJQUFJLEVBQUUsTUFBTTtpQkFDYjs7OztnQkFKUSxZQUFZOztJQVdyQixlQUFDO0NBQUEsQUFURCxJQVNDO1NBTlksUUFBUTs7Ozs7O0lBQ1AsNkJBQStCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRG9tU2FuaXRpemVyIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3NhZmUnXG59KVxuZXhwb3J0IGNsYXNzIFNhZmVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2FuaXRpemVyOiBEb21TYW5pdGl6ZXIpIHt9XG5cbiAgdHJhbnNmb3JtKHVybDogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHRoaXMuc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RSZXNvdXJjZVVybCh1cmwpO1xuICB9XG59XG4iXX0=

@@ -14,3 +14,4 @@ /**

export { ViewerComponent as ɵa } from './lib/components/viewer/viewer.component';
export { MediaDirective as ɵf } from './lib/directives/media.directive';
export { SafePipe as ɵe } from './lib/pipes/safe.pipe';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRvZS1nYWxsZXJ5LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibmd4LWRvZS1nYWxsZXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsK0hBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNsRixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDakcsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxRQUFRLElBQUksRUFBRSxFQUFDLE1BQU0sdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG5cbmV4cG9ydCB7Q291bnRlckNvbXBvbmVudCBhcyDJtWR9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvY291bnRlci9jb3VudGVyLmNvbXBvbmVudCc7XG5leHBvcnQge0NoZXZyb25JY29uQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9saWIvY29tcG9uZW50cy9pY29ucy9jaGV2cm9uL2NoZXZyb24taWNvbi5jb21wb25lbnQnO1xuZXhwb3J0IHtUaHVtYnNDb21wb25lbnQgYXMgybVifSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RodW1icy90aHVtYnMuY29tcG9uZW50JztcbmV4cG9ydCB7Vmlld2VyQ29tcG9uZW50IGFzIMm1YX0gZnJvbSAnLi9saWIvY29tcG9uZW50cy92aWV3ZXIvdmlld2VyLmNvbXBvbmVudCc7XG5leHBvcnQge1NhZmVQaXBlIGFzIMm1ZX0gZnJvbSAnLi9saWIvcGlwZXMvc2FmZS5waXBlJzsiXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRvZS1nYWxsZXJ5LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWRvZS1nYWxsZXJ5LyIsInNvdXJjZXMiOlsibmd4LWRvZS1nYWxsZXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsK0hBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNsRixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDakcsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDdEUsT0FBTyxFQUFDLFFBQVEsSUFBSSxFQUFFLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtDb3VudGVyQ29tcG9uZW50IGFzIMm1ZH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9jb3VudGVyL2NvdW50ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7Q2hldnJvbkljb25Db21wb25lbnQgYXMgybVjfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2ljb25zL2NoZXZyb24vY2hldnJvbi1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQge1RodW1ic0NvbXBvbmVudCBhcyDJtWJ9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGh1bWJzL3RodW1icy5jb21wb25lbnQnO1xuZXhwb3J0IHtWaWV3ZXJDb21wb25lbnQgYXMgybVhfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3ZpZXdlci92aWV3ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7TWVkaWFEaXJlY3RpdmUgYXMgybVmfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL21lZGlhLmRpcmVjdGl2ZSc7XG5leHBvcnQge1NhZmVQaXBlIGFzIMm1ZX0gZnJvbSAnLi9saWIvcGlwZXMvc2FmZS5waXBlJzsiXX0=

@@ -12,2 +12,2 @@ /**

export { GalleryItem, GalleryImage, GalleryVideo, isBrowser, SUPPORT, UA, orientations } from './lib/core';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFJQSxpQ0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw4RkFBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZG9lLWdhbGxlcnlcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2dhbGxlcnkvZ2FsbGVyeS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9nYWxsZXJ5Lm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcmUnO1xyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1kb2UtZ2FsbGVyeS8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFJQSxpQ0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCw4QkFBYyxzQkFBc0IsQ0FBQztBQUNyQyw4RkFBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGRvZS1nYWxsZXJ5XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9nYWxsZXJ5L2dhbGxlcnkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dhbGxlcnkubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcmUnO1xuIl19

@@ -0,0 +0,0 @@ import { VerticalOrientation } from '../../core';

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

import { ElementRef, EventEmitter, TemplateRef } from '@angular/core';
import { ElementRef, EventEmitter, TemplateRef, ChangeDetectorRef } from '@angular/core';
import { Aria, GalleryItem, GalleryItemEvent, ItemTemplateContext, Loading, ObjectFit, Orientation, OrientationFlag, VerticalOrientation, ThumbTemplateContext } from '../../core';

@@ -6,2 +6,4 @@ import { ThumbsComponent } from '../thumbs/thumbs.component';

export declare class GalleryComponent {
private cd;
private hostRef;
items: GalleryItem[];

@@ -15,4 +17,4 @@ selectedIndex: number;

touchGestures: boolean;
imageCounter: boolean;
imageCounterOrientation: VerticalOrientation;
counter: boolean;
counterOrientation: VerticalOrientation;
itemWidth: string;

@@ -40,9 +42,13 @@ loading: Loading;

selection: EventEmitter<GalleryItem>;
viewerRef: ViewerComponent;
thumbsRef: ThumbsComponent;
viewerElRef: ElementRef<HTMLElement>;
_viewerRef: ViewerComponent;
_thumbsRef: ThumbsComponent;
_viewerElRef: ElementRef<HTMLElement>;
_tabindex: number;
_touched: boolean;
INIT_INTERACTIONS: string[];
readonly ariaLabel: string;
readonly _galleryColumn: boolean;
readonly _thumbsOrientationFlag: OrientationFlag;
constructor(cd: ChangeDetectorRef, hostRef: ElementRef<HTMLElement>);
private _onInitInteraction;
focus(): void;

@@ -49,0 +55,0 @@ next(): void;

export declare class ChevronIconComponent {
}

@@ -6,4 +6,4 @@ import { ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, OnDestroy, QueryList, SimpleChanges, TemplateRef } from '@angular/core';

export declare class ThumbsComponent implements OnChanges, OnDestroy {
private cd;
private elRef;
private _cd;
private _elRef;
items: GalleryItemInternal[];

@@ -24,14 +24,15 @@ selectedIndex: number;

thumbsRef: QueryList<ElementRef<HTMLElement>>;
showStartArrow: boolean;
showEndArrow: boolean;
vertical: boolean;
private destroy$;
private arrowObserver;
isVideo: (item: import("../../core").GalleryItem) => boolean;
_showStartArrow: boolean;
_showEndArrow: boolean;
_vertical: boolean;
private _destroy$;
private _arrowObserver;
private _scrollBehavior;
private smoothScrollAllowed;
private scrollId;
private _scrollId;
private _smoothScrollAllowed;
readonly cssClass: string;
private readonly scrollKey;
private readonly hostOffsetAxis;
constructor(cd: ChangeDetectorRef, elRef: ElementRef<HTMLElement>);
private readonly _hostOffsetAxis;
private readonly _scrollKey;
constructor(_cd: ChangeDetectorRef, _elRef: ElementRef<HTMLElement>);
ngOnChanges({ arrows, items, orientation }: SimpleChanges): void;

@@ -42,4 +43,4 @@ ngOnDestroy(): void;

select(index: number): void;
onItemErrored(item: GalleryItemInternal): void;
emitEvent(index: number, item: GalleryItemInternal, event: Event, emitter: EventEmitter<GalleryItemEvent>): void;
_emitEvent(index: number, item: GalleryItemInternal, event: Event, emitter: EventEmitter<GalleryItemEvent>): void;
_onLoadChange(item: GalleryItemInternal, success: boolean): void;
private scroll;

@@ -46,0 +47,0 @@ private onArrowsObserved;

@@ -5,5 +5,5 @@ import { ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, OnInit, QueryList, SimpleChanges, TemplateRef } from '@angular/core';

export declare class ViewerComponent implements OnChanges, OnInit, OnDestroy {
private hostRef;
private cd;
private zone;
private _hostRef;
private _cd;
private _zone;
items: GalleryItemInternal[];

@@ -16,6 +16,5 @@ arrows: boolean;

touchGestures: boolean;
imageCounter: boolean;
imageCounterOrientation: VerticalOrientation;
counter: boolean;
counterOrientation: VerticalOrientation;
loading: Loading;
loop: boolean;
objectFit: ObjectFit;

@@ -28,3 +27,5 @@ itemTemplate: TemplateRef<ItemTemplateContext>;

aria: Aria;
loop: boolean;
itemWidth: string;
touched: boolean;
imageClick: EventEmitter<GalleryItemEvent>;

@@ -35,24 +36,24 @@ descriptionClick: EventEmitter<Event>;

itemsRef: QueryList<ElementRef<HTMLElement>>;
displayedItems: GalleryItemInternal[];
isVideo: (item: import("../../core").GalleryItem) => boolean;
UA: {
ios: boolean;
};
_displayedItems: GalleryItemInternal[];
private _destroy$;
private _fringeCount;
private _itemWidth;
private _loop;
private _viewerWidth;
private _listX;
_noAnimation: boolean;
readonly lazyLoading: boolean;
noAnimation: boolean;
readonly showArrow: boolean;
readonly showPrevArrow: boolean;
readonly showNextArrow: boolean;
constructor(hostRef: ElementRef<HTMLElement>, cd: ChangeDetectorRef, zone: NgZone);
constructor(_hostRef: ElementRef<HTMLElement>, _cd: ChangeDetectorRef, _zone: NgZone);
ngOnChanges({ thumbsOrientation, items }: SimpleChanges): void;
ngOnInit(): void;
ngOnDestroy(): void;
getSrc(item: GalleryItemInternal, index: number): string;
isInScrollportProximity(index: number): boolean;
isYoutube(item: GalleryItemInternal): boolean;
isVideo(item: GalleryItemInternal): boolean;
selectByDelta(delta: number): void;

@@ -59,0 +60,0 @@ select(index: number): void;

@@ -0,0 +0,0 @@ export interface Aria {

@@ -96,6 +96,2 @@ export declare abstract class GalleryItem {

/**
* Marks item as seen at least once
*/
_seen?: boolean;
/**
* `true` when media couldn't be loaded

@@ -109,1 +105,2 @@ */

}
export declare const isVideo: (item: GalleryItem) => boolean;

@@ -0,0 +0,0 @@ export * from './support';

export declare type Loading = 'auto' | 'lazy';
export declare type ObjectFit = 'contain' | 'cover';

@@ -0,0 +0,0 @@ export declare type Orientation = 'top' | 'bottom' | 'left' | 'right';

@@ -0,0 +0,0 @@ export declare const isBrowser: boolean;

@@ -6,3 +6,3 @@ import { GalleryItem } from './gallery-item';

item: GalleryItem;
seen: boolean;
video: boolean;
}

@@ -9,0 +9,0 @@ export interface ThumbTemplateContext {

export declare class GalleryModule {
}

@@ -0,0 +0,0 @@ import { PipeTransform } from '@angular/core';

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

export { ViewerComponent as ɵa } from './lib/components/viewer/viewer.component';
export { MediaDirective as ɵf } from './lib/directives/media.directive';
export { SafePipe as ɵe } from './lib/pipes/safe.pipe';

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

{"__symbolic":"module","version":4,"exports":[{"from":"./lib/support"},{"from":"./lib/object-fit"},{"from":"./lib/loading"},{"from":"./lib/orientation"},{"from":"./lib/template-contexts"},{"export":[{"name":"GalleryItem","as":"GalleryItem"},{"name":"GalleryImage","as":"GalleryImage"},{"name":"GalleryVideo","as":"GalleryVideo"},{"name":"GalleryItemEvent","as":"GalleryItemEvent"}],"from":"./lib/gallery-item"},{"export":[{"name":"Aria","as":"Aria"}],"from":"./lib/aria"}],"metadata":{"GalleryComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":29,"character":1},"arguments":[{"selector":"doe-gallery","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":33,"character":19},"member":"OnPush"},"template":"<doe-thumbs\r\n *ngIf=\"thumbs\"\r\n [items]=\"items\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [orientation]=\"thumbsOrientation\"\r\n [arrows]=\"thumbsArrows\"\r\n [arrowSlideByLength]=\"thumbsArrowSlideByLength\"\r\n [autoScroll]=\"thumbsAutoScroll\"\r\n [scrollBehavior]=\"thumbsScrollBehavior\"\r\n [thumbTemplate]=\"thumbTemplate\"\r\n [arrowTemplate]=\"thumbsArrowTemplate\"\r\n [errorTemplate]=\"thumbErrorTemplate\"\r\n [aria]=\"aria\"\r\n (thumbClick)=\"_onThumbClick($event)\"\r\n (thumbHover)=\"thumbHover.emit($event)\"\r\n></doe-thumbs>\r\n\r\n<doe-viewer\r\n tabindex=\"0\"\r\n [items]=\"items\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [arrows]=\"arrows\"\r\n [descriptions]=\"descriptions\"\r\n [errorText]=\"errorText\"\r\n [mouseGestures]=\"mouseGestures\"\r\n [touchGestures]=\"touchGestures\"\r\n [imageCounter]=\"imageCounter\"\r\n [imageCounterOrientation]=\"imageCounterOrientation\"\r\n [itemWidth]=\"itemWidth\"\r\n [objectFit]=\"objectFit\"\r\n [loading]=\"loading\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [loadingTemplate]=\"loadingTemplate || defaultLoadingTemplate\"\r\n [errorTemplate]=\"errorTemplate\"\r\n [loop]=\"loop\"\r\n [thumbsOrientation]=\"_thumbsOrientationFlag\"\r\n [arrowTemplate]=\"arrowTemplate\"\r\n [aria]=\"aria\"\r\n (imageClick)=\"imageClick.emit($event)\"\r\n (descriptionClick)=\"descriptionClick.emit($event)\"\r\n (selection)=\"_selectInternal($event); thumbsRef?.select($event)\"\r\n></doe-viewer>\r\n\r\n<ng-template #defaultLoadingTemplate>\r\n <div class=\"doe-loading\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n</ng-template>\r\n","styles":[":host{display:flex;height:600px;width:500px;outline:0;position:relative;background-color:#252525;border-radius:5px}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"aria":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"arrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"descriptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"errorText":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"mouseGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"touchGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":57,"character":3}}]}],"imageCounter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"imageCounterOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":3}}]}],"itemWidth":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"loading":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":69,"character":3}}]}],"loop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":72,"character":3}}]}],"objectFit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"itemTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"loadingTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":81,"character":3}}]}],"errorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"arrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3}}]}],"thumbs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":90,"character":3}}]}],"thumbsAutoScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"thumbsOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":96,"character":3}}]}],"thumbsArrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":99,"character":3}}]}],"thumbsArrowSlideByLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":102,"character":3}}]}],"thumbsScrollBehavior":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":105,"character":3}}]}],"thumbTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":108,"character":3}}]}],"thumbsArrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":111,"character":3}}]}],"thumbErrorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":114,"character":3}}]}],"imageClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":117,"character":3}}]}],"thumbClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":120,"character":3}}]}],"thumbHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":123,"character":3}}]}],"descriptionClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":126,"character":3}}]}],"selection":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":129,"character":3}}]}],"viewerRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":132,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"},{"static":false}]}]}],"thumbsRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":135,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵb"},{"static":false}]}]}],"viewerElRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":138,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"},{"static":false,"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":138,"character":53}}]}]}],"_tabindex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":141,"character":3},"arguments":["tabindex"]}]}],"ariaLabel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":144,"character":3},"arguments":["attr.aria-label"]}]}],"_galleryColumn":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":149,"character":3},"arguments":["class.doe-gallery--column"]}]}],"focus":[{"__symbolic":"method"}],"next":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":170,"character":3},"arguments":["keydown.arrowright"]}]}],"prev":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":175,"character":3},"arguments":["keydown.arrowleft"]}]}],"select":[{"__symbolic":"method"}],"slideThumbs":[{"__symbolic":"method"}],"_onThumbClick":[{"__symbolic":"method"}],"_selectInternal":[{"__symbolic":"method"}]}},"GalleryModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":11,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"GalleryComponent"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":20,"character":12},{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":20,"character":26}],"exports":[{"__symbolic":"reference","name":"GalleryComponent"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":35,"character":1},"arguments":[{"selector":"doe-viewer","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":39,"character":19},"member":"OnPush"},"animations":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"trigger","line":40,"character":15},"arguments":["remove",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":40,"character":34},"arguments":[":leave",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":40,"character":55},"arguments":["0ms 100ms"]}]}]]}],"template":"<div\r\n *ngIf=\"showPrevArrow\"\r\n class=\"doe-viewer-arrow doe-viewer-arrow-prev\"\r\n (click)=\"selectByDelta(-1)\"\r\n>\r\n <doe-chevron-icon\r\n *ngIf=\"!arrowTemplate; else arrowTemplate\"\r\n ></doe-chevron-icon>\r\n</div>\r\n\r\n<ul #itemList [attr.aria-label]=\"aria?.viewerLabel\">\r\n <li *ngIf=\"!displayedItems?.length\" class=\"doe-viewer-initial-item\"></li>\r\n <li\r\n #items\r\n *ngFor=\"let item of displayedItems; let i = index\"\r\n [class.doe-viewer-item--selected]=\"i === selectedIndex\"\r\n tabindex=\"0\"\r\n [attr.aria-label]=\"item.alt\"\r\n [attr.aria-describedby]=\"'doe-viewer-aria-description-' + i\"\r\n (click)=\"onImageClick(item, $event)\"\r\n (keydown.Tab)=\"onTab(i + 1)\"\r\n (keydown.shift.Tab)=\"onTab(i - 1)\"\r\n >\r\n <ng-container *ngIf=\"!itemTemplate; else customTemplate\">\r\n <ng-container *ngIf=\"isInScrollportProximity(i)\">\r\n <ng-container *ngIf=\"getSrc(item, i); let src\">\r\n <picture *ngIf=\"!isVideo(item)\" @remove>\r\n <source\r\n *ngFor=\"let source of item.pictureSources\"\r\n [srcset]=\"source.srcset\"\r\n [attr.media]=\"source.media\"\r\n [attr.sizes]=\"source.sizes\"\r\n [attr.type]=\"source.type\"\r\n />\r\n <img\r\n [src]=\"src\"\r\n [alt]=\"item.alt\"\r\n [class.doe-viewer-media-loading]=\"item._seen && !item._loaded\"\r\n [style.objectFit]=\"objectFit\"\r\n (load)=\"onItemLoaded(item, $event)\"\r\n (error)=\"onItemErrored(item, $event)\"\r\n />\r\n </picture>\r\n <!-- Using loadedmetadata instead of loadeddata because iOS loads data lazily upon user's interaction -->\r\n <video\r\n @remove\r\n *ngIf=\"!isYoutube(item) && isVideo(item)\"\r\n [src]=\"src\"\r\n [poster]=\"item.thumbSrc\"\r\n [class.doe-viewer-media-loading]=\"item._seen && !item._loaded\"\r\n [style.objectFit]=\"objectFit\"\r\n controls\r\n playsinline\r\n (loadedmetadata)=\"onItemLoaded(item, $event)\"\r\n (error)=\"onItemErrored(item, $event)\"\r\n ></video>\r\n\r\n <iframe\r\n @remove\r\n *ngIf=\"isYoutube(item)\"\r\n [src]=\"src | safe\"\r\n frameborder=\"0\"\r\n allow=\"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture\"\r\n allowfullscreen\r\n (load)=\"onItemLoaded(item, $event)\"\r\n ></iframe>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"item._seen && !item._loaded && !item._failed\">\r\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"item._failed\">\r\n <div\r\n *ngIf=\"!errorTemplate; else errorTemplate\"\r\n class=\"doe-viewer-error\"\r\n >\r\n <div class=\"doe-viewer-error-icon\">⚠</div>\r\n <p class=\"doe-viewer-error-text\">\r\n {{ errorText || 'Loading of this media failed' }}\r\n </p>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <span\r\n [id]=\"'doe-viewer-aria-description-' + i\"\r\n class=\"doe-viewer-aria-description\"\r\n [innerHTML]=\"item.description\"\r\n aria-hidden=\"true\"\r\n ></span>\r\n\r\n <ng-template #customTemplate>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n itemTemplate;\r\n context: {\r\n index: items.indexOf(item),\r\n selectedIndex: selectedIndex,\r\n item: item,\r\n seen: item._seen\r\n }\r\n \"\r\n ></ng-container>\r\n </ng-template>\r\n </li>\r\n</ul>\r\n\r\n<ng-container *ngIf=\"items?.length <= 0\">\r\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\r\n</ng-container>\r\n\r\n<div\r\n *ngIf=\"showNextArrow\"\r\n class=\"doe-viewer-arrow doe-viewer-arrow-next\"\r\n (click)=\"selectByDelta(1)\"\r\n>\r\n <doe-chevron-icon\r\n *ngIf=\"!arrowTemplate; else arrowTemplate\"\r\n ></doe-chevron-icon>\r\n</div>\r\n\r\n<doe-counter\r\n *ngIf=\"imageCounter && items?.length\"\r\n [itemQuantity]=\"items?.length\"\r\n [selectedIndex]=\"selectedIndex\"\r\n [orientation]=\"imageCounterOrientation\"\r\n></doe-counter>\r\n\r\n<div\r\n *ngIf=\"descriptions && items\"\r\n class=\"doe-viewer-description\"\r\n [class.doe-viewer-description--above-counter]=\"\r\n imageCounter && imageCounterOrientation === 'bottom'\r\n \"\r\n aria-hidden=\"true\"\r\n>\r\n <div\r\n *ngIf=\"items[selectedIndex]?.description as description\"\r\n class=\"doe-viewer-description-inner\"\r\n [innerHTML]=\"description\"\r\n (click)=\"descriptionClick.emit($event)\"\r\n ></div>\r\n</div>\r\n","styles":[":host{display:block;position:relative;width:100%;height:100%;overflow:hidden;outline:0;background-color:#232323;z-index:1}ul{--item-width:calc(100% - 0.01px);display:flex;width:100%;height:100%;transition:transform .4s;scrollbar-width:none;-ms-overflow-style:none}ul::-webkit-scrollbar{width:0;height:0}li{display:flex;align-items:center;flex:none;position:relative;width:var(--item-width);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}picture{width:100%;height:100%}iframe,img,video{width:100%;height:100%;background-color:transparent;transition:opacity .3s ease-out;outline:0}iframe[src=\"\"],img[src=\"\"],video[src=\"\"]{opacity:0}iframe.doe-viewer-media-loading,img.doe-viewer-media-loading,video.doe-viewer-media-loading{opacity:.5}img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.doe-viewer-description{position:absolute;bottom:5px;width:100%;display:flex;justify-content:center}.doe-viewer-description--above-counter{bottom:35px}.doe-viewer-description-inner{display:inline-block;background:#000;opacity:.8;color:#fff;padding:6px 15px;max-width:80%;font-size:.95em;text-align:center}.doe-viewer-aria-description{opacity:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:absolute;bottom:0;left:50%;transform:translateX(-50%)}.doe-viewer-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background-color:#f5f5f5;color:#424242}.doe-viewer-error-icon{font-size:40px}.doe-viewer-error-text{margin-top:20px;letter-spacing:.01em}.doe-viewer-arrow{display:flex;position:absolute;top:50%;transform:translateY(-50%);z-index:100;cursor:pointer}.doe-viewer-arrow-prev{left:0;transform:rotate(180deg) translateY(50%)}.doe-viewer-arrow-next{right:0}.doe-viewer-arrow doe-chevron-icon{margin:15px 6px;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-viewer-arrow doe-chevron-icon:hover{opacity:1}}.doe-viewer-arrow doe-chevron-icon::ng-deep svg{height:32px;width:32px}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"arrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"descriptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"errorText":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"mouseGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"touchGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":3}}]}],"imageCounter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":3}}]}],"imageCounterOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"loading":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3}}]}],"loop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"objectFit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"itemTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":3}}]}],"loadingTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":3}}]}],"errorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":57,"character":3}}]}],"arrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":58,"character":3}}]}],"thumbsOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":59,"character":3}}]}],"aria":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"itemWidth":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":62,"character":3}}]}],"imageClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"descriptionClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"selection":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"itemListRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":70,"character":3},"arguments":["itemList",{"static":true}]}]}],"itemsRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":71,"character":3},"arguments":["items"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":108,"character":32,"context":{"typeName":"HTMLElement"},"module":"./lib/components/viewer/viewer.component"}]},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":109,"character":16},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":110,"character":18}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getSrc":[{"__symbolic":"method"}],"isInScrollportProximity":[{"__symbolic":"method"}],"isYoutube":[{"__symbolic":"method"}],"isVideo":[{"__symbolic":"method"}],"selectByDelta":[{"__symbolic":"method"}],"select":[{"__symbolic":"method"}],"onImageClick":[{"__symbolic":"method"}],"onTab":[{"__symbolic":"method"}],"onItemLoaded":[{"__symbolic":"method"}],"onItemErrored":[{"__symbolic":"method"}],"center":[{"__symbolic":"method"}],"getFringeCount":[{"__symbolic":"method"}],"readDimensions":[{"__symbolic":"method"}],"selectBySwipeStats":[{"__symbolic":"method"}],"shift":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":28,"character":1},"arguments":[{"selector":"doe-thumbs","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":32,"character":19},"member":"OnPush"},"template":"<div\r\n *ngIf=\"showStartArrow\"\r\n class=\"doe-thumbs-arrow doe-thumbs-arrow-prev\"\r\n (click)=\"slide(-1)\"\r\n>\r\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n\r\n<ul\r\n #thumbs\r\n [style.scrollBehavior]=\"scrollBehavior\"\r\n tabindex=\"0\"\r\n [attr.aria-label]=\"aria?.thumbnailsLabel\"\r\n>\r\n <li *ngIf=\"!items || !items.length\" class=\"doe-thumbs-initial-item\"></li>\r\n <li\r\n #thumb\r\n *ngFor=\"let item of items; let i = index\"\r\n [class.doe-thumbs-item--selected]=\"i === selectedIndex\"\r\n aria-hidden=\"true\"\r\n (click)=\"emitEvent(i, item, $event, thumbClick)\"\r\n (mouseenter)=\"emitEvent(i, item, $event, thumbHover)\"\r\n >\r\n <ng-container *ngIf=\"!thumbTemplate; else customThumbTemplate\">\r\n <img\r\n [src]=\"item.thumbSrc || item.src\"\r\n [alt]=\"item.alt\"\r\n (error)=\"onItemErrored(item)\"\r\n />\r\n\r\n <ng-container *ngIf=\"item._thumbFailed\">\r\n <div\r\n *ngIf=\"!errorTemplate; else errorTemplate\"\r\n class=\"doe-thumbs-error\"\r\n >\r\n <div class=\"doe-thumbs-error-icon\">⚠</div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #customThumbTemplate>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n thumbTemplate;\r\n context: { index: i, selectedIndex: selectedIndex, item: item }\r\n \"\r\n ></ng-container>\r\n </ng-template>\r\n </li>\r\n</ul>\r\n\r\n<div\r\n *ngIf=\"showEndArrow\"\r\n class=\"doe-thumbs-arrow doe-thumbs-arrow-next\"\r\n (click)=\"slide(1)\"\r\n>\r\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\r\n <doe-chevron-icon></doe-chevron-icon>\r\n </div>\r\n</div>\r\n","styles":[":host{flex:1 0 auto;position:relative}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;border:1px solid #252525;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:\"\";display:block;position:absolute;left:0;bottom:0;width:100%;height:10px;background-color:#ffffffab;box-shadow:0 0 1px #000}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#222}.doe-thumbs-error-icon{font-size:20px;color:#f5f5f5}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"aria":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"orientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"arrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"arrowSlideByLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"autoScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"thumbTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"arrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"errorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"scrollBehavior":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"thumbClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":53,"character":3}}]}],"thumbHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":54,"character":3}}]}],"thumbListRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":56,"character":3},"arguments":["thumbs",{"static":true}]}]}],"thumbsRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":57,"character":3},"arguments":["thumb"]}]}],"cssClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":71,"character":3},"arguments":["class"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":87,"character":16},{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":88,"character":30,"context":{"typeName":"HTMLElement"},"module":"./lib/components/thumbs/thumbs.component"}]}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"slide":[{"__symbolic":"method"}],"centerThumbIfNeeded":[{"__symbolic":"method"}],"select":[{"__symbolic":"method"}],"onItemErrored":[{"__symbolic":"method"}],"emitEvent":[{"__symbolic":"method"}],"scroll":[{"__symbolic":"method"}],"observeArrows":[{"__symbolic":"method"}],"unobserveArrows":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"doe-chevron-icon","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":6,"character":19},"member":"OnPush"},"template":"<!-- Icon made by Dave Gandy from www.flaticon.com -->\r\n<svg\r\n version=\"1.1\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n x=\"0px\"\r\n y=\"0px\"\r\n viewBox=\"0 0 407.436 407.436\"\r\n xml:space=\"preserve\"\r\n>\r\n <polygon\r\n points=\"112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 \"\r\n />\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n <g></g>\r\n</svg>\r\n","styles":["svg{width:26px;height:26px;fill:#fff;-webkit-filter:drop-shadow(0 0 1px #000);filter:drop-shadow(0 0 1px #000);display:block}"]}]}],"members":{}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":9,"character":1},"arguments":[{"selector":"doe-counter","template":"\n <span aria-hidden=\"true\">\n {{ selectedIndex + 1 }}<span class=\"doe-counter-delimiter\">/</span\n >{{ itemQuantity || 0 }}\n </span>\n ","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":18,"character":19},"member":"OnPush"},"styles":[":host{position:absolute;left:50%;transform:translateX(-50%);background:#000;padding:4px 7px 3px;color:#fff;opacity:.7;font-size:14px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host.top{top:0}:host.bottom{bottom:0}.doe-counter-delimiter{padding:0 2px}"]}]}],"members":{"itemQuantity":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"orientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":27,"character":3},"arguments":["class"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Pipe","line":3,"character":1},"arguments":[{"name":"safe"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":7,"character":33}]}],"transform":[{"__symbolic":"method"}]}}},"origins":{"GalleryComponent":"./lib/components/gallery/gallery.component","GalleryModule":"./lib/gallery.module","ɵa":"./lib/components/viewer/viewer.component","ɵb":"./lib/components/thumbs/thumbs.component","ɵc":"./lib/components/icons/chevron/chevron-icon.component","ɵd":"./lib/components/counter/counter.component","ɵe":"./lib/pipes/safe.pipe"},"importAs":"ngx-doe-gallery"}
{"__symbolic":"module","version":4,"exports":[{"from":"./lib/support"},{"from":"./lib/object-fit"},{"from":"./lib/loading"},{"from":"./lib/orientation"},{"from":"./lib/template-contexts"},{"export":[{"name":"GalleryItem","as":"GalleryItem"},{"name":"GalleryImage","as":"GalleryImage"},{"name":"GalleryVideo","as":"GalleryVideo"},{"name":"GalleryItemEvent","as":"GalleryItemEvent"}],"from":"./lib/gallery-item"},{"export":[{"name":"Aria","as":"Aria"}],"from":"./lib/aria"}],"metadata":{"GalleryComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":30,"character":1},"arguments":[{"selector":"doe-gallery","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":34,"character":19},"member":"OnPush"},"template":"<doe-thumbs\n *ngIf=\"thumbs\"\n [items]=\"items\"\n [selectedIndex]=\"selectedIndex\"\n [orientation]=\"thumbsOrientation\"\n [arrows]=\"thumbsArrows\"\n [arrowSlideByLength]=\"thumbsArrowSlideByLength\"\n [autoScroll]=\"thumbsAutoScroll\"\n [scrollBehavior]=\"thumbsScrollBehavior\"\n [thumbTemplate]=\"thumbTemplate\"\n [arrowTemplate]=\"thumbsArrowTemplate\"\n [errorTemplate]=\"thumbErrorTemplate\"\n [aria]=\"aria\"\n (thumbClick)=\"_onThumbClick($event)\"\n (thumbHover)=\"thumbHover.emit($event)\"\n></doe-thumbs>\n\n<doe-viewer\n tabindex=\"0\"\n [items]=\"items\"\n [selectedIndex]=\"selectedIndex\"\n [arrows]=\"arrows\"\n [descriptions]=\"descriptions\"\n [errorText]=\"errorText\"\n [mouseGestures]=\"mouseGestures\"\n [touchGestures]=\"touchGestures\"\n [counter]=\"counter\"\n [counterOrientation]=\"counterOrientation\"\n [itemWidth]=\"itemWidth\"\n [objectFit]=\"objectFit\"\n [loading]=\"loading\"\n [itemTemplate]=\"itemTemplate\"\n [loadingTemplate]=\"loadingTemplate || defaultLoadingTemplate\"\n [errorTemplate]=\"errorTemplate\"\n [loop]=\"loop\"\n [thumbsOrientation]=\"_thumbsOrientationFlag\"\n [arrowTemplate]=\"arrowTemplate\"\n [aria]=\"aria\"\n [touched]=\"_touched\"\n (imageClick)=\"imageClick.emit($event)\"\n (descriptionClick)=\"descriptionClick.emit($event)\"\n (selection)=\"_selectInternal($event); _thumbsRef?.select($event)\"\n></doe-viewer>\n\n<ng-template #defaultLoadingTemplate>\n <div class=\"doe-loading\">\n <div></div>\n <div></div>\n <div></div>\n </div>\n</ng-template>\n","styles":[":host{display:flex;height:600px;width:500px;outline:0;position:relative}:host.doe-gallery--column{flex-direction:column}:host::ng-deep{font-family:Helvetica Neue,Helvetica,Arial,sans-serif}:host::ng-deep button{border:none}:host::ng-deep ul{list-style-type:none;margin:0;padding:0}.doe-loading{display:flex;justify-content:center;align-items:center;position:absolute;width:100%;height:100%;left:0;top:0;background-color:transparent;z-index:10}.doe-loading>div{height:13px;width:13px;background-color:#4a4a4a;-webkit-animation:2s infinite bounce;animation:2s infinite bounce;border-radius:50%;box-shadow:0 0 0 1px #f5f5f5,0 0 1px 1px #f5f5f5}.doe-loading>div+div{margin-left:10px;-webkit-animation-delay:125ms;animation-delay:125ms}.doe-loading>div+div+div{-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}@keyframes bounce{20%{transform:translateY(-20px)}50%{transform:translateY(0)}}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"aria":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"arrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"descriptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"errorText":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"mouseGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"touchGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"counter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"counterOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"itemWidth":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"loading":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"loop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":3}}]}],"objectFit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":3}}]}],"itemTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"loadingTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3}}]}],"errorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"arrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"thumbs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":3}}]}],"thumbsAutoScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":3}}]}],"thumbsOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":57,"character":3}}]}],"thumbsArrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":58,"character":3}}]}],"thumbsArrowSlideByLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":59,"character":3}}]}],"thumbsScrollBehavior":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"thumbTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"thumbsArrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":62,"character":3}}]}],"thumbErrorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":3}}]}],"imageClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":65,"character":3}}]}],"thumbClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"thumbHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"descriptionClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"selection":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"_viewerRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":71,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"},{"static":false}]}]}],"_thumbsRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":72,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵb"},{"static":false}]}]}],"_viewerElRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":73,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"},{"static":false,"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":73,"character":53}}]}]}],"_tabindex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":76,"character":3},"arguments":["tabindex"]}]}],"ariaLabel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":81,"character":3},"arguments":["attr.aria-label"]}]}],"_galleryColumn":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":86,"character":3},"arguments":["class.doe-gallery--column"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":104,"character":16},{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":105,"character":32,"context":{"typeName":"HTMLElement"},"module":"./lib/components/gallery/gallery.component"}]}]}],"focus":[{"__symbolic":"method"}],"next":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":127,"character":3},"arguments":["keydown.arrowright"]}]}],"prev":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":132,"character":3},"arguments":["keydown.arrowleft"]}]}],"select":[{"__symbolic":"method"}],"slideThumbs":[{"__symbolic":"method"}],"_onThumbClick":[{"__symbolic":"method"}],"_selectInternal":[{"__symbolic":"method"}]}},"GalleryModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":12,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"GalleryComponent"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":22,"character":12},{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":22,"character":26}],"exports":[{"__symbolic":"reference","name":"GalleryComponent"},{"__symbolic":"reference","name":"ɵf"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":35,"character":1},"arguments":[{"selector":"doe-viewer","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":39,"character":19},"member":"OnPush"},"animations":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"trigger","line":41,"character":4},"arguments":["remove",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":42,"character":6},"arguments":[":leave",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":42,"character":27},"arguments":["0ms 100ms"]}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":43,"character":6},"arguments":[":enter",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":44,"character":8},"arguments":[{"opacity":0}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":45,"character":8},"arguments":["400ms",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":45,"character":25},"arguments":[{"opacity":1}]}]}]]}]]}],"template":"<div\n *ngIf=\"showPrevArrow\"\n class=\"doe-viewer-arrow doe-viewer-arrow-prev\"\n (click)=\"selectByDelta(-1)\"\n>\n <doe-chevron-icon\n *ngIf=\"!arrowTemplate; else arrowTemplate\"\n ></doe-chevron-icon>\n</div>\n\n<ul #itemList [attr.aria-label]=\"aria?.viewerLabel\">\n <li *ngIf=\"!_displayedItems?.length\" class=\"doe-viewer-initial-item\"></li>\n <li\n #itemsRef\n *ngFor=\"let item of _displayedItems; let i = index\"\n [class.doe-viewer-item--selected]=\"i === selectedIndex\"\n tabindex=\"0\"\n [attr.aria-label]=\"item.alt\"\n [attr.aria-describedby]=\"'doe-viewer-aria-description-' + i\"\n (click)=\"onImageClick(item, $event)\"\n (doe-media-load)=\"onItemLoaded(item, $event.detail)\"\n (doe-media-error)=\"onItemErrored(item, $event.detail)\"\n (keydown.Tab)=\"onTab(i + 1)\"\n (keydown.shift.Tab)=\"onTab(i - 1)\"\n >\n <ng-container *ngIf=\"!lazyLoading || isInScrollportProximity(i)\">\n <ng-container *ngIf=\"!itemTemplate; else customTemplate\">\n <picture *ngIf=\"!isVideo(item)\" @remove>\n <source\n *ngFor=\"let source of item.pictureSources\"\n [srcset]=\"source.srcset\"\n [attr.media]=\"source.media\"\n [attr.sizes]=\"source.sizes\"\n [attr.type]=\"source.type\"\n />\n <img\n [src]=\"item.src\"\n [alt]=\"item.alt\"\n [class.doe-viewer-media-loading]=\"!item._loaded\"\n [style.objectFit]=\"objectFit\"\n (load)=\"onItemLoaded(item, $event)\"\n (error)=\"onItemErrored(item, $event)\"\n />\n </picture>\n <!-- Using loadedmetadata instead of loadeddata because iOS loads data lazily upon user's interaction -->\n <video\n @remove\n *ngIf=\"!isYoutube(item) && isVideo(item)\"\n [src]=\"item.src\"\n [poster]=\"item.thumbSrc || ''\"\n [class.doe-viewer-media-loading]=\"!item._loaded\"\n [style.objectFit]=\"objectFit\"\n controls\n playsinline\n (loadedmetadata)=\"onItemLoaded(item, $event)\"\n (error)=\"onItemErrored(item, $event)\"\n ></video>\n\n <iframe\n @remove\n *ngIf=\"isYoutube(item)\"\n [src]=\"item.src | safe\"\n frameborder=\"0\"\n allow=\"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture\"\n allowfullscreen\n (load)=\"onItemLoaded(item, $event)\"\n ></iframe>\n </ng-container>\n\n <ng-container *ngIf=\"!item._loaded && !item._failed\">\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"item._failed\">\n <div\n *ngIf=\"!errorTemplate; else errorTemplate\"\n class=\"doe-viewer-error\"\n >\n <div class=\"doe-viewer-error-icon\">⚠</div>\n <p class=\"doe-viewer-error-text\">\n {{ errorText || 'Loading of this media failed' }}\n </p>\n </div>\n </ng-container>\n\n <span\n [id]=\"'doe-viewer-aria-description-' + i\"\n class=\"doe-viewer-aria-description\"\n [innerHTML]=\"item.description\"\n aria-hidden=\"true\"\n ></span>\n </ng-container>\n\n <ng-template #customTemplate>\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n index: items?.indexOf(item),\n selectedIndex: selectedIndex,\n item: item,\n video: isVideo(item)\n }\n \"\n ></ng-container>\n </ng-template>\n </li>\n</ul>\n\n<ng-container *ngIf=\"items?.length <= 0\">\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n</ng-container>\n\n<div\n *ngIf=\"showNextArrow\"\n class=\"doe-viewer-arrow doe-viewer-arrow-next\"\n (click)=\"selectByDelta(1)\"\n>\n <doe-chevron-icon\n *ngIf=\"!arrowTemplate; else arrowTemplate\"\n ></doe-chevron-icon>\n</div>\n\n<doe-counter\n *ngIf=\"counter && items?.length\"\n [itemQuantity]=\"items?.length\"\n [selectedIndex]=\"selectedIndex\"\n [orientation]=\"counterOrientation\"\n></doe-counter>\n\n<div\n *ngIf=\"descriptions && items\"\n class=\"doe-viewer-description\"\n [class.doe-viewer-description--above-counter]=\"\n counter && counterOrientation === 'bottom'\n \"\n aria-hidden=\"true\"\n>\n <div\n *ngIf=\"items[selectedIndex]?.description as description\"\n class=\"doe-viewer-description-inner\"\n [innerHTML]=\"description\"\n (click)=\"descriptionClick.emit($event)\"\n ></div>\n</div>\n","styles":[":host{display:block;position:relative;width:100%;height:100%;overflow:hidden;outline:0;background-color:#ececec;z-index:1}ul{--item-width:calc(100% - 0.01px);display:flex;width:100%;height:100%;transition:transform .4s;scrollbar-width:none;-ms-overflow-style:none}ul::-webkit-scrollbar{width:0;height:0}li{display:flex;align-items:center;flex:none;position:relative;width:var(--item-width);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}picture{width:100%;height:100%}iframe,img,video{width:100%;height:100%;background-color:transparent;transition:opacity .3s ease-out;outline:0}iframe[src=\"\"],img[src=\"\"],video[src=\"\"]{opacity:0}iframe.doe-viewer-media-loading,img.doe-viewer-media-loading,video.doe-viewer-media-loading{opacity:.5}img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.doe-viewer-description{position:absolute;bottom:5px;width:100%;display:flex;justify-content:center}.doe-viewer-description--above-counter{bottom:35px}.doe-viewer-description-inner{display:inline-block;background:#000;opacity:.8;color:#fff;padding:6px 15px;max-width:80%;font-size:.95em;text-align:center}.doe-viewer-aria-description{opacity:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:absolute;bottom:0;left:50%;transform:translateX(-50%)}.doe-viewer-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background-color:#f5f5f5;color:#7d7d7d}.doe-viewer-error-icon{font-size:40px}.doe-viewer-error-text{margin-top:10px;letter-spacing:.01em}.doe-viewer-arrow{display:flex;position:absolute;top:50%;transform:translateY(-50%);z-index:100;cursor:pointer}.doe-viewer-arrow-prev{left:0;transform:rotate(180deg) translateY(50%)}.doe-viewer-arrow-next{right:0}.doe-viewer-arrow doe-chevron-icon{margin:15px 6px;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-viewer-arrow doe-chevron-icon:hover{opacity:1}}.doe-viewer-arrow doe-chevron-icon::ng-deep svg{height:32px;width:32px}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"arrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"descriptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"errorText":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":3}}]}],"mouseGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":3}}]}],"touchGestures":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":57,"character":3}}]}],"counter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":58,"character":3}}]}],"counterOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":59,"character":3}}]}],"loading":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"objectFit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"itemTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":62,"character":3}}]}],"loadingTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":3}}]}],"errorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":64,"character":3}}]}],"arrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":65,"character":3}}]}],"thumbsOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"aria":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":3}}]}],"loop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"itemWidth":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"touched":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":79,"character":3}}]}],"imageClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":81,"character":3}}]}],"descriptionClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":82,"character":3}}]}],"selection":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":83,"character":3}}]}],"itemListRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":85,"character":3},"arguments":["itemList",{"static":true}]}]}],"itemsRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":86,"character":3},"arguments":["itemsRef"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":125,"character":33,"context":{"typeName":"HTMLElement"},"module":"./lib/components/viewer/viewer.component"}]},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":126,"character":17},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":127,"character":19}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"isInScrollportProximity":[{"__symbolic":"method"}],"isYoutube":[{"__symbolic":"method"}],"selectByDelta":[{"__symbolic":"method"}],"select":[{"__symbolic":"method"}],"onImageClick":[{"__symbolic":"method"}],"onTab":[{"__symbolic":"method"}],"onItemLoaded":[{"__symbolic":"method"}],"onItemErrored":[{"__symbolic":"method"}],"center":[{"__symbolic":"method"}],"getFringeCount":[{"__symbolic":"method"}],"readDimensions":[{"__symbolic":"method"}],"selectBySwipeStats":[{"__symbolic":"method"}],"shift":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":32,"character":1},"arguments":[{"selector":"doe-thumbs","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":36,"character":19},"member":"OnPush"},"template":"<div\n *ngIf=\"_showStartArrow\"\n class=\"doe-thumbs-arrow doe-thumbs-arrow-prev\"\n (click)=\"slide(-1)\"\n>\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n\n<ul\n #thumbs\n [style.scrollBehavior]=\"scrollBehavior\"\n tabindex=\"0\"\n [attr.aria-label]=\"aria?.thumbnailsLabel\"\n>\n <li *ngIf=\"!items || !items.length\" class=\"doe-thumbs-initial-item\"></li>\n <li\n #thumb\n *ngFor=\"let item of items; let i = index\"\n [class.doe-thumbs-item--selected]=\"i === selectedIndex\"\n aria-hidden=\"true\"\n (click)=\"_emitEvent(i, item, $event, thumbClick)\"\n (mouseenter)=\"_emitEvent(i, item, $event, thumbHover)\"\n >\n <ng-container *ngIf=\"!thumbTemplate; else customThumbTemplate\">\n <img\n [src]=\"item.thumbSrc || ''\"\n [alt]=\"item.alt\"\n (load)=\"_onLoadChange(item, true)\"\n (error)=\"_onLoadChange(item, false)\"\n />\n\n <ng-container *ngIf=\"item._thumbFailed\">\n <div\n *ngIf=\"!errorTemplate; else errorTemplate\"\n class=\"doe-thumbs-error\"\n >\n <div\n class=\"doe-thumbs-error-icon\"\n [class.doe-thumbs-error-icon--video]=\"isVideo(item)\"\n ></div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-template #customThumbTemplate>\n <ng-container\n *ngTemplateOutlet=\"\n thumbTemplate;\n context: { index: i, selectedIndex: selectedIndex, item: item }\n \"\n ></ng-container>\n </ng-template>\n </li>\n</ul>\n\n<div\n *ngIf=\"_showEndArrow\"\n class=\"doe-thumbs-arrow doe-thumbs-arrow-next\"\n (click)=\"slide(1)\"\n>\n <div *ngIf=\"!arrowTemplate; else arrowTemplate\">\n <doe-chevron-icon></doe-chevron-icon>\n </div>\n</div>\n","styles":[":host{flex:1 0 auto;position:relative;background-color:#f3f3f3}:host.doe-thumbs--bottom,:host.doe-thumbs--top{width:100%}:host.doe-thumbs--bottom ul,:host.doe-thumbs--top ul{width:100%;display:flex;overflow-x:scroll;overflow-y:hidden}:host.doe-thumbs--bottom li,:host.doe-thumbs--top li{flex:none}:host.doe-thumbs--bottom li:not(:first-child),:host.doe-thumbs--top li:not(:first-child){border-left:0}:host.doe-thumbs--bottom li:first-child,:host.doe-thumbs--top li:first-child{margin-left:auto}:host.doe-thumbs--bottom li:last-child,:host.doe-thumbs--top li:last-child{margin-right:auto}:host.doe-thumbs--bottom .doe-thumbs-arrow,:host.doe-thumbs--top .doe-thumbs-arrow{top:0;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow>div,:host.doe-thumbs--top .doe-thumbs-arrow>div{width:30px;height:100%}:host.doe-thumbs--bottom .doe-thumbs-arrow-prev,:host.doe-thumbs--top .doe-thumbs-arrow-prev{left:0}:host.doe-thumbs--bottom .doe-thumbs-arrow-next,:host.doe-thumbs--top .doe-thumbs-arrow-next{right:0}:host.doe-thumbs--bottom .doe-thumbs-error,:host.doe-thumbs--top .doe-thumbs-error{border-right:1px solid #cecece}:host.doe-thumbs--left,:host.doe-thumbs--right{height:100%}:host.doe-thumbs--left ul,:host.doe-thumbs--right ul{height:100%;overflow-y:scroll;overflow-x:hidden}:host.doe-thumbs--left li,:host.doe-thumbs--right li{border-top:0}:host.doe-thumbs--left .doe-thumbs-arrow,:host.doe-thumbs--right .doe-thumbs-arrow{width:100%}:host.doe-thumbs--left .doe-thumbs-arrow>div,:host.doe-thumbs--right .doe-thumbs-arrow>div{width:100%;height:30px}:host.doe-thumbs--left .doe-thumbs-arrow doe-chevron-icon,:host.doe-thumbs--right .doe-thumbs-arrow doe-chevron-icon{transform:rotate(90deg)}:host.doe-thumbs--left .doe-thumbs-arrow-prev,:host.doe-thumbs--right .doe-thumbs-arrow-prev{top:0}:host.doe-thumbs--left .doe-thumbs-arrow-next,:host.doe-thumbs--right .doe-thumbs-arrow-next{bottom:0}:host.doe-thumbs--left .doe-thumbs-error,:host.doe-thumbs--right .doe-thumbs-error{border-bottom:1px solid #cecece}:host.doe-thumbs--bottom,:host.doe-thumbs--right{order:1}ul{outline:0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;transform:translate3d(0,0,0)}ul::-webkit-scrollbar{width:0;height:0}li{box-sizing:border-box;width:120px;height:80px;position:relative;cursor:pointer}li.doe-thumbs-initial-item{visibility:hidden}li.doe-thumbs-item--selected::after{content:\"\";display:block;position:absolute;left:0;bottom:0;width:100%;height:100%;border:10px solid #ffffffcf;box-sizing:border-box}img{width:100%;height:100%;background-repeat:no-repeat;background-position:center;-o-object-fit:cover;object-fit:cover}.doe-thumbs-error{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:#e8e8e8;box-sizing:border-box}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video){position:relative;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid #a5a5a5;margin-left:-8px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after,.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{content:\"\";position:absolute}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::before{height:10px;width:10px;background-color:#a5a5a5;border-radius:100%;left:14px}.doe-thumbs-error-icon:not(.doe-thumbs-error-icon--video)::after{border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:17px solid #a5a5a5;top:11px}.doe-thumbs-error-icon--video{border-top:16px solid transparent;border-bottom:16px solid transparent;border-left:28px solid #a5a5a5;margin-left:9px}.doe-thumbs-arrow{position:absolute;cursor:pointer;z-index:10}.doe-thumbs-arrow-prev{transform:rotate(180deg)}.doe-thumbs-arrow>div{display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.5);padding:0;opacity:.7}@media (hover:hover) and (pointer:fine){.doe-thumbs-arrow>div:hover{opacity:1}}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"aria":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"orientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"arrows":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"arrowSlideByLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"autoScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"thumbTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"arrowTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"errorTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"scrollBehavior":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":3}}]}],"thumbClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":57,"character":3}}]}],"thumbHover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":58,"character":3}}]}],"thumbListRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":60,"character":3},"arguments":["thumbs",{"static":true}]}]}],"thumbsRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":61,"character":3},"arguments":["thumb"]}]}],"cssClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":75,"character":3},"arguments":["class"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":91,"character":17},{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":92,"character":31,"context":{"typeName":"HTMLElement"},"module":"./lib/components/thumbs/thumbs.component"}]}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"slide":[{"__symbolic":"method"}],"centerThumbIfNeeded":[{"__symbolic":"method"}],"select":[{"__symbolic":"method"}],"_emitEvent":[{"__symbolic":"method"}],"_onLoadChange":[{"__symbolic":"method"}],"scroll":[{"__symbolic":"method"}],"observeArrows":[{"__symbolic":"method"}],"unobserveArrows":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"doe-chevron-icon","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":6,"character":19},"member":"OnPush"},"template":"<!-- Icon made by Dave Gandy from www.flaticon.com -->\n<svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 407.436 407.436\"\n xml:space=\"preserve\"\n>\n <polygon\n points=\"112.814,0 91.566,21.178 273.512,203.718 91.566,386.258 112.814,407.436 315.869,203.718 \"\n />\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n <g></g>\n</svg>\n","styles":["svg{width:26px;height:26px;fill:#fff;-webkit-filter:drop-shadow(0 0 1px #000);filter:drop-shadow(0 0 1px #000);display:block}"]}]}],"members":{}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":9,"character":1},"arguments":[{"selector":"doe-counter","template":"\n <span aria-hidden=\"true\">\n {{ selectedIndex + 1 }}<span class=\"doe-counter-delimiter\">/</span\n >{{ itemQuantity || 0 }}\n </span>\n ","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":18,"character":19},"member":"OnPush"},"styles":[":host{position:absolute;left:50%;transform:translateX(-50%);background:#000;padding:4px 7px 3px;color:#fff;opacity:.7;font-size:14px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host.top{top:0}:host.bottom{bottom:0}.doe-counter-delimiter{padding:0 2px}"]}]}],"members":{"itemQuantity":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"orientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":27,"character":3},"arguments":["class"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Pipe","line":3,"character":1},"arguments":[{"name":"safe"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":7,"character":33}]}],"transform":[{"__symbolic":"method"}]}},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":2,"character":1},"arguments":[{"selector":"[doeMedia]"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":6,"character":42,"context":{"typeName":"HTMLElement"},"module":"./lib/directives/media.directive"}]}]}],"onLoad":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":8,"character":3},"arguments":["load",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":9,"character":3},"arguments":["loadedmetadata",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":10,"character":3},"arguments":["error",["$event"]]}]}]}}},"origins":{"GalleryComponent":"./lib/components/gallery/gallery.component","GalleryModule":"./lib/gallery.module","ɵa":"./lib/components/viewer/viewer.component","ɵb":"./lib/components/thumbs/thumbs.component","ɵc":"./lib/components/icons/chevron/chevron-icon.component","ɵd":"./lib/components/counter/counter.component","ɵe":"./lib/pipes/safe.pipe","ɵf":"./lib/directives/media.directive"},"importAs":"ngx-doe-gallery"}
{
"name": "ngx-doe-gallery",
"version": "1.0.0-alpha.1",
"version": "1.0.0-beta.0",
"license": "Apache-2.0",

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

export * from './lib/components/gallery/gallery.component';
export * from './lib/gallery.module';
export * from './lib/core';

@@ -0,0 +0,0 @@ # Doe Gallery

Sorry, the diff of this file is too big to display

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 too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

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