1 import { Component, OnInit, TemplateRef, ViewChild } from '@angular/core';
2 import { FormControl, Validators } from '@angular/forms';
4 import { BsModalRef } from 'ngx-bootstrap/modal';
5 import { Observable } from 'rxjs';
7 import { CdFormGroup } from '../../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)
17 submitButton: SubmitButtonComponent;
18 bodyTemplate: TemplateRef<any>;
20 submitActionObservable: () => Observable<any>;
21 submitAction: Function;
22 deletionForm: CdFormGroup;
23 itemDescription: 'entry';
24 actionDescription = 'delete';
26 constructor(public modalRef: BsModalRef) {}
29 this.deletionForm = new CdFormGroup({
30 confirmation: new FormControl(false, [Validators.requiredTrue])
33 if (!(this.submitAction || this.submitActionObservable)) {
34 throw new Error('No submit action defined');
39 if (this.submitActionObservable) {
40 this.submitActionObservable().subscribe(
42 this.stopLoadingSpinner.bind(this),
43 this.hideModal.bind(this)
54 stopLoadingSpinner() {
55 this.deletionForm.setErrors({ cdSubmitButton: true });