mirror of https://github.com/Ombi-app/Ombi
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
102 lines
3.9 KiB
102 lines
3.9 KiB
import { Component, OnInit } from "@angular/core";
|
|
import { FormBuilder, FormGroup, Validators } from "@angular/forms";
|
|
|
|
import { IEmailNotificationSettings, INotificationTemplates, NotificationType } from "../../interfaces";
|
|
import { TesterService } from "../../services";
|
|
import { ValidationService } from "../../services";
|
|
import { NotificationService } from "../../services";
|
|
import { SettingsService } from "../../services";
|
|
|
|
@Component({
|
|
templateUrl: "./emailnotification.component.html",
|
|
styleUrls: ["./notificationtemplate.component.scss"]
|
|
})
|
|
export class EmailNotificationComponent implements OnInit {
|
|
public NotificationType = NotificationType;
|
|
public templates: INotificationTemplates[];
|
|
public emailForm: FormGroup;
|
|
|
|
constructor(private settingsService: SettingsService,
|
|
private notificationService: NotificationService,
|
|
private fb: FormBuilder,
|
|
private validationService: ValidationService,
|
|
private testerService: TesterService) { }
|
|
|
|
public ngOnInit() {
|
|
this.settingsService.getEmailNotificationSettings().subscribe(x => {
|
|
this.templates = x.notificationTemplates;
|
|
|
|
this.emailForm = this.fb.group({
|
|
enabled: [x.enabled],
|
|
authentication: [x.authentication],
|
|
host: [x.host, [Validators.required]],
|
|
password: [x.password],
|
|
port: [x.port, [Validators.required]],
|
|
senderAddress: [x.senderAddress, [Validators.required, Validators.email]],
|
|
senderName: [x.senderName],
|
|
username: [x.username],
|
|
adminEmail: [x.adminEmail, [Validators.required, Validators.email]],
|
|
disableTLS: [x.disableTLS],
|
|
disableCertificateChecking: [x.disableCertificateChecking],
|
|
});
|
|
|
|
if (x.authentication) {
|
|
this.validationService.enableValidation(this.emailForm, "username");
|
|
this.validationService.enableValidation(this.emailForm, "password");
|
|
}
|
|
|
|
this.subscribeToAuthChanges();
|
|
});
|
|
}
|
|
|
|
public onSubmit(form: FormGroup) {
|
|
if (form.invalid) {
|
|
this.notificationService.error("Please check your entered values");
|
|
return;
|
|
}
|
|
|
|
const settings = <IEmailNotificationSettings> form.value;
|
|
settings.notificationTemplates = this.templates;
|
|
|
|
this.settingsService.saveEmailNotificationSettings(settings).subscribe(x => {
|
|
if (x) {
|
|
this.notificationService.success("Successfully saved Email settings");
|
|
} else {
|
|
this.notificationService.success("There was an error when saving the Email settings");
|
|
}
|
|
});
|
|
|
|
}
|
|
|
|
public test(form: FormGroup) {
|
|
if (form.invalid) {
|
|
this.notificationService.error("Please check your entered values");
|
|
return;
|
|
}
|
|
|
|
this.testerService.emailTest(form.value).subscribe(x => {
|
|
if (x === true) {
|
|
this.notificationService.success("Successfully sent an email message, please check your inbox");
|
|
} else {
|
|
this.notificationService.error("There was an error when sending the Email message, please check your settings.");
|
|
}
|
|
});
|
|
}
|
|
|
|
private subscribeToAuthChanges() {
|
|
const authCtrl = this.emailForm.controls.authentication;
|
|
const changes$ = authCtrl.valueChanges;
|
|
|
|
changes$.subscribe((auth: boolean) => {
|
|
|
|
if (auth) {
|
|
this.validationService.enableValidation(this.emailForm, "username");
|
|
this.validationService.enableValidation(this.emailForm, "password");
|
|
} else {
|
|
this.validationService.disableValidation(this.emailForm, "username");
|
|
this.validationService.disableValidation(this.emailForm, "password");
|
|
}
|
|
});
|
|
}
|
|
}
|