2017-07-15 12:47:11 +02:00
|
|
|
import {Component} from "@angular/core";
|
|
|
|
import {SettingsComponent} from "../_abstract/abstract.settings.component";
|
|
|
|
import {AuthenticationService} from "../../model/network/authentication.service";
|
|
|
|
import {NavigationService} from "../../model/navigation.service";
|
|
|
|
import {NotificationService} from "../../model/notification.service";
|
|
|
|
import {ThumbnailConfig, ThumbnailProcessingLib} from "../../../../common/config/private/IPrivateConfig";
|
|
|
|
import {ClientConfig} from "../../../../common/config/public/ConfigClass";
|
|
|
|
import {ThumbnailSettingsService} from "./thumbanil.settings.service";
|
|
|
|
import {Utils} from "../../../../common/Utils";
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'settings-thumbnail',
|
|
|
|
templateUrl: './thumbanil.settings.component.html',
|
|
|
|
styleUrls: ['./thumbanil.settings.component.css',
|
|
|
|
'./../_abstract/abstract.settings.component.css'],
|
|
|
|
providers: [ThumbnailSettingsService],
|
|
|
|
})
|
|
|
|
export class ThumbnailSettingsComponent extends SettingsComponent<{ server: ThumbnailConfig, client: ClientConfig.ThumbnailConfig }> {
|
|
|
|
types: Array<any> = [];
|
|
|
|
ThumbnailProcessingLib: any;
|
|
|
|
|
|
|
|
constructor(_authService: AuthenticationService,
|
|
|
|
_navigation: NavigationService,
|
2017-07-15 14:27:12 +02:00
|
|
|
_settingsService: ThumbnailSettingsService,
|
2017-07-15 12:47:11 +02:00
|
|
|
notification: NotificationService) {
|
2017-07-15 17:29:40 +02:00
|
|
|
super("Thumbnail", _authService, _navigation, _settingsService, notification, s => ({
|
|
|
|
client: s.Client.Thumbnail,
|
|
|
|
server: s.Server.thumbnail
|
|
|
|
}));
|
2017-07-15 12:47:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
get ThumbnailSizes(): string {
|
2017-07-15 17:29:40 +02:00
|
|
|
return this.settings.client.thumbnailSizes.join("; ");
|
2017-07-15 12:47:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
set ThumbnailSizes(value: string) {
|
|
|
|
value = value.replace(new RegExp(',', 'g'), ";");
|
|
|
|
value = value.replace(new RegExp(' ', 'g'), ";");
|
2017-07-15 17:29:40 +02:00
|
|
|
this.settings.client.thumbnailSizes = value.split(";").map(s => parseInt(s)).filter(i => !isNaN(i) && i > 0);
|
2017-07-15 12:47:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ngOnInit() {
|
|
|
|
super.ngOnInit();
|
|
|
|
this.types = Utils
|
|
|
|
.enumToArray(ThumbnailProcessingLib).map((v) => {
|
|
|
|
if (v.value.toLowerCase() == "sharp") {
|
|
|
|
v.value += " (recommended)";
|
|
|
|
}
|
|
|
|
return v;
|
|
|
|
});
|
|
|
|
this.ThumbnailProcessingLib = ThumbnailProcessingLib;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|