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';
25 actionDescription = 'delete';
27 constructor(public modalRef: BsModalRef) {}
30 this.deletionForm = new CdFormGroup({
31 confirmation: new FormControl(false, [Validators.requiredTrue])
34 if (!(this.submitAction || this.submitActionObservable)) {
35 throw new Error('No submit action defined');
40 if (this.submitActionObservable) {
41 this.submitActionObservable().subscribe(
43 this.stopLoadingSpinner.bind(this),
44 this.hideModal.bind(this)
55 stopLoadingSpinner() {
56 this.deletionForm.setErrors({ cdSubmitButton: true });