mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
Adding save album button to search query builder #45
This commit is contained in:
parent
1e8ec4e96e
commit
c31e7b8e3a
@ -1,21 +1,15 @@
|
|||||||
.star {
|
.delete {
|
||||||
margin: 2px;
|
margin: 2px;
|
||||||
color: #888;
|
|
||||||
cursor: default;
|
cursor: default;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.star.favourite {
|
.delete {
|
||||||
color: white;
|
|
||||||
}
|
|
||||||
|
|
||||||
.star.clickable {
|
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
transition: all .05s ease-in-out;
|
transition: all .05s ease-in-out;
|
||||||
transform: scale(1.0, 1.0);
|
transform: scale(1.0, 1.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
.star.clickable:hover {
|
.delete:hover {
|
||||||
transform: scale(1.4, 1.4);
|
transform: scale(1.4, 1.4);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,13 +40,6 @@ a {
|
|||||||
background-position: center;
|
background-position: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.button {
|
|
||||||
border: 0;
|
|
||||||
padding: 0;
|
|
||||||
text-align: left;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.info {
|
.info {
|
||||||
background-color: rgba(0, 0, 0, 0.6);
|
background-color: rgba(0, 0, 0, 0.6);
|
||||||
color: white;
|
color: white;
|
||||||
@ -71,9 +58,3 @@ a:hover .info {
|
|||||||
a:hover .photo-container {
|
a:hover .photo-container {
|
||||||
border-color: #000;
|
border-color: #000;
|
||||||
}
|
}
|
||||||
|
|
||||||
.person-name {
|
|
||||||
display: inline-block;
|
|
||||||
width: 180px;
|
|
||||||
white-space: normal;
|
|
||||||
}
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
{{album.name}}
|
{{album.name}}
|
||||||
<span *ngIf="CanUpdate"
|
<span *ngIf="CanUpdate"
|
||||||
(click)="deleteAlbum($event)"
|
(click)="deleteAlbum($event)"
|
||||||
class="star oi oi-remove"></span>
|
class="delete oi oi-trash float-right"></span>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
|
@ -37,14 +37,14 @@ export class AlbumComponent implements OnInit, OnDestroy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
get CanUpdate(): boolean {
|
get CanUpdate(): boolean {
|
||||||
return this.authenticationService.user.getValue().role >= UserRoles.Admin;
|
return this.authenticationService.user.getValue().role >= UserRoles.Admin;
|
||||||
}
|
}
|
||||||
|
|
||||||
get RouterLink(): any[] {
|
get RouterLink(): any[] {
|
||||||
if (this.IsSavedSearch) {
|
if (this.IsSavedSearch) {
|
||||||
return ['/search', this.AsSavedSearch.searchQuery];
|
return ['/search', JSON.stringify(this.AsSavedSearch.searchQuery)];
|
||||||
}
|
}
|
||||||
// TODO: add nomral albums here once they are ready
|
// TODO: add "normal" albums here once they are ready, see: https://github.com/bpatrik/pigallery2/issues/301
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ import {Injectable} from '@angular/core';
|
|||||||
import {NetworkService} from '../../model/network/network.service';
|
import {NetworkService} from '../../model/network/network.service';
|
||||||
import {BehaviorSubject} from 'rxjs';
|
import {BehaviorSubject} from 'rxjs';
|
||||||
import {AlbumBaseDTO} from '../../../../common/entities/album/AlbumBaseDTO';
|
import {AlbumBaseDTO} from '../../../../common/entities/album/AlbumBaseDTO';
|
||||||
|
import {SearchQueryDTO} from '../../../../common/entities/SearchQueryDTO';
|
||||||
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
@ -22,4 +23,9 @@ export class AlbumsService {
|
|||||||
await this.networkService.deleteJson('/albums/' + album.id);
|
await this.networkService.deleteJson('/albums/' + album.id);
|
||||||
await this.getAlbums();
|
await this.getAlbums();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async addSavedSearch(name: string, searchQuery: SearchQueryDTO): Promise<void> {
|
||||||
|
await this.networkService.putJson('/albums/saved-searches', {name, searchQuery});
|
||||||
|
await this.getAlbums();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,8 +72,3 @@ a:hover .photo-container {
|
|||||||
border-color: #000;
|
border-color: #000;
|
||||||
}
|
}
|
||||||
|
|
||||||
.person-name {
|
|
||||||
display: inline-block;
|
|
||||||
width: 180px;
|
|
||||||
white-space: normal;
|
|
||||||
}
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
<form class="navbar-form" role="search" #SearchForm="ngForm">
|
<form class="navbar-form" role="search" #SearchForm="ngForm">
|
||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
|
|
||||||
<app-gallery-search-field [(ngModel)]="rawSearchText"
|
<app-gallery-search-field [(ngModel)]="rawSearchText"
|
||||||
(ngModelChange)="validateRawSearchText()"
|
(ngModelChange)="validateRawSearchText()"
|
||||||
class="search-field"
|
class="search-field"
|
||||||
(search)="Search()"
|
(search)="Search()"
|
||||||
name="search-field">
|
name="search-field">
|
||||||
|
|
||||||
</app-gallery-search-field>
|
</app-gallery-search-field>
|
||||||
|
|
||||||
@ -17,7 +17,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="input-group-btn" style="display: block">
|
<div class="input-group-btn" style="display: block">
|
||||||
<button class="btn btn-light" type="button" (click)="openModal(searchModal)">
|
<button class="btn btn-light" type="button" (click)="openSearchModal(searchModal)">
|
||||||
<span class="oi oi-chevron-bottom"></span>
|
<span class="oi oi-chevron-bottom"></span>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
@ -29,19 +29,20 @@
|
|||||||
<!-- sharing Modal-->
|
<!-- sharing Modal-->
|
||||||
<div class="modal-header">
|
<div class="modal-header">
|
||||||
<h5 class="modal-title" i18n>Search</h5>
|
<h5 class="modal-title" i18n>Search</h5>
|
||||||
<button type="button" class="close" (click)="hideModal()" data-dismiss="modal" aria-label="Close">
|
<button type="button" class="close" (click)="hideSearchModal()" data-dismiss="modal" aria-label="Close">
|
||||||
<span aria-hidden="true">×</span>
|
<span aria-hidden="true">×</span>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
<form #searchPanelForm="ngForm" class="form-horizontal">
|
<form #searchPanelForm="ngForm" class="form-horizontal">
|
||||||
|
|
||||||
<app-gallery-search-field [(ngModel)]="rawSearchText"
|
<app-gallery-search-field [(ngModel)]="rawSearchText"
|
||||||
(ngModelChange)="validateRawSearchText()"
|
(ngModelChange)="validateRawSearchText()"
|
||||||
(search)="Search()"
|
(search)="Search()"
|
||||||
name="form-search-field">
|
name="form-search-field">
|
||||||
|
|
||||||
</app-gallery-search-field>
|
</app-gallery-search-field>
|
||||||
|
<hr>
|
||||||
<app-gallery-search-query-entry
|
<app-gallery-search-query-entry
|
||||||
[(ngModel)]="searchQueryDTO"
|
[(ngModel)]="searchQueryDTO"
|
||||||
(change)="onQueryChange()"
|
(change)="onQueryChange()"
|
||||||
@ -50,13 +51,49 @@
|
|||||||
|
|
||||||
</app-gallery-search-query-entry>
|
</app-gallery-search-query-entry>
|
||||||
|
|
||||||
<div class="input-group-btn float-right" style="display: block">
|
<div class="input-group-btn float-right row" style="display: block">
|
||||||
|
|
||||||
|
<button class="btn btn-secondary mr-2" type="button"
|
||||||
|
[disabled]="rawSearchText == ''"
|
||||||
|
(click)="openSaveSearchModal(saveSearchModal)">
|
||||||
|
<span class="oi oi-folder"></span> Save
|
||||||
|
</button>
|
||||||
<button class="btn btn-primary" type="button"
|
<button class="btn btn-primary" type="button"
|
||||||
[routerLink]="['/search', HTMLSearchQuery]"
|
[routerLink]="['/search', HTMLSearchQuery]"
|
||||||
(click)="hideModal()">
|
(click)="hideSearchModal()">
|
||||||
<span class="oi oi-magnifying-glass"></span> Search
|
<span class="oi oi-magnifying-glass"></span> Search
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</ng-template>
|
</ng-template>
|
||||||
|
|
||||||
|
<ng-template #saveSearchModal>
|
||||||
|
<!-- sharing Modal-->
|
||||||
|
<div class="modal-header">
|
||||||
|
<h5 class="modal-title" i18n>Save search to album</h5>
|
||||||
|
<button type="button" class="close" (click)="hideSaveSearchModal()" data-dismiss="modal" aria-label="Close">
|
||||||
|
<span aria-hidden="true">×</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
|
||||||
|
<form #saveSearchPanelForm="ngForm" class="form-horizontal">
|
||||||
|
<div class="row">
|
||||||
|
<input
|
||||||
|
id="saveSearchName"
|
||||||
|
name="saveSearchName"
|
||||||
|
placeholder="Search text"
|
||||||
|
class="form-control input-md"
|
||||||
|
[(ngModel)]="saveSearchName"
|
||||||
|
type="text"/>
|
||||||
|
</div>
|
||||||
|
<div class="input-group-btn float-right row mt-2" style="display: block">
|
||||||
|
<button class="btn btn-primary" type="button"
|
||||||
|
(click)="saveSearch()">
|
||||||
|
<span class="oi oi-folder"></span> Save as album
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</ng-template>
|
||||||
|
@ -9,6 +9,7 @@ import {MetadataSearchQueryTypes, SearchQueryDTO, SearchQueryTypes, TextSearch}
|
|||||||
import {BsModalService} from 'ngx-bootstrap/modal';
|
import {BsModalService} from 'ngx-bootstrap/modal';
|
||||||
import {BsModalRef} from 'ngx-bootstrap/modal/bs-modal-ref.service';
|
import {BsModalRef} from 'ngx-bootstrap/modal/bs-modal-ref.service';
|
||||||
import {SearchQueryParserService} from './search-query-parser.service';
|
import {SearchQueryParserService} from './search-query-parser.service';
|
||||||
|
import {AlbumsService} from '../../albums/albums.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-gallery-search',
|
selector: 'app-gallery-search',
|
||||||
@ -22,13 +23,16 @@ export class GallerySearchComponent implements OnDestroy {
|
|||||||
public rawSearchText = '';
|
public rawSearchText = '';
|
||||||
mouseOverAutoComplete = false;
|
mouseOverAutoComplete = false;
|
||||||
readonly SearchQueryTypes: typeof SearchQueryTypes;
|
readonly SearchQueryTypes: typeof SearchQueryTypes;
|
||||||
modalRef: BsModalRef;
|
|
||||||
public readonly MetadataSearchQueryTypes: { value: string; key: SearchQueryTypes }[];
|
public readonly MetadataSearchQueryTypes: { value: string; key: SearchQueryTypes }[];
|
||||||
|
private searchModalRef: BsModalRef;
|
||||||
private readonly subscription: Subscription = null;
|
private readonly subscription: Subscription = null;
|
||||||
|
private saveSearchModalRef: BsModalRef;
|
||||||
|
public saveSearchName: string;
|
||||||
|
|
||||||
constructor(private autoCompleteService: AutoCompleteService,
|
constructor(private autoCompleteService: AutoCompleteService,
|
||||||
private searchQueryParserService: SearchQueryParserService,
|
private searchQueryParserService: SearchQueryParserService,
|
||||||
private galleryService: GalleryService,
|
private galleryService: GalleryService,
|
||||||
|
private albumService: AlbumsService,
|
||||||
private navigationService: NavigationService,
|
private navigationService: NavigationService,
|
||||||
private route: ActivatedRoute,
|
private route: ActivatedRoute,
|
||||||
public router: Router,
|
public router: Router,
|
||||||
@ -60,14 +64,24 @@ export class GallerySearchComponent implements OnDestroy {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public async openModal(template: TemplateRef<any>): Promise<void> {
|
public async openSearchModal(template: TemplateRef<any>): Promise<void> {
|
||||||
this.modalRef = this.modalService.show(template, {class: 'modal-lg'});
|
this.searchModalRef = this.modalService.show(template, {class: 'modal-lg'});
|
||||||
document.body.style.paddingRight = '0px';
|
document.body.style.paddingRight = '0px';
|
||||||
}
|
}
|
||||||
|
|
||||||
public hideModal(): void {
|
public async openSaveSearchModal(template: TemplateRef<any>): Promise<void> {
|
||||||
this.modalRef.hide();
|
this.saveSearchModalRef = this.modalService.show(template, {class: 'modal-lg'});
|
||||||
this.modalRef = null;
|
document.body.style.paddingRight = '0px';
|
||||||
|
}
|
||||||
|
|
||||||
|
public hideSaveSearchModal(): void {
|
||||||
|
this.saveSearchModalRef.hide();
|
||||||
|
this.saveSearchModalRef = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public hideSearchModal(): void {
|
||||||
|
this.searchModalRef.hide();
|
||||||
|
this.searchModalRef = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
resetQuery(): void {
|
resetQuery(): void {
|
||||||
@ -92,6 +106,10 @@ export class GallerySearchComponent implements OnDestroy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
async saveSearch(): Promise<void> {
|
||||||
|
await this.albumService.addSavedSearch(this.saveSearchName, this.searchQueryDTO);
|
||||||
|
this.hideSaveSearchModal();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user