Merge pull request #3849 from tidusjar/themoviedbkeywords

Themoviedbkeywords
pull/3856/head
Jamie 4 years ago committed by GitHub
commit 1104bd4e87
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -54,14 +54,15 @@ namespace Ombi.Core.Tests.Rule.Search
{ {
new EmbyServers new EmbyServers
{ {
ServerHostname = "http://test.com/" ServerHostname = "http://test.com/",
ServerId = "8"
} }
} }
}); });
ContextMock.Setup(x => x.GetByTheMovieDbId(It.IsAny<string>())).ReturnsAsync(new EmbyContent ContextMock.Setup(x => x.GetByTheMovieDbId(It.IsAny<string>())).ReturnsAsync(new EmbyContent
{ {
ProviderId = "123", ProviderId = "123",
EmbyId = 1.ToString() EmbyId = 1.ToString(),
}); });
var search = new SearchMovieViewModel() var search = new SearchMovieViewModel()
{ {
@ -70,7 +71,7 @@ namespace Ombi.Core.Tests.Rule.Search
var result = await Rule.Execute(search); var result = await Rule.Execute(search);
Assert.True(result.Success); Assert.True(result.Success);
Assert.That(search.EmbyUrl, Is.EqualTo("http://test.com/#!/item?id=1")); Assert.That(search.EmbyUrl, Is.EqualTo("http://test.com/web/index.html#!/item?id=1&serverId=8"));
} }
[Test] [Test]
@ -83,7 +84,8 @@ namespace Ombi.Core.Tests.Rule.Search
{ {
new EmbyServers new EmbyServers
{ {
ServerHostname = string.Empty ServerHostname = string.Empty,
ServerId = "8"
} }
} }
}); });
@ -99,7 +101,7 @@ namespace Ombi.Core.Tests.Rule.Search
var result = await Rule.Execute(search); var result = await Rule.Execute(search);
Assert.True(result.Success); Assert.True(result.Success);
Assert.That(search.EmbyUrl, Is.EqualTo("https://app.emby.media/#!/item?id=1")); Assert.That(search.EmbyUrl, Is.EqualTo("https://app.emby.media/web/index.html#!/item?id=1&serverId=8"));
} }
[Test] [Test]

