import { AuthServiceService } from './../../../shared/auth-service.service'; import { NgxSpinnerService } from 'ngx-spinner'; import { ActivatedRoute, Router, Params } from '@angular/router'; import { DashboardService } from './../../../shared/dashboard.service'; import { HttpClient } from '@angular/common/http'; import { Component, OnInit } from '@angular/core'; import { Modal } from 'ngx-modialog/plugins/bootstrap'; import { UserService } from '../../../shared/user.service'; import { ToastrService } from 'ngx-toastr'; @Component({ selector: 'app-definition-of-covenants-list', templateUrl: './definition-of-covenants-list.component.html', styleUrls: ['./definition-of-covenants-list.component.css'] }) export class DefinitionOfCovenantsListComponent implements OnInit { dataList = []; pages= []; pageId: number; Ids = []; count: number; perPagePagenation: number; currentPage:number = 1; filtterStatus = 'all'; selectedAll: any; userLoginId:number; serviceId:number; dataTableNumber: number = 5; absorpationListIds = []; dataListIds = []; constructor( private route: ActivatedRoute, private router: Router, private modal: Modal, private userSer: UserService, private spinner: NgxSpinnerService, public authSer: AuthServiceService, private toastr: ToastrService, private dashboardSer: DashboardService, private http: HttpClient ) { } ngOnInit() { //init the values of permision boolean this.authSer.showAddBtn = false; this.authSer.showDeleteBtn = false; this.authSer.showEditBtn = false; //show / hide notification search in header this.authSer.notificationLogin = true; this.authSer.showSearchHeader = false; this.authSer.showHeaderLogin = false; this.authSer.showHeaderDashBoard = true; this.authSer.showDashboardHeader = true; this.authSer.internalHeader = false; this.route.params.subscribe( (parmas: Params) => { this.pageId = +parmas['listPageId']; localStorage.setItem('pageIdActive', parmas['listPageId']); console.log(this.pageId); } ); this.route.parent.params.subscribe( (params:Params) => { this.userLoginId = params['userID']; this.serviceId = params['serviceID']; this.userSer.getPagesPermetiotns(this.userLoginId, this.serviceId).subscribe( (responce) => { console.log(responce); this.pages = responce['pages']; for(let i = 0; i< this.pages.length; i++) { if(this.pages[i].id == 64){ if(this.pages[i]['permissions'][0].name == 'covenants') { this.authSer.showAddBtn = true; this.authSer.showEditBtn = true; this.authSer.showDeleteBtn = true; } else { console.log('no permissions'); } } else { console.log('no events'); } } this.spinner.hide(); }, (error) => {console.log(error)} ); } ); console.log('current page',this.pageId) this.dashboardSer.getListData(this.pageId, this.currentPage ,this.dataTableNumber).subscribe( res => { console.log(res); this.dataList = res['covenants']; this.count = res['count']; this.perPagePagenation = res['per_page']; }, err => { console.log(err); } ); } //make all checkbox of user checked selectAll() { for (var i = 0; i < this.dataList.length; i++) { this.dataList[i].selected = this.selectedAll; } }; checkIfAllSelected() { this.selectedAll = this.dataList.every(function(item:any) { return item.selected == true; }); }; filtterFunc(data) { this.dataList =[]; this.absorpationListIds = []; console.log(data.target.value); const dataSearch = data.target.value; this.currentPage = 1; console.log('search curent page', this.currentPage); console.log('search page id', this.pageId); this.dashboardSer.getDataUSerSearchBar(dataSearch, this.pageId, this.currentPage, this.dataTableNumber).subscribe( res => { console.log(res); this.dataList = res['covenants']; console.log('hey',this.dataList) this.count = res['count']; this.perPagePagenation = res['per_page']; console.log('filtter count', this.count); console.log('filtter perPagePAgenation', this.perPagePagenation); }, err => { console.log(err); } ); }; onPageChange(pagenationNumber) { this.spinner.show(); this.currentPage = pagenationNumber; this.absorpationListIds = []; console.log(pagenationNumber); console.log(this.pageId); this.dashboardSer.getListData(this.pageId, pagenationNumber, this.dataTableNumber).subscribe( res => { console.log(res); this.dataList = res['covenants']; this.count = res['count']; this.perPagePagenation = res['per_page']; console.log('FFFFFF', this.absorpationListIds); this.spinner.hide(); }, err => { console.log(err); this.spinner.hide(); } ); } //determine the list count from select element onGetValue(event) { this.spinner.show(); this.absorpationListIds = []; this.dataTableNumber = event.target.value; this.dashboardSer.getListData(this.pageId, this.currentPage, this.dataTableNumber).subscribe( res => { console.log(res); this.absorpationListIds = res['covenants']; this.count = res['count']; this.perPagePagenation = res['per_page']; this.spinner.hide(); }, err => { console.log(err); this.spinner.hide(); } ); }; onGetValueFiltter(event) { console.log(event.target.value) this.spinner.show(); this.dataList = []; const typeId = event.target.value; this.filtterStatus = event.target.value; console.log(this.filtterStatus); this.http.get(this.authSer.pathApi +'/page_list/' + this.pageId + '/' + this.currentPage + '/' + this.dataTableNumber + '/' + typeId).subscribe( res => { console.log(res); this.dataList = res['covenants']; this.count = res['count']; this.perPagePagenation = res['per_page']; this.spinner.hide(); console.log('UrL>>', this.authSer.pathApi +'/page_list/' + this.pageId + '/' + this.currentPage + '/' + this.dataTableNumber + '/' + typeId) }, err=> { console.log(err); } ); } onDelete() { this.dataListIds = []; for(let i = 0; i < this.dataList.length; i++) { if(this.dataList[i].selected == true) { this.dataListIds.push(this.dataList[i].id); } } console.log(this.dataListIds); if(this.dataListIds.length > 0) { const dialogRef = this.modal.alert() .size('sm') .showClose(true) .title('تأكيد الحذف') .body(`