В моем проекте я открываю один диалог подтверждения удаления записи. Для этого я делаю один общий компонент, который можно легко использовать в любом месте проекта.
Я проверяю все ссылки из переполнения стека и многие другие, но не получил никакой помощи.
Вот мой код. (Весь необходимый импорт выполнен)
Confirmation.component.ts
@Injectable()
export class Confirmation {
constructor(public sharedResource: Shared) {
this.sharedData = sharedResource.SharedComponent;
this.sharedData.deleteConfirmation = this;
}
@ViewChild('deleteConfirmationModal') public modal: Ng2Bs3ModalModule;
@Output() OnConfirmClicked = new EventEmitter();
public sharedData: SharedModel;
public title: string = "Action Required";
public confirmationText: string = "";
public confirmationHeader: string = "Remove";
public icon: string = 'create-account-icon.png';
public isShowOnlyAlert: boolean = false;
inputValue: any;
parentComponent: any = null;
callBackMethodName: string = 'Remove';
public isShowDiffMsg: boolean = false;
public Open(name: any, parentComponent: any, methodName: string, item: any = null, headername: any = null, isObjectComparision: any = false, isShowOnlyAlert: any = false): void {
this.inputValue = item;
this.parentComponent = parentComponent;
this.callBackMethodName = methodName;
this.isShowOnlyAlert = isShowOnlyAlert;
if (isObjectComparision) {
this.icon = 'ic-alert.png';
this.confirmationText = name;
this.confirmationHeader = headername;
}
else {
this.icon = 'create-account-icon.png';
this.confirmationHeader = 'Remove';
this.confirmationText = "Do you really want to delete " + name + "?";
}
this.sharedResource.GoToNextModal(this.modal);
}
public OnConfirm(): void {
try {
if (this.parentComponent != null) {
this.parentComponent[this.callBackMethodName](this.inputValue);
}
else {
this.OnConfirmClicked.emit(this.inputValue);
}
}
catch (e) {
console.log((<Error>e).message);
}
}
public Close(): void {
this.OnConfirmClicked.emit(this.inputValue);
}
}
Confirmation.component.html
<modal data-backdrop="static" #deleteConfirmationModal id="deleteConfirmationModal" [size]="'sm'" tabindex="-1">
<modal-header [show-close]="true">
<h5 class="modal-title pl35">
<img src="images/{{icon}}" alt="" />
{{confirmationHeader}}
</h5>
<ul>
<li><a href="javascript:;" title="Close" data-dismiss="modal"><img src="images/modal-close.png" alt=""></a></li>
</ul>
</modal-header>
<modal-body>
<p class="line-breaker">{{confirmationText}}</p>
</modal-body>
<modal-footer>
<div *ngIf="!isShowOnlyAlert">
<button id="btnYes" type="button" class="btn btn-primary" (click)="OnConfirm()">Yes</button>
<button id="btnNo" type="button" class="btn btn-default" (click)="Close()">No</button>
</div>
<div *ngIf="isShowOnlyAlert">
<button id="btnOk" type="button" class="btn btn-primary" data-dismiss="modal">Ok</button>
</div>
</modal-footer>
</modal>
В моем компоненте, где я хочу использовать этот диалог подтверждения
lookupEntry.component.ts
export class LookupMasterComponent implements OnInit {
constructor(public sharedResource: Shared,public frameworkService: FrameworkServices) {
this.sharedData = sharedResource.SharedComponent;
}
public OnActionClicked(action) {
if (action.actionName === 'Edit') {
this.lookup = action.row;
this.addLookupComponent.EditLookup(this.lookup);
} else if (action.actionName === 'Delete') {
this.id_deleteLookup = action.row.LookupDetailID;
this.lookupName = action.row.Name;
this.sharedData.deleteConfirmation.Open("Are you sure you want to delete '" + this.lookupName + "'? <br /> All releated data to '" + this.lookupName + "' will permanently removed.", this, "DeleteLookupDetail", toolbar, "Confirmation", true)
}
}
public DeleteLookupDetail() {
console.log(this.id_deleteLookup);
this.frameworkService.DeleteLookupDetail(this.id_deleteLookup).subscribe((data: any) => {
// console.log(data);
// this.deleteLookupModal.close();
this.GetLookupDetails();
});
}
}
Я получаю ошибку открытия null / undefined.
shared.ts
import { Injectable } from "@angular/core";
import { Confirmation } from "../confirmation/confirmation.component";
export interface SharedModel {
templateData: any;
templateType: any;
deleteConfirmation: Confirmation;
loaderDivId: string;
EditorList: any;
}
@Injectable()
export class Shared {
SharedComponent: SharedModel = {
templateData: [],
templateType: [],
loaderDivId: 'dynamicTabs',
EditorList: [],
deleteConfirmation: null,
};
constructor() {
}
GoToNextModal(modal: any) {
this.SharedComponent.loaderDivId = modal.element.nativeElement.id;
if (this.SharedComponent.EditorList.length > 0) {
this.SharedComponent.EditorList[this.SharedComponent.EditorList.length - 1].close();
this.SharedComponent.EditorList.push(modal);
this.SharedComponent.EditorList[this.SharedComponent.EditorList.length - 1].open();
}
else {
this.SharedComponent.EditorList.push(modal);
modal.open();
}
}
}