2017-03-25 21:59:30 +01:00
|
|
|
import {Component, ElementRef, HostListener, Input, OnChanges, ViewChild} from "@angular/core";
|
2017-02-05 17:27:58 +01:00
|
|
|
import {PhotoDTO} from "../../../../../common/entities/PhotoDTO";
|
|
|
|
import {Dimension} from "../../../model/IRenderable";
|
|
|
|
import {FullScreenService} from "../../fullscreen.service";
|
2017-05-27 10:15:57 +02:00
|
|
|
import {AgmMap} from "@agm/core";
|
2017-03-25 21:59:30 +01:00
|
|
|
import {IconThumbnail, ThumbnailManagerService} from "../../thumnailManager.service";
|
2017-03-20 21:37:23 +01:00
|
|
|
import {IconPhoto} from "../../IconPhoto";
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'gallery-map-lightbox',
|
|
|
|
styleUrls: ['app/gallery/map/lightbox/lightbox.map.gallery.component.css'],
|
|
|
|
templateUrl: 'app/gallery/map/lightbox/lightbox.map.gallery.component.html',
|
|
|
|
})
|
|
|
|
export class GalleryMapLightboxComponent implements OnChanges {
|
|
|
|
|
|
|
|
@Input() photos: Array<PhotoDTO>;
|
|
|
|
private startPosition = null;
|
|
|
|
public lightboxDimension: Dimension = <Dimension>{top: 0, left: 0, width: 0, height: 0};
|
|
|
|
public mapDimension: Dimension = <Dimension>{top: 0, left: 0, width: 0, height: 0};
|
|
|
|
private visible = false;
|
|
|
|
private opacity = 1.0;
|
2017-03-20 21:37:23 +01:00
|
|
|
mapPhotos: Array<{latitude: number, longitude: number, iconUrl?: string, thumbnail: IconThumbnail}> = [];
|
2017-03-20 00:01:41 +01:00
|
|
|
mapCenter = {latitude: 0, longitude: 0};
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
@ViewChild("root") elementRef: ElementRef;
|
|
|
|
|
2017-05-27 10:15:57 +02:00
|
|
|
@ViewChild(AgmMap) map: AgmMap;
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
|
2017-03-20 21:37:23 +01:00
|
|
|
constructor(private fullScreenService: FullScreenService, private thumbnailService: ThumbnailManagerService) {
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO: fix zooming
|
|
|
|
ngOnChanges() {
|
2017-03-20 00:01:41 +01:00
|
|
|
if (this.visible == false) {
|
|
|
|
return;
|
2017-02-05 17:27:58 +01:00
|
|
|
}
|
2017-03-20 00:01:41 +01:00
|
|
|
this.showImages();
|
2017-02-05 17:27:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public show(position: Dimension) {
|
|
|
|
this.visible = true;
|
|
|
|
this.opacity = 1.0;
|
|
|
|
this.startPosition = position;
|
|
|
|
this.lightboxDimension = position;
|
|
|
|
this.lightboxDimension.top -= this.getBodyScrollTop();
|
|
|
|
this.mapDimension = <Dimension>{
|
|
|
|
top: 0,
|
|
|
|
left: 0,
|
|
|
|
width: this.getScreenWidth(),
|
|
|
|
height: this.getScreenHeight()
|
|
|
|
};
|
|
|
|
this.map.triggerResize();
|
|
|
|
|
|
|
|
document.getElementsByTagName('body')[0].style.overflow = 'hidden';
|
2017-03-20 00:01:41 +01:00
|
|
|
this.showImages();
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
setImmediate(() => {
|
|
|
|
this.lightboxDimension = <Dimension>{
|
|
|
|
top: 0,
|
|
|
|
left: 0,
|
|
|
|
width: this.getScreenWidth(),
|
|
|
|
height: this.getScreenHeight()
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
public hide() {
|
|
|
|
this.fullScreenService.exitFullScreen();
|
|
|
|
let to = this.startPosition;
|
|
|
|
|
|
|
|
//iff target image out of screen -> scroll to there
|
|
|
|
if (this.getBodyScrollTop() > to.top || this.getBodyScrollTop() + this.getScreenHeight() < to.top) {
|
|
|
|
this.setBodyScrollTop(to.top);
|
|
|
|
}
|
|
|
|
|
|
|
|
this.lightboxDimension = this.startPosition;
|
|
|
|
this.lightboxDimension.top -= this.getBodyScrollTop();
|
|
|
|
document.getElementsByTagName('body')[0].style.overflow = 'scroll';
|
|
|
|
this.opacity = 0.0;
|
|
|
|
setTimeout(() => {
|
|
|
|
this.visible = false;
|
2017-03-20 21:37:23 +01:00
|
|
|
this.hideImages();
|
2017-02-05 17:27:58 +01:00
|
|
|
}, 500);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-03-20 00:01:41 +01:00
|
|
|
showImages() {
|
2017-03-20 21:37:23 +01:00
|
|
|
this.hideImages();
|
|
|
|
|
2017-03-20 00:01:41 +01:00
|
|
|
this.mapPhotos = this.photos.filter(p => {
|
|
|
|
return p.metadata && p.metadata.positionData && p.metadata.positionData.GPSData;
|
|
|
|
}).map(p => {
|
2017-03-20 21:37:23 +01:00
|
|
|
let th = this.thumbnailService.getIcon(new IconPhoto(p));
|
|
|
|
let obj: {latitude: number, longitude: number, iconUrl?: string, thumbnail: IconThumbnail} = {
|
2017-03-20 00:01:41 +01:00
|
|
|
latitude: p.metadata.positionData.GPSData.latitude,
|
|
|
|
longitude: p.metadata.positionData.GPSData.longitude,
|
2017-03-20 21:37:23 +01:00
|
|
|
thumbnail: th
|
|
|
|
|
2017-03-20 00:01:41 +01:00
|
|
|
};
|
2017-03-20 21:37:23 +01:00
|
|
|
if (th.Available == true) {
|
|
|
|
obj.iconUrl = th.Src;
|
|
|
|
} else {
|
|
|
|
th.OnLoad = () => {
|
|
|
|
obj.iconUrl = th.Src;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
return obj;
|
2017-03-20 00:01:41 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
if (this.mapPhotos.length > 0) {
|
|
|
|
this.mapCenter = this.mapPhotos[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-20 21:37:23 +01:00
|
|
|
hideImages() {
|
|
|
|
this.mapPhotos.forEach(mp => mp.thumbnail.destroy());
|
|
|
|
this.mapPhotos = [];
|
|
|
|
}
|
|
|
|
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
private getBodyScrollTop(): number {
|
|
|
|
return window.scrollY;
|
|
|
|
}
|
|
|
|
|
|
|
|
private setBodyScrollTop(value: number) {
|
|
|
|
window.scrollTo(window.scrollX, value);
|
|
|
|
}
|
|
|
|
|
|
|
|
private getScreenWidth() {
|
|
|
|
return window.innerWidth;
|
|
|
|
}
|
|
|
|
|
|
|
|
private getScreenHeight() {
|
|
|
|
return window.innerHeight;
|
|
|
|
}
|
|
|
|
|
2017-03-25 21:59:30 +01:00
|
|
|
//noinspection JSUnusedGlobalSymbols
|
|
|
|
@HostListener('window:keydown', ['$event'])
|
|
|
|
onKeyPress(e: KeyboardEvent) {
|
|
|
|
if (this.visible != true) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
let event: KeyboardEvent = window.event ? <any>window.event : e;
|
|
|
|
switch (event.keyCode) {
|
|
|
|
case 27: //escape
|
|
|
|
this.hide();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-05 17:27:58 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|