mirror of
https://github.com/bpatrik/pigallery2.git
synced 2025-01-10 04:07:35 +02:00
Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
6a4c38a868
@ -125,7 +125,6 @@
|
|||||||
"leaflet": "1.7.1",
|
"leaflet": "1.7.1",
|
||||||
"leaflet.markercluster": "1.5.0",
|
"leaflet.markercluster": "1.5.0",
|
||||||
"mocha": "8.4.0",
|
"mocha": "8.4.0",
|
||||||
"natural-orderby": "2.0.3",
|
|
||||||
"ngx-bootstrap": "6.2.0",
|
"ngx-bootstrap": "6.2.0",
|
||||||
"ngx-clipboard": "14.0.1",
|
"ngx-clipboard": "14.0.1",
|
||||||
"ngx-cookie-service": "11.0.2",
|
"ngx-cookie-service": "11.0.2",
|
||||||
|
@ -2,10 +2,6 @@ nav {
|
|||||||
z-index: 999;
|
z-index: 999;
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar {
|
|
||||||
margin-bottom: 20px;
|
|
||||||
}
|
|
||||||
|
|
||||||
ng2-slim-loading-bar {
|
ng2-slim-loading-bar {
|
||||||
/* display: block; */
|
/* display: block; */
|
||||||
z-index: 999999;
|
z-index: 999999;
|
||||||
|
@ -17,7 +17,6 @@ import {PhotoDTO} from '../../../../common/entities/PhotoDTO';
|
|||||||
import {QueryParams} from '../../../../common/QueryParams';
|
import {QueryParams} from '../../../../common/QueryParams';
|
||||||
import {SeededRandomService} from '../../model/seededRandom.service';
|
import {SeededRandomService} from '../../model/seededRandom.service';
|
||||||
import {take} from 'rxjs/operators';
|
import {take} from 'rxjs/operators';
|
||||||
import {compare} from 'natural-orderby';
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-gallery',
|
selector: 'app-gallery',
|
||||||
@ -160,6 +159,8 @@ export class GalleryComponent implements OnInit, OnDestroy {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private collator = new Intl.Collator(undefined, {numeric: true});
|
||||||
|
|
||||||
private sortDirectories(): void {
|
private sortDirectories(): void {
|
||||||
if (!this.directories) {
|
if (!this.directories) {
|
||||||
return;
|
return;
|
||||||
@ -167,26 +168,25 @@ export class GalleryComponent implements OnInit, OnDestroy {
|
|||||||
switch (this.galleryService.sorting.value) {
|
switch (this.galleryService.sorting.value) {
|
||||||
case SortingMethods.ascRating: // directories does not have rating
|
case SortingMethods.ascRating: // directories does not have rating
|
||||||
case SortingMethods.ascName:
|
case SortingMethods.ascName:
|
||||||
this.directories.sort((a, b) => compare()(a.name, b.name));
|
this.directories.sort((a, b) => this.collator.compare(a.name, b.name));
|
||||||
break;
|
break;
|
||||||
case SortingMethods.ascDate:
|
case SortingMethods.ascDate:
|
||||||
if (Config.Client.Other.enableDirectorySortingByDate === true) {
|
if (Config.Client.Other.enableDirectorySortingByDate === true) {
|
||||||
this.directories.sort((a, b) => compare()(a.lastModified, b.lastModified));
|
this.directories.sort((a, b) => a.lastModified - b.lastModified);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
this.directories.sort((a, b) => compare()(a.name, b.name));
|
this.directories.sort((a, b) => this.collator.compare(a.name, b.name));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SortingMethods.descRating: // directories does not have rating
|
case SortingMethods.descRating: // directories does not have rating
|
||||||
case SortingMethods.descName:
|
case SortingMethods.descName:
|
||||||
this.directories.sort((a, b) => compare({order: 'desc'})(a.name, b.name));
|
this.directories.sort((a, b) => this.collator.compare(b.name, a.name));
|
||||||
break;
|
break;
|
||||||
case SortingMethods.descDate:
|
case SortingMethods.descDate:
|
||||||
if (Config.Client.Other.enableDirectorySortingByDate === true) {
|
if (Config.Client.Other.enableDirectorySortingByDate === true) {
|
||||||
this.directories.sort((a, b) => compare({order: 'desc'})(a.lastModified, b.lastModified));
|
this.directories.sort((a, b) => b.lastModified - a.lastModified);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
this.directories.sort((a, b) => compare({order: 'desc'})(a.name, b.name));
|
this.directories.sort((a, b) => this.collator.compare(b.name, a.name));
|
||||||
break;
|
break;
|
||||||
case SortingMethods.random:
|
case SortingMethods.random:
|
||||||
this.rndService.setSeed(this.directories.length);
|
this.rndService.setSeed(this.directories.length);
|
||||||
@ -207,4 +207,3 @@ export class GalleryComponent implements OnInit, OnDestroy {
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,7 +28,6 @@ import {SortingMethods} from '../../../../../common/entities/SortingMethods';
|
|||||||
import {MediaDTO, MediaDTOUtils} from '../../../../../common/entities/MediaDTO';
|
import {MediaDTO, MediaDTOUtils} from '../../../../../common/entities/MediaDTO';
|
||||||
import {QueryParams} from '../../../../../common/QueryParams';
|
import {QueryParams} from '../../../../../common/QueryParams';
|
||||||
import {SeededRandomService} from '../../../model/seededRandom.service';
|
import {SeededRandomService} from '../../../model/seededRandom.service';
|
||||||
import {compare} from 'natural-orderby';
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-gallery-grid',
|
selector: 'app-gallery-grid',
|
||||||
@ -239,13 +238,15 @@ export class GalleryGridComponent implements OnChanges, OnInit, AfterViewInit, O
|
|||||||
this.changeDetector.detectChanges();
|
this.changeDetector.detectChanges();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private collator = new Intl.Collator(undefined, {numeric: true});
|
||||||
|
|
||||||
private sortPhotos(): void {
|
private sortPhotos(): void {
|
||||||
switch (this.galleryService.sorting.value) {
|
switch (this.galleryService.sorting.value) {
|
||||||
case SortingMethods.ascName:
|
case SortingMethods.ascName:
|
||||||
this.media.sort((a: PhotoDTO, b: PhotoDTO) => compare()(a.name, b.name));
|
this.media.sort((a: PhotoDTO, b: PhotoDTO) => this.collator.compare(a.name, b.name));
|
||||||
break;
|
break;
|
||||||
case SortingMethods.descName:
|
case SortingMethods.descName:
|
||||||
this.media.sort((a: PhotoDTO, b: PhotoDTO) => compare({order: 'desc'})(a.name, b.name));
|
this.media.sort((a: PhotoDTO, b: PhotoDTO) => this.collator.compare(b.name, a.name));
|
||||||
break;
|
break;
|
||||||
case SortingMethods.ascDate:
|
case SortingMethods.ascDate:
|
||||||
this.media.sort((a: PhotoDTO, b: PhotoDTO): number => {
|
this.media.sort((a: PhotoDTO, b: PhotoDTO): number => {
|
||||||
@ -378,6 +379,3 @@ export class GalleryGridComponent implements OnChanges, OnInit, AfterViewInit, O
|
|||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user