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:
parent
90a6c4b6b1
commit
f0f47f96bb
@ -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);
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
[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">
|
||||||
|
<ng-container *ngIf="searchEnabled">
|
||||||
<a
|
<a
|
||||||
class="face"
|
class="face"
|
||||||
[routerLink]="['/search', getPersonSearchQuery(face.name)]"
|
[routerLink]="['/search', getPersonSearchQuery(face.name)]"
|
||||||
@ -67,6 +68,19 @@
|
|||||||
<div class="face-box"></div>
|
<div class="face-box"></div>
|
||||||
<span class="face-name">{{face.name}}</span>
|
<span class="face-name">{{face.name}}</span>
|
||||||
</a>
|
</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>
|
||||||
|
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user