@gipisistemas/ng-core 1.1.1 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/gipisistemas-ng-core.umd.js +115 -54
 - package/bundles/gipisistemas-ng-core.umd.js.map +1 -1
 - package/bundles/gipisistemas-ng-core.umd.min.js +3 -3
 - package/bundles/gipisistemas-ng-core.umd.min.js.map +1 -1
 - package/esm2015/shared/components/table/table.component.js +102 -40
 - package/esm2015/shared/gipi-components/input-monthpicker/input-monthpicker.component.js +1 -1
 - package/esm2015/shared/gipi-components/month-year-picker/month-year-picker.component.js +1 -1
 - package/esm5/shared/components/table/table.component.js +115 -54
 - package/esm5/shared/gipi-components/input-monthpicker/input-monthpicker.component.js +1 -1
 - package/esm5/shared/gipi-components/month-year-picker/month-year-picker.component.js +1 -1
 - package/fesm2015/gipisistemas-ng-core.js +102 -40
 - package/fesm2015/gipisistemas-ng-core.js.map +1 -1
 - package/fesm5/gipisistemas-ng-core.js +115 -54
 - package/fesm5/gipisistemas-ng-core.js.map +1 -1
 - package/gipisistemas-ng-core.metadata.json +1 -1
 - package/package.json +1 -1
 - package/shared/components/table/table.component.d.ts +60 -9
 
| 
         @@ -1,14 +1,15 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            import { __decorate, __metadata } from "tslib";
         
     | 
| 
       2 
2 
     | 
    
         
             
            import { animate, state, style, transition, trigger } from '@angular/animations';
         
     | 
| 
       3 
     | 
    
         
            -
            import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef, ViewChild } from '@angular/core';
         
     | 
| 
      
 3 
     | 
    
         
            +
            import { AfterViewInit, Component, ContentChild, EventEmitter, Input, NgZone, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';
         
     | 
| 
       4 
4 
     | 
    
         
             
            import { MatPaginator, MatSort, MatTableDataSource } from '@angular/material';
         
     | 
| 
       5 
5 
     | 
    
         
             
            import { of } from 'rxjs';
         
     | 
| 
       6 
6 
     | 
    
         
             
            import { delay } from 'rxjs/operators';
         
     | 
| 
       7 
7 
     | 
    
         
             
            import { ArrayUtil, ObjectUtil, StringUtil } from '../../../core';
         
     | 
| 
       8 
8 
     | 
    
         
             
            import { TableGroupHeaderDTO } from '../../../core/models/dto/table-group-header.dto';
         
     | 
| 
       9 
9 
     | 
    
         
             
            let TableComponent = class TableComponent {
         
     | 
| 
       10 
     | 
    
         
            -
                constructor() {
         
     | 
| 
       11 
     | 
    
         
            -
                    this. 
     | 
| 
      
 10 
     | 
    
         
            +
                constructor(_ngZone) {
         
     | 
| 
      
 11 
     | 
    
         
            +
                    this._ngZone = _ngZone;
         
     | 
| 
      
 12 
     | 
    
         
            +
                    this._expandedRows = [];
         
     | 
| 
       12 
13 
     | 
    
         
             
                    this._scrollHeightCalc = 410;
         
     | 
| 
       13 
14 
     | 
    
         
             
                    this._isPopoverHover = null;
         
     | 
| 
       14 
15 
     | 
    
         
             
                    this._displayedColumns = [];
         
     | 
| 
         @@ -34,10 +35,11 @@ let TableComponent = class TableComponent { 
     | 
|
| 
       34 
35 
     | 
    
         
             
                    this.showColumnExpandableFixed = false;
         
     | 
| 
       35 
36 
     | 
    
         
             
                    this.expandableOneRow = false;
         
     | 
| 
       36 
37 
     | 
    
         
             
                    this.ignoreChildrenExpandRow = false;
         
     | 
| 
      
 38 
     | 
    
         
            +
                    this.sort = true;
         
     | 
| 
       37 
39 
     | 
    
         
             
                    this.clearSort = false;
         
     | 
| 
       38 
40 
     | 
    
         
             
                    this.sortActive = '';
         
     | 
| 
       39 
41 
     | 
    
         
             
                    this.sortDirection = 'asc';
         
     | 
| 
       40 
     | 
    
         
            -
                    this. 
     | 
| 
      
 42 
     | 
    
         
            +
                    this.rowExpanded = new EventEmitter();
         
     | 
| 
       41 
43 
     | 
    
         
             
                    this.dataChange = new EventEmitter(true);
         
     | 
| 
       42 
44 
     | 
    
         
             
                    this.page = new EventEmitter();
         
     | 
| 
       43 
45 
     | 
    
         
             
                    this.rowHover = new EventEmitter();
         
     | 
| 
         @@ -147,9 +149,9 @@ let TableComponent = class TableComponent { 
     | 
|
| 
       147 
149 
     | 
    
         
             
                    if (this.paginator && !this.backendPagination) {
         
     | 
| 
       148 
150 
     | 
    
         
             
                        this._dataSource.paginator = this.matFrontendPaginator;
         
     | 
| 
       149 
151 
     | 
    
         
             
                    }
         
     | 
| 
       150 
     | 
    
         
            -
                    if (!this.groupStartExpanded && (this.groupHeaderRef || (this.expandable && this.expandedRef)) && !ArrayUtil.isEmpty(this._dataSource.data)) {
         
     | 
| 
       151 
     | 
    
         
            -
             
     | 
| 
       152 
     | 
    
         
            -
                    }
         
     | 
| 
      
 152 
     | 
    
         
            +
                    // if (!this.groupStartExpanded && (this.groupHeaderRef || (this.expandable && this.expandedRef)) && !ArrayUtil.isEmpty(this._dataSource.data)) {
         
     | 
| 
      
 153 
     | 
    
         
            +
                    // this._dataSource.data.forEach(row => this.addCollapse(row));
         
     | 
| 
      
 154 
     | 
    
         
            +
                    // }
         
     | 
| 
       153 
155 
     | 
    
         
             
                }
         
     | 
| 
       154 
156 
     | 
    
         
             
                calcScrollHeight() {
         
     | 
| 
       155 
157 
     | 
    
         
             
                    if ((this._dataSource && (this._dataSource.data.length > 0)) && (Math.floor(this._scrollHeightCalc) <= 700)) {
         
     | 
| 
         @@ -161,25 +163,24 @@ let TableComponent = class TableComponent { 
     | 
|
| 
       161 
163 
     | 
    
         
             
                    pageEvent.paginatorPageSizeOptions = ArrayUtil.isEmpty(pageEvent.paginatorPageSizeOptions) ? this.paginatorPageSizeOptions : pageEvent.paginatorPageSizeOptions;
         
     | 
| 
       162 
164 
     | 
    
         
             
                    this.page.emit(pageEvent);
         
     | 
| 
       163 
165 
     | 
    
         
             
                }
         
     | 
| 
       164 
     | 
    
         
            -
                 
     | 
| 
       165 
     | 
    
         
            -
                     
     | 
| 
       166 
     | 
    
         
            -
             
     | 
| 
       167 
     | 
    
         
            -
                removeCollapse(element) {
         
     | 
| 
       168 
     | 
    
         
            -
                    if (this.expandableOneRow) {
         
     | 
| 
       169 
     | 
    
         
            -
                        this._dataSource.data.forEach(row => this.addCollapse(row));
         
     | 
| 
      
 166 
     | 
    
         
            +
                isExpandedRow(row) {
         
     | 
| 
      
 167 
     | 
    
         
            +
                    if (ArrayUtil.isEmpty(this._expandedRows)) {
         
     | 
| 
      
 168 
     | 
    
         
            +
                        return of(false);
         
     | 
| 
       170 
169 
     | 
    
         
             
                    }
         
     | 
| 
       171 
     | 
    
         
            -
                    const  
     | 
| 
       172 
     | 
    
         
            -
                     
     | 
| 
       173 
     | 
    
         
            -
                    this._expandedElements = ArrayUtil.clone(expandedElementsAux);
         
     | 
| 
      
 170 
     | 
    
         
            +
                    const index = this._expandedRows.findIndex(r => r === row);
         
     | 
| 
      
 171 
     | 
    
         
            +
                    return of(index >= 0);
         
     | 
| 
       174 
172 
     | 
    
         
             
                }
         
     | 
| 
       175 
     | 
    
         
            -
                 
     | 
| 
       176 
     | 
    
         
            -
                    const  
     | 
| 
       177 
     | 
    
         
            -
                    if ( 
     | 
| 
       178 
     | 
    
         
            -
                        this. 
     | 
| 
      
 173 
     | 
    
         
            +
                toggleExpandRow(row) {
         
     | 
| 
      
 174 
     | 
    
         
            +
                    const index = this._expandedRows.findIndex(r => r === row);
         
     | 
| 
      
 175 
     | 
    
         
            +
                    if (ArrayUtil.isEmpty(this._expandedRows) || (index < 0)) {
         
     | 
| 
      
 176 
     | 
    
         
            +
                        this._expandedRows = [row];
         
     | 
| 
      
 177 
     | 
    
         
            +
                        this.rowExpanded.emit(row);
         
     | 
| 
      
 178 
     | 
    
         
            +
                        return;
         
     | 
| 
       179 
179 
     | 
    
         
             
                    }
         
     | 
| 
       180 
     | 
    
         
            -
             
     | 
| 
       181 
     | 
    
         
            -
             
     | 
| 
       182 
     | 
    
         
            -
                    this. 
     | 
| 
      
 180 
     | 
    
         
            +
                    const _expandedRowsAux = ArrayUtil.clone(this._expandedRows);
         
     | 
| 
      
 181 
     | 
    
         
            +
                    _expandedRowsAux.splice(index, 1);
         
     | 
| 
      
 182 
     | 
    
         
            +
                    this._expandedRows = ArrayUtil.clone(_expandedRowsAux);
         
     | 
| 
      
 183 
     | 
    
         
            +
                    this.rowExpanded.emit(null);
         
     | 
| 
       183 
184 
     | 
    
         
             
                }
         
     | 
| 
       184 
185 
     | 
    
         
             
                sortData(sort) {
         
     | 
| 
       185 
186 
     | 
    
         
             
                    if (this.infiniteScroll) {
         
     | 
| 
         @@ -201,41 +202,94 @@ let TableComponent = class TableComponent { 
     | 
|
| 
       201 
202 
     | 
    
         
             
                    const popover = document.getElementById('table-popover');
         
     | 
| 
       202 
203 
     | 
    
         
             
                    if (!ObjectUtil.isNull(popover)) {
         
     | 
| 
       203 
204 
     | 
    
         
             
                        popover.style.visibility = 'hidden';
         
     | 
| 
      
 205 
     | 
    
         
            +
                        if (!this.loading) {
         
     | 
| 
      
 206 
     | 
    
         
            +
                            this._ngZone.runOutsideAngular(() => {
         
     | 
| 
      
 207 
     | 
    
         
            +
                                const domRectPopover = popover.getBoundingClientRect();
         
     | 
| 
      
 208 
     | 
    
         
            +
                                const domRectRow = event.currentTarget.getBoundingClientRect();
         
     | 
| 
      
 209 
     | 
    
         
            +
                                const cells = event.currentTarget.children;
         
     | 
| 
      
 210 
     | 
    
         
            +
                                if (domRectPopover && domRectRow) {
         
     | 
| 
      
 211 
     | 
    
         
            +
                                    popover.style.visibility = 'visible';
         
     | 
| 
      
 212 
     | 
    
         
            +
                                    popover.style.top = `${(domRectRow.top + domRectRow.height) - 1}px`;
         
     | 
| 
      
 213 
     | 
    
         
            +
                                    let startPosition = 0;
         
     | 
| 
      
 214 
     | 
    
         
            +
                                    let endPosition = 0;
         
     | 
| 
      
 215 
     | 
    
         
            +
                                    if (this.columnInitial && (this.columnInitial >= 0)) {
         
     | 
| 
      
 216 
     | 
    
         
            +
                                        if (!cells[this.columnInitial]) {
         
     | 
| 
      
 217 
     | 
    
         
            +
                                            throw new Error('Initial column undefined or null');
         
     | 
| 
      
 218 
     | 
    
         
            +
                                        }
         
     | 
| 
      
 219 
     | 
    
         
            +
                                        startPosition = cells[this.columnInitial].getBoundingClientRect().left;
         
     | 
| 
      
 220 
     | 
    
         
            +
                                    }
         
     | 
| 
      
 221 
     | 
    
         
            +
                                    else {
         
     | 
| 
      
 222 
     | 
    
         
            +
                                        startPosition = domRectRow.left;
         
     | 
| 
      
 223 
     | 
    
         
            +
                                    }
         
     | 
| 
      
 224 
     | 
    
         
            +
                                    if (this.columnFinal && (this.columnFinal >= 0)) {
         
     | 
| 
      
 225 
     | 
    
         
            +
                                        if (!cells[this.columnFinal]) {
         
     | 
| 
      
 226 
     | 
    
         
            +
                                            throw new Error('Final column undefined or null');
         
     | 
| 
      
 227 
     | 
    
         
            +
                                        }
         
     | 
| 
      
 228 
     | 
    
         
            +
                                        endPosition = cells[this.columnFinal].getBoundingClientRect().left - domRectPopover.width;
         
     | 
| 
      
 229 
     | 
    
         
            +
                                    }
         
     | 
| 
      
 230 
     | 
    
         
            +
                                    else {
         
     | 
| 
      
 231 
     | 
    
         
            +
                                        endPosition = domRectRow.right - domRectPopover.width;
         
     | 
| 
      
 232 
     | 
    
         
            +
                                    }
         
     | 
| 
      
 233 
     | 
    
         
            +
                                    this._ngZone.run(() => {
         
     | 
| 
      
 234 
     | 
    
         
            +
                                        if (event.clientX > startPosition + 15 && event.clientX < endPosition) {
         
     | 
| 
      
 235 
     | 
    
         
            +
                                            popover.style.left = `${event.clientX - 15}px`;
         
     | 
| 
      
 236 
     | 
    
         
            +
                                        }
         
     | 
| 
      
 237 
     | 
    
         
            +
                                        else if (event.clientX <= startPosition) {
         
     | 
| 
      
 238 
     | 
    
         
            +
                                            popover.style.left = `${startPosition}px`;
         
     | 
| 
      
 239 
     | 
    
         
            +
                                        }
         
     | 
| 
      
 240 
     | 
    
         
            +
                                        else if (event.clientX >= endPosition) {
         
     | 
| 
      
 241 
     | 
    
         
            +
                                            popover.style.left = `${endPosition}px`;
         
     | 
| 
      
 242 
     | 
    
         
            +
                                        }
         
     | 
| 
      
 243 
     | 
    
         
            +
                                    });
         
     | 
| 
      
 244 
     | 
    
         
            +
                                }
         
     | 
| 
      
 245 
     | 
    
         
            +
                            });
         
     | 
| 
      
 246 
     | 
    
         
            +
                        }
         
     | 
| 
      
 247 
     | 
    
         
            +
                    }
         
     | 
| 
      
 248 
     | 
    
         
            +
                    this.rowHover.emit(data);
         
     | 
| 
      
 249 
     | 
    
         
            +
                    this._contextPopover = data;
         
     | 
| 
      
 250 
     | 
    
         
            +
                }
         
     | 
| 
      
 251 
     | 
    
         
            +
                /**
         
     | 
| 
      
 252 
     | 
    
         
            +
                showPopover(event: MouseEvent, data: any): void {
         
     | 
| 
      
 253 
     | 
    
         
            +
                    const popover: HTMLElement = document.getElementById('table-popover');
         
     | 
| 
      
 254 
     | 
    
         
            +
                    if (!ObjectUtil.isNull(popover)) {
         
     | 
| 
      
 255 
     | 
    
         
            +
                        popover.style.visibility = 'hidden';
         
     | 
| 
      
 256 
     | 
    
         
            +
             
     | 
| 
       204 
257 
     | 
    
         
             
                        if (!this.loading) {
         
     | 
| 
       205 
258 
     | 
    
         
             
                            const domRectPopover = popover.getBoundingClientRect();
         
     | 
| 
       206 
     | 
    
         
            -
                            const domRectRow = event.currentTarget.getBoundingClientRect();
         
     | 
| 
       207 
     | 
    
         
            -
                            const cells = event.currentTarget.children;
         
     | 
| 
      
 259 
     | 
    
         
            +
                            const domRectRow = (event.currentTarget as HTMLElement).getBoundingClientRect();
         
     | 
| 
      
 260 
     | 
    
         
            +
                            const cells = (event.currentTarget as HTMLTableRowElement).children;
         
     | 
| 
      
 261 
     | 
    
         
            +
             
     | 
| 
       208 
262 
     | 
    
         
             
                            if (domRectPopover && domRectRow) {
         
     | 
| 
       209 
263 
     | 
    
         
             
                                popover.style.visibility = 'visible';
         
     | 
| 
       210 
264 
     | 
    
         
             
                                popover.style.top = `${(domRectRow.top + domRectRow.height) - 1}px`;
         
     | 
| 
       211 
     | 
    
         
            -
             
     | 
| 
       212 
     | 
    
         
            -
                                let  
     | 
| 
      
 265 
     | 
    
         
            +
             
     | 
| 
      
 266 
     | 
    
         
            +
                                let startPosition: number = 0;
         
     | 
| 
      
 267 
     | 
    
         
            +
                                let endPosition: number = 0;
         
     | 
| 
      
 268 
     | 
    
         
            +
             
     | 
| 
       213 
269 
     | 
    
         
             
                                if (this.columnInitial && (this.columnInitial >= 0)) {
         
     | 
| 
       214 
270 
     | 
    
         
             
                                    if (!cells[this.columnInitial]) {
         
     | 
| 
       215 
271 
     | 
    
         
             
                                        throw new Error('Initial column undefined or null');
         
     | 
| 
       216 
272 
     | 
    
         
             
                                    }
         
     | 
| 
       217 
273 
     | 
    
         
             
                                    startPosition = cells[this.columnInitial].getBoundingClientRect().left;
         
     | 
| 
       218 
     | 
    
         
            -
                                }
         
     | 
| 
       219 
     | 
    
         
            -
                                else {
         
     | 
| 
      
 274 
     | 
    
         
            +
                                } else {
         
     | 
| 
       220 
275 
     | 
    
         
             
                                    startPosition = domRectRow.left;
         
     | 
| 
       221 
276 
     | 
    
         
             
                                }
         
     | 
| 
      
 277 
     | 
    
         
            +
             
     | 
| 
       222 
278 
     | 
    
         
             
                                if (this.columnFinal && (this.columnFinal >= 0)) {
         
     | 
| 
       223 
279 
     | 
    
         
             
                                    if (!cells[this.columnFinal]) {
         
     | 
| 
       224 
280 
     | 
    
         
             
                                        throw new Error('Final column undefined or null');
         
     | 
| 
       225 
281 
     | 
    
         
             
                                    }
         
     | 
| 
       226 
282 
     | 
    
         
             
                                    endPosition = cells[this.columnFinal].getBoundingClientRect().left - domRectPopover.width;
         
     | 
| 
       227 
     | 
    
         
            -
                                }
         
     | 
| 
       228 
     | 
    
         
            -
                                else {
         
     | 
| 
      
 283 
     | 
    
         
            +
                                } else {
         
     | 
| 
       229 
284 
     | 
    
         
             
                                    endPosition = domRectRow.right - domRectPopover.width;
         
     | 
| 
       230 
285 
     | 
    
         
             
                                }
         
     | 
| 
      
 286 
     | 
    
         
            +
             
     | 
| 
       231 
287 
     | 
    
         
             
                                setTimeout(() => {
         
     | 
| 
       232 
288 
     | 
    
         
             
                                    if (event.clientX > startPosition + 15 && event.clientX < endPosition) {
         
     | 
| 
       233 
289 
     | 
    
         
             
                                        popover.style.left = `${event.clientX - 15}px`;
         
     | 
| 
       234 
     | 
    
         
            -
                                    }
         
     | 
| 
       235 
     | 
    
         
            -
                                    else if (event.clientX <= startPosition) {
         
     | 
| 
      
 290 
     | 
    
         
            +
                                    } else if (event.clientX <= startPosition) {
         
     | 
| 
       236 
291 
     | 
    
         
             
                                        popover.style.left = `${startPosition}px`;
         
     | 
| 
       237 
     | 
    
         
            -
                                    }
         
     | 
| 
       238 
     | 
    
         
            -
                                    else if (event.clientX >= endPosition) {
         
     | 
| 
      
 292 
     | 
    
         
            +
                                    } else if (event.clientX >= endPosition) {
         
     | 
| 
       239 
293 
     | 
    
         
             
                                        popover.style.left = `${endPosition}px`;
         
     | 
| 
       240 
294 
     | 
    
         
             
                                    }
         
     | 
| 
       241 
295 
     | 
    
         
             
                                });
         
     | 
| 
         @@ -245,6 +299,7 @@ let TableComponent = class TableComponent { 
     | 
|
| 
       245 
299 
     | 
    
         
             
                    this.rowHover.emit(data);
         
     | 
| 
       246 
300 
     | 
    
         
             
                    this._contextPopover = data;
         
     | 
| 
       247 
301 
     | 
    
         
             
                }
         
     | 
| 
      
 302 
     | 
    
         
            +
                */
         
     | 
| 
       248 
303 
     | 
    
         
             
                closePopover(time) {
         
     | 
| 
       249 
304 
     | 
    
         
             
                    of(null).pipe(delay(time)).subscribe(() => {
         
     | 
| 
       250 
305 
     | 
    
         
             
                        if (!ObjectUtil.isNull(this._isPopoverHover) && !this._isPopoverHover) {
         
     | 
| 
         @@ -311,6 +366,9 @@ let TableComponent = class TableComponent { 
     | 
|
| 
       311 
366 
     | 
    
         
             
                    }
         
     | 
| 
       312 
367 
     | 
    
         
             
                }
         
     | 
| 
       313 
368 
     | 
    
         
             
            };
         
     | 
| 
      
 369 
     | 
    
         
            +
            TableComponent.ctorParameters = () => [
         
     | 
| 
      
 370 
     | 
    
         
            +
                { type: NgZone }
         
     | 
| 
      
 371 
     | 
    
         
            +
            ];
         
     | 
| 
       314 
372 
     | 
    
         
             
            __decorate([
         
     | 
| 
       315 
373 
     | 
    
         
             
                ViewChild(MatSort, { static: true }),
         
     | 
| 
       316 
374 
     | 
    
         
             
                __metadata("design:type", MatSort)
         
     | 
| 
         @@ -476,6 +534,10 @@ __decorate([ 
     | 
|
| 
       476 
534 
     | 
    
         
             
                Input(),
         
     | 
| 
       477 
535 
     | 
    
         
             
                __metadata("design:type", Boolean)
         
     | 
| 
       478 
536 
     | 
    
         
             
            ], TableComponent.prototype, "ignoreChildrenExpandRow", void 0);
         
     | 
| 
      
 537 
     | 
    
         
            +
            __decorate([
         
     | 
| 
      
 538 
     | 
    
         
            +
                Input(),
         
     | 
| 
      
 539 
     | 
    
         
            +
                __metadata("design:type", Boolean)
         
     | 
| 
      
 540 
     | 
    
         
            +
            ], TableComponent.prototype, "sort", void 0);
         
     | 
| 
       479 
541 
     | 
    
         
             
            __decorate([
         
     | 
| 
       480 
542 
     | 
    
         
             
                Input(),
         
     | 
| 
       481 
543 
     | 
    
         
             
                __metadata("design:type", Boolean)
         
     | 
| 
         @@ -491,7 +553,7 @@ __decorate([ 
     | 
|
| 
       491 
553 
     | 
    
         
             
            __decorate([
         
     | 
| 
       492 
554 
     | 
    
         
             
                Output(),
         
     | 
| 
       493 
555 
     | 
    
         
             
                __metadata("design:type", EventEmitter)
         
     | 
| 
       494 
     | 
    
         
            -
            ], TableComponent.prototype, " 
     | 
| 
      
 556 
     | 
    
         
            +
            ], TableComponent.prototype, "rowExpanded", void 0);
         
     | 
| 
       495 
557 
     | 
    
         
             
            __decorate([
         
     | 
| 
       496 
558 
     | 
    
         
             
                Output(),
         
     | 
| 
       497 
559 
     | 
    
         
             
                __metadata("design:type", EventEmitter)
         
     | 
| 
         @@ -507,7 +569,7 @@ __decorate([ 
     | 
|
| 
       507 
569 
     | 
    
         
             
            TableComponent = __decorate([
         
     | 
| 
       508 
570 
     | 
    
         
             
                Component({
         
     | 
| 
       509 
571 
     | 
    
         
             
                    selector: 'itss-table',
         
     | 
| 
       510 
     | 
    
         
            -
                    template: "<div [class.box-shadow]=\"shadow\"\n     [style.height]=\"(matTableHeigth | async)\"\n     style=\"background: transparent !important;\"\n     fxLayout=\"column\"\n     fxFlex>\n\n    <itss-table-scrolled [more]=\"hasMore()\"\n                         [scrollOffset]=\"scrollOffset\"\n                         [scrollDelay]=\"scrollDelay\"\n                         (scrolled)=\"handleScroll($event)\"\n                         [ngStyle]=\"{'flex-basis': scrollHeigth ? scrollHeigth + 'px' : _scrollHeightCalc + 'px' }\"\n                         *ngIf=\"infiniteScroll; else table\">\n        <ng-template *ngTemplateOutlet=\"table\"> </ng-template>\n    </itss-table-scrolled>\n\n    <ng-template #table>\n        <mat-table matSort\n                   multiTemplateDataRows\n                   [dataSource]=\"_dataSource\"\n                   [matSortDisabled]=\"!clearSort\"\n                   [matSortDisableClear]=\"!clearSort\"\n                   [matSortActive]=\"sortActive\"\n                   [matSortDirection]=\"sortDirection?.toLocaleLowerCase()\"\n                   (matSortChange)=\"sortData($event)\"\n                   (mouseleave)=\"_isPopoverHover = false; closePopover(0)\">\n\n            <ng-container *ngIf=\"expandedRef\"\n                          cdkColumnDef=\"expandedColumn\">\n                <mat-header-cell fxFlex=\"5\"\n                                 fxLayoutAlign=\"end center\"\n                                 *cdkHeaderCellDef>\n                </mat-header-cell>\n                <mat-cell fxFlex=\"5\"\n                          fxLayoutAlign=\"end center\"\n                          *cdkCellDef=\"let row\">\n                    <itss-button [icon]=\"isExpansed(row) ? 'chevron_right' : 'expand_more'\"\n                                 *ngIf=\"((row?.children) && (row.children.length > 0)) || (row?.expandable) || showColumnExpandableFixed\"\n                                 color=\"primary\"\n                                 type=\"icon\"\n                                 tooltip=\"Expandir | Retrair\"\n                                 (click)=\"(isExpansed(row) ? removeCollapse(row) : addCollapse(row)); rowExpandedChangeEmit(row)\">\n                    </itss-button>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngFor=\"let column of columns\"\n                          [cdkColumnDef]=\"column.property\">\n                <div *ngIf=\"column.sortable\">\n                    <mat-header-cell [fxFlex]=\"column.width | async\"\n                                     [fxLayoutAlign]=\"column.align\"\n                                     [ngStyle]=\"{'padding-left': column.sortable && column.align !== '' && (column.align.toLowerCase() === 'center' || column.align.toLowerCase() === 'center center') ? '15px' : '' }\"\n                                     [style.padding-left.px]=\"column.marginLeft | async\"\n                                     [style.padding-right.px]=\"column.marginRight | async\"\n                                     *cdkHeaderCellDef\n                                     mat-sort-header>\n                        {{ column.name }}\n                    </mat-header-cell>\n                </div>\n                <div *ngIf=\"!column.sortable\">\n                    <mat-header-cell [fxFlex]=\"column.width | async\"\n                                     [fxHide.lt-md]=\"column.hiddenSm\"\n                                     [fxLayoutAlign]=\"column.align\"\n                                     [style.padding-left.px]=\"column.marginLeft | async\"\n                                     [style.padding-right.px]=\"column.marginRight | async\"\n                                     *cdkHeaderCellDef>\n                        <ng-container *ngIf=\"column.name; else templateHeader\">\n                            {{ column.name }}\n                        </ng-container>\n\n                        <ng-template #templateHeader>\n                            <ng-container *ngIf=\"column.templateHeader\">\n                                <ng-container [ngTemplateOutlet]=\"column.templateHeader\"\n                                              [ngTemplateOutletContext]=\"{$implicit: data}\">\n                                </ng-container>\n                            </ng-container>\n                        </ng-template>\n                    </mat-header-cell>\n                </div>\n                <mat-cell [fxFlex]=\"column.width | async\"\n                          [fxHide.lt-md]=\"column.hiddenSm\"\n                          [fxHide]=\"!column.visible\"\n                          [fxLayoutAlign]=\"column.align\"\n                          [class.mat-cell-pointer]=\"column.action\"\n                          [style.padding-left.px]=\"column.marginLeft | async\"\n                          [style.padding-right.px]=\"column.marginRight | async\"\n                          (click)=\"column.action ? column.action(row) : null\"\n                          *cdkCellDef=\"let row\">\n                    <ng-container *ngIf=\"column.value; else template\">\n                        {{ (column.value(row) && (column.value(row).length > (column.sliceLength ? column.sliceLength :\n                        50)))\n                        ? (column.value(row) | slice:0:(column.sliceLength ? column.sliceLength : 50)) + '...'\n                        : column.value(row) }}\n                    </ng-container>\n\n                    <ng-template #template>\n                        <ng-container *ngIf=\"column.template\">\n                            <ng-container [ngTemplateOutlet]=\"column.template\"\n                                          [ngTemplateOutletContext]=\"{$implicit: row}\">\n                            </ng-container>\n                        </ng-container>\n                    </ng-template>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"actionsRef\"\n                          cdkColumnDef=\"actionsColumn\">\n                <mat-header-cell fxFlex.gt-md=\"15\"\n                                 fxLayoutAlign=\"center center\"\n                                 *cdkHeaderCellDef>\n                    A\u00E7\u00F5es\n                </mat-header-cell>\n                <mat-cell fxFlex=\"15\"\n                          fxLayoutAlign=\"center center\"\n                          *cdkCellDef=\"let row\">\n                    <ng-template [ngTemplateOutlet]=\"actionsRef\"\n                                 [ngTemplateOutletContext]=\"{$implicit: row}\">\n                    </ng-template>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"expandedRef\"\n                          matColumnDef=\"expandedDetail\">\n                <mat-cell *matCellDef=\"let row\"\n                          fxFlexFill\n                          class=\"cell-element-detail\">\n                    <div class=\"element-detail\"\n                         *ngIf=\"!ignoreChildrenExpandRow ? (row.children.length > 0) : ignoreChildrenExpandRow\"\n                         [ngClass]=\"{'collapsed': isExpansed(row), 'expanded': !isExpansed(row)}\">\n                        <ng-template [ngTemplateOutlet]=\"expandedRef\"\n                                     [ngTemplateOutletContext]=\"{$implicit: row}\">\n                        </ng-template>\n                    </div>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"groupByColumn && groupHeaderRef\"\n                          matColumnDef=\"groupHeader\">\n                <mat-cell fxFlex\n                          [attr.colspan]=\"columns.length\"\n                          *matCellDef=\"let rowGroup\"\n                          style=\"cursor: pointer;\"\n                          [class.group-header-cell-expanded]=\"!isExpansed(rowGroup)\"\n                          [class.group-header-cell-collapsed]=\"isExpansed(rowGroup)\"\n                          (click)=\"isExpansed(rowGroup) ? removeCollapse(rowGroup) : addCollapse(rowGroup)\">\n                    <div class=\"group-header-cell\">\n                        <itss-button *ngIf=\"rowGroup.childrenGroup.length > 0\"\n                                     [icon]=\"isExpansed(rowGroup) ? 'chevron_right' : 'expand_more'\"\n                                     style.margin-right=\"1.25rem\"\n                                     color=\"primary\"\n                                     type=\"icon\"\n                                     tooltip=\"Expandir | Retrair\"\n                                     (click)=\"isExpansed(rowGroup) ? removeCollapse(rowGroup) : addCollapse(rowGroup)\">\n                        </itss-button>\n\n                        <ng-template [ngTemplateOutlet]=\"groupHeaderRef\"\n                                     [ngTemplateOutletContext]=\"{$implicit: rowGroup}\">\n                        </ng-template>\n                    </div>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"groupByColumn && groupHeaderRef\"\n                          matColumnDef=\"expandedGroupHeader\">\n                <mat-cell *matCellDef=\"let rowGroup\"\n                          fxFlexFill>\n                    <div class=\"element-detail\"\n                         *ngIf=\"rowGroup.childrenGroup.length > 0\"\n                         [ngClass]=\"{'collapsed': isExpansed(rowGroup), 'expanded': !isExpansed(rowGroup)}\">\n\n                        <itss-table *ngIf=\"rowGroup.childrenGroup.length > 0; else noChildrenGroup\"\n                                    [paginator]=\"false\"\n                                    [shadow]=\"false\"\n                                    [showHeader]=\"false\"\n                                    [columns]=\"columns\"\n                                    [data]=\"rowGroup.childrenGroup\"\n                                    class=\"table-level-1\"\n                                    fxFlexFill>\n                            <ng-template #footer\n                                         *ngIf=\"groupByColumn && groupHeaderRef && groupFooterRef\">\n                                <ng-template [ngTemplateOutlet]=\"groupFooterRef\"\n                                             [ngTemplateOutletContext]=\"{$implicit: rowGroup}\">\n                                </ng-template>\n                            </ng-template>\n                        </itss-table>\n\n                        <ng-template #noChildrenGroup>\n                            <div *ngIf=\"!loading\"\n                                 class=\"no-records\">\n                                <mat-icon>sentiment_very_dissatisfied</mat-icon>\n                                <span>Nenhum registro foi encontrado</span>\n                            </div>\n                        </ng-template>\n                    </div>\n                </mat-cell>\n            </ng-container>\n\n            <mat-header-row #matHeaderRow\n                            (mouseenter)=\"_isPopoverHover = false; closePopover(0)\"\n                            *matHeaderRowDef=\"_displayedColumns; sticky: headerSticky || groupHeaderSticky\"\n                            [ngClass]=\"{ 'hidden-header': !showHeader }\">\n            </mat-header-row>\n\n            <div *ngIf=\"!loading && !expandable && !actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row (mouseover)=\"rowHover.emit(row)\"\n                         *matRowDef=\"let row; columns: _displayedColumns;\"\n                         [ngClass]=\"{ 'hoversimulator': row.isMouseHover === true }\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && !expandable && actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row #rowTemplate\n                         *matRowDef=\"let row; columns: _displayedColumns;\"\n                         class=\"element-row\"\n                         (mousemove)=\"showPopover($event, row)\"\n                         [class.hoversimulator]=\"_contextPopover === row\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && expandable && !actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row *matRowDef=\"let row; columns: _displayedColumns;\"\n                         class=\"element-row\"\n                         (mouseover)=\"rowHover.emit(row)\"\n                         [class.expanded-row]=\"_expandedElement === row\"\n                         [ngClass]=\"{ 'hoversimulator': row.isMouseHover === true }\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n\n                <mat-row *matRowDef=\"let row; columns: ['expandedDetail'];\"\n                         class=\"detail-row\"\n                         [attr.id]=\"'row_expand'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && expandable && actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row #rowTemplate\n                         *matRowDef=\"let row; columns: _displayedColumns;\"\n                         class=\"element-row\"\n                         (mousemove)=\"showPopover($event, row)\"\n                         [class.hoversimulator]=\"_contextPopover === row\"\n                         [class.expanded-row]=\"_expandedElement === row\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n\n                <mat-row *matRowDef=\"let row; columns: ['expandedDetail'];\"\n                         class=\"detail-row\"\n                         [attr.id]=\"'row_expand'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && !expandable && !actionsPopoverRef && groupByColumn && groupHeaderRef\">\n                <mat-row *matRowDef=\"let row; columns: ['groupHeader'];\"\n                         class=\"element-row\"\n                         (mouseover)=\"rowHover.emit(row)\"\n                         [class.expanded-row]=\"_expandedElement === row\"\n                         [class.group-header-sticky]=\"groupHeaderSticky\"\n                         [ngClass]=\"{ 'hoversimulator': row.isMouseHover === true }\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n\n                <mat-row *matRowDef=\"let row; columns: ['expandedGroupHeader'];\"\n                         class=\"detail-row\"\n                         [attr.id]=\"'row_group'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n        </mat-table>\n\n        <mat-progress-bar mode=\"indeterminate\"\n                          color=\"accent\"\n                          *ngIf=\"loading\">\n        </mat-progress-bar>\n\n        <div *ngIf=\"!loading && (data && (data.length > 0)) && footerRef\"\n             class=\"footer-row\"\n             fxLayout=\"column\"\n             fxLayoutGap=\"10px\">\n            <ng-template [ngTemplateOutlet]=\"footerRef\"\n                         [ngTemplateOutletContext]=\"{$implicit: data}\">\n            </ng-template>\n        </div>\n\n        <div *ngIf=\"!loading && (data && (data.length <= 0))\"\n             class=\"no-records\">\n            <mat-icon>sentiment_very_dissatisfied</mat-icon>\n            <span>Nenhum registro foi encontrado</span>\n        </div>\n\n        <ng-container *ngIf=\"!loading && paginator && (data && (data.length > 0))\">\n            <ng-container #backendPaginatorTemplate\n                          *ngIf=\"backendPagination && !infiniteScroll\">\n                <mat-paginator #backendPaginator\n                               [hidePageSize]=\"!showPageSizeOptions || (paginatorPageSizeOptions && (paginatorPageSizeOptions.length <= 0))\"\n                               [length]=\"paginatorLength\"\n                               [pageIndex]=\"paginatorPageIndex\"\n                               [pageSize]=\"paginatorPageSize\"\n                               [pageSizeOptions]=\"paginatorPageSizeOptions\"\n                               (page)=\"onPage($event)\"\n                               (mouseenter)=\"closePopover(0)\"\n                               showFirstLastButtons>\n                </mat-paginator>\n            </ng-container>\n\n            <ng-container #frontendPaginatorTemplate\n                          *ngIf=\"!backendPagination && !infiniteScroll\">\n                <mat-paginator #frontendPaginator\n                               [hidePageSize]=\"!showPageSizeOptions || (paginatorPageSizeOptions && (paginatorPageSizeOptions.length <= 0))\"\n                               [length]=\"paginatorLength\"\n                               [pageIndex]=\"paginatorPageIndex\"\n                               [pageSize]=\"paginatorPageSize\"\n                               [pageSizeOptions]=\"paginatorPageSizeOptions\"\n                               (page)=\"onPage($event)\"\n                               showFirstLastButtons>\n                </mat-paginator>\n            </ng-container>\n        </ng-container>\n\n        <ng-container #infiniteScrollPaginatorTemplate\n                      *ngIf=\"infiniteScroll && (data && (data.length > 0))\">\n            <span class=\"infinite-scroll-paginator\">\n                1 - {{ data.length }} de {{ paginatorLength }}\n            </span>\n        </ng-container>\n    </ng-template>\n</div>\n\n<div id=\"table-popover\"\n     class=\"table-popover\"\n     (mouseover)=\"_isPopoverHover = true\"\n     (mouseout)=\"_isPopoverHover = false; closePopover(0)\"\n     *ngIf=\"!loading && actionsPopoverRef\">\n    <ng-container [ngTemplateOutlet]=\"actionsPopoverRef\"\n                  [ngTemplateOutletContext]=\"{ $implicit: _contextPopover }\">\n    </ng-container>\n</div>",
         
     | 
| 
      
 572 
     | 
    
         
            +
                    template: "<div [class.box-shadow]=\"shadow\"\n     [style.height]=\"(matTableHeigth | async)\"\n     style=\"background: transparent !important;\"\n     fxLayout=\"column\"\n     fxFlex>\n\n    <itss-table-scrolled [more]=\"hasMore()\"\n                         [scrollOffset]=\"scrollOffset\"\n                         [scrollDelay]=\"scrollDelay\"\n                         (scrolled)=\"handleScroll($event)\"\n                         [ngStyle]=\"{'flex-basis': scrollHeigth ? scrollHeigth + 'px' : _scrollHeightCalc + 'px' }\"\n                         *ngIf=\"infiniteScroll; else table\">\n        <ng-template *ngTemplateOutlet=\"table\"> </ng-template>\n    </itss-table-scrolled>\n\n    <ng-template #table>\n        <mat-table matSort\n                   multiTemplateDataRows\n                   [dataSource]=\"_dataSource\"\n                   [matSortDisabled]=\"!sort\"\n                   [matSortDisableClear]=\"!clearSort\"\n                   [matSortActive]=\"sortActive\"\n                   [matSortDirection]=\"sortDirection?.toLocaleLowerCase()\"\n                   (matSortChange)=\"sortData($event)\"\n                   (mouseleave)=\"_isPopoverHover = false; closePopover(0)\">\n\n            <ng-container *ngIf=\"expandedRef\"\n                          cdkColumnDef=\"expandedColumn\">\n                <mat-header-cell fxFlex=\"5\"\n                                 fxLayoutAlign=\"end center\"\n                                 *cdkHeaderCellDef>\n                </mat-header-cell>\n                <mat-cell fxFlex=\"5\"\n                          fxLayoutAlign=\"end center\"\n                          *cdkCellDef=\"let row\">\n                    <itss-button tooltip=\"Expandir | Retrair\"\n                                 color=\"primary\"\n                                 type=\"icon\"\n                                 *ngIf=\"((row?.children) && (row.children.length > 0)) || (row?.expandable) || showColumnExpandableFixed\"\n                                 [icon]=\"(isExpandedRow(row) | async) ? 'expand_more' : 'chevron_right'\"\n                                 (click)=\"toggleExpandRow(row)\">\n                    </itss-button>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngFor=\"let column of columns\"\n                          [cdkColumnDef]=\"column.property\">\n                <div *ngIf=\"column.sortable\">\n                    <mat-header-cell [fxFlex]=\"column.width | async\"\n                                     [fxLayoutAlign]=\"column.align\"\n                                     [ngStyle]=\"{'padding-left': column.sortable && column.align !== '' && (column.align.toLowerCase() === 'center' || column.align.toLowerCase() === 'center center') ? '15px' : '' }\"\n                                     [style.padding-left.px]=\"column.marginLeft | async\"\n                                     [style.padding-right.px]=\"column.marginRight | async\"\n                                     *cdkHeaderCellDef\n                                     mat-sort-header>\n                        {{ column.name }}\n                    </mat-header-cell>\n                </div>\n                <div *ngIf=\"!column.sortable\">\n                    <mat-header-cell [fxFlex]=\"column.width | async\"\n                                     [fxHide.lt-md]=\"column.hiddenSm\"\n                                     [fxLayoutAlign]=\"column.align\"\n                                     [style.padding-left.px]=\"column.marginLeft | async\"\n                                     [style.padding-right.px]=\"column.marginRight | async\"\n                                     *cdkHeaderCellDef>\n                        <ng-container *ngIf=\"column.name; else templateHeader\">\n                            {{ column.name }}\n                        </ng-container>\n\n                        <ng-template #templateHeader>\n                            <ng-container *ngIf=\"column.templateHeader\">\n                                <ng-container [ngTemplateOutlet]=\"column.templateHeader\"\n                                              [ngTemplateOutletContext]=\"{$implicit: data}\">\n                                </ng-container>\n                            </ng-container>\n                        </ng-template>\n                    </mat-header-cell>\n                </div>\n                <mat-cell [fxFlex]=\"column.width | async\"\n                          [fxHide.lt-md]=\"column.hiddenSm\"\n                          [fxHide]=\"!column.visible\"\n                          [fxLayoutAlign]=\"column.align\"\n                          [class.mat-cell-pointer]=\"column.action\"\n                          [style.padding-left.px]=\"column.marginLeft | async\"\n                          [style.padding-right.px]=\"column.marginRight | async\"\n                          (click)=\"column.action ? column.action(row) : null\"\n                          *cdkCellDef=\"let row\">\n                    <ng-container *ngIf=\"column.value; else template\">\n                        {{ (column.value(row) && (column.value(row).length > (column.sliceLength ? column.sliceLength :\n                        50)))\n                        ? (column.value(row) | slice:0:(column.sliceLength ? column.sliceLength : 50)) + '...'\n                        : column.value(row) }}\n                    </ng-container>\n\n                    <ng-template #template>\n                        <ng-container *ngIf=\"column.template\">\n                            <ng-container [ngTemplateOutlet]=\"column.template\"\n                                          [ngTemplateOutletContext]=\"{$implicit: row}\">\n                            </ng-container>\n                        </ng-container>\n                    </ng-template>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"actionsRef\"\n                          cdkColumnDef=\"actionsColumn\">\n                <mat-header-cell fxFlex.gt-md=\"15\"\n                                 fxLayoutAlign=\"center center\"\n                                 *cdkHeaderCellDef>\n                    A\u00E7\u00F5es\n                </mat-header-cell>\n                <mat-cell fxFlex=\"15\"\n                          fxLayoutAlign=\"center center\"\n                          *cdkCellDef=\"let row\">\n                    <ng-template [ngTemplateOutlet]=\"actionsRef\"\n                                 [ngTemplateOutletContext]=\"{$implicit: row}\">\n                    </ng-template>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"expandedRef\"\n                          matColumnDef=\"expandedDetail\">\n                <mat-cell *matCellDef=\"let row\"\n                          fxFlexFill\n                          class=\"cell-element-detail\">\n                    <div class=\"element-detail\"\n                         *ngIf=\"!ignoreChildrenExpandRow ? (row.children.length > 0) : ignoreChildrenExpandRow\"\n                         [class.collapsed]=\"!(isExpandedRow(row) | async)\"\n                         [class.expanded]=\"(isExpandedRow(row) | async)\">\n                        <ng-template [ngTemplateOutlet]=\"expandedRef\"\n                                     [ngTemplateOutletContext]=\"{$implicit: row}\">\n                        </ng-template>\n                    </div>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"groupByColumn && groupHeaderRef\"\n                          matColumnDef=\"groupHeader\">\n                <mat-cell fxFlex\n                          [attr.colspan]=\"columns.length\"\n                          *matCellDef=\"let rowGroup\"\n                          style=\"cursor: pointer;\"\n                          [class.group-header-cell-collapsed]=\"!(isExpandedRow(rowGroup) | async)\"\n                          [class.group-header-cell-expanded]=\"(isExpandedRow(rowGroup) | async)\"\n                          (click)=\"toggleExpandRow(rowGroup)\">\n                    <div class=\"group-header-cell\">\n                        <itss-button *ngIf=\"rowGroup.childrenGroup.length > 0\"\n                                     [icon]=\"(isExpandedRow(rowGroup) | async) ? 'expand_more' : 'chevron_right'\"\n                                     style.margin-right=\"1.25rem\"\n                                     color=\"primary\"\n                                     type=\"icon\"\n                                     tooltip=\"Expandir | Retrair\">\n                        </itss-button>\n\n                        <ng-template [ngTemplateOutlet]=\"groupHeaderRef\"\n                                     [ngTemplateOutletContext]=\"{$implicit: rowGroup}\">\n                        </ng-template>\n                    </div>\n                </mat-cell>\n            </ng-container>\n\n            <ng-container *ngIf=\"groupByColumn && groupHeaderRef\"\n                          matColumnDef=\"expandedGroupHeader\">\n                <mat-cell *matCellDef=\"let rowGroup\"\n                          fxFlexFill>\n                    <div class=\"element-detail\"\n                         *ngIf=\"rowGroup.childrenGroup.length > 0\"\n                         [class.collapsed]=\"!(isExpandedRow(rowGroup) | async)\"\n                         [class.expanded]=\"(isExpandedRow(rowGroup) | async)\">\n\n                        <itss-table *ngIf=\"rowGroup.childrenGroup.length > 0; else noChildrenGroup\"\n                                    [paginator]=\"false\"\n                                    [shadow]=\"false\"\n                                    [showHeader]=\"false\"\n                                    [columns]=\"columns\"\n                                    [data]=\"rowGroup.childrenGroup\"\n                                    class=\"table-level-1\"\n                                    fxFlexFill>\n                            <ng-template #footer\n                                         *ngIf=\"groupByColumn && groupHeaderRef && groupFooterRef\">\n                                <ng-template [ngTemplateOutlet]=\"groupFooterRef\"\n                                             [ngTemplateOutletContext]=\"{$implicit: rowGroup}\">\n                                </ng-template>\n                            </ng-template>\n                        </itss-table>\n\n                        <ng-template #noChildrenGroup>\n                            <div *ngIf=\"!loading\"\n                                 class=\"no-records\">\n                                <mat-icon>sentiment_very_dissatisfied</mat-icon>\n                                <span>Nenhum registro foi encontrado</span>\n                            </div>\n                        </ng-template>\n                    </div>\n                </mat-cell>\n            </ng-container>\n\n            <mat-header-row #matHeaderRow\n                            (mouseenter)=\"_isPopoverHover = false; closePopover(0)\"\n                            *matHeaderRowDef=\"_displayedColumns; sticky: headerSticky || groupHeaderSticky\"\n                            [ngClass]=\"{ 'hidden-header': !showHeader }\">\n            </mat-header-row>\n\n            <div *ngIf=\"!loading && !expandable && !actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row (mouseover)=\"rowHover.emit(row)\"\n                         *matRowDef=\"let row; columns: _displayedColumns;\"\n                         [ngClass]=\"{ 'hoversimulator': row.isMouseHover === true }\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && !expandable && actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row #rowTemplate\n                         *matRowDef=\"let row; columns: _displayedColumns;\"\n                         class=\"element-row\"\n                         (mousemove)=\"showPopover($event, row)\"\n                         [class.hoversimulator]=\"_contextPopover === row\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && expandable && !actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row *matRowDef=\"let row; columns: _displayedColumns;\"\n                         class=\"element-row\"\n                         [class.expanded-row]=\"(isExpandedRow(row) | async)\"\n                         [ngClass]=\"{ 'hoversimulator': row.isMouseHover === true }\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\"\n                         (mouseover)=\"rowHover.emit(row)\"\n                         (click)=\"toggleExpandRow(row)\">\n                </mat-row>\n\n                <mat-row *matRowDef=\"let row; columns: ['expandedDetail'];\"\n                         class=\"detail-row\"\n                         [attr.id]=\"'row_expand'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && expandable && actionsPopoverRef && !groupByColumn && !groupHeaderRef\">\n                <mat-row #rowTemplate\n                         *matRowDef=\"let row; columns: _displayedColumns;\"\n                         class=\"element-row\"\n                         [class.hoversimulator]=\"_contextPopover === row\"\n                         [class.expanded-row]=\"(isExpandedRow(row) | async)\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\"\n                         (mousemove)=\"showPopover($event, row)\"\n                         (click)=\"toggleExpandRow(row)\">\n                </mat-row>\n\n                <mat-row *matRowDef=\"let row; columns: ['expandedDetail'];\"\n                         class=\"detail-row\"\n                         [attr.id]=\"'row_expand'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n\n            <div *ngIf=\"!loading && !expandable && !actionsPopoverRef && groupByColumn && groupHeaderRef\">\n                <mat-row *matRowDef=\"let row; columns: ['groupHeader'];\"\n                         class=\"element-row\"\n                         [class.expanded-row]=\"(isExpandedRow(row) | async)\"\n                         [class.group-header-sticky]=\"groupHeaderSticky\"\n                         [ngClass]=\"{ 'hoversimulator': row.isMouseHover === true }\"\n                         [class.highlight]=\"getHighlightRow(row)\"\n                         [attr.id]=\"'row_'+ getIndexRow(row)\"\n                         (mouseover)=\"rowHover.emit(row)\"\n                         (click)=\"toggleExpandRow(row)\">\n                </mat-row>\n\n                <mat-row *matRowDef=\"let row; columns: ['expandedGroupHeader'];\"\n                         class=\"detail-row\"\n                         [attr.id]=\"'row_group'+ getIndexRow(row)\">\n                </mat-row>\n            </div>\n        </mat-table>\n\n        <mat-progress-bar mode=\"indeterminate\"\n                          color=\"accent\"\n                          *ngIf=\"loading\">\n        </mat-progress-bar>\n\n        <div *ngIf=\"!loading && (data && (data.length > 0)) && footerRef\"\n             class=\"footer-row\"\n             fxLayout=\"column\"\n             fxLayoutGap=\"10px\">\n            <ng-template [ngTemplateOutlet]=\"footerRef\"\n                         [ngTemplateOutletContext]=\"{$implicit: data}\">\n            </ng-template>\n        </div>\n\n        <div *ngIf=\"!loading && (data && (data.length <= 0))\"\n             class=\"no-records\">\n            <mat-icon>sentiment_very_dissatisfied</mat-icon>\n            <span>Nenhum registro foi encontrado</span>\n        </div>\n\n        <ng-container *ngIf=\"!loading && paginator && (data && (data.length > 0))\">\n            <ng-container #backendPaginatorTemplate\n                          *ngIf=\"backendPagination && !infiniteScroll\">\n                <mat-paginator #backendPaginator\n                               [hidePageSize]=\"!showPageSizeOptions || (paginatorPageSizeOptions && (paginatorPageSizeOptions.length <= 0))\"\n                               [length]=\"paginatorLength\"\n                               [pageIndex]=\"paginatorPageIndex\"\n                               [pageSize]=\"paginatorPageSize\"\n                               [pageSizeOptions]=\"paginatorPageSizeOptions\"\n                               (page)=\"onPage($event)\"\n                               (mouseenter)=\"closePopover(0)\"\n                               showFirstLastButtons>\n                </mat-paginator>\n            </ng-container>\n\n            <ng-container #frontendPaginatorTemplate\n                          *ngIf=\"!backendPagination && !infiniteScroll\">\n                <mat-paginator #frontendPaginator\n                               [hidePageSize]=\"!showPageSizeOptions || (paginatorPageSizeOptions && (paginatorPageSizeOptions.length <= 0))\"\n                               [length]=\"paginatorLength\"\n                               [pageIndex]=\"paginatorPageIndex\"\n                               [pageSize]=\"paginatorPageSize\"\n                               [pageSizeOptions]=\"paginatorPageSizeOptions\"\n                               (page)=\"onPage($event)\"\n                               showFirstLastButtons>\n                </mat-paginator>\n            </ng-container>\n        </ng-container>\n\n        <ng-container #infiniteScrollPaginatorTemplate\n                      *ngIf=\"infiniteScroll && (data && (data.length > 0))\">\n            <span class=\"infinite-scroll-paginator\">\n                1 - {{ data.length }} de {{ paginatorLength }}\n            </span>\n        </ng-container>\n    </ng-template>\n</div>\n\n<div id=\"table-popover\"\n     class=\"table-popover\"\n     (mouseover)=\"_isPopoverHover = true\"\n     (mouseout)=\"_isPopoverHover = false; closePopover(0)\"\n     *ngIf=\"!loading && actionsPopoverRef\">\n    <ng-container [ngTemplateOutlet]=\"actionsPopoverRef\"\n                  [ngTemplateOutletContext]=\"{ $implicit: _contextPopover }\">\n    </ng-container>\n</div>",
         
     | 
| 
       511 
573 
     | 
    
         
             
                    animations: [
         
     | 
| 
       512 
574 
     | 
    
         
             
                        trigger('detailExpand', [
         
     | 
| 
       513 
575 
     | 
    
         
             
                            state('collapsed', style({ height: '0px', minHeight: '0', display: 'none' })),
         
     | 
| 
         @@ -515,9 +577,9 @@ TableComponent = __decorate([ 
     | 
|
| 
       515 
577 
     | 
    
         
             
                            transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),
         
     | 
| 
       516 
578 
     | 
    
         
             
                        ]),
         
     | 
| 
       517 
579 
     | 
    
         
             
                    ],
         
     | 
| 
       518 
     | 
    
         
            -
                    styles: [".box-shadow{border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.14),0 2px 2px 0 rgba(0,0,0,.098),0 1px 5px 0 rgba(0,0,0,.084)}table{width:100%}itss-loading{margin:25px;opacity:.7}.no-records{height:48px;display:flex;align-items:center;justify-content:center;flex-direction:column;margin:30px;font-size:14px!important;font-weight:600!important;color:#b3afb3!important}.no-records mat-icon{font-size:32px;height:32px;width:32px;margin-bottom:5px}.footer-row{min-height:57px;font-weight:700;padding:15px 24px;display:flex;align-items:flex-end;justify-content:center;flex-direction:column;color:rgba(0,0,0,.67);border-bottom:1px solid rgba(0,0,0,.12)}.mat-cell-pointer{cursor:pointer}.detail-row{min-height:0!important;border-bottom-width:0}element-row:not(.expanded-row):hover{background:#f5f5f5}element-row:not(.expanded-row):active{background:#efefef}.hoversimulator:not(.highlight){background:#f5f5f5}.hoversimulator:has(.highlight){background-color:rgba(255,217,0,.212)!important}.highlight{background-color:rgba(255,217,0,.102)!important}::ng-deep mat-cell.cell-element-detail{font-weight:400!important}.element-detail{width:100%;overflow:hidden;display:flex;min-height:45px!important}.element-detail.collapsed{height:0!important;min-height:0!important;display:none!important}.element-detail.expanded{height:auto!important}.hidden-header,.hidden-header .mat-header-cell{height:0!important;min-height:0!important}.actions-popover.mat-card{min-width:auto!important;padding:5px!important;background:#f5f5f5;border-radius:5px!important}.actions-popover.mat-card .mat-card-content itss-button .mat-icon-button mat-icon{height:18px!important;width:18px!important}.table-level-1 .mat-table .mat-header-row{border-bottom:unset!important}.mat-column-expandedGroupHeader{padding:0!important}.group-header-cell{display:flex;flex-direction:row;align-items:center;width:100%}.group-header-sticky{position:-webkit-sticky;position:sticky;top:54px}.infinite-scroll-paginator{color:#696969;font-size:14px;display:flex;align-items:center;justify-content:center;height:56px;position:-webkit-sticky;position:sticky;bottom:0;background:#fff;border-top:1px solid #f3465c}.table-popover{position:fixed;display:inline-flex;background-color:#f5f5f5;width:auto;border-radius:0 0 10px 10px;border:1px solid #ddd;border-top-width:0;padding:2px 5px;z-index:1;visibility:hidden}"]
         
     | 
| 
      
 580 
     | 
    
         
            +
                    styles: [".box-shadow{border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.14),0 2px 2px 0 rgba(0,0,0,.098),0 1px 5px 0 rgba(0,0,0,.084)}table{width:100%}itss-loading{margin:25px;opacity:.7}.no-records{height:48px;display:flex;align-items:center;justify-content:center;flex-direction:column;margin:30px;font-size:14px!important;font-weight:600!important;color:#b3afb3!important;text-transform:initial!important}.no-records mat-icon{font-size:32px;height:32px;width:32px;margin-bottom:5px}.footer-row{min-height:57px;font-weight:700;padding:15px 24px;display:flex;align-items:flex-end;justify-content:center;flex-direction:column;color:rgba(0,0,0,.67);border-bottom:1px solid rgba(0,0,0,.12)}.mat-cell-pointer{cursor:pointer}.detail-row{min-height:0!important;border-bottom-width:0}element-row:not(.expanded-row):hover{background:#f5f5f5}element-row:not(.expanded-row):active{background:#efefef}.hoversimulator:not(.highlight){background:#f5f5f5}.hoversimulator:has(.highlight){background-color:rgba(255,217,0,.212)!important}.highlight{background-color:rgba(255,217,0,.102)!important}::ng-deep mat-cell.cell-element-detail{font-weight:400!important}.element-detail{width:100%;overflow:hidden;display:flex;min-height:45px!important}.element-detail.collapsed{height:0!important;min-height:0!important;display:none!important}.element-detail.expanded{height:auto!important}.hidden-header,.hidden-header .mat-header-cell{height:0!important;min-height:0!important}.actions-popover.mat-card{min-width:auto!important;padding:5px!important;background:#f5f5f5;border-radius:5px!important}.actions-popover.mat-card .mat-card-content itss-button .mat-icon-button mat-icon{height:18px!important;width:18px!important}.table-level-1 .mat-table .mat-header-row{border-bottom:unset!important}.mat-column-expandedGroupHeader{padding:0!important}.group-header-cell{display:flex;flex-direction:row;align-items:center;width:100%}.group-header-sticky{position:-webkit-sticky;position:sticky;top:54px}.infinite-scroll-paginator{color:#696969;font-size:14px;display:flex;align-items:center;justify-content:center;height:56px;position:-webkit-sticky;position:sticky;bottom:0;background:#fff;border-top:1px solid #f3465c}.table-popover{position:fixed;display:inline-flex;background-color:#f5f5f5;width:auto;border-radius:0 0 10px 10px;border:1px solid #ddd;border-top-width:0;padding:2px 5px;z-index:1;visibility:hidden}"]
         
     | 
| 
       519 
581 
     | 
    
         
             
                }),
         
     | 
| 
       520 
     | 
    
         
            -
                __metadata("design:paramtypes", [])
         
     | 
| 
      
 582 
     | 
    
         
            +
                __metadata("design:paramtypes", [NgZone])
         
     | 
| 
       521 
583 
     | 
    
         
             
            ], TableComponent);
         
     | 
| 
       522 
584 
     | 
    
         
             
            export { TableComponent };
         
     | 
| 
       523 
     | 
    
         
            -
            //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["shared/components/table/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { AfterViewInit, Component, ContentChild, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\nimport { MatHeaderRowDef, MatPaginator, MatSort, MatTableDataSource, Sort, SortDirection } from '@angular/material';\nimport { Observable, of } from 'rxjs';\nimport { delay } from 'rxjs/operators';\n\nimport { ArrayUtil, ObjectUtil, StringUtil } from '../../../core';\nimport { TableColumnDTO } from '../../../core/models/dto/table-column.dto';\nimport { TableGroupHeaderDTO } from '../../../core/models/dto/table-group-header.dto';\nimport { TablePageEventDTO } from '../../../core/models/dto/table-page-event.dto';\n\n\n@Component({\n    selector: 'itss-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss'],\n    animations: [\n        trigger('detailExpand', [\n            state('collapsed', style({ height: '0px', minHeight: '0', display: 'none' })),\n            state('expanded', style({ height: '*' })),\n            transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),\n        ]),\n    ],\n})\nexport class TableComponent<T> implements AfterViewInit, OnChanges, OnInit {\n\n    private _expandedElements: any[] = [];\n\n    public _scrollHeightCalc: number = 410;\n    public _isPopoverHover: any = null;\n    public _contextPopover: T;\n    public _expandedElement: any;\n    public _displayedColumns: any[] = [];\n    public _dataSource: MatTableDataSource<T | TableGroupHeaderDTO>;\n\n    @ViewChild(MatSort, { static: true }) matSort: MatSort;\n    @ViewChild(MatPaginator, { static: true }) matPaginator: MatPaginator;\n    @ViewChild('frontendPaginator', { static: false }) matFrontendPaginator: MatPaginator;\n    @ViewChild('backendPaginator', { static: false }) matBackendPaginator: MatPaginator;\n\n    @ViewChild('matHeaderRow', { static: true }) private _matHeaderRowRef: TemplateRef<MatHeaderRowDef>;\n    @ViewChild('frontendPaginator', { static: true }) private _matFrontendPaginatorRowRef: TemplateRef<any>;\n    @ViewChild('backendPaginator', { static: true }) private _matBackendPaginatorRowRef: TemplateRef<any>;\n\n    @ContentChild('actions', { static: false }) actionsRef: TemplateRef<any>;\n    @ContentChild('actionsPopover', { static: false }) actionsPopoverRef: TemplateRef<any>;\n    @ContentChild('footer', { static: false }) footerRef: TemplateRef<any>;\n    @ContentChild('expanded', { static: false }) expandedRef: TemplateRef<any>;\n    @ContentChild('groupHeader', { static: false }) groupHeaderRef: TemplateRef<any>;\n    @ContentChild('groupFooter', { static: false }) groupFooterRef: TemplateRef<any>;\n\n    @Input() shadow: boolean = false;\n\n    @Input() columns: TableColumnDTO[] = [];\n\n    private _dataValue: T[];\n    @Input() get data(): T[] {\n        return this._dataValue;\n    }\n    set data(data: T[]) {\n        this._dataValue = data;\n        this.dataChange.emit(this._dataValue);\n    }\n\n    @Input() paginator: boolean = false;\n\n    @Input() backendPagination: boolean = true;\n\n    @Input() paginatorPageIndex: number = 0;\n\n    @Input() paginatorLength: number = 0;\n\n    @Input() paginatorPageSize: number = 10;\n\n    @Input() paginatorPageSizeOptions: number[] = [10, 20, 30];\n\n    @Input() showPageSizeOptions: boolean = false;\n\n    @Input() loading: boolean = false;\n\n    @Input() expandable: boolean = false;\n\n    @Input() showHeader: boolean = true;\n\n    @Input() columnInitial: number;\n\n    @Input() columnFinal: number;\n\n    @Input() headerSticky: boolean = false;\n\n    @Input() groupByColumn: string;\n\n    @Input() groupHeaderSticky: boolean = false;\n\n    @Input() groupStartExpanded: boolean = false;\n\n    @Input() highlightRowFn: (row: T | TableGroupHeaderDTO) => boolean;\n\n    @Input() infiniteScroll: boolean = false;\n\n    @Input() scrollDelay: number = 1000;\n\n    @Input() scrollOffset: number = 1000;\n\n    @Input() scrollHeigth: number;\n\n    @Input() isFiltering: boolean = false;\n\n    @Input('columnExpandableFixed') showColumnExpandableFixed: boolean = false;\n\n    @Input() expandableOneRow: boolean = false;\n\n    @Input() ignoreChildrenExpandRow: boolean = false;\n\n    @Input() clearSort: boolean = false;\n    @Input() sortActive: string = '';\n    @Input() sortDirection: SortDirection = 'asc';\n\n    @Output() rowExpandedChange: EventEmitter<T> = new EventEmitter<T>(true);\n    @Output() dataChange: EventEmitter<T[]> = new EventEmitter<T[]>(true);\n    @Output() page: EventEmitter<TablePageEventDTO> = new EventEmitter();\n    @Output() rowHover: EventEmitter<any> = new EventEmitter();\n\n    public get matTableHeigth(): Observable<string> {\n        let headerRowHeight: number;\n        if (!ObjectUtil.isNull(this._matHeaderRowRef)) {\n            headerRowHeight = (this._matHeaderRowRef.elementRef.nativeElement as HTMLElement).clientHeight;\n        }\n\n        let paginatorRowHeight: number;\n        const paginatorRef = this.backendPagination ? this._matBackendPaginatorRowRef : this._matFrontendPaginatorRowRef;\n        if (!ObjectUtil.isNull(paginatorRef)) {\n            paginatorRowHeight = (paginatorRef.elementRef.nativeElement as HTMLElement).clientHeight;\n        }\n\n        const matHeaderwHeight: number = headerRowHeight || 60;\n        const matPaginatorHeight: number = paginatorRowHeight || 57;\n\n        const pageSize: number = this.paginatorPageSize && (this.paginatorPageSize <= 10) ? this.paginatorPageSize : 10;\n        const setHeigth: boolean = this.headerSticky && (this.data.length > pageSize);\n\n        return of(setHeigth ? `${((57 * pageSize) + matHeaderwHeight + matPaginatorHeight)}px` : 'auto');\n    }\n\n    constructor() { }\n\n    ngOnInit(): void { }\n\n    ngAfterViewInit(): void {\n        setTimeout(() => {\n            if (!ObjectUtil.isNull(this._dataSource)) {\n                this._dataSource.sort = this.matSort;\n\n                if (this.paginator && !this.backendPagination && !this.infiniteScroll) {\n                    this._dataSource.paginator = this.matFrontendPaginator;\n                }\n            }\n\n            if (this.paginator && (this.backendPagination || this.infiniteScroll)) {\n                this.onPage({\n                    pageSize: this.paginatorPageSize,\n                    paginatorPageSizeOptions: this.paginatorPageSizeOptions,\n                    pageIndex: 0,\n                    length: 0,\n                    previousPageIndex: 0\n                });\n            }\n\n            if (!ObjectUtil.isNull(this.actionsPopoverRef)) {\n                this._contextPopover = null;\n                this._isPopoverHover = false;\n                this.closePopover(0);\n\n                const popover: HTMLElement = document.getElementById('table-popover');\n                if (!ObjectUtil.isNull(popover)) {\n                    popover.style.visibility = 'hidden';\n                }\n            }\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        setTimeout(() => {\n            if (changes.data) {\n                this._createDataSource();\n            }\n        });\n    }\n\n    private _createDataSource(): void {\n        let columns: string[] = this.columns.filter(c => c.visible).map(c => c.property);\n        if (!ObjectUtil.isNull(this.expandedRef)) {\n            columns = ['expandedColumn', ...columns];\n        }\n        if (!ObjectUtil.isNull(this.actionsRef)) {\n            columns = [...columns, 'actionsColumn'];\n        }\n        this._displayedColumns = columns;\n\n        if (this.infiniteScroll) {\n            let dataAll: T[] = [];\n\n            if (!this.isFiltering) {\n                if (!ObjectUtil.isNull(this._dataSource)) {\n                    dataAll = ArrayUtil.clone(this._dataSource.data);\n                }\n            }\n\n            if (!ArrayUtil.isEmpty(this.data)) {\n                dataAll.push(...this.data);\n            }\n\n            this._dataSource = new MatTableDataSource([]);\n            if (!StringUtil.isEmpty(this.groupByColumn) && !ObjectUtil.isNull(this.groupHeaderRef)) {\n                this._dataSource.data = this.genereteGroupsByColumn(dataAll);\n            } else {\n                this._dataSource.data = dataAll;\n            }\n\n            this.data = dataAll;\n            this.dataChange.emit(this.data);\n            this.calcScrollHeight();\n        } else {\n            this._dataSource = new MatTableDataSource([]);\n            if (!StringUtil.isEmpty(this.groupByColumn) && !ObjectUtil.isNull(this.groupHeaderRef)) {\n                this._dataSource.data = this.genereteGroupsByColumn(this.data);\n            } else {\n                this._dataSource.data = this.data;\n            }\n        }\n\n        if (!ArrayUtil.isEmpty(this._dataSource.data)) {\n            this._dataSource.sort = this.matSort;\n            this.setSortingDataAccessor();\n        }\n\n        if (this.paginator && !this.backendPagination) {\n            this._dataSource.paginator = this.matFrontendPaginator;\n        }\n\n        if (!this.groupStartExpanded && (this.groupHeaderRef || (this.expandable && this.expandedRef)) && !ArrayUtil.isEmpty(this._dataSource.data)) {\n            this._dataSource.data.forEach(row => this.addCollapse(row));\n        }\n    }\n\n    calcScrollHeight(): void {\n        if ((this._dataSource && (this._dataSource.data.length > 0)) && (Math.floor(this._scrollHeightCalc) <= 700)) {\n            this._scrollHeightCalc = 130 + (this._dataSource.data.length * 48);\n        }\n    }\n\n    onPage(pageEvent: TablePageEventDTO): void {\n        this.paginatorPageSize = pageEvent.pageSize;\n        pageEvent.paginatorPageSizeOptions = ArrayUtil.isEmpty(pageEvent.paginatorPageSizeOptions) ? this.paginatorPageSizeOptions : pageEvent.paginatorPageSizeOptions;\n        this.page.emit(pageEvent);\n    }\n\n    isExpansed(element: any): boolean {\n        return this._expandedElements.filter(e => ObjectUtil.equals(e, element)).length > 0;\n    }\n\n    removeCollapse(element: any): void {\n        if (this.expandableOneRow) {\n            this._dataSource.data.forEach(row => this.addCollapse(row));\n        }\n\n        const expandedElementsAux: any[] = ArrayUtil.clone(this._expandedElements);\n        expandedElementsAux.splice(this._expandedElements.indexOf(element), 1);\n        this._expandedElements = ArrayUtil.clone(expandedElementsAux);\n    }\n\n    addCollapse(element: any): void {\n        const collapsedElement: boolean = this._expandedElements.filter(e => ObjectUtil.equals(e, element)).length > 0;\n        if (!collapsedElement) {\n            this._expandedElements.push(element);\n        }\n    }\n\n    rowExpandedChangeEmit(element: any): void {\n        this.rowExpandedChange.emit(element);\n    }\n\n    sortData(sort: Sort): void {\n        if (this.infiniteScroll) {\n            this.data = [];\n            this.dataChange.emit([]);\n            this._dataSource = new MatTableDataSource([]);\n            this.calcScrollHeight();\n        }\n\n        this.onPage({\n            pageSize: this.paginatorPageSize,\n            pageIndex: 0,\n            length: 0,\n            previousPageIndex: 0,\n            paginatorPageSizeOptions: this.paginatorPageSizeOptions,\n            sort: sort\n        });\n    }\n\n    showPopover(event: MouseEvent, data: any): void {\n        const popover: HTMLElement = document.getElementById('table-popover');\n        if (!ObjectUtil.isNull(popover)) {\n            popover.style.visibility = 'hidden';\n\n            if (!this.loading) {\n                const domRectPopover = popover.getBoundingClientRect();\n                const domRectRow = (event.currentTarget as HTMLElement).getBoundingClientRect();\n                const cells = (event.currentTarget as HTMLTableRowElement).children;\n\n                if (domRectPopover && domRectRow) {\n                    popover.style.visibility = 'visible';\n                    popover.style.top = `${(domRectRow.top + domRectRow.height) - 1}px`;\n\n                    let startPosition: number = 0;\n                    let endPosition: number = 0;\n\n                    if (this.columnInitial && (this.columnInitial >= 0)) {\n                        if (!cells[this.columnInitial]) {\n                            throw new Error('Initial column undefined or null');\n                        }\n                        startPosition = cells[this.columnInitial].getBoundingClientRect().left;\n                    } else {\n                        startPosition = domRectRow.left;\n                    }\n\n                    if (this.columnFinal && (this.columnFinal >= 0)) {\n                        if (!cells[this.columnFinal]) {\n                            throw new Error('Final column undefined or null');\n                        }\n                        endPosition = cells[this.columnFinal].getBoundingClientRect().left - domRectPopover.width;\n                    } else {\n                        endPosition = domRectRow.right - domRectPopover.width;\n                    }\n\n                    setTimeout(() => {\n                        if (event.clientX > startPosition + 15 && event.clientX < endPosition) {\n                            popover.style.left = `${event.clientX - 15}px`;\n                        } else if (event.clientX <= startPosition) {\n                            popover.style.left = `${startPosition}px`;\n                        } else if (event.clientX >= endPosition) {\n                            popover.style.left = `${endPosition}px`;\n                        }\n                    });\n                }\n            }\n        }\n        this.rowHover.emit(data);\n        this._contextPopover = data;\n    }\n\n    closePopover(time: number): void {\n        of(null).pipe(delay(time)).subscribe(() => {\n            if (!ObjectUtil.isNull(this._isPopoverHover) && !this._isPopoverHover) {\n                if (!ObjectUtil.isNull(this._isPopoverHover) && !ObjectUtil.isNull(this.actionsPopoverRef)) {\n                    const popover: HTMLElement = document.getElementById('table-popover');\n                    if (!ObjectUtil.isNull(popover)) {\n                        popover.style.visibility = 'hidden';\n                    }\n                }\n                this._contextPopover = null;\n                this._isPopoverHover = null;\n            }\n        });\n    }\n\n    setSortingDataAccessor(): void {\n        this._dataSource.sortingDataAccessor = (data: any, sortHeaderId: string): string => {\n            if (typeof data[sortHeaderId] === 'string') {\n                return data[sortHeaderId].toLowerCase();\n            }\n            return data[sortHeaderId];\n        };\n    }\n\n    // group header\n    genereteGroupsByColumn(data: any[]): TableGroupHeaderDTO[] {\n        const groups: {} = data.reduce((group, row) => {\n            const dataColumn: string = row[this.groupByColumn].toString();\n            if (!group[dataColumn]) {\n                group[dataColumn] = [];\n            }\n            group[dataColumn].push(row);\n            return group;\n        }, {});\n\n        return Object.keys(groups).map(groupValue => {\n            return new TableGroupHeaderDTO(groupValue, groups[groupValue], groups[groupValue].length);\n        });\n    }\n\n    getHighlightRow(row: T | TableGroupHeaderDTO): boolean {\n        if (!ObjectUtil.isNull(row)) {\n            if (!ObjectUtil.isNull(this.highlightRowFn)) {\n                return this.highlightRowFn(row);\n            }\n            return false;\n        }\n        return false;\n    }\n\n    getIndexRow(row: T | TableGroupHeaderDTO): number {\n        if (!ObjectUtil.isNull(this._dataSource) && !ArrayUtil.isEmpty(this._dataSource.data) && !ObjectUtil.isNull(row)) {\n            return this._dataSource.data.findIndex(r => r === row);\n        }\n    }\n\n    // infinite scroll\n    hasMore(): boolean {\n        return !this._dataSource || (this._dataSource.data.length < this.paginatorLength);\n    }\n\n    handleScroll(scrolled: boolean): void {\n        if (scrolled && this.hasMore()) {\n            this.onPage({\n                pageSize: this.paginatorPageSize,\n                pageIndex: this.paginatorPageIndex,\n                length: this.paginatorLength,\n                previousPageIndex: this.paginatorPageIndex,\n            });\n\n            this.paginatorPageIndex += 1;\n        }\n    }\n\n}\n"]}
         
     | 
| 
      
 585 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["shared/components/table/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { AfterViewInit, Component, ContentChild, EventEmitter, Input, NgZone, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\nimport { MatHeaderRowDef, MatPaginator, MatSort, MatTableDataSource, Sort, SortDirection } from '@angular/material';\nimport { Observable, of } from 'rxjs';\nimport { delay } from 'rxjs/operators';\n\nimport { ArrayUtil, ObjectUtil, StringUtil } from '../../../core';\nimport { TableColumnDTO } from '../../../core/models/dto/table-column.dto';\nimport { TableGroupHeaderDTO } from '../../../core/models/dto/table-group-header.dto';\nimport { TablePageEventDTO } from '../../../core/models/dto/table-page-event.dto';\n\n\n@Component({\n    selector: 'itss-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss'],\n    animations: [\n        trigger('detailExpand', [\n            state('collapsed', style({ height: '0px', minHeight: '0', display: 'none' })),\n            state('expanded', style({ height: '*' })),\n            transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),\n        ]),\n    ],\n})\nexport class TableComponent<T> implements AfterViewInit, OnChanges, OnInit {\n\n    public _expandedRows: T[] = [];\n\n    public _scrollHeightCalc: number = 410;\n    public _isPopoverHover: any = null;\n    public _contextPopover: T;\n    public _displayedColumns: any[] = [];\n    public _dataSource: MatTableDataSource<T | TableGroupHeaderDTO>;\n\n    @ViewChild(MatSort, { static: true }) matSort: MatSort;\n    @ViewChild(MatPaginator, { static: true }) matPaginator: MatPaginator;\n    @ViewChild('frontendPaginator', { static: false }) matFrontendPaginator: MatPaginator;\n    @ViewChild('backendPaginator', { static: false }) matBackendPaginator: MatPaginator;\n\n    @ViewChild('matHeaderRow', { static: true }) private _matHeaderRowRef: TemplateRef<MatHeaderRowDef>;\n    @ViewChild('frontendPaginator', { static: true }) private _matFrontendPaginatorRowRef: TemplateRef<any>;\n    @ViewChild('backendPaginator', { static: true }) private _matBackendPaginatorRowRef: TemplateRef<any>;\n\n    @ContentChild('actions', { static: false }) actionsRef: TemplateRef<any>;\n    @ContentChild('actionsPopover', { static: false }) actionsPopoverRef: TemplateRef<any>;\n    @ContentChild('footer', { static: false }) footerRef: TemplateRef<any>;\n    @ContentChild('expanded', { static: false }) expandedRef: TemplateRef<any>;\n    @ContentChild('groupHeader', { static: false }) groupHeaderRef: TemplateRef<any>;\n    @ContentChild('groupFooter', { static: false }) groupFooterRef: TemplateRef<any>;\n\n    @Input() shadow: boolean = false;\n\n    @Input() columns: TableColumnDTO[] = [];\n\n    private _dataValue: T[];\n    @Input() get data(): T[] {\n        return this._dataValue;\n    }\n    set data(data: T[]) {\n        this._dataValue = data;\n        this.dataChange.emit(this._dataValue);\n    }\n\n    @Input() paginator: boolean = false;\n\n    @Input() backendPagination: boolean = true;\n\n    @Input() paginatorPageIndex: number = 0;\n\n    @Input() paginatorLength: number = 0;\n\n    @Input() paginatorPageSize: number = 10;\n\n    @Input() paginatorPageSizeOptions: number[] = [10, 20, 30];\n\n    @Input() showPageSizeOptions: boolean = false;\n\n    @Input() loading: boolean = false;\n\n    @Input() expandable: boolean = false;\n\n    @Input() showHeader: boolean = true;\n\n    @Input() columnInitial: number;\n\n    @Input() columnFinal: number;\n\n    @Input() headerSticky: boolean = false;\n\n    @Input() groupByColumn: string;\n\n    @Input() groupHeaderSticky: boolean = false;\n\n    @Input() groupStartExpanded: boolean = false;\n\n    @Input() highlightRowFn: (row: T | TableGroupHeaderDTO) => boolean;\n\n    @Input() infiniteScroll: boolean = false;\n\n    @Input() scrollDelay: number = 1000;\n\n    @Input() scrollOffset: number = 1000;\n\n    @Input() scrollHeigth: number;\n\n    @Input() isFiltering: boolean = false;\n\n    @Input('columnExpandableFixed') showColumnExpandableFixed: boolean = false;\n\n    @Input() expandableOneRow: boolean = false;\n\n    @Input() ignoreChildrenExpandRow: boolean = false;\n\n    @Input() sort: boolean = true;\n    @Input() clearSort: boolean = false;\n    @Input() sortActive: string = '';\n    @Input() sortDirection: SortDirection = 'asc';\n\n    @Output() rowExpanded: EventEmitter<T> = new EventEmitter();\n    @Output() dataChange: EventEmitter<T[]> = new EventEmitter(true);\n    @Output() page: EventEmitter<TablePageEventDTO> = new EventEmitter();\n    @Output() rowHover: EventEmitter<any> = new EventEmitter();\n\n    public get matTableHeigth(): Observable<string> {\n        let headerRowHeight: number;\n        if (!ObjectUtil.isNull(this._matHeaderRowRef)) {\n            headerRowHeight = (this._matHeaderRowRef.elementRef.nativeElement as HTMLElement).clientHeight;\n        }\n\n        let paginatorRowHeight: number;\n        const paginatorRef = this.backendPagination ? this._matBackendPaginatorRowRef : this._matFrontendPaginatorRowRef;\n        if (!ObjectUtil.isNull(paginatorRef)) {\n            paginatorRowHeight = (paginatorRef.elementRef.nativeElement as HTMLElement).clientHeight;\n        }\n\n        const matHeaderwHeight: number = headerRowHeight || 60;\n        const matPaginatorHeight: number = paginatorRowHeight || 57;\n\n        const pageSize: number = this.paginatorPageSize && (this.paginatorPageSize <= 10) ? this.paginatorPageSize : 10;\n        const setHeigth: boolean = this.headerSticky && (this.data.length > pageSize);\n\n        return of(setHeigth ? `${((57 * pageSize) + matHeaderwHeight + matPaginatorHeight)}px` : 'auto');\n    }\n\n    constructor(private _ngZone: NgZone) { }\n\n    ngOnInit(): void { }\n\n    ngAfterViewInit(): void {\n        setTimeout(() => {\n            if (!ObjectUtil.isNull(this._dataSource)) {\n                this._dataSource.sort = this.matSort;\n\n                if (this.paginator && !this.backendPagination && !this.infiniteScroll) {\n                    this._dataSource.paginator = this.matFrontendPaginator;\n                }\n            }\n\n            if (this.paginator && (this.backendPagination || this.infiniteScroll)) {\n                this.onPage({\n                    pageSize: this.paginatorPageSize,\n                    paginatorPageSizeOptions: this.paginatorPageSizeOptions,\n                    pageIndex: 0,\n                    length: 0,\n                    previousPageIndex: 0\n                });\n            }\n\n            if (!ObjectUtil.isNull(this.actionsPopoverRef)) {\n                this._contextPopover = null;\n                this._isPopoverHover = false;\n                this.closePopover(0);\n\n                const popover: HTMLElement = document.getElementById('table-popover');\n                if (!ObjectUtil.isNull(popover)) {\n                    popover.style.visibility = 'hidden';\n                }\n            }\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        setTimeout(() => {\n            if (changes.data) {\n                this._createDataSource();\n            }\n        });\n    }\n\n    private _createDataSource(): void {\n        let columns: string[] = this.columns.filter(c => c.visible).map(c => c.property);\n        if (!ObjectUtil.isNull(this.expandedRef)) {\n            columns = ['expandedColumn', ...columns];\n        }\n        if (!ObjectUtil.isNull(this.actionsRef)) {\n            columns = [...columns, 'actionsColumn'];\n        }\n        this._displayedColumns = columns;\n\n        if (this.infiniteScroll) {\n            let dataAll: T[] = [];\n\n            if (!this.isFiltering) {\n                if (!ObjectUtil.isNull(this._dataSource)) {\n                    dataAll = ArrayUtil.clone(this._dataSource.data);\n                }\n            }\n\n            if (!ArrayUtil.isEmpty(this.data)) {\n                dataAll.push(...this.data);\n            }\n\n            this._dataSource = new MatTableDataSource([]);\n            if (!StringUtil.isEmpty(this.groupByColumn) && !ObjectUtil.isNull(this.groupHeaderRef)) {\n                this._dataSource.data = this.genereteGroupsByColumn(dataAll);\n            } else {\n                this._dataSource.data = dataAll;\n            }\n\n            this.data = dataAll;\n            this.dataChange.emit(this.data);\n            this.calcScrollHeight();\n        } else {\n            this._dataSource = new MatTableDataSource([]);\n            if (!StringUtil.isEmpty(this.groupByColumn) && !ObjectUtil.isNull(this.groupHeaderRef)) {\n                this._dataSource.data = this.genereteGroupsByColumn(this.data);\n            } else {\n                this._dataSource.data = this.data;\n            }\n        }\n\n        if (!ArrayUtil.isEmpty(this._dataSource.data)) {\n            this._dataSource.sort = this.matSort;\n            this.setSortingDataAccessor();\n        }\n\n        if (this.paginator && !this.backendPagination) {\n            this._dataSource.paginator = this.matFrontendPaginator;\n        }\n\n        // if (!this.groupStartExpanded && (this.groupHeaderRef || (this.expandable && this.expandedRef)) && !ArrayUtil.isEmpty(this._dataSource.data)) {\n        // this._dataSource.data.forEach(row => this.addCollapse(row));\n        // }\n    }\n\n    calcScrollHeight(): void {\n        if ((this._dataSource && (this._dataSource.data.length > 0)) && (Math.floor(this._scrollHeightCalc) <= 700)) {\n            this._scrollHeightCalc = 130 + (this._dataSource.data.length * 48);\n        }\n    }\n\n    onPage(pageEvent: TablePageEventDTO): void {\n        this.paginatorPageSize = pageEvent.pageSize;\n        pageEvent.paginatorPageSizeOptions = ArrayUtil.isEmpty(pageEvent.paginatorPageSizeOptions) ? this.paginatorPageSizeOptions : pageEvent.paginatorPageSizeOptions;\n        this.page.emit(pageEvent);\n    }\n\n    public isExpandedRow(row: T): Observable<boolean> {\n        if (ArrayUtil.isEmpty(this._expandedRows)) {\n            return of(false);\n        }\n\n        const index: number = this._expandedRows.findIndex(r => r === row);\n        return of(index >= 0);\n    }\n\n    public toggleExpandRow(row: T): void {\n        const index: number = this._expandedRows.findIndex(r => r === row);\n        if (ArrayUtil.isEmpty(this._expandedRows) || (index < 0)) {\n            this._expandedRows = [row];\n            this.rowExpanded.emit(row);\n            return;\n        }\n\n        const _expandedRowsAux: T[] = ArrayUtil.clone(this._expandedRows);\n        _expandedRowsAux.splice(index, 1);\n        this._expandedRows = ArrayUtil.clone(_expandedRowsAux);\n        this.rowExpanded.emit(null);\n    }\n\n    sortData(sort: Sort): void {\n        if (this.infiniteScroll) {\n            this.data = [];\n            this.dataChange.emit([]);\n            this._dataSource = new MatTableDataSource([]);\n            this.calcScrollHeight();\n        }\n\n        this.onPage({\n            pageSize: this.paginatorPageSize,\n            pageIndex: 0,\n            length: 0,\n            previousPageIndex: 0,\n            paginatorPageSizeOptions: this.paginatorPageSizeOptions,\n            sort: sort\n        });\n    }\n\n    public showPopover(event: MouseEvent, data: any): void {\n        const popover: HTMLElement = document.getElementById('table-popover');\n        if (!ObjectUtil.isNull(popover)) {\n            popover.style.visibility = 'hidden';\n\n            if (!this.loading) {\n                this._ngZone.runOutsideAngular(() => {\n                    const domRectPopover = popover.getBoundingClientRect();\n                    const domRectRow = (event.currentTarget as HTMLElement).getBoundingClientRect();\n                    const cells = (event.currentTarget as HTMLTableRowElement).children;\n\n                    if (domRectPopover && domRectRow) {\n                        popover.style.visibility = 'visible';\n                        popover.style.top = `${(domRectRow.top + domRectRow.height) - 1}px`;\n\n                        let startPosition: number = 0;\n                        let endPosition: number = 0;\n\n                        if (this.columnInitial && (this.columnInitial >= 0)) {\n                            if (!cells[this.columnInitial]) {\n                                throw new Error('Initial column undefined or null');\n                            }\n                            startPosition = cells[this.columnInitial].getBoundingClientRect().left;\n                        } else {\n                            startPosition = domRectRow.left;\n                        }\n\n                        if (this.columnFinal && (this.columnFinal >= 0)) {\n                            if (!cells[this.columnFinal]) {\n                                throw new Error('Final column undefined or null');\n                            }\n                            endPosition = cells[this.columnFinal].getBoundingClientRect().left - domRectPopover.width;\n                        } else {\n                            endPosition = domRectRow.right - domRectPopover.width;\n                        }\n\n                        this._ngZone.run(() => {\n                            if (event.clientX > startPosition + 15 && event.clientX < endPosition) {\n                                popover.style.left = `${event.clientX - 15}px`;\n                            } else if (event.clientX <= startPosition) {\n                                popover.style.left = `${startPosition}px`;\n                            } else if (event.clientX >= endPosition) {\n                                popover.style.left = `${endPosition}px`;\n                            }\n                        });\n                    }\n                });\n            }\n        }\n        this.rowHover.emit(data);\n        this._contextPopover = data;\n    }\n\n    /**\n    showPopover(event: MouseEvent, data: any): void {\n        const popover: HTMLElement = document.getElementById('table-popover');\n        if (!ObjectUtil.isNull(popover)) {\n            popover.style.visibility = 'hidden';\n\n            if (!this.loading) {\n                const domRectPopover = popover.getBoundingClientRect();\n                const domRectRow = (event.currentTarget as HTMLElement).getBoundingClientRect();\n                const cells = (event.currentTarget as HTMLTableRowElement).children;\n\n                if (domRectPopover && domRectRow) {\n                    popover.style.visibility = 'visible';\n                    popover.style.top = `${(domRectRow.top + domRectRow.height) - 1}px`;\n\n                    let startPosition: number = 0;\n                    let endPosition: number = 0;\n\n                    if (this.columnInitial && (this.columnInitial >= 0)) {\n                        if (!cells[this.columnInitial]) {\n                            throw new Error('Initial column undefined or null');\n                        }\n                        startPosition = cells[this.columnInitial].getBoundingClientRect().left;\n                    } else {\n                        startPosition = domRectRow.left;\n                    }\n\n                    if (this.columnFinal && (this.columnFinal >= 0)) {\n                        if (!cells[this.columnFinal]) {\n                            throw new Error('Final column undefined or null');\n                        }\n                        endPosition = cells[this.columnFinal].getBoundingClientRect().left - domRectPopover.width;\n                    } else {\n                        endPosition = domRectRow.right - domRectPopover.width;\n                    }\n\n                    setTimeout(() => {\n                        if (event.clientX > startPosition + 15 && event.clientX < endPosition) {\n                            popover.style.left = `${event.clientX - 15}px`;\n                        } else if (event.clientX <= startPosition) {\n                            popover.style.left = `${startPosition}px`;\n                        } else if (event.clientX >= endPosition) {\n                            popover.style.left = `${endPosition}px`;\n                        }\n                    });\n                }\n            }\n        }\n        this.rowHover.emit(data);\n        this._contextPopover = data;\n    }\n    */\n\n    closePopover(time: number): void {\n        of(null).pipe(delay(time)).subscribe(() => {\n            if (!ObjectUtil.isNull(this._isPopoverHover) && !this._isPopoverHover) {\n                if (!ObjectUtil.isNull(this._isPopoverHover) && !ObjectUtil.isNull(this.actionsPopoverRef)) {\n                    const popover: HTMLElement = document.getElementById('table-popover');\n                    if (!ObjectUtil.isNull(popover)) {\n                        popover.style.visibility = 'hidden';\n                    }\n                }\n                this._contextPopover = null;\n                this._isPopoverHover = null;\n            }\n        });\n    }\n\n    setSortingDataAccessor(): void {\n        this._dataSource.sortingDataAccessor = (data: any, sortHeaderId: string): string => {\n            if (typeof data[sortHeaderId] === 'string') {\n                return data[sortHeaderId].toLowerCase();\n            }\n            return data[sortHeaderId];\n        };\n    }\n\n    // group header\n    genereteGroupsByColumn(data: any[]): TableGroupHeaderDTO[] {\n        const groups: {} = data.reduce((group, row) => {\n            const dataColumn: string = row[this.groupByColumn].toString();\n            if (!group[dataColumn]) {\n                group[dataColumn] = [];\n            }\n            group[dataColumn].push(row);\n            return group;\n        }, {});\n\n        return Object.keys(groups).map(groupValue => {\n            return new TableGroupHeaderDTO(groupValue, groups[groupValue], groups[groupValue].length);\n        });\n    }\n\n    getHighlightRow(row: T | TableGroupHeaderDTO): boolean {\n        if (!ObjectUtil.isNull(row)) {\n            if (!ObjectUtil.isNull(this.highlightRowFn)) {\n                return this.highlightRowFn(row);\n            }\n            return false;\n        }\n        return false;\n    }\n\n    getIndexRow(row: T | TableGroupHeaderDTO): number {\n        if (!ObjectUtil.isNull(this._dataSource) && !ArrayUtil.isEmpty(this._dataSource.data) && !ObjectUtil.isNull(row)) {\n            return this._dataSource.data.findIndex(r => r === row);\n        }\n    }\n\n    // infinite scroll\n    hasMore(): boolean {\n        return !this._dataSource || (this._dataSource.data.length < this.paginatorLength);\n    }\n\n    handleScroll(scrolled: boolean): void {\n        if (scrolled && this.hasMore()) {\n            this.onPage({\n                pageSize: this.paginatorPageSize,\n                pageIndex: this.paginatorPageIndex,\n                length: this.paginatorLength,\n                previousPageIndex: this.paginatorPageIndex,\n            });\n\n            this.paginatorPageIndex += 1;\n        }\n    }\n\n}\n"]}
         
     | 
| 
         @@ -399,7 +399,7 @@ GIPIInputMonthPickerComponent = GIPIInputMonthPickerComponent_1 = __decorate([ 
     | 
|
| 
       399 
399 
     | 
    
         
             
                        'class': 'gipi-input-monthpicker',
         
     | 
| 
       400 
400 
     | 
    
         
             
                    },
         
     | 
| 
       401 
401 
     | 
    
         
             
                    changeDetection: ChangeDetectionStrategy.OnPush,
         
     | 
| 
       402 
     | 
    
         
            -
                    styles: [".input-monthpicker-container{display:flex;flex-direction:column;gap:12px;width:100%}.input-monthpicker-container .input-monthpicker-label{color:#131313;font-size:1.4rem;line-height:100%}.input-monthpicker-container .input-monthpicker-label>span{color:#d14014;font-size:inherit;line-height:inherit}.input-monthpicker-container .input-monthpicker-content{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:12px;width:100%;max-height:4rem;border-radius:5px;cursor:text;background-color:#fff;border:1px solid rgba(0,0,0,.12);color:#696969;caret-color:#9a9da2;transition:.2s;position:relative}.input-monthpicker-container .input-monthpicker-content:focus-within,.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:active),.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:focus){box-shadow:0 0 0 .2rem #f0f0f0}.input-monthpicker-container .input-monthpicker-content:focus-within,.input-monthpicker-container .input-monthpicker-content:hover{border-color:#bfbfbf!important}.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input: 
     | 
| 
      
 402 
     | 
    
         
            +
                    styles: [".input-monthpicker-container{display:flex;flex-direction:column;gap:12px;width:100%}.input-monthpicker-container .input-monthpicker-label{color:#131313;font-size:1.4rem;line-height:100%}.input-monthpicker-container .input-monthpicker-label>span{color:#d14014;font-size:inherit;line-height:inherit}.input-monthpicker-container .input-monthpicker-content{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:12px;width:100%;max-height:4rem;border-radius:5px;cursor:text;background-color:#fff;border:1px solid rgba(0,0,0,.12);color:#696969;caret-color:#9a9da2;transition:.2s;position:relative}.input-monthpicker-container .input-monthpicker-content:focus-within,.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:active),.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:focus){box-shadow:0 0 0 .2rem #f0f0f0}.input-monthpicker-container .input-monthpicker-content:focus-within,.input-monthpicker-container .input-monthpicker-content:hover{border-color:#bfbfbf!important}.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:disabled){border-color:#e0e1e2!important;color:#d1d2d4!important;box-shadow:none!important;cursor:not-allowed!important;caret-color:#d1d2d4!important;pointer-events:none!important}.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:disabled) .input-monthpicker-input,.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:disabled) .input-monthpicker-suffix .input-monthpicker-button{cursor:not-allowed!important;pointer-events:none!important}.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:disabled) .input-monthpicker-suffix .input-monthpicker-trigger{border-color:#e0e1e2!important;pointer-events:none!important}.input-monthpicker-container .input-monthpicker-content:has(.input-monthpicker-input:disabled) mat-icon{color:#d1d2d4!important;fill:#d1d2d4!important;cursor:not-allowed!important;pointer-events:none!important}.input-monthpicker-container .input-monthpicker-content .input-monthpicker-input{height:16px;max-width:84%;outline:0;border:none;background-color:transparent;color:inherit;flex:1}.input-monthpicker-container .input-monthpicker-content .input-monthpicker-suffix{display:flex;flex-direction:row;align-items:center;gap:16px}.input-monthpicker-container .input-monthpicker-content .input-monthpicker-suffix .input-monthpicker-button{display:flex;align-items:center;justify-content:center;outline:0;border:none;cursor:pointer;background-color:transparent}.input-monthpicker-container .input-monthpicker-content .input-monthpicker-suffix .input-monthpicker-button:hover:not(:disabled)>mat-icon{transform:scale(1.08)}.input-monthpicker-icon{width:1.6rem;height:1.6rem;font-size:1.6rem;color:#131313;fill:#131313}::ng-deep .calendar{width:100%;display:flex;flex-direction:column}::ng-deep .calendar .calendar-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;padding-bottom:10px;border-bottom:1px solid #aeb1b5;margin-bottom:8px}::ng-deep .calendar .calendar-header .calendar-title{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:1.6rem;line-height:1.8rem;font-weight:600;cursor:default;border-radius:8px;padding:8px;white-space:nowrap}::ng-deep .calendar .calendar-header .calendar-title>mat-icon{font-size:2rem;width:20px;height:20px}::ng-deep .calendar .calendar-header .calendar-title.month:hover{cursor:pointer;background-color:#f0f0f0}::ng-deep .calendar .calendar-header .calendar-controls{display:flex;flex-direction:row;align-items:center;gap:8px}::ng-deep .calendar .calendar-header .calendar-controls>button{display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;background-color:#e0313e;cursor:pointer;transition:.3s;border:0;outline:0;color:#fff}::ng-deep .calendar .calendar-header .calendar-controls>button:hover{background-color:#cc2d38}::ng-deep .calendar .calendar-header .calendar-controls>button>mat-icon{font-size:1.8rem;width:18px;height:18px}::ng-deep .calendar .table-months{display:-ms-grid;display:grid;-ms-grid-columns:(1fr)[3];grid-template-columns:repeat(3,1fr);gap:4px}::ng-deep .calendar .table-months .month{display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;font-size:1.4rem;line-height:1.7rem;color:#555659;background-color:#f0f0f0;transition:background-color .1s;cursor:pointer}::ng-deep .calendar .table-months .month.disabled{color:#bbbdc1;background-color:#e0e1e2}::ng-deep .calendar .table-months .month:not(.disabled).selected,::ng-deep .calendar .table-months .month:not(.disabled):hover{color:#fff;background-color:#e0313e}::ng-deep .calendar .table-months .month:not(.disabled).selected:hover{background-color:#cc2d38}::ng-deep .calendar .table-years{display:-ms-grid;display:grid;-ms-grid-columns:(1fr)[4];grid-template-columns:repeat(4,1fr);gap:4px}::ng-deep .calendar .table-years .year{display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;font-size:1.4rem;line-height:1.7rem;color:#555659;background-color:#f0f0f0;transition:background-color .1s;cursor:pointer}::ng-deep .calendar .table-years .year.disabled{color:#bbbdc1;background-color:#e0e1e2}::ng-deep .calendar .table-years .year:not(.disabled).selected,::ng-deep .calendar .table-years .year:not(.disabled):hover{color:#fff;background-color:#e0313e}::ng-deep .calendar .table-years .year:not(.disabled).selected:hover{background-color:#cc2d38}"]
         
     | 
| 
       403 
403 
     | 
    
         
             
                }),
         
     | 
| 
       404 
404 
     | 
    
         
             
                __metadata("design:paramtypes", [ChangeDetectorRef,
         
     | 
| 
       405 
405 
     | 
    
         
             
                    GIPINgConfig])
         
     | 
| 
         @@ -445,7 +445,7 @@ MonthYearPickerComponent = MonthYearPickerComponent_1 = __decorate([ 
     | 
|
| 
       445 
445 
     | 
    
         
             
                        'class': 'gipi-month-year-picker',
         
     | 
| 
       446 
446 
     | 
    
         
             
                    },
         
     | 
| 
       447 
447 
     | 
    
         
             
                    changeDetection: ChangeDetectionStrategy.OnPush,
         
     | 
| 
       448 
     | 
    
         
            -
                    styles: [":host{display:block;width:100%}.input-wrapper{display:flex;flex-direction:column;gap:.8rem;font-size:1.4rem;color:#696969}.input-wrapper .input-label{display:flex;align-items:center;gap:.4rem;color:#131313;line-height:1.6rem}.input-wrapper .input-label>span{font-size:1.6rem;line-height:1.6rem;color:#d14014}.input-wrapper .input-content{display:flex;font-family:inherit;font-size:inherit;color:inherit;height:4rem;background:#fff;border:1px solid rgba(0,0,0,.12);transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.6rem}.input-wrapper .input-content .input-element{padding:.75rem .8rem;border:none;outline:0;background-color:transparent;flex:1;color:inherit;caret-color:#696969;min-width:0}.input-wrapper .input-content:not(.input-element:disabled):has(.input-element:enabled:hover),.input-wrapper .input-content:not(.input-element:disabled):has(.prefix:hover),.input-wrapper .input-content:not(.input-element:disabled):has(.suffix:hover){border-color:#6d6f73}.input-wrapper .input-content:not(.input-element:disabled):has(.input-element 
     | 
| 
      
 448 
     | 
    
         
            +
                    styles: [":host{display:block;width:100%}.input-wrapper{display:flex;flex-direction:column;gap:.8rem;font-size:1.4rem;color:#696969}.input-wrapper .input-label{display:flex;align-items:center;gap:.4rem;color:#131313;line-height:1.6rem}.input-wrapper .input-label>span{font-size:1.6rem;line-height:1.6rem;color:#d14014}.input-wrapper .input-content{display:flex;font-family:inherit;font-size:inherit;color:inherit;height:4rem;background:#fff;border:1px solid rgba(0,0,0,.12);transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.6rem}.input-wrapper .input-content .input-element{padding:.75rem .8rem;border:none;outline:0;background-color:transparent;flex:1;color:inherit;caret-color:#696969;min-width:0}.input-wrapper .input-content:not(.input-element:disabled):has(.input-element:enabled:hover),.input-wrapper .input-content:not(.input-element:disabled):has(.prefix:hover),.input-wrapper .input-content:not(.input-element:disabled):has(.suffix:hover){border-color:#6d6f73}.input-wrapper .input-content:not(.input-element:disabled):has(.input-element:enabled:focus){outline:0;outline-offset:0;box-shadow:0 0 0 .2rem #e0e1e2;border-color:#6d6f73}.input-wrapper .input-content:has(.input-element:disabled){color:#bbbdc1!important;border-color:#e0e1e2!important;background-color:#f5f5f6!important;cursor:not-allowed}.input-wrapper .input-content:has(.input-element:disabled) .suffix>mat-icon{color:#bbbdc1!important}.input-wrapper .input-content .input-element:disabled{cursor:not-allowed}.input-wrapper .input-content .suffix{display:flex;align-items:center;justify-content:center;padding-block:.75rem;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding-right:.8rem}.input-wrapper .input-content .suffix>mat-icon{width:2rem;height:2rem;font-size:2rem;color:#696969}.input-wrapper .input-help{flex:1;font-size:1rem;font-weight:500;margin-top:-.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.month-year-toggle-default-icon{display:block;width:1.5em;height:1.5em}.mat-icon-button .month-year-toggle-default-icon{margin:auto}.btn-month-year-toggle{width:2rem!important;height:2rem!important;line-height:2rem!important}"]
         
     | 
| 
       449 
449 
     | 
    
         
             
                }),
         
     | 
| 
       450 
450 
     | 
    
         
             
                __param(5, Inject(GIPI_MONTH_YEAR_SCROLL_STRATEGY)),
         
     | 
| 
       451 
451 
     | 
    
         
             
                __param(6, Optional()),
         
     |