Я пытаюсь вызвать один API-интерфейс ReST, когда у меня установлен флажок в форме. Когда я вызываю метод для вызова api, я получаю сообщение об ошибке:
Cannot set property 'nUserId' of undefined at
Мой html файл содержит следующий код,
<div>
<button mat-raised-button color="primary" (click)="getUserPermisionsByUsernameSearch()">
Search</button>
</div>
<br /> <br><br />
<div *ngIf="userPermissionObj">
<div><label for="pl">Permission Level:</label> {{userPermissionObj.sPermLevel}} </div>
<label for="pm">Permissions:</label>
<div *ngFor="let pt of permissionType">
<label>
<input type="checkbox" [value]="pt.id" [checked]="userPermissionObj.sPermissionType == pt.name ? true : false"
(change)="updateUserPermisionsByUsername(userPermissionObj,pt)" />
{{pt.name}} -- {{userPermissionObj.nUserId}}
</label>
И мой ts файл содержит следующий код ,
export class ModifyuserpermissionsComponent implements OnInit {
selectedUser: string;
selectedInstitution: string;
filtertext: string;
public status: boolean = false;
public data = new Array();
institutionalUsers: any;
userNameDetails: any;
userPermissionObj: any;
permissionRequestUser: any;
modificationObj: any;
userObj: any;
permision: any;
dataSource = new MatTableDataSource();
selection = new SelectionModel<Element>(true, []);
displayedColumns = ['UserId', 'PermissionId', 'PermissionLevel', 'PermissionType'];
constructor(public dialog: MatDialog,
public manageuserService: ManageuserService) { }
ngOnInit() {
this.manageuserService.loadUserListApiMethod()
.subscribe((data: any) => { this.institutionalUsers = data });
}
loadUserForSearchPermission(event: any, obj: any) {
if (event.isUserInput) {
this.permissionRequestUser = obj.sUsername;
}
}
permissionType = [
{ id: 1, name: 'R' },
{ id: 2, name: 'W' }
];
getUserPermisionsByUsernameSearch() {
var param: string = this.permissionRequestUser;
this.manageuserService.getUserPermissionApiMethod(param)
.subscribe((data: any) => { this.userPermissionObj = data });
}
updateUserPermisionsByUsername(userObj, permision) {
this.modificationObj.nUserId = userObj.nUserId;
this.modificationObj.name = permision.name;
this.manageuserService.modifyUserPermissionApiMethod(this.userObj)
.subscribe((data: any) => { this.institutionalUsers = data });
}
}
Может ли кто-нибудь помочь найти мою неправильную реализацию здесь, пожалуйста?