mirror of
https://github.com/bpatrik/pigallery2.git
synced 2025-01-20 04:59:33 +02:00
Implementing custom folder sorting, by adding support for pg2conf metafiles. Fixes: #177
This commit is contained in:
parent
cdd1139bab
commit
73a8c4202a
@ -201,6 +201,9 @@ apt-get install build-essential libkrb5-dev gcc g++
|
||||
* cleaning up temp folder
|
||||
* indexing db
|
||||
* folder ignoring [#87](https://github.com/bpatrik/pigallery2/issues/87)
|
||||
* `.pg2conf` UI modifying files. [#177](https://github.com/bpatrik/pigallery2/issues/177).
|
||||
* List of these files are passed down to the UI modify its behaviour.
|
||||
* Currently, supported custom, per folder sorting.
|
||||
* Dockerized
|
||||
* **Markdown based blogging support** - `future plan`
|
||||
* you can write some note in the blog.md for every directory
|
||||
|
16
src/common/PG2ConfMap.ts
Normal file
16
src/common/PG2ConfMap.ts
Normal file
@ -0,0 +1,16 @@
|
||||
import {SortingMethods} from './entities/SortingMethods';
|
||||
|
||||
|
||||
/**
|
||||
* This contains the action of the supported list of *.pg2conf files.
|
||||
* These files are passed down to the client as metaFiles (like photos and directories)
|
||||
*/
|
||||
export const PG2ConfMap = {
|
||||
sorting: {
|
||||
'.order_descending_name.pg2conf': SortingMethods.descName,
|
||||
'.order_ascending_name.pg2conf': SortingMethods.ascName,
|
||||
'.order_descending_date.pg2conf': SortingMethods.descDate,
|
||||
'.order_ascending_date.pg2conf': SortingMethods.ascDate,
|
||||
'.order_random.pg2conf': SortingMethods.random
|
||||
}
|
||||
};
|
@ -15,7 +15,7 @@ export const SupportedFormats = {
|
||||
'ogg'
|
||||
],
|
||||
MetaFiles: [
|
||||
'gpx'
|
||||
'gpx', 'pg2conf'
|
||||
],
|
||||
// These formats need to be transcoded (with the build-in ffmpeg support)
|
||||
TranscodeNeed: {
|
||||
|
@ -24,6 +24,7 @@ import {LoginComponent} from './ui/login/login.component';
|
||||
import {AdminComponent} from './ui/admin/admin.component';
|
||||
import {GalleryComponent} from './ui/gallery/gallery.component';
|
||||
import {StringifyRole} from './pipes/StringifyRolePipe';
|
||||
import {GPXFilesFilterPipe} from './pipes/GPXFilesFilterPipe';
|
||||
import {GalleryMapComponent} from './ui/gallery/map/map.gallery.component';
|
||||
import {GalleryMapLightboxComponent} from './ui/gallery/map/lightbox/lightbox.map.gallery.component';
|
||||
import {ThumbnailManagerService} from './ui/gallery/thumbnailManager.service';
|
||||
@ -211,7 +212,8 @@ export function translationsFactory(locale: string) {
|
||||
IconizeSortingMethod,
|
||||
StringifySortingMethod,
|
||||
DurationPipe,
|
||||
FileSizePipe
|
||||
FileSizePipe,
|
||||
GPXFilesFilterPipe
|
||||
],
|
||||
providers: [
|
||||
{provide: HTTP_INTERCEPTORS, useClass: CSRFInterceptor, multi: true},
|
||||
|
10
src/frontend/app/pipes/GPXFilesFilterPipe.ts
Normal file
10
src/frontend/app/pipes/GPXFilesFilterPipe.ts
Normal file
@ -0,0 +1,10 @@
|
||||
import {Pipe, PipeTransform} from '@angular/core';
|
||||
import {FileDTO} from '../../../common/entities/FileDTO';
|
||||
|
||||
|
||||
@Pipe({name: 'gpxFiles'})
|
||||
export class GPXFilesFilterPipe implements PipeTransform {
|
||||
transform(metaFiles: FileDTO[]) {
|
||||
return metaFiles.filter((f: FileDTO) => f.name.toLocaleLowerCase().endsWith('.gpx'));
|
||||
}
|
||||
}
|
@ -34,7 +34,7 @@
|
||||
|
||||
<app-gallery-map *ngIf="isPhotoWithLocation && mapEnabled"
|
||||
[photos]="_galleryService.content.value.directory.media"
|
||||
[metaFiles]="_galleryService.content.value.directory.metaFile"></app-gallery-map>
|
||||
[gpxFiles]="_galleryService.content.value.directory.metaFile | gpxFiles"></app-gallery-map>
|
||||
<app-gallery-grid [media]="_galleryService.content.value.directory.media"
|
||||
[lightbox]="lightbox"></app-gallery-grid>
|
||||
</div>
|
||||
@ -48,7 +48,7 @@
|
||||
|
||||
<app-gallery-map *ngIf="isPhotoWithLocation && mapEnabled"
|
||||
[photos]="_galleryService.content.value.searchResult.media"
|
||||
[metaFiles]="_galleryService.content.value.searchResult.metaFile"></app-gallery-map>
|
||||
[gpxFiles]="_galleryService.content.value.searchResult.metaFile | gpxFiles"></app-gallery-map>
|
||||
|
||||
<app-gallery-directories class="directories" [directories]="directories"></app-gallery-directories>
|
||||
|
||||
|
@ -18,6 +18,7 @@ import {PhotoDTO} from '../../../../common/entities/PhotoDTO';
|
||||
import {QueryParams} from '../../../../common/QueryParams';
|
||||
import {SeededRandomService} from '../../model/seededRandom.service';
|
||||
import {take} from 'rxjs/operators';
|
||||
import {FileDTO} from '../../../../common/entities/FileDTO';
|
||||
|
||||
@Component({
|
||||
selector: 'app-gallery',
|
||||
@ -57,6 +58,7 @@ export class GalleryComponent implements OnInit, OnDestroy {
|
||||
PageHelper.showScrollY();
|
||||
}
|
||||
|
||||
|
||||
updateTimer(t: number) {
|
||||
if (this.shareService.sharingSubject.value == null) {
|
||||
return;
|
||||
@ -210,6 +212,5 @@ export class GalleryComponent implements OnInit, OnDestroy {
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
@ -10,6 +10,7 @@ import {ShareService} from './share.service';
|
||||
import {NavigationService} from '../../model/navigation.service';
|
||||
import {SortingMethods} from '../../../../common/entities/SortingMethods';
|
||||
import {QueryParams} from '../../../../common/QueryParams';
|
||||
import {PG2ConfMap} from '../../../../common/PG2ConfMap';
|
||||
|
||||
|
||||
@Injectable()
|
||||
@ -40,10 +41,21 @@ export class GalleryService {
|
||||
this.sorting = new BehaviorSubject<SortingMethods>(Config.Client.Other.defaultPhotoSortingMethod);
|
||||
}
|
||||
|
||||
getDefaultSorting(directory: DirectoryDTO): SortingMethods {
|
||||
if (directory && directory.metaFile) {
|
||||
for (const file in PG2ConfMap.sorting) {
|
||||
if (directory.metaFile.some(f => f.name === file)) {
|
||||
return (<any>PG2ConfMap.sorting)[file];
|
||||
}
|
||||
}
|
||||
}
|
||||
return Config.Client.Other.defaultPhotoSortingMethod;
|
||||
}
|
||||
|
||||
setSorting(sorting: SortingMethods): void {
|
||||
this.sorting.next(sorting);
|
||||
if (this.content.value.directory) {
|
||||
if (sorting !== Config.Client.Other.defaultPhotoSortingMethod) {
|
||||
if (sorting !== this.getDefaultSorting(this.content.value.directory)) {
|
||||
this.galleryCacheService.setSorting(this.content.value.directory, sorting);
|
||||
} else {
|
||||
this.galleryCacheService.removeSorting(this.content.value.directory);
|
||||
@ -59,7 +71,7 @@ export class GalleryService {
|
||||
if (sort !== null) {
|
||||
this.sorting.next(sort);
|
||||
} else {
|
||||
this.sorting.next(Config.Client.Other.defaultPhotoSortingMethod);
|
||||
this.sorting.next(this.getDefaultSorting(content.directory));
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -199,7 +211,6 @@ export class GalleryService {
|
||||
}
|
||||
|
||||
|
||||
|
||||
isSearchResult(): boolean {
|
||||
return !!this.content.value.searchResult;
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
<ng-template [ngIf]="mapPhotos.length>0">
|
||||
<app-gallery-map-lightbox [photos]="photos" [gpxFiles]="metaFiles"></app-gallery-map-lightbox>
|
||||
<app-gallery-map-lightbox [photos]="photos" [gpxFiles]="gpxFiles"></app-gallery-map-lightbox>
|
||||
<div id="map" #map>
|
||||
|
||||
<yaga-map #yagaMap
|
||||
|
@ -14,7 +14,7 @@ import {MapComponent} from '@yaga/leaflet-ng2';
|
||||
export class GalleryMapComponent implements OnChanges, IRenderable, AfterViewInit {
|
||||
|
||||
@Input() photos: PhotoDTO[];
|
||||
@Input() metaFiles: FileDTO[];
|
||||
@Input() gpxFiles: FileDTO[];
|
||||
@ViewChild(GalleryMapLightboxComponent, {static: false}) mapLightbox: GalleryMapLightboxComponent;
|
||||
|
||||
mapPhotos: Array<{ lat: number, lng: number }> = [];
|
||||
|
@ -45,6 +45,7 @@ export class GalleryNavigatorComponent implements OnChanges {
|
||||
|
||||
ngOnChanges() {
|
||||
this.getPath();
|
||||
this.DefaultSorting = this.galleryService.getDefaultSorting(this.directory);
|
||||
}
|
||||
|
||||
getPath(): any {
|
||||
|
Loading…
x
Reference in New Issue
Block a user