Skip to content
Snippets Groups Projects
datatable.component.ts 3.97 KiB
Newer Older
  • Learn to ignore specific revisions
  • Tifenn Guillas's avatar
    Tifenn Guillas committed
    import { Component, Input, ChangeDetectionStrategy, Output, EventEmitter, ViewEncapsulation, OnInit } from '@angular/core';
    
    François Agneray's avatar
    François Agneray committed
    
    
    import { SearchQueryParams } from '../../store/model';
    
    François Agneray's avatar
    François Agneray committed
    import { Attribute, Dataset } from 'src/app/metamodel/model';
    
    François Agneray's avatar
    François Agneray committed
    
    @Component({
        selector: 'app-datatable',
        templateUrl: 'datatable.component.html',
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        styleUrls: ['datatable.component.css'],
    
        changeDetection: ChangeDetectionStrategy.OnPush,
        encapsulation: ViewEncapsulation.None
    
    François Agneray's avatar
    François Agneray committed
    })
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
    export class DatatableComponent implements OnInit {
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        @Input() datasetName: string;
    
    François Agneray's avatar
    François Agneray committed
        @Input() datasetList: Dataset[];
    
        @Input() queryParams: SearchQueryParams;
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        @Input() datasetAttributeList: Attribute[];
    
        @Input() outputList: number[];
    
    François Agneray's avatar
    François Agneray committed
        @Input() searchData: any[];
    
        @Input() dataLength: number;
    
    François Agneray's avatar
    François Agneray committed
        @Input() selectedData: any[];
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        @Input() processWip: boolean;
        @Input() processDone: boolean;
        @Input() processId: string;
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        @Output() getSearchData: EventEmitter<[number, number, number, string]> = new EventEmitter();
    
    François Agneray's avatar
    François Agneray committed
        @Output() addSelectedData: EventEmitter<any> = new EventEmitter();
        @Output() deleteSelectedData: EventEmitter<any> = new EventEmitter();
    
        @Output() executeProcess: EventEmitter<string> = new EventEmitter();
    
        nbItems = 10;
        page = 1;
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        sortedCol: number = null;
        sortedOrder: string = null;
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        ngOnInit() {
            this.sortedCol = this.datasetAttributeList.find(a => a.search_flag === 'ID').id; 
            this.sortedOrder = 'a';
    
            this.getSearchData.emit([this.page, this.nbItems, this.sortedCol, this.sortedOrder]);
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        }
    
        getOutputList(): Attribute[] {
    
            return this.datasetAttributeList
                .filter(a => this.outputList.includes(a.id))
                .sort((a, b) => a.output_display - b.output_display);
        }
    
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        getDataset(): Dataset {
    
    François Agneray's avatar
    François Agneray committed
            return this.datasetList.find(dataset => dataset.name === this.datasetName);
        }
    
    
    François Agneray's avatar
    François Agneray committed
        getAttributeId(attributeName: string): number {
            const attribute = this.datasetAttributeList.find(a => a.name === attributeName);
            return attribute.id;
        }
    
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        getAttributeRenderer(attributeName: string): string {
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
            const attribute = this.datasetAttributeList.find(a => a.name === attributeName);
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
            return attribute.renderer;
        }
    
        getAttributeUriAction(attributeName: string, datum: string): string {
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
            const attribute = this.datasetAttributeList.find(a => a.name === attributeName);
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
            if (attribute.uri_action) {
                return attribute.uri_action + datum;
            } else {
                return datum;
            }
    
    François Agneray's avatar
    François Agneray committed
        toggleSelection(datum: any): void {
            const attribute = this.datasetAttributeList.find(a => a.search_flag === 'ID');
    
    
            const index = this.selectedData.indexOf(datum[attribute.label]);
    
            if (index > -1) {
    
                this.deleteSelectedData.emit(datum[attribute.label]);
    
            } else {
    
                this.addSelectedData.emit(datum[attribute.label]);
    
    François Agneray's avatar
    François Agneray committed
        isSelected(datum: any): boolean {
            const attribute = this.datasetAttributeList.find(a => a.search_flag === 'ID');
    
    
            if (this.selectedData.indexOf(datum[attribute.label]) > -1) {
    
                return true;
            }
            return false;
        }
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
        noSelectedData(): boolean {
    
    François Agneray's avatar
    François Agneray committed
            return this.selectedData.length < 1;
        }
    
        emitProcess(typeProcess: string): void {
    
            this.executeProcess.emit(typeProcess);
    
    
        changePage(nb: number): void {
            this.page = nb;
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
            this.getSearchData.emit([this.page, this.nbItems, this.sortedCol, this.sortedOrder]);
    
        } 
        changeNbItems(nb: number): void {
            this.nbItems = nb;
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
            this.getSearchData.emit([this.page, this.nbItems, this.sortedCol, this.sortedOrder]);
        }
    
        sort(id: number): void {
    
            if (id === this.sortedCol) {
                this.sortedOrder = this.sortedOrder === 'a' ? 'd' : 'a';
            } else {
                this.sortedCol = id;
                this.sortedOrder = 'a';
            }
            this.getSearchData.emit([this.page, this.nbItems, this.sortedCol, this.sortedOrder]);
    
    Tifenn Guillas's avatar
    Tifenn Guillas committed
    }