mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
80 lines
2.3 KiB
TypeScript
80 lines
2.3 KiB
TypeScript
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 {BasicSettingsService} from './basic.settings.service';
|
|
import {BasicConfigDTO} from '../../../../common/entities/settings/BasicConfigDTO';
|
|
import {I18n} from '@ngx-translate/i18n-polyfill';
|
|
|
|
@Component({
|
|
selector: 'app-settings-basic',
|
|
templateUrl: './basic.settings.component.html',
|
|
styleUrls: ['./basic.settings.component.css',
|
|
'./../_abstract/abstract.settings.component.css'],
|
|
providers: [BasicSettingsService],
|
|
})
|
|
export class BasicSettingsComponent extends SettingsComponent<BasicConfigDTO> {
|
|
|
|
urlPlaceholder = location.origin;
|
|
urlBaseChanged = false;
|
|
urlError = false;
|
|
|
|
constructor(_authService: AuthenticationService,
|
|
_navigation: NavigationService,
|
|
_settingsService: BasicSettingsService,
|
|
notification: NotificationService,
|
|
i18n: I18n) {
|
|
super(i18n('Basic'), _authService, _navigation, _settingsService, notification, i18n, s => ({
|
|
port: s.Server.port,
|
|
imagesFolder: s.Server.imagesFolder,
|
|
applicationTitle: s.Client.applicationTitle,
|
|
publicUrl: s.Client.publicUrl,
|
|
urlBase: s.Client.urlBase
|
|
}));
|
|
this.checkUrlError();
|
|
}
|
|
|
|
public async save(): Promise<boolean> {
|
|
const val = await super.save();
|
|
if (val === true) {
|
|
this.notification.info(this.i18n('Restart the server to apply the new settings'));
|
|
}
|
|
return val;
|
|
}
|
|
|
|
calcBaseUrl(): string {
|
|
const url = this.settings.publicUrl.replace(new RegExp('\\\\', 'g'), '/')
|
|
.replace(new RegExp('http://', 'g'), '')
|
|
.replace(new RegExp('https://', 'g'), '');
|
|
if (url.indexOf('/') !== -1) {
|
|
return url.substring(url.indexOf('/'));
|
|
}
|
|
return '';
|
|
|
|
}
|
|
|
|
checkUrlError() {
|
|
this.urlError = this.settings.urlBase !== this.calcBaseUrl();
|
|
}
|
|
|
|
onUrlChanged() {
|
|
if (this.urlBaseChanged === false) {
|
|
this.settings.urlBase = this.calcBaseUrl();
|
|
} else {
|
|
this.checkUrlError();
|
|
}
|
|
|
|
}
|
|
|
|
onUrlBaseChanged() {
|
|
this.urlBaseChanged = true;
|
|
|
|
this.checkUrlError();
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|