{"version":3,"file":"galleria.js","sourceRoot":"","sources":["galleria.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgModule,Component,ElementRef,AfterViewChecked,AfterViewInit,OnDestroy,Input,Output,IterableDiffers,EventEmitter} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {DomHandler} from '../dom/domhandler';\n\n@Component({\n selector: 'p-galleria',\n template: `\n
\n \n
\n \n
\n
\n
\n
\n

{{images[activeIndex]?.title}}

{{images[activeIndex]?.alt}}

\n
\n
\n `,\n providers: [DomHandler]\n})\nexport class Galleria implements AfterViewChecked,AfterViewInit,OnDestroy {\n \n @Input() images: any[];\n \n @Input() style: any;\n\n @Input() styleClass: string;\n\n @Input() panelWidth: number = 600;\n\n @Input() panelHeight: number = 400;\n\n @Input() frameWidth: number = 60;\n \n @Input() frameHeight: number = 40;\n\n @Input() activeIndex: number = 0;\n\n @Input() showFilmstrip: boolean = true;\n\n @Input() autoPlay: boolean = true;\n\n @Input() transitionInterval: number = 4000;\n\n @Input() showCaption: boolean = true;\n \n @Output() onImageClicked = new EventEmitter();\n \n differ: any;\n \n slideshowActive: boolean;\n \n public container: any;\n \n public panelWrapper: any;\n \n public panels: any;\n \n public caption: any;\n \n public stripWrapper: any;\n \n public strip: any;\n \n public frames: any;\n \n public interval: any;\n \n public stripLeft: number = 0;\n \n public imagesChanged: boolean;\n \n public initialized: boolean;\n\n constructor(public el: ElementRef, public domHandler: DomHandler, differs: IterableDiffers) {\n this.differ = differs.find([]).create(null);\n }\n \n ngAfterViewChecked() {\n if(this.imagesChanged) {\n this.stopSlideshow();\n this.render();\n this.imagesChanged = false;\n }\n }\n \n ngDoCheck() {\n let changes = this.differ.diff(this.images);\n \n if(changes && this.initialized) {\n this.activeIndex = 0;\n this.imagesChanged = true;\n }\n }\n \n ngAfterViewInit() {\n this.container = this.el.nativeElement.children[0];\n this.panelWrapper = this.domHandler.findSingle(this.el.nativeElement, 'ul.ui-galleria-panel-wrapper');\n this.initialized = true;\n \n if(this.showFilmstrip) {\n this.stripWrapper = this.domHandler.findSingle(this.container,'div.ui-galleria-filmstrip-wrapper');\n this.strip = this.domHandler.findSingle(this.stripWrapper,'ul.ui-galleria-filmstrip');\n }\n \n if(this.images && this.images.length) {\n this.render();\n } \n }\n \n render() {\n this.panels = this.domHandler.find(this.panelWrapper, 'li.ui-galleria-panel'); \n \n if(this.showFilmstrip) {\n this.frames = this.domHandler.find(this.strip,'li.ui-galleria-frame');\n this.stripWrapper.style.width = this.domHandler.width(this.panelWrapper) - 50 + 'px';\n this.stripWrapper.style.height = this.frameHeight + 'px';\n }\n \n if(this.showCaption) {\n this.caption = this.domHandler.findSingle(this.container,'div.ui-galleria-caption');\n this.caption.style.bottom = this.showFilmstrip ? this.domHandler.getOuterHeight(this.stripWrapper,true) + 'px' : 0 + 'px';\n this.caption.style.width = this.domHandler.width(this.panelWrapper) + 'px';\n }\n \n if(this.autoPlay) {\n this.startSlideshow();\n }\n \n this.container.style.visibility = 'visible';\n }\n \n startSlideshow() {\n this.interval = setInterval(() => {\n this.next();\n }, this.transitionInterval);\n \n this.slideshowActive = true;\n }\n \n stopSlideshow() {\n if(this.interval) {\n clearInterval(this.interval);\n }\n \n this.slideshowActive = false;\n }\n \n clickNavRight() {\n if(this.slideshowActive) {\n this.stopSlideshow();\n }\n this.next();\n } \n \n clickNavLeft() {\n if(this.slideshowActive) {\n this.stopSlideshow();\n }\n this.prev();\n }\n \n frameClick(frame) {\n if(this.slideshowActive) {\n this.stopSlideshow();\n }\n \n this.select(this.domHandler.index(frame), false);\n }\n \n prev() {\n if(this.activeIndex !== 0) {\n this.select(this.activeIndex - 1, true);\n }\n }\n \n next() {\n if(this.activeIndex !== (this.panels.length-1)) {\n this.select(this.activeIndex + 1, true);\n }\n else {\n this.select(0, false);\n this.stripLeft = 0;\n }\n }\n \n select(index, reposition) {\n if(index !== this.activeIndex) { \n let oldPanel = this.panels[this.activeIndex],\n newPanel = this.panels[index];\n \n this.domHandler.fadeIn(newPanel, 500);\n \n if(this.showFilmstrip) {\n let oldFrame = this.frames[this.activeIndex],\n newFrame = this.frames[index];\n \n if(reposition === undefined || reposition === true) {\n let frameLeft = newFrame.offsetLeft,\n stepFactor = this.frameWidth + parseInt(getComputedStyle(newFrame)['margin-right'], 10),\n stripLeft = this.strip.offsetLeft,\n frameViewportLeft = frameLeft + stripLeft,\n frameViewportRight = frameViewportLeft + this.frameWidth;\n \n if(frameViewportRight > this.domHandler.width(this.stripWrapper))\n this.stripLeft -= stepFactor;\n else if(frameViewportLeft < 0)\n this.stripLeft += stepFactor;\n }\n }\n \n this.activeIndex = index;\n }\n }\n \n clickImage(event, image, i) {\n this.onImageClicked.emit({originalEvent: event, image: image, index: i})\n }\n \n ngOnDestroy() {\n this.stopSlideshow();\n }\n\n}\n\n@NgModule({\n imports: [CommonModule],\n exports: [Galleria],\n declarations: [Galleria]\n})\nexport class GalleriaModule { }"]}