1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/frontend/app/ui/settings/_abstract/abstract.settings.component.ts

157 lines
4.5 KiB
TypeScript
Raw Normal View History

2018-03-30 15:30:30 -04:00
import {Input, OnChanges, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';
import {AuthenticationService} from '../../../model/network/authentication.service';
import {UserRoles} from '../../../../../common/entities/UserDTO';
import {Utils} from '../../../../../common/Utils';
import {ErrorDTO} from '../../../../../common/entities/Error';
import {NotificationService} from '../../../model/notification.service';
import {NavigationService} from '../../../model/navigation.service';
2018-03-30 15:30:30 -04:00
import {AbstractSettingsService} from './abstract.settings.service';
import {IPrivateConfig} from '../../../../../common/config/private/IPrivateConfig';
2018-03-30 15:30:30 -04:00
import {I18n} from '@ngx-translate/i18n-polyfill';
2018-11-28 23:49:33 +01:00
import {Subscription} from 'rxjs';
2017-07-13 23:39:09 +02:00
2018-11-28 23:49:33 +01:00
export abstract class SettingsComponent<T extends { [key: string]: any }, S extends AbstractSettingsService<T> = AbstractSettingsService<T>>
2017-07-28 00:04:19 +02:00
implements OnInit, OnDestroy, OnChanges {
2017-07-15 17:29:40 +02:00
@Input()
2018-05-03 18:23:48 -04:00
public simplifiedMode = true;
2017-07-15 17:29:40 +02:00
@ViewChild('settingsForm')
form: HTMLFormElement;
@Output()
2018-05-03 18:23:48 -04:00
hasAvailableSettings = true;
2017-07-13 23:39:09 +02:00
public inProgress = false;
public error: string = null;
2018-05-03 18:23:48 -04:00
public changed = false;
2018-11-28 23:49:33 +01:00
private _subscription: Subscription = null;
private readonly _settingsSubscription: Subscription = null;
2017-07-13 23:39:09 +02:00
2017-07-15 17:29:40 +02:00
public settings: T = <any>{};
public original: T = <any>{};
2018-03-29 20:30:23 -04:00
text = {
2018-03-30 15:30:30 -04:00
Enabled: 'Enabled',
Disabled: 'Disabled',
Low: 'Low',
High: 'High'
2018-03-29 20:30:23 -04:00
};
2018-11-28 23:49:33 +01:00
protected constructor(private name: string,
private _authService: AuthenticationService,
private _navigation: NavigationService,
public _settingsService: S,
protected notification: NotificationService,
public i18n: I18n,
private sliceFN?: (s: IPrivateConfig) => T) {
2017-07-25 21:09:37 +02:00
if (this.sliceFN) {
2017-07-27 23:10:16 +02:00
this._settingsSubscription = this._settingsService.Settings.subscribe(this.onNewSettings);
2017-07-25 21:09:37 +02:00
this.onNewSettings(this._settingsService._settingsService.settings.value);
}
2018-03-30 15:30:30 -04:00
this.text.Enabled = i18n('Enabled');
this.text.Disabled = i18n('Disabled');
this.text.Low = i18n('Low');
this.text.High = i18n('High');
2017-07-13 23:39:09 +02:00
}
2018-11-28 23:49:33 +01:00
onNewSettings = (s: IPrivateConfig) => {
2017-07-15 17:29:40 +02:00
this.settings = Utils.clone(this.sliceFN(s));
this.original = Utils.clone(this.settings);
this.ngOnChanges();
};
settingsSame(newSettings: T, original: T): boolean {
if (typeof original !== 'object' || original == null) {
return newSettings === original;
}
if (!newSettings) {
return false;
}
const keys = Object.keys(newSettings);
for (let i = 0; i < keys.length; i++) {
const key = keys[i];
if (typeof original[key] === 'undefined') {
throw new Error('unknown settings: ' + key);
}
if (typeof original[key] === 'object') {
if (this.settingsSame(newSettings[key], original[key]) === false) {
return false;
}
} else if (newSettings[key] !== original[key]) {
return false;
}
}
return true;
}
2017-07-13 23:39:09 +02:00
ngOnInit() {
if (!this._authService.isAuthenticated() ||
this._authService.user.value.role < UserRoles.Admin) {
this._navigation.toLogin();
return;
}
this.getSettings();
// TODO: fix after this issue is fixed: https://github.com/angular/angular/issues/24818
this._subscription = this.form.valueChanges.subscribe(() => {
setTimeout(() => {
this.changed = !this.settingsSame(this.settings, this.original);
}, 0);
2017-07-13 23:39:09 +02:00
});
2017-07-15 17:29:40 +02:00
}
ngOnChanges(): void {
2018-10-23 00:33:17 +02:00
this.hasAvailableSettings = ((this._settingsService.isSupported() &&
this._settingsService.showInSimplifiedMode())
|| !this.simplifiedMode);
2017-07-13 23:39:09 +02:00
}
2017-07-15 17:29:40 +02:00
2017-07-13 23:39:09 +02:00
ngOnDestroy() {
2017-07-27 23:10:16 +02:00
if (this._subscription != null) {
this._subscription.unsubscribe();
2017-07-13 23:39:09 +02:00
}
2017-07-27 23:10:16 +02:00
if (this._settingsSubscription != null) {
this._settingsSubscription.unsubscribe();
2017-07-19 22:40:27 +02:00
}
2017-07-13 23:39:09 +02:00
}
private async getSettings() {
2017-07-15 14:27:12 +02:00
await this._settingsService.getSettings();
2017-07-13 23:39:09 +02:00
this.changed = false;
}
public reset() {
this.getSettings();
}
2017-07-15 12:47:11 +02:00
public async save() {
2017-07-13 23:39:09 +02:00
this.inProgress = true;
2018-03-30 15:30:30 -04:00
this.error = '';
2017-07-13 23:39:09 +02:00
try {
2017-07-15 17:29:40 +02:00
await this._settingsService.updateSettings(this.settings);
2017-07-15 12:47:11 +02:00
await this.getSettings();
2018-11-18 20:26:29 +01:00
this.notification.success(this.name + ' ' + this.i18n('settings saved'), this.i18n('Success'));
2017-07-15 16:31:43 +02:00
this.inProgress = false;
return true;
2017-07-13 23:39:09 +02:00
} catch (err) {
console.log(err);
if (err.message) {
2017-07-15 12:47:11 +02:00
this.error = (<ErrorDTO>err).message;
2017-07-13 23:39:09 +02:00
}
}
2017-07-15 16:31:43 +02:00
this.inProgress = false;
return false;
2017-07-13 23:39:09 +02:00
}
}