Получение ошибки Открытие неопределенного при открытии модального - PullRequest
0 голосов
/ 04 мая 2018

В моем проекте я открываю один диалог подтверждения удаления записи. Для этого я делаю один общий компонент, который можно легко использовать в любом месте проекта.

Я проверяю все ссылки из переполнения стека и многие другие, но не получил никакой помощи.

Вот мой код. (Весь необходимый импорт выполнен)

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();
            }
        }
    }
...