2020-11-11 15:43:13 +01:00
|
|
|
import {Component} from '@angular/core';
|
2019-10-02 16:15:08 +02:00
|
|
|
import {ElementRef, Input} from '@angular/core';
|
|
|
|
import {ActivatedRoute, Router} from '@angular/router';
|
|
|
|
|
|
|
|
import {EnvProperties} from '../../../utils/properties/env-properties';
|
|
|
|
import {OrganizationInfo} from '../../../utils/entities/organizationInfo';
|
|
|
|
import {RouterHelper} from '../../../utils/routerHelper.class';
|
|
|
|
import {ErrorCodes} from '../../../utils/properties/errorCodes';
|
|
|
|
|
|
|
|
import {OrganizationsDeletedByInferenceService} from './deletedByInference.service';
|
2020-03-16 14:09:46 +01:00
|
|
|
import {ResultPreview} from "../../../utils/result-preview/result-preview";
|
|
|
|
import {AlertModal} from "../../../utils/modal/alert";
|
2020-11-11 15:43:13 +01:00
|
|
|
import {Subscriber} from "rxjs";
|
2020-11-18 17:06:27 +01:00
|
|
|
import {properties} from "../../../../../environments/environment";
|
2019-10-02 16:15:08 +02:00
|
|
|
|
|
|
|
@Component({
|
2020-03-16 14:09:46 +01:00
|
|
|
selector: 'organizationsDeletedByInference',
|
2019-10-02 16:15:08 +02:00
|
|
|
template: `
|
|
|
|
<errorMessages [status]="[status]" [type]="type" tab_error_class=true></errorMessages>
|
2020-03-16 14:09:46 +01:00
|
|
|
<no-load-paging *ngIf="results.length > pageSize" [type]="type"
|
|
|
|
(pageChange)="updatePage($event)"
|
|
|
|
[page]="page" [pageSize]="pageSize"
|
|
|
|
[totalResults]="results.length">
|
|
|
|
</no-load-paging>
|
|
|
|
<ul class="uk-list uk-list-divider uk-margin">
|
|
|
|
<li *ngFor="let result of results.slice((page-1)*pageSize, page*pageSize)">
|
2022-03-15 12:13:28 +01:00
|
|
|
<result-preview [modal]="modal" [properties]="properties" [hasLink]="false" [result]="getResultPreview(result)" [isCard]="false"></result-preview>
|
2020-03-16 14:09:46 +01:00
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
<no-load-paging *ngIf="results.length > pageSize" [type]="type"
|
|
|
|
(pageChange)="updatePage($event)"
|
|
|
|
[page]="page" [pageSize]="pageSize"
|
|
|
|
[totalResults]="results.length">
|
|
|
|
</no-load-paging>
|
2019-10-02 16:15:08 +02:00
|
|
|
`
|
|
|
|
})
|
|
|
|
export class OrganizationsDeletedByInferenceComponent {
|
|
|
|
public results: OrganizationInfo[] = [];
|
|
|
|
@Input() id: string;
|
|
|
|
@Input() ids: string[] = [];
|
|
|
|
@Input() type: string;
|
2020-03-16 14:09:46 +01:00
|
|
|
@Input() modal: AlertModal;
|
2019-10-02 16:15:08 +02:00
|
|
|
|
|
|
|
// Custom tab paging variables
|
|
|
|
public page: number = 1;
|
|
|
|
public pageSize: number = 5;
|
|
|
|
|
|
|
|
public status: number;
|
|
|
|
public routerHelper:RouterHelper = new RouterHelper();
|
|
|
|
public errorCodes:ErrorCodes = new ErrorCodes();
|
|
|
|
|
2020-11-11 15:43:13 +01:00
|
|
|
subscriptions = [];
|
2019-10-02 16:15:08 +02:00
|
|
|
properties:EnvProperties;
|
|
|
|
|
|
|
|
constructor ( private element: ElementRef,
|
|
|
|
private _deletedByInferenceService: OrganizationsDeletedByInferenceService,
|
2020-11-11 15:43:13 +01:00
|
|
|
private route: ActivatedRoute) {
|
2019-10-02 16:15:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ngOnInit() {
|
|
|
|
|
2020-11-18 17:06:27 +01:00
|
|
|
this.properties = properties;
|
|
|
|
|
2020-11-11 15:43:13 +01:00
|
|
|
this.subscriptions.push(this.route.queryParams.subscribe(data => {
|
2019-10-02 16:15:08 +02:00
|
|
|
this.errorCodes = new ErrorCodes();
|
|
|
|
this.status = this.errorCodes.LOADING;
|
|
|
|
|
|
|
|
this.getDeletedByInference();
|
2020-11-11 15:43:13 +01:00
|
|
|
}));
|
2019-10-02 16:15:08 +02:00
|
|
|
}
|
|
|
|
|
2020-11-11 15:43:13 +01:00
|
|
|
ngOnDestroy() {
|
|
|
|
this.subscriptions.forEach(subscription => {
|
|
|
|
if (subscription instanceof Subscriber) {
|
|
|
|
subscription.unsubscribe();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2019-10-02 16:15:08 +02:00
|
|
|
getDeletedByInference() {
|
|
|
|
this.results = [];
|
|
|
|
this.status = this.errorCodes.LOADING;
|
|
|
|
|
2020-11-11 15:43:13 +01:00
|
|
|
this.subscriptions.push(this._deletedByInferenceService.getDeletedByInferenceResults(this.id, String(this.ids.length), this.properties).subscribe(
|
2019-10-02 16:15:08 +02:00
|
|
|
data => {
|
|
|
|
this.results = data;
|
|
|
|
this.status = this.errorCodes.DONE;
|
|
|
|
},
|
|
|
|
error => {
|
|
|
|
if(error.status == '404') {
|
|
|
|
this.status = this.errorCodes.NOT_FOUND;
|
|
|
|
} else if(error.status == '500') {
|
|
|
|
this.status = this.errorCodes.ERROR;
|
|
|
|
} else {
|
|
|
|
this.status = this.errorCodes.NOT_AVAILABLE;
|
|
|
|
}
|
|
|
|
}
|
2020-11-11 15:43:13 +01:00
|
|
|
));
|
2019-10-02 16:15:08 +02:00
|
|
|
}
|
2020-03-16 14:09:46 +01:00
|
|
|
|
|
|
|
public getResultPreview(result: OrganizationInfo): ResultPreview {
|
|
|
|
return ResultPreview.organizationInfoConvert(result);
|
|
|
|
}
|
2019-10-02 16:15:08 +02:00
|
|
|
|
|
|
|
public totalPages(totalResults: number): number {
|
|
|
|
let totalPages:any = totalResults/this.pageSize;
|
|
|
|
if(!(Number.isInteger(totalPages))) {
|
|
|
|
totalPages = (parseInt(totalPages, this.pageSize) + 1);
|
|
|
|
}
|
|
|
|
return totalPages;
|
|
|
|
}
|
|
|
|
|
|
|
|
public updatePage($event) {
|
|
|
|
this.page = $event.value;
|
|
|
|
}
|
|
|
|
}
|