1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/frontend/app/gallery/gallery.component.ts

161 lines
5.3 KiB
TypeScript
Raw Normal View History

2018-03-30 15:30:30 -04:00
import {Component, OnDestroy, OnInit, ViewChild} from '@angular/core';
import {AuthenticationService} from '../model/network/authentication.service';
import {ActivatedRoute, Params, Router} from '@angular/router';
import {GalleryService} from './gallery.service';
import {GalleryGridComponent} from './grid/grid.gallery.component';
import {GallerySearchComponent} from './search/search.gallery.component';
import {SearchTypes} from '../../../common/entities/AutoCompleteItem';
import {Config} from '../../../common/config/public/Config';
import {DirectoryDTO} from '../../../common/entities/DirectoryDTO';
import {SearchResultDTO} from '../../../common/entities/SearchResultDTO';
import {ShareService} from './share.service';
import {NavigationService} from '../model/navigation.service';
import {UserRoles} from '../../../common/entities/UserDTO';
2018-05-03 18:23:48 -04:00
import {interval} from 'rxjs/observable/interval';
2018-03-30 15:30:30 -04:00
import {ContentWrapper} from '../../../common/entities/ConentWrapper';
2018-05-09 13:56:02 -04:00
import {PageHelper} from '../model/page.helper';
2016-03-13 11:28:29 +01:00
@Component({
selector: 'app-gallery',
templateUrl: './gallery.component.html',
styleUrls: ['./gallery.component.css']
2016-03-13 11:28:29 +01:00
})
2017-07-03 19:17:49 +02:00
export class GalleryComponent implements OnInit, OnDestroy {
@ViewChild(GallerySearchComponent) search: GallerySearchComponent;
@ViewChild(GalleryGridComponent) grid: GalleryGridComponent;
2016-05-09 17:04:56 +02:00
2018-05-03 18:23:48 -04:00
public showSearchBar = false;
public showShare = false;
2017-06-21 11:46:23 +02:00
public directories: DirectoryDTO[] = [];
2017-06-21 21:32:57 +02:00
public isPhotoWithLocation = false;
2017-07-09 12:03:17 +02:00
private $counter;
2017-07-03 19:17:49 +02:00
private subscription = {
content: null,
2017-07-09 12:03:17 +02:00
route: null,
timer: null
2017-07-03 19:17:49 +02:00
};
2017-07-09 12:03:17 +02:00
public countDown = null;
2017-07-13 23:39:09 +02:00
public mapEnabled = true;
2018-05-13 16:59:57 -04:00
SearchTypes: any = [];
2016-05-16 11:03:11 +02:00
constructor(public _galleryService: GalleryService,
private _authService: AuthenticationService,
private _router: Router,
2017-07-03 19:17:49 +02:00
private shareService: ShareService,
2017-07-09 12:03:17 +02:00
private _route: ActivatedRoute,
private _navigation: NavigationService) {
2017-07-13 23:39:09 +02:00
this.mapEnabled = Config.Client.Map.enabled;
2018-05-13 16:59:57 -04:00
this.SearchTypes = SearchTypes;
2018-05-09 13:56:02 -04:00
PageHelper.showScrollY();
}
2017-07-09 12:03:17 +02:00
updateTimer(t: number) {
if (this.shareService.sharing.value == null) {
return;
}
t = Math.floor((this.shareService.sharing.value.expires - Date.now()) / 1000);
this.countDown = {};
this.countDown.day = Math.floor(t / 86400);
t -= this.countDown.day * 86400;
this.countDown.hour = Math.floor(t / 3600) % 24;
t -= this.countDown.hour * 3600;
this.countDown.minute = Math.floor(t / 60) % 60;
t -= this.countDown.minute * 60;
this.countDown.second = t % 60;
}
2017-07-03 19:17:49 +02:00
2018-03-30 15:30:30 -04:00
private onRoute = async (params: Params) => {
const searchText = params['searchText'];
2018-05-03 18:23:48 -04:00
if (searchText && searchText !== '') {
const typeString = params['type'];
2017-07-09 12:03:17 +02:00
2018-05-03 18:23:48 -04:00
if (typeString && typeString !== '') {
const type: SearchTypes = <any>SearchTypes[typeString];
2018-03-30 15:30:30 -04:00
this._galleryService.search(searchText, type);
return;
}
2018-03-30 15:30:30 -04:00
this._galleryService.search(searchText);
return;
}
2017-06-21 11:46:23 +02:00
2018-05-03 18:23:48 -04:00
if (params['sharingKey'] && params['sharingKey'] !== '') {
2018-03-30 15:30:30 -04:00
const sharing = await this.shareService.getSharing();
this._router.navigate(['/gallery', sharing.path], {queryParams: {sk: this.shareService.getSharingKey()}});
return;
2017-07-09 12:03:17 +02:00
}
2018-03-30 15:30:30 -04:00
let directoryName = params['directory'];
directoryName = directoryName || '';
this._galleryService.getDirectory(directoryName);
};
2017-07-03 19:17:49 +02:00
ngOnDestroy() {
if (this.subscription.content !== null) {
this.subscription.content.unsubscribe();
}
if (this.subscription.route !== null) {
this.subscription.route.unsubscribe();
}
2017-07-19 22:40:27 +02:00
if (this.subscription.timer !== null) {
this.subscription.timer.unsubscribe();
}
2017-07-03 19:17:49 +02:00
}
2016-05-16 11:03:11 +02:00
2017-07-20 21:06:48 +02:00
private onContentChange = (content: ContentWrapper) => {
2017-07-03 19:17:49 +02:00
const dirSorter = (a: DirectoryDTO, b: DirectoryDTO) => {
return a.name.localeCompare(b.name);
};
2016-05-16 11:03:11 +02:00
2017-07-03 19:17:49 +02:00
const tmp = <DirectoryDTO | SearchResultDTO>(content.searchResult || content.directory || {
directories: [],
photos: []
});
this.directories = tmp.directories.sort(dirSorter);
this.isPhotoWithLocation = false;
for (let i = 0; i < tmp.photos.length; i++) {
if (tmp.photos[i].metadata &&
tmp.photos[i].metadata.positionData &&
tmp.photos[i].metadata.positionData.GPSData &&
tmp.photos[i].metadata.positionData.GPSData.longitude
) {
this.isPhotoWithLocation = true;
break;
}
}
};
2018-03-30 15:30:30 -04:00
async ngOnInit() {
await this.shareService.wait();
if (!this._authService.isAuthenticated() &&
(!this.shareService.isSharing() ||
2018-05-09 13:37:21 -04:00
(this.shareService.isSharing() && Config.Client.Sharing.passwordProtected === true))) {
2016-05-16 11:03:11 +02:00
2018-03-30 15:30:30 -04:00
return this._navigation.toLogin();
2017-07-03 19:17:49 +02:00
}
2018-03-30 15:30:30 -04:00
this.showSearchBar = Config.Client.Search.enabled && this._authService.isAuthorized(UserRoles.Guest);
this.showShare = Config.Client.Sharing.enabled && this._authService.isAuthorized(UserRoles.User);
2018-03-30 15:30:30 -04:00
this.subscription.content = this._galleryService.content.subscribe(this.onContentChange);
this.subscription.route = this._route.params.subscribe(this.onRoute);
2016-05-16 11:03:11 +02:00
2018-03-30 15:30:30 -04:00
if (this.shareService.isSharing()) {
2018-05-03 18:23:48 -04:00
this.$counter = interval(1000);
2018-03-30 15:30:30 -04:00
this.subscription.timer = this.$counter.subscribe((x) => this.updateTimer(x));
}
2016-05-16 11:03:11 +02:00
2018-03-30 15:30:30 -04:00
}
2017-06-21 21:32:57 +02:00
onLightboxLastElement() {
this.grid.renderARow();
}
2016-03-13 11:28:29 +01:00
}