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

Disabling searching with shared link #269

This commit is contained in:
Patrik J. Braun 2021-04-23 17:54:43 +02:00
parent 90a6c4b6b1
commit f0f47f96bb
6 changed files with 46 additions and 19 deletions

View File

@ -8,7 +8,7 @@ import {NetworkService} from './network.service';
import {ErrorCodes, ErrorDTO} from '../../../../common/entities/Error'; import {ErrorCodes, ErrorDTO} from '../../../../common/entities/Error';
import {CookieNames} from '../../../../common/CookieNames'; import {CookieNames} from '../../../../common/CookieNames';
import {ShareService} from '../../ui/gallery/share.service'; import {ShareService} from '../../ui/gallery/share.service';
import { CookieService } from 'ngx-cookie-service'; import {CookieService} from 'ngx-cookie-service';
/* Injected config / user from server side */ /* Injected config / user from server side */
// tslint:disable-next-line:no-internal-module no-namespace // tslint:disable-next-line:no-internal-module no-namespace
@ -85,6 +85,10 @@ export class AuthenticationService {
return this.user.value && this.user.value.role >= role; return this.user.value && this.user.value.role >= role;
} }
public canSearch(): boolean {
return this.isAuthorized(UserRoles.Guest);
}
public async logout(): Promise<void> { public async logout(): Promise<void> {
await this.userService.logout(); await this.userService.logout();
this.user.next(null); this.user.next(null);

View File

@ -99,9 +99,9 @@ export class GalleryComponent implements OnInit, OnDestroy {
return this.navigation.toLogin(); return this.navigation.toLogin();
} }
this.showSearchBar = Config.Client.Search.enabled && this.authService.isAuthorized(UserRoles.Guest); this.showSearchBar = Config.Client.Search.enabled && this.authService.canSearch();
this.showShare = Config.Client.Sharing.enabled && this.authService.isAuthorized(UserRoles.User); this.showShare = Config.Client.Sharing.enabled && this.authService.isAuthorized(UserRoles.User);
this.showRandomPhotoBuilder = Config.Client.RandomPhoto.enabled && this.authService.isAuthorized(UserRoles.Guest); this.showRandomPhotoBuilder = Config.Client.RandomPhoto.enabled && this.authService.isAuthorized(UserRoles.User);
this.subscription.content = this.galleryService.content.subscribe(this.onContentChange); this.subscription.content = this.galleryService.content.subscribe(this.onContentChange);
this.subscription.route = this.route.params.subscribe(this.onRoute); this.subscription.route = this.route.params.subscribe(this.onRoute);

View File

@ -7,6 +7,8 @@ import {Config} from '../../../../../../common/config/public/Config';
import {PageHelper} from '../../../../model/page.helper'; import {PageHelper} from '../../../../model/page.helper';
import {PhotoDTO, PhotoMetadata} from '../../../../../../common/entities/PhotoDTO'; import {PhotoDTO, PhotoMetadata} from '../../../../../../common/entities/PhotoDTO';
import {SearchQueryTypes, TextSearch, TextSearchQueryMatchTypes} from '../../../../../../common/entities/SearchQueryDTO'; import {SearchQueryTypes, TextSearch, TextSearchQueryMatchTypes} from '../../../../../../common/entities/SearchQueryDTO';
import {UserRoles} from '../../../../../../common/entities/UserDTO';
import {AuthenticationService} from '../../../../model/network/authentication.service';
@Component({ @Component({
selector: 'app-gallery-grid-photo', selector: 'app-gallery-grid-photo',
@ -29,8 +31,9 @@ export class GalleryPhotoComponent implements IRenderable, OnInit, OnDestroy {
wasInView: boolean = null; wasInView: boolean = null;
constructor(private thumbnailService: ThumbnailManagerService) { constructor(private thumbnailService: ThumbnailManagerService,
this.searchEnabled = Config.Client.Search.enabled; private authService: AuthenticationService) {
this.searchEnabled = Config.Client.Search.enabled && this.authService.canSearch();
} }
get ScrollListener(): boolean { get ScrollListener(): boolean {

View File

@ -56,17 +56,31 @@
[style.width.px]="faceContainerDim.width* zoom" [style.width.px]="faceContainerDim.width* zoom"
[style.height.px]="faceContainerDim.height* zoom" [style.height.px]="faceContainerDim.height* zoom"
*ngIf="facesEnabled && activePhoto && activePhoto.gridMedia.Photo.metadata.faces && activePhoto.gridMedia.Photo.metadata.faces.length > 0"> *ngIf="facesEnabled && activePhoto && activePhoto.gridMedia.Photo.metadata.faces && activePhoto.gridMedia.Photo.metadata.faces.length > 0">
<a <ng-container *ngIf="searchEnabled">
class="face" <a
[routerLink]="['/search', getPersonSearchQuery(face.name)]" class="face"
[style.top.%]="face.box.top / activePhoto.gridMedia.Photo.metadata.size.height*100" [routerLink]="['/search', getPersonSearchQuery(face.name)]"
[style.left.%]="face.box.left / activePhoto.gridMedia.Photo.metadata.size.width*100" [style.top.%]="face.box.top / activePhoto.gridMedia.Photo.metadata.size.height*100"
[style.height.%]="face.box.height / activePhoto.gridMedia.Photo.metadata.size.height*100" [style.left.%]="face.box.left / activePhoto.gridMedia.Photo.metadata.size.width*100"
[style.width.%]="face.box.width / activePhoto.gridMedia.Photo.metadata.size.width*100" [style.height.%]="face.box.height / activePhoto.gridMedia.Photo.metadata.size.height*100"
*ngFor="let face of activePhoto.gridMedia.Photo.metadata.faces"> [style.width.%]="face.box.width / activePhoto.gridMedia.Photo.metadata.size.width*100"
<div class="face-box"></div> *ngFor="let face of activePhoto.gridMedia.Photo.metadata.faces">
<span class="face-name">{{face.name}}</span> <div class="face-box"></div>
</a> <span class="face-name">{{face.name}}</span>
</a>
</ng-container>
<ng-container *ngIf="!searchEnabled">
<div
class="face"
[style.top.%]="face.box.top / activePhoto.gridMedia.Photo.metadata.size.height*100"
[style.left.%]="face.box.left / activePhoto.gridMedia.Photo.metadata.size.width*100"
[style.height.%]="face.box.height / activePhoto.gridMedia.Photo.metadata.size.height*100"
[style.width.%]="face.box.width / activePhoto.gridMedia.Photo.metadata.size.width*100"
*ngFor="let face of activePhoto.gridMedia.Photo.metadata.faces">
<div class="face-box"></div>
<span class="face-name">{{face.name}}</span>
</div>
</ng-container>
</div> </div>

View File

@ -8,6 +8,7 @@ import {PhotoDTO} from '../../../../../../common/entities/PhotoDTO';
import {GalleryLightboxMediaComponent} from '../media/media.lightbox.gallery.component'; import {GalleryLightboxMediaComponent} from '../media/media.lightbox.gallery.component';
import {Config} from '../../../../../../common/config/public/Config'; import {Config} from '../../../../../../common/config/public/Config';
import {SearchQueryTypes, TextSearch, TextSearchQueryMatchTypes} from '../../../../../../common/entities/SearchQueryDTO'; import {SearchQueryTypes, TextSearch, TextSearchQueryMatchTypes} from '../../../../../../common/entities/SearchQueryDTO';
import {AuthenticationService} from '../../../../model/network/authentication.service';
export enum PlayBackStates { export enum PlayBackStates {
Paused = 1, Paused = 1,
@ -48,13 +49,16 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
public drag = {x: 0, y: 0}; public drag = {x: 0, y: 0};
public SearchQueryTypes = SearchQueryTypes; public SearchQueryTypes = SearchQueryTypes;
public faceContainerDim = {width: 0, height: 0}; public faceContainerDim = {width: 0, height: 0};
public searchEnabled: boolean;
private visibilityTimer: number = null; private visibilityTimer: number = null;
private timer: Observable<number>; private timer: Observable<number>;
private timerSub: Subscription; private timerSub: Subscription;
private prevDrag = {x: 0, y: 0}; private prevDrag = {x: 0, y: 0};
private prevZoom = 1; private prevZoom = 1;
constructor(public fullScreenService: FullScreenService) { constructor(public fullScreenService: FullScreenService,
private authService: AuthenticationService) {
this.searchEnabled = Config.Client.Search.enabled && this.authService.canSearch();
} }
public get Zoom(): number { public get Zoom(): number {

View File

@ -7,6 +7,7 @@ import {Utils} from '../../../../../../common/Utils';
import {QueryService} from '../../../../model/query.service'; import {QueryService} from '../../../../model/query.service';
import {MapService} from '../../map/map.service'; import {MapService} from '../../map/map.service';
import {SearchQueryTypes, TextSearch, TextSearchQueryMatchTypes} from '../../../../../../common/entities/SearchQueryDTO'; import {SearchQueryTypes, TextSearch, TextSearchQueryMatchTypes} from '../../../../../../common/entities/SearchQueryDTO';
import {AuthenticationService} from '../../../../model/network/authentication.service';
@Component({ @Component({
selector: 'app-info-panel', selector: 'app-info-panel',
@ -23,9 +24,10 @@ export class InfoPanelLightboxComponent implements OnInit {
readonly SearchQueryTypes: typeof SearchQueryTypes = SearchQueryTypes; readonly SearchQueryTypes: typeof SearchQueryTypes = SearchQueryTypes;
constructor(public queryService: QueryService, constructor(public queryService: QueryService,
public mapService: MapService) { public mapService: MapService,
private authService: AuthenticationService) {
this.mapEnabled = Config.Client.Map.enabled; this.mapEnabled = Config.Client.Map.enabled;
this.searchEnabled = Config.Client.Search.enabled; this.searchEnabled = Config.Client.Search.enabled && this.authService.canSearch();
} }
get FullPath(): string { get FullPath(): string {