загруженные данные обновляются - PullRequest
0 голосов
/ 16 октября 2018

Я пытаюсь дать разрешение различным пользователям в зависимости от их ролей.Разрешения: выборка, добавление, удаление, редактирование и т. Д. .Когда я даю только определенное разрешение пользователю, как, например, если я даю только добавить и удалить для пользователя1, то при создании следующего пользователя и затем при предоставлении разрешения только добавить и удалить доступны, другие разрешения не доступны.Как мне решить это?Я хочу новый идентификатор группы для каждого разрешения роли.Я попытался написать код ниже, но, похоже, он не работает.

service.ts

add_permission(data){
var headers = new HttpHeaders().set('Authorization', 'Token ' + 
localStorage.getItem('usertoken'));

var options =  {
  headers: headers
};
return this.httpClient.post('/api/auth/permission_list/',data, 
options)
 }

component.ts

id :number;
dropdown_data:any = [];
checkedList = [];
permissionList:any = [];
perms:any = [];
permission_data:any = [];


onChange(email:string, checked: boolean) {
if(checked) {
this.perms.push(this.permission_data.permission_list)
} 
}

ngOnInit(): void{

//get permission 

  this.Authentication.get_permissions().subscribe(res =>{
    this.permissionList = res;
    console.log(res);

    for(let val of this.permissionList){ 
      this.dropdown_data = val.permission_list
      this.id = val.group_id
    }    
  })

}

//getting values of selected check box

onCheckboxChange(val, event) {
if(event.target.checked) {
this.checkedList.push(val);
console.log(this.checkedList);
} else {
for(var i=0 ; i < this.dropdown_data.length; i++) {
  if(this.checkedList[i] == val){
    this.checkedList.splice(i,1);
  }
}
}
}

// add permission

addPermission(){
let permissions = {};
permissions['group_id'] = this.id
permissions['permission_list']= this.checkedList;
console.log(permissions)

this.Authentication.add_permission(permissions).subscribe(res => {
  console.log('added')
},
err =>{
console.log('error');
})
} 

component.html

<div class="modal-body">
   <table class="table">
      <thead>
         <tr>
           <th scope="col">Permissions</th>
           <th scope="col">Select/Unselect</th>    
          </tr>
       </thead>
       <tbody *ngFor="let val of dropdown_data" >
          <tr>

            <td>{{val}}</td>
              <td><label class="container-1">
                <input type="checkbox"  value="{{val}}" (change)="onCheckboxChange(val,$event)" >
                <span class="checkmark"></span>
              </label></td>
              </tr>

            </tbody>
          </table>
          <button type="button"  class="btn btn-primary pull-right" (click)="addPermission()">Submit</button>
         </div>
...