1
0
mirror of https://github.com/bpatrik/pigallery2.git synced 2024-12-16 11:37:13 +02:00
pigallery2/frontend/app/settings/thumbnail/thumbanil.settings.component.ts

60 lines
2.2 KiB
TypeScript
Raw Normal View History

2018-03-30 21:30:30 +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';
import {I18n} from '@ngx-translate/i18n-polyfill';
2017-07-15 12:47:11 +02:00
@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,
2018-03-30 02:30:23 +02:00
notification: NotificationService,
i18n: I18n) {
2018-03-30 21:30:30 +02:00
super(i18n('Thumbnail'), _authService, _navigation, _settingsService, notification, i18n, s => ({
2017-07-15 17:29:40 +02:00
client: s.Client.Thumbnail,
server: s.Server.thumbnail
}));
2017-07-15 12:47:11 +02:00
}
get ThumbnailSizes(): string {
2018-03-30 21:30:30 +02:00
return this.settings.client.thumbnailSizes.join('; ');
2017-07-15 12:47:11 +02:00
}
set ThumbnailSizes(value: string) {
2018-03-30 21:30:30 +02:00
value = value.replace(new RegExp(',', 'g'), ';');
value = value.replace(new RegExp(' ', 'g'), ';');
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) => {
2018-03-30 21:30:30 +02:00
if (v.value.toLowerCase() == 'sharp') {
v.value += ' ' + this.i18n('(recommended)');
2017-07-15 12:47:11 +02:00
}
return v;
});
this.ThumbnailProcessingLib = ThumbnailProcessingLib;
}
}