@ -1,6 +1,6 @@
namespace Ombi.Helpers namespace Ombi.Helpers
{ {
public class EmbyHelper public static class EmbyHelper
{ {
public static string GetEmbyMediaUrl(string mediaId, string serverId, string customerServerUrl = null, bool isJellyfin = false) public static string GetEmbyMediaUrl(string mediaId, string serverId, string customerServerUrl = null, bool isJellyfin = false)
{ {

@ -23,7 +23,9 @@ namespace Ombi.Store.Context.Sqlite
Database.ExecuteSqlRaw(@"INSERT OR IGNORE INTO __EFMigrationsHistory (MigrationId,ProductVersion) Database.ExecuteSqlRaw(@"INSERT OR IGNORE INTO __EFMigrationsHistory (MigrationId,ProductVersion)
VALUES('20191103205204_Inital', '2.2.6-servicing-10079'); "); VALUES('20191103205204_Inital', '2.2.6-servicing-10079'); ");
} }
#pragma warning disable RCS1075 // Avoid empty catch clause that catches System.Exception.
catch (Exception) catch (Exception)
#pragma warning restore RCS1075 // Avoid empty catch clause that catches System.Exception.
{ {
// ignored // ignored
} }

@ -1,76 +1,55 @@
<settings-menu></settings-menu> <settings-menu></settings-menu>
<div class="small-middle-container"> <div class="small-middle-container">
<fieldset *ngIf="settings"> Upgraded <fieldset *ngIf="settings">
<legend>The Movie Database</legend> <legend>The Movie Database</legend>
<div class="md-form-field" style="margin-top:1em;"> <div class="md-form-field" style="margin-top:1em;">
<div class="form-group"> <div class="form-group">
<div class="checkbox"> <div class="checkbox">
<mat-checkbox id="showAdultMovies" name="showAdultMovies" [(ngModel)]="settings.showAdultMovies" matTooltip="Include adult movies (pornography) in results"> <mat-slide-toggle id="showAdultMovies" name="showAdultMovies" [(ngModel)]="settings.showAdultMovies"
Show Adult Movies</mat-checkbox> matTooltip="Include adult movies (pornography) in results">
Show Adult Movies</mat-slide-toggle>
</div>
</div> </div>
</div>
<div class="form-group"> <div class="form-group">
<label class="control-label" matTooltip="Prevent movies with certain keywords from being suggested. May require a restart to take effect."> <form [formGroup]='tagForm'>
Excluded Keyword IDs for Movie Suggestions
</label> <mat-form-field class="example-full-width">
<form [formGroup]='tagForm'> <input type="text" placeholder="Excluded Keyword IDs for Movie Suggestions" matInput
<mat-form-field class="example-chip-list"> formControlName="input" [matAutocomplete]="auto"
<mat-chip-list #chipList> matTooltip="Prevent movies with certain keywords from being suggested. May require a restart to take effect.">
<mat-chip *ngFor="let fruit of excludedKeywords" [selectable]="false" <mat-autocomplete (optionSelected)="optionSelected($event.option.value)" autoActiveFirstOption
[removable]="true" (removed)="remove(fruit)"> #auto="matAutocomplete">
{{fruit.name}} <mat-option *ngFor="let option of filteredTags" [value]="option">
<mat-icon matChipRemove >cancel</mat-icon> {{option.name}}
</mat-chip> </mat-option>
<input placeholder="New Keyword" </mat-autocomplete>
#fruitInput </mat-form-field>
formControlName='input'
[matChipInputFor]="chipList" <mat-chip-list #chipList>
[matChipInputSeparatorKeyCodes]="separatorKeysCodes" <mat-chip *ngFor="let key of excludedKeywords" [selectable]="false" [removable]="true"
[matChipInputAddOnBlur]="true" (removed)="remove(key)">
> {{key.name}}
</mat-chip-list> <mat-icon matChipRemove>cancel</mat-icon>
<mat-autocomplete #auto="matAutocomplete" (optionSelected)="selected($event)"> </mat-chip>
<mat-option *ngFor="let fruit of filteredTags" [value]="fruit"> </mat-chip-list>
{{fruit.name}}
</mat-option> </form>
</mat-autocomplete> </div>
</mat-form-field>
</form>
<!-- <tag-input #input
[(ngModel)]="excludedKeywords"
[identifyBy]="'id'" [displayBy]="'name'"
[placeholder]="'Search by keyword'"
[secondaryPlaceholder]="'Search by keyword'"
[theme]="'dark'"
[onTextChangeDebounce]="500"
[onAdding]="onAddingKeyword"
(onSelect)="onKeywordSelect($event)">
<ng-template item-template let-item="item" let-index="index">
<span class="fa fa-cloud-download" *ngIf="item.initial"></span>
<span>{{item.id}}</span>
<span *ngIf="!item.initial">&nbsp;({{item.name}})</span>
<delete-icon aria-label="Remove tag" role="button"
(click)="input.removeItem(item, index)">
</delete-icon>
</ng-template>
<tag-input-dropdown [autocompleteObservable]="autocompleteKeyword"
[identifyBy]="'id'" [displayBy]="'name'"
[limitItemsTo]="6"
[minimumTextLength]="1"
[showDropdownIfEmpty]="false"
[keepOpen]="false">
</tag-input-dropdown>
</tag-input> -->
</div>
<div class="form-group"> <div class="form-group">
<div> <div>
<button mat-raised-button (click)="save()" type="submit" id="save" class="mat-focus-indicator mat-stroked-button accent mat-accent mat-raised-button mat-button-base" ng-reflect-disabled="false"> <button mat-raised-button (click)="save()" type="submit" id="save"
<span class="mat-button-wrapper">Submit</span><div matripple="" class="mat-ripple mat-button-ripple" ng-reflect-disabled="false" ng-reflect-centered="false" ng-reflect-trigger="[object HTMLButtonElement]"></div> class="mat-focus-indicator mat-stroked-button accent mat-accent mat-raised-button mat-button-base"
<div class="mat-button-focus-overlay"></div></button><div class="md-form-field" style="margin-top:1em;"></div> ng-reflect-disabled="false">
<span class="mat-button-wrapper">Submit</span>
<div matripple="" class="mat-ripple mat-button-ripple" ng-reflect-disabled="false"
ng-reflect-centered="false" ng-reflect-trigger="[object HTMLButtonElement]"></div>
<div class="mat-button-focus-overlay"></div>
</button>
<div class="md-form-field" style="margin-top:1em;"></div>
</div>
</div> </div>
</div> </div>
</div> </fieldset>
</fieldset>
</div> </div>

@ -1,15 +1,13 @@
import {COMMA, ENTER} from "@angular/cdk/keycodes"; import {COMMA, ENTER} from "@angular/cdk/keycodes";
import { Component, OnInit, ElementRef, ViewChild } from "@angular/core"; import { Component, OnInit, ElementRef, ViewChild } from "@angular/core";
import { MatChipInputEvent } from "@angular/material/chips"; import { MatAutocomplete } from "@angular/material/autocomplete";
import { MatAutocompleteSelectedEvent, MatAutocomplete } from "@angular/material/autocomplete";
import { empty, of, Observable } from "rxjs";
import { ITheMovieDbSettings, IMovieDbKeyword } from "../../interfaces"; import { ITheMovieDbSettings, IMovieDbKeyword } from "../../interfaces";
import { NotificationService } from "../../services"; import { NotificationService } from "../../services";
import { SettingsService } from "../../services"; import { SettingsService } from "../../services";
import { TheMovieDbService } from "../../services"; import { TheMovieDbService } from "../../services";
import { FormControl, FormBuilder, FormGroup } from "@angular/forms"; import { FormBuilder, FormGroup } from "@angular/forms";
import { startWith, map, debounceTime, tap, switchMap, finalize } from "rxjs/operators"; import { debounceTime, switchMap } from "rxjs/operators";
interface IKeywordTag { interface IKeywordTag {
id: number; id: number;
@ -28,9 +26,6 @@ export class TheMovieDbComponent implements OnInit {
public tagForm: FormGroup; public tagForm: FormGroup;
public filteredTags: IMovieDbKeyword[]; public filteredTags: IMovieDbKeyword[];
@ViewChild('fruitInput') public fruitInput: ElementRef<HTMLInputElement>; @ViewChild('fruitInput') public fruitInput: ElementRef<HTMLInputElement>;
@ViewChild('auto') public matAutocomplete: MatAutocomplete;
private readonly separatorKeysCodes: number[] = [ENTER, COMMA];
constructor(private settingsService: SettingsService, constructor(private settingsService: SettingsService,
private notificationService: NotificationService, private notificationService: NotificationService,
@ -50,6 +45,13 @@ export class TheMovieDbComponent implements OnInit {
initial: true, initial: true,
})) }))
: []; : [];
this.excludedKeywords.forEach(key => {
this.tmdbService.getKeyword(key.id).subscribe(keyResult => {
this.excludedKeywords.filter((val, idx) => {
val.name = keyResult.name;
})
});
});
}); });
this.tagForm this.tagForm
@ -64,61 +66,8 @@ export class TheMovieDbComponent implements OnInit {
) )
.subscribe((r) => (this.filteredTags = r)); .subscribe((r) => (this.filteredTags = r));
// this.tagForm.controls.input.valueChanges
// .pipe(
// debounceTime(500),
// switchMap(value => this.tmdbService.getKeywords(value))
// )
// .subscribe((data: IMovieDbKeyword[]) => {
// this.filteredTags = data;
// });
}
public async selected(event: MatAutocompleteSelectedEvent) {
const keywordId = await this.tmdbService.getKeyword(+event.option.value).toPromise();
this.excludedKeywords.push({ id: keywordId.id, name: keywordId.name, initial: false});
this.fruitInput.nativeElement.value = '';
this.tagForm.controls.input.setValue(null);
}
public autocompleteKeyword = (text: string) => this.tmdbService.getKeywords(text);
public onAddingKeyword = (tag: string | IKeywordTag) => {
if (typeof tag === "string") {
const id = Number(tag);
return isNaN(id) ? empty() : this.tmdbService.getKeyword(id);
} else {
return of(tag);
}
}
public onKeywordSelect = (keyword: IKeywordTag) => {
if (keyword.initial) {
this.tmdbService.getKeyword(keyword.id)
.subscribe(k => {
keyword.name = k.name;
keyword.initial = false;
});
}
} }
public async add(event: MatChipInputEvent) {
const input = event.input;
const value = event.value;
// Add our fruit
if ((value || '').trim()) {
const keyword = await this.tmdbService.getKeywords(value).toPromise();
this.excludedKeywords.push({ id: keyword[0].id, name: keyword[0].name, initial: false });
}
// Reset the input value
if (input) {
input.value = '';
}
this.tagForm.controls.input.setValue(null);
}
public remove(tag: IKeywordTag): void { public remove(tag: IKeywordTag): void {
const index = this.excludedKeywords.indexOf(tag); const index = this.excludedKeywords.indexOf(tag);
@ -137,4 +86,13 @@ export class TheMovieDbComponent implements OnInit {
} }
}); });
} }
public async optionSelected(item: IMovieDbKeyword) {
if ((item.name || '').trim()) {
this.excludedKeywords.push({ id: item.id, name: item.name, initial: false });
}
this.tagForm.controls.input.setValue(null);
}
} }

Loading…
Cancel
Save