1 import { Component, OnInit, TemplateRef, ViewChild } from '@angular/core';
2 import { UntypedFormControl, Validators } from '@angular/forms';
4 import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
5 import { Observable } from 'rxjs';
7 import { CdFormGroup } from '~/app/shared/forms/cd-form-group';
8 import { SubmitButtonComponent } from '../submit-button/submit-button.component';
11 selector: 'cd-deletion-modal',
12 templateUrl: './critical-confirmation-modal.component.html',
13 styleUrls: ['./critical-confirmation-modal.component.scss']
15 export class CriticalConfirmationModalComponent implements OnInit {
16 @ViewChild(SubmitButtonComponent, { static: true })
17 submitButton: SubmitButtonComponent;
18 bodyTemplate: TemplateRef<any>;
20 submitActionObservable: () => Observable<any>;
21 callBackAtionObservable: () => Observable<any>;
22 submitAction: Function;
24 deletionForm: CdFormGroup;
25 itemDescription: 'entry';
27 actionDescription = 'delete';
29 childFormGroup: CdFormGroup;
30 childFormGroupTemplate: TemplateRef<any>;
32 constructor(public activeModal: NgbActiveModal) {}
36 confirmation: new UntypedFormControl(false, [Validators.requiredTrue])
38 if (this.childFormGroup) {
39 controls['child'] = this.childFormGroup;
41 this.deletionForm = new CdFormGroup(controls);
42 if (!(this.submitAction || this.submitActionObservable)) {
43 throw new Error('No submit action defined');
48 if (this.submitActionObservable) {
49 this.submitActionObservable().subscribe({
50 error: this.stopLoadingSpinner.bind(this),
51 complete: this.hideModal.bind(this)
59 if (this.callBackAtionObservable) {
60 this.callBackAtionObservable().subscribe({
61 error: this.stopLoadingSpinner.bind(this),
62 complete: this.hideModal.bind(this)
70 this.activeModal.close();
73 stopLoadingSpinner() {
74 this.deletionForm.setErrors({ cdSubmitButton: true });