2017-07-17 18:30:16 +02:00
|
|
|
import {Component, ElementRef, EventEmitter, Input, Output} from "@angular/core";
|
2017-07-09 22:00:42 +02:00
|
|
|
import {PhotoDTO} from "../../../../../common/entities/PhotoDTO";
|
2017-07-13 23:39:09 +02:00
|
|
|
import {Config} from "../../../../../common/config/public/Config";
|
2017-07-09 22:00:42 +02:00
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'info-panel',
|
|
|
|
styleUrls: ['./info-panel.lightbox.gallery.component.css'],
|
|
|
|
templateUrl: './info-panel.lightbox.gallery.component.html',
|
|
|
|
})
|
|
|
|
export class InfoPanelLightboxComponent {
|
|
|
|
@Input() photo: PhotoDTO;
|
2017-07-17 18:30:16 +02:00
|
|
|
@Output('onClose') onClose = new EventEmitter();
|
2017-07-13 23:39:09 +02:00
|
|
|
public mapEnabled = true;
|
2017-07-09 22:00:42 +02:00
|
|
|
|
2017-07-10 22:00:22 +02:00
|
|
|
constructor(public elementRef: ElementRef) {
|
2017-07-13 23:39:09 +02:00
|
|
|
this.mapEnabled = Config.Client.Map.enabled;
|
2017-07-09 22:00:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
calcMpx() {
|
|
|
|
return (this.photo.metadata.size.width * this.photo.metadata.size.height / 1000000).toFixed(2);
|
|
|
|
}
|
|
|
|
|
|
|
|
calcFileSize() {
|
|
|
|
let postFixes = ["B", "KB", "MB", "GB", "TB"];
|
|
|
|
let index = 0;
|
|
|
|
let size = this.photo.metadata.fileSize;
|
|
|
|
while (size > 1000 && index < postFixes.length - 1) {
|
|
|
|
size /= 1000;
|
|
|
|
index++;
|
|
|
|
}
|
|
|
|
return size.toFixed(2) + postFixes[index];
|
|
|
|
}
|
|
|
|
|
|
|
|
getCurrentYear() {
|
|
|
|
return (new Date()).getFullYear();
|
|
|
|
}
|
|
|
|
|
|
|
|
getYear() {
|
|
|
|
const date = new Date(this.photo.metadata.creationDate);
|
|
|
|
return date.getFullYear();
|
|
|
|
}
|
|
|
|
|
|
|
|
getDate() {
|
|
|
|
const date = new Date(this.photo.metadata.creationDate);
|
|
|
|
let locale = "en-us";
|
2017-07-10 22:00:22 +02:00
|
|
|
return date.toLocaleString(locale, {month: "long"}) + " " + date.getDate();
|
2017-07-09 22:00:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
getTime() {
|
|
|
|
const date = new Date(this.photo.metadata.creationDate);
|
|
|
|
return date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds();
|
|
|
|
}
|
|
|
|
|
|
|
|
getDay() {
|
|
|
|
const date = new Date(this.photo.metadata.creationDate);
|
|
|
|
let locale = "en-us";
|
|
|
|
return date.toLocaleString(locale, {weekday: "long"});
|
|
|
|
}
|
|
|
|
|
|
|
|
toFraction(f) {
|
|
|
|
if (f > 1) {
|
|
|
|
return f;
|
|
|
|
}
|
2017-07-10 22:00:22 +02:00
|
|
|
return "1/" + (1 / f);
|
2017-07-09 22:00:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
hasGPS() {
|
|
|
|
return this.photo.metadata.positionData && this.photo.metadata.positionData.GPSData &&
|
|
|
|
this.photo.metadata.positionData.GPSData.latitude && this.photo.metadata.positionData.GPSData.longitude
|
|
|
|
}
|
|
|
|
|
|
|
|
getPositionText(): string {
|
|
|
|
if (!this.photo.metadata.positionData) {
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
let str = this.photo.metadata.positionData.city ||
|
|
|
|
this.photo.metadata.positionData.state;
|
|
|
|
|
|
|
|
if (str.length != 0) {
|
|
|
|
str += ", ";
|
|
|
|
}
|
|
|
|
str += this.photo.metadata.positionData.country;
|
|
|
|
|
|
|
|
return str;
|
|
|
|
}
|
2017-07-17 18:30:16 +02:00
|
|
|
|
|
|
|
close() {
|
|
|
|
this.onClose.emit();
|
|
|
|
}
|
2017-07-09 22:00:42 +02:00
|
|
|
}
|
|
|
|
|