Lots of Filtering Fixes & New Fields (#2244)
* Added an id for komf userscript to help it inject into Kavita's UI without relying on strings, given localization. * Still working the filter fields, there is a bug with selecting an input and it setting undefined like crazy. Path is coded but not tested or validated. * Stashing changed. Really not sure what's happening. I'm seeing 2 constructor calls for one row. I'm seeing a field change trigger 400 events. Values aren't getting set correctly on default string. I've made a ton of changes, when resuming this work, look at the diff. All of this can be reset excluding the Path work. * Lots of comments but the double instantiation is due to the mobile drawer. Added an ngIf which seems to work. * Fixed dropdown options triggering a ton of looped calls. Default limitTo to 0 when user empties blank or negative. * Removed a ton of UserId db calls from a ton of apis. Added a new API to allow UI to query a specific role to lessen load on UI. * Optimized the code on new filtering to only load people by a given role. This should speed up heavily tagged libraries. Commented out a bunch of code that's no longer used. Will be cleaned up later. * Fixed support so that library filter can handle multiple selections. * Fixed a bug when hitting enter in an input, the statement would be removed. * Fixed multi-select not resuming from url correctly. * Restored the series/all api for Tachiyomi to continue using until I'm motivated enough to update the extension. * Fixed some resuming of state with dropdowns, not always setting values in correct order. * Added FilePath Filter which lets a user search on individual files (slow, may need index) * Added a full filepath for new filtering.
This commit is contained in:
parent
69b5530a93
commit
cd84913fb9
29 changed files with 576 additions and 238 deletions
|
@ -8,7 +8,7 @@ import {AgeRating} from '../_models/metadata/age-rating';
|
|||
import {AgeRatingDto} from '../_models/metadata/age-rating-dto';
|
||||
import {Language} from '../_models/metadata/language';
|
||||
import {PublicationStatusDto} from '../_models/metadata/publication-status-dto';
|
||||
import {Person} from '../_models/metadata/person';
|
||||
import {Person, PersonRole} from '../_models/metadata/person';
|
||||
import {Tag} from '../_models/tag';
|
||||
import {TextResonse} from '../_types/text-response';
|
||||
import {FilterComparison} from '../_models/metadata/v2/filter-comparison';
|
||||
|
@ -33,44 +33,44 @@ export class MetadataService {
|
|||
|
||||
constructor(private httpClient: HttpClient, private router: Router) { }
|
||||
|
||||
applyFilter(page: Array<any>, filter: FilterField, comparison: FilterComparison, value: string) {
|
||||
const dto: SeriesFilterV2 = {
|
||||
statements: [this.createDefaultFilterStatement(filter, comparison, value + '')],
|
||||
combination: FilterCombination.Or,
|
||||
limitTo: 0
|
||||
};
|
||||
//
|
||||
// console.log('navigating to: ', this.filterUtilityService.urlFromFilterV2(page.join('/'), dto));
|
||||
// this.router.navigateByUrl(this.filterUtilityService.urlFromFilterV2(page.join('/'), dto));
|
||||
// applyFilter(page: Array<any>, filter: FilterField, comparison: FilterComparison, value: string) {
|
||||
// const dto: SeriesFilterV2 = {
|
||||
// statements: [this.createDefaultFilterStatement(filter, comparison, value + '')],
|
||||
// combination: FilterCombination.Or,
|
||||
// limitTo: 0
|
||||
// };
|
||||
// //
|
||||
// // console.log('navigating to: ', this.filterUtilityService.urlFromFilterV2(page.join('/'), dto));
|
||||
// // this.router.navigateByUrl(this.filterUtilityService.urlFromFilterV2(page.join('/'), dto));
|
||||
//
|
||||
// // Creates a temp name for the filter
|
||||
// this.httpClient.post<string>(this.baseUrl + 'filter/create-temp', dto, TextResonse).pipe(map(name => {
|
||||
// dto.name = name;
|
||||
// }), switchMap((_) => {
|
||||
// let params: any = {};
|
||||
// params['filterName'] = dto.name;
|
||||
// return this.router.navigate(page, {queryParams: params});
|
||||
// })).subscribe();
|
||||
//
|
||||
// }
|
||||
|
||||
// Creates a temp name for the filter
|
||||
this.httpClient.post<string>(this.baseUrl + 'filter/create-temp', dto, TextResonse).pipe(map(name => {
|
||||
dto.name = name;
|
||||
}), switchMap((_) => {
|
||||
let params: any = {};
|
||||
params['filterName'] = dto.name;
|
||||
return this.router.navigate(page, {queryParams: params});
|
||||
})).subscribe();
|
||||
// getFilter(filterName: string) {
|
||||
// return this.httpClient.get<SeriesFilterV2>(this.baseUrl + 'filter?name=' + filterName);
|
||||
// }
|
||||
|
||||
}
|
||||
|
||||
getFilter(filterName: string) {
|
||||
return this.httpClient.get<SeriesFilterV2>(this.baseUrl + 'filter?name=' + filterName);
|
||||
}
|
||||
|
||||
getAgeRating(ageRating: AgeRating) {
|
||||
if (this.ageRatingTypes != undefined && this.ageRatingTypes.hasOwnProperty(ageRating)) {
|
||||
return of(this.ageRatingTypes[ageRating]);
|
||||
}
|
||||
return this.httpClient.get<string>(this.baseUrl + 'series/age-rating?ageRating=' + ageRating, TextResonse).pipe(map(ratingString => {
|
||||
if (this.ageRatingTypes === undefined) {
|
||||
this.ageRatingTypes = {};
|
||||
}
|
||||
|
||||
this.ageRatingTypes[ageRating] = ratingString;
|
||||
return this.ageRatingTypes[ageRating];
|
||||
}));
|
||||
}
|
||||
// getAgeRating(ageRating: AgeRating) {
|
||||
// if (this.ageRatingTypes != undefined && this.ageRatingTypes.hasOwnProperty(ageRating)) {
|
||||
// return of(this.ageRatingTypes[ageRating]);
|
||||
// }
|
||||
// return this.httpClient.get<string>(this.baseUrl + 'series/age-rating?ageRating=' + ageRating, TextResonse).pipe(map(ratingString => {
|
||||
// if (this.ageRatingTypes === undefined) {
|
||||
// this.ageRatingTypes = {};
|
||||
// }
|
||||
//
|
||||
// this.ageRatingTypes[ageRating] = ratingString;
|
||||
// return this.ageRatingTypes[ageRating];
|
||||
// }));
|
||||
// }
|
||||
|
||||
getAllAgeRatings(libraries?: Array<number>) {
|
||||
let method = 'metadata/age-ratings'
|
||||
|
@ -132,10 +132,14 @@ export class MetadataService {
|
|||
return this.httpClient.get<Array<Person>>(this.baseUrl + method);
|
||||
}
|
||||
|
||||
getChapterSummary(chapterId: number) {
|
||||
return this.httpClient.get<string>(this.baseUrl + 'metadata/chapter-summary?chapterId=' + chapterId, TextResonse);
|
||||
getAllPeopleByRole(role: PersonRole) {
|
||||
return this.httpClient.get<Array<Person>>(this.baseUrl + 'metadata/people-by-role?role=' + role);
|
||||
}
|
||||
|
||||
// getChapterSummary(chapterId: number) {
|
||||
// return this.httpClient.get<string>(this.baseUrl + 'metadata/chapter-summary?chapterId=' + chapterId, TextResonse);
|
||||
// }
|
||||
|
||||
createDefaultFilterDto(): SeriesFilterV2 {
|
||||
return {
|
||||
statements: [] as FilterStatement[],
|
||||
|
@ -159,6 +163,6 @@ export class MetadataService {
|
|||
updateFilter(arr: Array<FilterStatement>, index: number, filterStmt: FilterStatement) {
|
||||
arr[index].comparison = filterStmt.comparison;
|
||||
arr[index].field = filterStmt.field;
|
||||
arr[index].value = filterStmt.value + '';
|
||||
arr[index].value = filterStmt.value ? filterStmt.value + '' : '';
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue