ngx-vector-components 4.20.0 → 4.20.1
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/CHANGELOG.md +6 -0
- package/esm2020/lib/components/fields/data-table/data-table.component.mjs +2 -1
- package/esm2020/lib/services/menu.service.mjs +1 -1
- package/fesm2015/ngx-vector-components.mjs +1 -1
- package/fesm2015/ngx-vector-components.mjs.map +1 -1
- package/fesm2020/ngx-vector-components.mjs +1 -0
- package/fesm2020/ngx-vector-components.mjs.map +1 -1
- package/lib/services/menu.service.d.ts +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -143,6 +143,7 @@ export class DataTableComponent {
|
|
|
143
143
|
this._lastLazyLoadEvent = {
|
|
144
144
|
...this._lastLazyLoadEvent,
|
|
145
145
|
...params.data,
|
|
146
|
+
start: 0,
|
|
146
147
|
};
|
|
147
148
|
if (this._tabSelected) {
|
|
148
149
|
this._lastLazyLoadEvent = {
|
|
@@ -288,4 +289,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
288
289
|
type: ViewChild,
|
|
289
290
|
args: [FiltersComponent, { static: true }]
|
|
290
291
|
}] } });
|
|
291
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { DateTime } from 'luxon';\r\nimport { Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { FilterChangedEvent, ListItem, Status } from '../../../models';\r\nimport { DataTableLazyLoadEvent, TableColumn, TableColumnType } from '../../../models/data-table.model';\r\nimport { MaskUtil } from '../../../utils';\r\nimport { FilterField, FiltersComponent } from '../filters/filters.component';\r\n\r\n@Component({\r\n  selector: 'vector-data-table',\r\n  templateUrl: './data-table.component.html',\r\n  styleUrls: ['./data-table.component.scss'],\r\n})\r\nexport class DataTableComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  public columns: TableColumn[] = [];\r\n  @Input()\r\n  public data: any[] = [];\r\n  @Input()\r\n  public exportExcel = false;\r\n  @Input()\r\n  public exportPDF = false;\r\n  @Input()\r\n  public totalRecords = 0;\r\n  @Input()\r\n  public filters: FilterField[] = [];\r\n  @Input()\r\n  public addItemLabel = '';\r\n  @Input()\r\n  public pagination = true;\r\n  @Input()\r\n  public virtualPagination = false;\r\n  @Input()\r\n  public set tabs(_tabs: ListItem[]) {\r\n    this._tabs = _tabs;\r\n    this._tabSelected = _tabs[0];\r\n  }\r\n  @Input()\r\n  public customButtons: { label: string; clickFunction: Function }[] | undefined;\r\n  @Input()\r\n  public addItemButtonPlusSign = false;\r\n  @Input()\r\n  public hasActions: boolean = true;\r\n  @Input()\r\n  public set selectionMode(_selectionMode) {\r\n    switch (_selectionMode) {\r\n      case 'single':\r\n        this._selectionMode = 'single';\r\n        break;\r\n      case 'multiple':\r\n        this._selectionMode = 'multiple';\r\n        break;\r\n      default:\r\n        this._selectionMode = null;\r\n        break;\r\n    }\r\n  }\r\n  @Input()\r\n  public selectionType: 'checkbox' | 'radiobutton' | null = null;\r\n  @Input()\r\n  public set height(_height: string) {\r\n    switch (_height) {\r\n      case 'small':\r\n        this._height = '300px';\r\n        break;\r\n      case 'medium':\r\n        this._height = '500px';\r\n        break;\r\n      case 'large':\r\n        this._height = '700px';\r\n        break;\r\n      case 'full':\r\n        this._height = 'flex';\r\n        break;\r\n      default:\r\n        this._height = '300px';\r\n    }\r\n  }\r\n  @Output()\r\n  public onLazyLoad = new EventEmitter<DataTableLazyLoadEvent>();\r\n  @Output()\r\n  public onFilter = new EventEmitter<any>();\r\n  @Output()\r\n  public onAdd = new EventEmitter<void>();\r\n  @Output()\r\n  public onExportExcel = new EventEmitter<void>();\r\n  @Output()\r\n  public onExportPDF = new EventEmitter<void>();\r\n  @Output()\r\n  public onSelectedRows = new EventEmitter<any>();\r\n  @Output()\r\n  public onFilterChanged = new EventEmitter<FilterChangedEvent>();\r\n  @ViewChild(FiltersComponent, { static: true })\r\n  public filtersComponent: FiltersComponent | undefined;\r\n\r\n  public selectedItems: any = [];\r\n\r\n  get tabs() {\r\n    return this._tabs;\r\n  }\r\n  get height() {\r\n    return this._height;\r\n  }\r\n  get selectionMode() {\r\n    return this._selectionMode;\r\n  }\r\n\r\n  private _selectionMode: 'single' | 'multiple' | null = null;\r\n  private _height: string = 'small';\r\n  private _tabs: ListItem[] = [];\r\n  private _draw = 1;\r\n  private _firstLazyLoadedDone = false;\r\n  private _lastLazyLoadEvent: DataTableLazyLoadEvent | undefined;\r\n  private _tabSelected: ListItem | undefined;\r\n  private _filterSubscription = new Subscription();\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    if (!this.height) {\r\n      this.height = 'small';\r\n    }\r\n\r\n    if (!this.pagination || this.virtualPagination) {\r\n      this.filtersComponent?.search();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._filterSubscription.unsubscribe();\r\n  }\r\n\r\n  getColStyle(col: TableColumn) {\r\n    return { 'min-width': col.width };\r\n  }\r\n\r\n  lazyLoaded(params: { filter: boolean; data: any } = { filter: false, data: { start: 0, rows: 10 } }) {\r\n    if (!params.filter) {\r\n      const columns = this.columns.map((col) => {\r\n        return {\r\n          data: col.field,\r\n          name: `${col.field.substring(0, 1).toUpperCase()}${col.field.substring(1, col.field.length)}`,\r\n          orderable: true,\r\n          search: { value: '', regex: false },\r\n          searchable: true,\r\n        };\r\n      });\r\n      if (this.hasActions) {\r\n        columns.unshift({\r\n          data: 'active',\r\n          name: 'Active',\r\n          orderable: true,\r\n          search: { value: '', regex: false },\r\n          searchable: true,\r\n        });\r\n      }\r\n      this._lastLazyLoadEvent = {\r\n        ...(this._lastLazyLoadEvent || ({} as any)),\r\n        start: params.data.first,\r\n        length: params.data.rows,\r\n        draw: this._draw++,\r\n        order: params.data.sortField\r\n          ? [\r\n              {\r\n                column:\r\n                  this.columns.findIndex((col) => col.field === params.data.sortField) + (this.hasActions ? 1 : 0),\r\n                dir: params.data.sortOrder > 0 ? 'asc' : 'desc',\r\n              },\r\n            ]\r\n          : [{ column: 0, dir: 'desc' }],\r\n        columns: columns,\r\n      };\r\n    } else {\r\n      this._lastLazyLoadEvent = {\r\n        ...this._lastLazyLoadEvent,\r\n        ...params.data,\r\n      };\r\n      if (this._tabSelected) {\r\n        this._lastLazyLoadEvent = {\r\n          ...(this._lastLazyLoadEvent || ({} as any)),\r\n          ...{ Status: this._tabSelected.code },\r\n        };\r\n      }\r\n    }\r\n\r\n    if (this._firstLazyLoadedDone) {\r\n      this.onLazyLoad.emit(this._lastLazyLoadEvent);\r\n    }\r\n    this._firstLazyLoadedDone = true;\r\n  }\r\n\r\n  getCellContent(item: any, col: TableColumn) {\r\n    let content = `<span class=\"p-column-title\">${col.header}</span><span class=\"w-100\">`;\r\n    if (!col.type || col.type === TableColumnType.TEXT) {\r\n      content += item[col.field] || '';\r\n    }\r\n\r\n    if (col.type === TableColumnType.CUSTOM_STYLE) {\r\n      content += `<span class=\"${col.textFieldClass ? item[col.textFieldClass] : ''}\">${item[col.field || '']}</span>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.BOOLEAN) {\r\n      content += `<div class=\"text-centered\"><i class=\" status-table-field fas fa-${\r\n        item[col.field] ? 'check boolean-value-positive' : 'times boolean-value-negative'\r\n      }\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.ENUM && col.getEnumTranslated) {\r\n      content += col.getEnumTranslated(item[col.field]);\r\n    }\r\n\r\n    if (col.type === TableColumnType.DATETIME && item[col.field]) {\r\n      const dateTime =\r\n        item[col.field] instanceof Date ? DateTime.fromJSDate(item[col.field]) : DateTime.fromISO(item[col.field]);\r\n      content += dateTime.toFormat('dd/MM/yyyy HH:mm');\r\n    }\r\n\r\n    if (col.type === TableColumnType.STATUS_BADGE) {\r\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getStatusColor(\r\n        item[col.field]\r\n      )}\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.ACTIVE_BOOLEAN_BADGE) {\r\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getActiveStatusColor(\r\n        item[col.field]\r\n      )}\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.BUTTON) {\r\n      content += `<div class=\"text-centered\"><i class=\"fas ${\r\n        col.icon || 'fa-circle'\r\n      } status-table-field table-button\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.MASK) {\r\n      content += MaskUtil.doMaskString(item[col.field] || '', col.mask);\r\n    }\r\n\r\n    content += `</span>`;\r\n    return content;\r\n  }\r\n\r\n  onTabChange($event: any) {\r\n    this._tabSelected = this.tabs[$event.index];\r\n    this.lazyLoaded({ filter: true, data: {} });\r\n  }\r\n\r\n  subscribeToFilterChanges() {\r\n    this._filterSubscription.unsubscribe();\r\n    this._filterSubscription = new Subscription();\r\n    Object.keys(this.filtersComponent?.formGroup.controls || {}).forEach((key) => {\r\n      this._filterSubscription.add(\r\n        this.filtersComponent?.formGroup\r\n          .get(key)\r\n          ?.valueChanges.pipe(debounceTime(300))\r\n          .subscribe((value) => {\r\n            this.onFilterChanged.emit({ field: key, value });\r\n          })\r\n      );\r\n      this.onFilterChanged.emit({ field: key, value: this.filtersComponent?.formGroup.get(key)?.value });\r\n    });\r\n  }\r\n\r\n  get listHasActions() {\r\n    return this.data.some((item) => item.actions?.length);\r\n  }\r\n\r\n  private getStatusColor(status: Status) {\r\n    switch (status) {\r\n      case Status.PENDING:\r\n        return 'warning';\r\n      case Status.APPROVED:\r\n        return 'success';\r\n      case Status.REJECTED:\r\n        return 'error';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  private getActiveStatusColor(active: boolean) {\r\n    return active ? 'success' : 'error';\r\n  }\r\n\r\n  public changeSelectedItems(value: any) {\r\n    this.onSelectedRows.emit(this.selectedItems);\r\n  }\r\n\r\n  public isHtmlCell(col: TableColumn) {\r\n    if (!col.type) {\r\n      return true;\r\n    }\r\n    return ![TableColumnType.TEXT_BADGE].includes(col.type);\r\n  }\r\n}\r\n","<div class=\"grid\">\r\n  <div class=\"col-12\">\r\n    <vector-filters\r\n      [fields]=\"filters\"\r\n      (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\r\n      (formBuilded)=\"subscribeToFilterChanges()\"\r\n    ></vector-filters>\r\n  </div>\r\n  <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\r\n    <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\r\n      <i class=\"fas fa-file\"></i><span>Excel</span>\r\n    </button>\r\n    <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\r\n      <i class=\"fas fa-file\"></i><span>PDF</span>\r\n    </button>\r\n    <vector-button\r\n      *ngFor=\"let button of customButtons\"\r\n      class=\"add-item-button\"\r\n      [label]=\"button.label\"\r\n      (click)=\"button.clickFunction()\"\r\n      [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\r\n    ></vector-button>\r\n    <vector-button\r\n      *ngIf=\"addItemLabel\"\r\n      class=\"add-item-button\"\r\n      [label]=\"addItemLabel\"\r\n      (click)=\"onAdd.emit()\"\r\n      [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\r\n    ></vector-button>\r\n  </div>\r\n  <div class=\"col-12\">\r\n    <vector-panel class=\"data-table-panel\">\r\n      <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\r\n        <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\r\n      </p-tabView>\r\n      <p-table\r\n        currentPageReportTemplate=\"Mostrando {first} até {last} de {totalRecords} registros\"\r\n        sortMode=\"single\"\r\n        [rows]=\"10\"\r\n        [lazy]=\"pagination && !virtualPagination\"\r\n        [value]=\"data\"\r\n        [paginator]=\"pagination\"\r\n        [totalRecords]=\"totalRecords\"\r\n        [showCurrentPageReport]=\"true\"\r\n        [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\r\n        [responsive]=\"true\"\r\n        [resizableColumns]=\"true\"\r\n        [scrollable]=\"true\"\r\n        scrollDirection=\"vertical\"\r\n        responsiveLayout=\"scroll\"\r\n        [scrollHeight]=\"height\"\r\n        [attr.selectionMode]=\"selectionMode\"\r\n        [(selection)]=\"selectedItems\"\r\n        (onRowSelect)=\"changeSelectedItems($event)\"\r\n        (onRowUnselect)=\"changeSelectedItems($event)\"\r\n        (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\r\n      >\r\n        <ng-template pTemplate=\"header\">\r\n          <tr class=\"header\">\r\n            <th style=\"max-width: 3rem\" *ngIf=\"selectionType === 'checkbox'\">\r\n              <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n            </th>\r\n            <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">Ações</th>\r\n            <th\r\n              *ngFor=\"let col of columns\"\r\n              [ngStyle]=\"getColStyle(col)\"\r\n              [pSortableColumn]=\"col.notSortable ? '' : col.field\"\r\n            >\r\n              {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\r\n            </th>\r\n          </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"body\" let-rowData let-item>\r\n          <tr class=\"row\" [pSelectableRow]=\"rowData\">\r\n            <ng-container *ngIf=\"selectionType === 'checkbox'\">\r\n              <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\r\n                <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\r\n              </td>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"selectionType === 'radiobutton'\">\r\n              <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\r\n                <p-tableRadioButton [value]=\"item\"></p-tableRadioButton>\r\n              </td>\r\n            </ng-container>\r\n            <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\r\n              <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\r\n              <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\r\n            </td>\r\n            <ng-container *ngFor=\"let col of columns\">\r\n              <td\r\n                *ngIf=\"isHtmlCell(col)\"\r\n                class=\"cell\"\r\n                [innerHTML]=\"getCellContent(item, col)\"\r\n                (click)=\"col && col.clickFunction && col.clickFunction(item)\"\r\n                [ngStyle]=\"getColStyle(col)\"\r\n              ></td>\r\n              <td\r\n                *ngIf=\"!isHtmlCell(col)\"\r\n                class=\"cell\"\r\n                (click)=\"col && col.clickFunction && col.clickFunction(item)\"\r\n                [ngStyle]=\"getColStyle(col)\"\r\n              >\r\n                <vector-badge\r\n                  *ngIf=\"col.type === 'TEXT_BADGE' && !!col.getStatus\"\r\n                  [label]=\"item[col.field]\"\r\n                  [type]=\"col.getStatus(item[col.field])\"\r\n                ></vector-badge>\r\n              </td>\r\n            </ng-container>\r\n          </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"emptymessage\">\r\n          <tr class=\"row\">\r\n            <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\r\n          </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"paginatorright\"> </ng-template>\r\n        <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\r\n      </p-table>\r\n    </vector-panel>\r\n  </div>\r\n</div>\r\n"]}
|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { DateTime } from 'luxon';\r\nimport { Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { FilterChangedEvent, ListItem, Status } from '../../../models';\r\nimport { DataTableLazyLoadEvent, TableColumn, TableColumnType } from '../../../models/data-table.model';\r\nimport { MaskUtil } from '../../../utils';\r\nimport { FilterField, FiltersComponent } from '../filters/filters.component';\r\n\r\n@Component({\r\n  selector: 'vector-data-table',\r\n  templateUrl: './data-table.component.html',\r\n  styleUrls: ['./data-table.component.scss'],\r\n})\r\nexport class DataTableComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  public columns: TableColumn[] = [];\r\n  @Input()\r\n  public data: any[] = [];\r\n  @Input()\r\n  public exportExcel = false;\r\n  @Input()\r\n  public exportPDF = false;\r\n  @Input()\r\n  public totalRecords = 0;\r\n  @Input()\r\n  public filters: FilterField[] = [];\r\n  @Input()\r\n  public addItemLabel = '';\r\n  @Input()\r\n  public pagination = true;\r\n  @Input()\r\n  public virtualPagination = false;\r\n  @Input()\r\n  public set tabs(_tabs: ListItem[]) {\r\n    this._tabs = _tabs;\r\n    this._tabSelected = _tabs[0];\r\n  }\r\n  @Input()\r\n  public customButtons: { label: string; clickFunction: Function }[] | undefined;\r\n  @Input()\r\n  public addItemButtonPlusSign = false;\r\n  @Input()\r\n  public hasActions: boolean = true;\r\n  @Input()\r\n  public set selectionMode(_selectionMode) {\r\n    switch (_selectionMode) {\r\n      case 'single':\r\n        this._selectionMode = 'single';\r\n        break;\r\n      case 'multiple':\r\n        this._selectionMode = 'multiple';\r\n        break;\r\n      default:\r\n        this._selectionMode = null;\r\n        break;\r\n    }\r\n  }\r\n  @Input()\r\n  public selectionType: 'checkbox' | 'radiobutton' | null = null;\r\n  @Input()\r\n  public set height(_height: string) {\r\n    switch (_height) {\r\n      case 'small':\r\n        this._height = '300px';\r\n        break;\r\n      case 'medium':\r\n        this._height = '500px';\r\n        break;\r\n      case 'large':\r\n        this._height = '700px';\r\n        break;\r\n      case 'full':\r\n        this._height = 'flex';\r\n        break;\r\n      default:\r\n        this._height = '300px';\r\n    }\r\n  }\r\n  @Output()\r\n  public onLazyLoad = new EventEmitter<DataTableLazyLoadEvent>();\r\n  @Output()\r\n  public onFilter = new EventEmitter<any>();\r\n  @Output()\r\n  public onAdd = new EventEmitter<void>();\r\n  @Output()\r\n  public onExportExcel = new EventEmitter<void>();\r\n  @Output()\r\n  public onExportPDF = new EventEmitter<void>();\r\n  @Output()\r\n  public onSelectedRows = new EventEmitter<any>();\r\n  @Output()\r\n  public onFilterChanged = new EventEmitter<FilterChangedEvent>();\r\n  @ViewChild(FiltersComponent, { static: true })\r\n  public filtersComponent: FiltersComponent | undefined;\r\n\r\n  public selectedItems: any = [];\r\n\r\n  get tabs() {\r\n    return this._tabs;\r\n  }\r\n  get height() {\r\n    return this._height;\r\n  }\r\n  get selectionMode() {\r\n    return this._selectionMode;\r\n  }\r\n\r\n  private _selectionMode: 'single' | 'multiple' | null = null;\r\n  private _height: string = 'small';\r\n  private _tabs: ListItem[] = [];\r\n  private _draw = 1;\r\n  private _firstLazyLoadedDone = false;\r\n  private _lastLazyLoadEvent: DataTableLazyLoadEvent | undefined;\r\n  private _tabSelected: ListItem | undefined;\r\n  private _filterSubscription = new Subscription();\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    if (!this.height) {\r\n      this.height = 'small';\r\n    }\r\n\r\n    if (!this.pagination || this.virtualPagination) {\r\n      this.filtersComponent?.search();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._filterSubscription.unsubscribe();\r\n  }\r\n\r\n  getColStyle(col: TableColumn) {\r\n    return { 'min-width': col.width };\r\n  }\r\n\r\n  lazyLoaded(params: { filter: boolean; data: any } = { filter: false, data: { start: 0, rows: 10 } }) {\r\n    if (!params.filter) {\r\n      const columns = this.columns.map((col) => {\r\n        return {\r\n          data: col.field,\r\n          name: `${col.field.substring(0, 1).toUpperCase()}${col.field.substring(1, col.field.length)}`,\r\n          orderable: true,\r\n          search: { value: '', regex: false },\r\n          searchable: true,\r\n        };\r\n      });\r\n      if (this.hasActions) {\r\n        columns.unshift({\r\n          data: 'active',\r\n          name: 'Active',\r\n          orderable: true,\r\n          search: { value: '', regex: false },\r\n          searchable: true,\r\n        });\r\n      }\r\n      this._lastLazyLoadEvent = {\r\n        ...(this._lastLazyLoadEvent || ({} as any)),\r\n        start: params.data.first,\r\n        length: params.data.rows,\r\n        draw: this._draw++,\r\n        order: params.data.sortField\r\n          ? [\r\n              {\r\n                column:\r\n                  this.columns.findIndex((col) => col.field === params.data.sortField) + (this.hasActions ? 1 : 0),\r\n                dir: params.data.sortOrder > 0 ? 'asc' : 'desc',\r\n              },\r\n            ]\r\n          : [{ column: 0, dir: 'desc' }],\r\n        columns: columns,\r\n      };\r\n    } else {\r\n      this._lastLazyLoadEvent = {\r\n        ...this._lastLazyLoadEvent,\r\n        ...params.data,\r\n        start: 0,\r\n      };\r\n      if (this._tabSelected) {\r\n        this._lastLazyLoadEvent = {\r\n          ...(this._lastLazyLoadEvent || ({} as any)),\r\n          ...{ Status: this._tabSelected.code },\r\n        };\r\n      }\r\n    }\r\n\r\n    if (this._firstLazyLoadedDone) {\r\n      this.onLazyLoad.emit(this._lastLazyLoadEvent);\r\n    }\r\n    this._firstLazyLoadedDone = true;\r\n  }\r\n\r\n  getCellContent(item: any, col: TableColumn) {\r\n    let content = `<span class=\"p-column-title\">${col.header}</span><span class=\"w-100\">`;\r\n    if (!col.type || col.type === TableColumnType.TEXT) {\r\n      content += item[col.field] || '';\r\n    }\r\n\r\n    if (col.type === TableColumnType.CUSTOM_STYLE) {\r\n      content += `<span class=\"${col.textFieldClass ? item[col.textFieldClass] : ''}\">${item[col.field || '']}</span>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.BOOLEAN) {\r\n      content += `<div class=\"text-centered\"><i class=\" status-table-field fas fa-${\r\n        item[col.field] ? 'check boolean-value-positive' : 'times boolean-value-negative'\r\n      }\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.ENUM && col.getEnumTranslated) {\r\n      content += col.getEnumTranslated(item[col.field]);\r\n    }\r\n\r\n    if (col.type === TableColumnType.DATETIME && item[col.field]) {\r\n      const dateTime =\r\n        item[col.field] instanceof Date ? DateTime.fromJSDate(item[col.field]) : DateTime.fromISO(item[col.field]);\r\n      content += dateTime.toFormat('dd/MM/yyyy HH:mm');\r\n    }\r\n\r\n    if (col.type === TableColumnType.STATUS_BADGE) {\r\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getStatusColor(\r\n        item[col.field]\r\n      )}\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.ACTIVE_BOOLEAN_BADGE) {\r\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getActiveStatusColor(\r\n        item[col.field]\r\n      )}\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.BUTTON) {\r\n      content += `<div class=\"text-centered\"><i class=\"fas ${\r\n        col.icon || 'fa-circle'\r\n      } status-table-field table-button\"></i></div>`;\r\n    }\r\n\r\n    if (col.type === TableColumnType.MASK) {\r\n      content += MaskUtil.doMaskString(item[col.field] || '', col.mask);\r\n    }\r\n\r\n    content += `</span>`;\r\n    return content;\r\n  }\r\n\r\n  onTabChange($event: any) {\r\n    this._tabSelected = this.tabs[$event.index];\r\n    this.lazyLoaded({ filter: true, data: {} });\r\n  }\r\n\r\n  subscribeToFilterChanges() {\r\n    this._filterSubscription.unsubscribe();\r\n    this._filterSubscription = new Subscription();\r\n    Object.keys(this.filtersComponent?.formGroup.controls || {}).forEach((key) => {\r\n      this._filterSubscription.add(\r\n        this.filtersComponent?.formGroup\r\n          .get(key)\r\n          ?.valueChanges.pipe(debounceTime(300))\r\n          .subscribe((value) => {\r\n            this.onFilterChanged.emit({ field: key, value });\r\n          })\r\n      );\r\n      this.onFilterChanged.emit({ field: key, value: this.filtersComponent?.formGroup.get(key)?.value });\r\n    });\r\n  }\r\n\r\n  get listHasActions() {\r\n    return this.data.some((item) => item.actions?.length);\r\n  }\r\n\r\n  private getStatusColor(status: Status) {\r\n    switch (status) {\r\n      case Status.PENDING:\r\n        return 'warning';\r\n      case Status.APPROVED:\r\n        return 'success';\r\n      case Status.REJECTED:\r\n        return 'error';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  private getActiveStatusColor(active: boolean) {\r\n    return active ? 'success' : 'error';\r\n  }\r\n\r\n  public changeSelectedItems(value: any) {\r\n    this.onSelectedRows.emit(this.selectedItems);\r\n  }\r\n\r\n  public isHtmlCell(col: TableColumn) {\r\n    if (!col.type) {\r\n      return true;\r\n    }\r\n    return ![TableColumnType.TEXT_BADGE].includes(col.type);\r\n  }\r\n}\r\n","<div class=\"grid\">\r\n  <div class=\"col-12\">\r\n    <vector-filters\r\n      [fields]=\"filters\"\r\n      (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\r\n      (formBuilded)=\"subscribeToFilterChanges()\"\r\n    ></vector-filters>\r\n  </div>\r\n  <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\r\n    <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\r\n      <i class=\"fas fa-file\"></i><span>Excel</span>\r\n    </button>\r\n    <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\r\n      <i class=\"fas fa-file\"></i><span>PDF</span>\r\n    </button>\r\n    <vector-button\r\n      *ngFor=\"let button of customButtons\"\r\n      class=\"add-item-button\"\r\n      [label]=\"button.label\"\r\n      (click)=\"button.clickFunction()\"\r\n      [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\r\n    ></vector-button>\r\n    <vector-button\r\n      *ngIf=\"addItemLabel\"\r\n      class=\"add-item-button\"\r\n      [label]=\"addItemLabel\"\r\n      (click)=\"onAdd.emit()\"\r\n      [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\r\n    ></vector-button>\r\n  </div>\r\n  <div class=\"col-12\">\r\n    <vector-panel class=\"data-table-panel\">\r\n      <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\r\n        <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\r\n      </p-tabView>\r\n      <p-table\r\n        currentPageReportTemplate=\"Mostrando {first} até {last} de {totalRecords} registros\"\r\n        sortMode=\"single\"\r\n        [rows]=\"10\"\r\n        [lazy]=\"pagination && !virtualPagination\"\r\n        [value]=\"data\"\r\n        [paginator]=\"pagination\"\r\n        [totalRecords]=\"totalRecords\"\r\n        [showCurrentPageReport]=\"true\"\r\n        [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\r\n        [responsive]=\"true\"\r\n        [resizableColumns]=\"true\"\r\n        [scrollable]=\"true\"\r\n        scrollDirection=\"vertical\"\r\n        responsiveLayout=\"scroll\"\r\n        [scrollHeight]=\"height\"\r\n        [attr.selectionMode]=\"selectionMode\"\r\n        [(selection)]=\"selectedItems\"\r\n        (onRowSelect)=\"changeSelectedItems($event)\"\r\n        (onRowUnselect)=\"changeSelectedItems($event)\"\r\n        (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\r\n      >\r\n        <ng-template pTemplate=\"header\">\r\n          <tr class=\"header\">\r\n            <th style=\"max-width: 3rem\" *ngIf=\"selectionType === 'checkbox'\">\r\n              <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n            </th>\r\n            <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">Ações</th>\r\n            <th\r\n              *ngFor=\"let col of columns\"\r\n              [ngStyle]=\"getColStyle(col)\"\r\n              [pSortableColumn]=\"col.notSortable ? '' : col.field\"\r\n            >\r\n              {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\r\n            </th>\r\n          </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"body\" let-rowData let-item>\r\n          <tr class=\"row\" [pSelectableRow]=\"rowData\">\r\n            <ng-container *ngIf=\"selectionType === 'checkbox'\">\r\n              <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\r\n                <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\r\n              </td>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"selectionType === 'radiobutton'\">\r\n              <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\r\n                <p-tableRadioButton [value]=\"item\"></p-tableRadioButton>\r\n              </td>\r\n            </ng-container>\r\n            <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\r\n              <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\r\n              <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\r\n            </td>\r\n            <ng-container *ngFor=\"let col of columns\">\r\n              <td\r\n                *ngIf=\"isHtmlCell(col)\"\r\n                class=\"cell\"\r\n                [innerHTML]=\"getCellContent(item, col)\"\r\n                (click)=\"col && col.clickFunction && col.clickFunction(item)\"\r\n                [ngStyle]=\"getColStyle(col)\"\r\n              ></td>\r\n              <td\r\n                *ngIf=\"!isHtmlCell(col)\"\r\n                class=\"cell\"\r\n                (click)=\"col && col.clickFunction && col.clickFunction(item)\"\r\n                [ngStyle]=\"getColStyle(col)\"\r\n              >\r\n                <vector-badge\r\n                  *ngIf=\"col.type === 'TEXT_BADGE' && !!col.getStatus\"\r\n                  [label]=\"item[col.field]\"\r\n                  [type]=\"col.getStatus(item[col.field])\"\r\n                ></vector-badge>\r\n              </td>\r\n            </ng-container>\r\n          </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"emptymessage\">\r\n          <tr class=\"row\">\r\n            <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\r\n          </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"paginatorright\"> </ng-template>\r\n        <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\r\n      </p-table>\r\n    </vector-panel>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -144,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
144
144
|
type: Inject,
|
|
145
145
|
args: ['appName']
|
|
146
146
|
}] }]; } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-vector-components/src/lib/services/menu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { Subject } from 'rxjs';\r\nimport { AuthService, ProfileService, StorageService } from '.';\r\nimport { AppName, MenuItem, View } from '../models';\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class MenuService {\r\n  public toggleMenu$ = new Subject<void>();\r\n  public menuOpened$ = new Subject<boolean>();\r\n  public frameUrl$ = new Subject<string>();\r\n  public menuNotifications: { [menuId: string]: number } = {};\r\n\r\n  constructor(\r\n    private authService: AuthService,\r\n    private router: Router,\r\n    private storageService: StorageService,\r\n    private profileService: ProfileService,\r\n    @Inject('environment') private environment: any,\r\n    @Inject('menuOptions') private menuOptions: MenuItem[],\r\n    @Inject('appName') private appName: AppName\r\n  ) {}\r\n\r\n  public getSideMainMenuOptions(): MenuItem[] {\r\n    return this.menuOptions\r\n      .filter(\r\n        (menu) =>\r\n          (!menu.view || ![View.HOME, View.ADMIN].includes(menu.view)) &&\r\n          !menu.hidden &&\r\n          this.profileService.userHasPermission(menu.permission)\r\n      )\r\n      .map((menu) => this.removeHiddenChildren(menu))\r\n      .filter((menu) => !menu.hidden)\r\n      .map((menu, index) => this.generateId(menu, index));\r\n  }\r\n\r\n  public getSideAdminMenuOptions(): MenuItem[] {\r\n    return this.menuOptions\r\n      .filter(\r\n        (menu) => menu.view === View.ADMIN && !menu.hidden && this.profileService.userHasPermission(menu.permission)\r\n      )\r\n      .map((menu) => this.removeHiddenChildren(menu))\r\n      .filter((menu) => !menu.hidden)\r\n      .map((menu, index) => this.generateId(menu, index));\r\n  }\r\n\r\n  public navigateToPortal(params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean }): void {\r\n    this.authService.generateTokenGuid().subscribe((tokenGuid) => {\r\n      const userId = this.storageService.getUserId();\r\n      switch (this.appName) {\r\n        case AppName.FINTECH:\r\n          this.handleFintechRedirects(params, tokenGuid, userId);\r\n          break;\r\n        case AppName.MARKETPLACE:\r\n          this.handleMarketplaceRedirects(params, tokenGuid, userId);\r\n          break;\r\n        case AppName.LOGTECH:\r\n          this.handleLogtechRedirects(params, tokenGuid, userId);\r\n          break;\r\n      }\r\n      this.storageService.clear();\r\n    });\r\n  }\r\n\r\n  public addMenuNotification(menuId: string) {\r\n    this.updateMenuNotifications(menuId, (this.menuNotifications[menuId] || 0) + 1);\r\n  }\r\n\r\n  public subtractMenuNotification(menuId: string) {\r\n    this.updateMenuNotifications(menuId, this.menuNotifications[menuId] ? this.menuNotifications[menuId] - 1 : 0);\r\n  }\r\n\r\n  public updateMenuNotifications(menuId: string, notificationsCount: number): void {\r\n    this.menuNotifications[menuId] = notificationsCount;\r\n  }\r\n\r\n  private removeHiddenChildren(menu: MenuItem) {\r\n    const newMenu = { ...menu };\r\n    const hadChildren = !!newMenu.children?.length;\r\n    newMenu.children = newMenu.children\r\n      ?.filter((child) => !child.hidden && this.profileService.userHasPermission(child.permission))\r\n      .map((menu) => this.removeHiddenChildren(menu))\r\n      .filter((child) => !child.hidden);\r\n    if (\r\n      hadChildren &&\r\n      !newMenu.children?.length &&\r\n      !newMenu.route &&\r\n      !newMenu.frameUrl &&\r\n      !newMenu.externalUrl &&\r\n      !newMenu.command\r\n    ) {\r\n      newMenu.hidden = true;\r\n    }\r\n    return newMenu;\r\n  }\r\n\r\n  private generateId(menu: MenuItem, index: number, parentId: string = '') {\r\n    menu.id = `${parentId}${index}`;\r\n    menu.children = menu.children?.map((child, childIndex) => this.generateId(child, childIndex, menu.id));\r\n    return menu;\r\n  }\r\n\r\n  private handleFintechRedirects(\r\n    params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean },\r\n    tokenGuid: string,\r\n    userId: number\r\n  ) {\r\n    if (params.portal === 'fintech') {\r\n      this.router.navigate([''], {\r\n        queryParams: { Token: tokenGuid, role: params.admin ? btoa('ADMIN') : '', userId },\r\n      });\r\n    } else {\r\n      let url = params.portal === 'marketplace' ? this.environment.MARKETPLACE_URL : this.environment.LOGITECH_URL;\r\n      url += `?Token=${tokenGuid}&userId=${userId}`;\r\n      if (params.admin) {\r\n        url += `&role=${btoa('ADMIN')}`;\r\n      }\r\n      window.location.href = url;\r\n    }\r\n  }\r\n\r\n  private handleMarketplaceRedirects(\r\n    params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean },\r\n    tokenGuid: string,\r\n    userId: number\r\n  ) {\r\n    if (params.portal === 'marketplace') {\r\n      this.router.navigate([''], {\r\n        queryParams: { Token: tokenGuid, role: params.admin ? btoa('ADMIN') : '', userId: btoa(`${userId}`) },\r\n      });\r\n    } else {\r\n      let url = params.portal === 'fintech' ? this.environment.FINTECH_URL : this.environment.LOGITECH_URL;\r\n      url += `?Token=${tokenGuid}&userId=${userId}`;\r\n      if (params.admin) {\r\n        url += `&role=${btoa('ADMIN')}`;\r\n      }\r\n      window.location.href = url;\r\n    }\r\n  }\r\n\r\n  private handleLogtechRedirects(\r\n    params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean },\r\n    tokenGuid: string,\r\n    userId: number\r\n  ) {\r\n    if (params.portal === 'logtech') {\r\n      this.router.navigate([''], {\r\n        queryParams: { Token: tokenGuid, userId: btoa(`${userId}`) },\r\n      });\r\n    } else {\r\n      let url = params.portal === 'fintech' ? this.environment.FINTECH_URL : this.environment.MARKETPLACE_URL;\r\n      url += `?Token=${tokenGuid}&userId=${userId}`;\r\n      if (params.admin) {\r\n        url += `&role=${btoa('ADMIN')}`;\r\n      }\r\n      window.location.href = url;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-vector-components/src/lib/services/menu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { Subject } from 'rxjs';\r\nimport { AuthService, ProfileService, StorageService } from '.';\r\nimport { AppName, MenuItem, View } from '../models';\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class MenuService {\r\n  public toggleMenu$ = new Subject<void>();\r\n  public menuOpened$ = new Subject<boolean>();\r\n  public frameUrl$ = new Subject<string | undefined>();\r\n  public menuNotifications: { [menuId: string]: number } = {};\r\n\r\n  constructor(\r\n    private authService: AuthService,\r\n    private router: Router,\r\n    private storageService: StorageService,\r\n    private profileService: ProfileService,\r\n    @Inject('environment') private environment: any,\r\n    @Inject('menuOptions') private menuOptions: MenuItem[],\r\n    @Inject('appName') private appName: AppName\r\n  ) {}\r\n\r\n  public getSideMainMenuOptions(): MenuItem[] {\r\n    return this.menuOptions\r\n      .filter(\r\n        (menu) =>\r\n          (!menu.view || ![View.HOME, View.ADMIN].includes(menu.view)) &&\r\n          !menu.hidden &&\r\n          this.profileService.userHasPermission(menu.permission)\r\n      )\r\n      .map((menu) => this.removeHiddenChildren(menu))\r\n      .filter((menu) => !menu.hidden)\r\n      .map((menu, index) => this.generateId(menu, index));\r\n  }\r\n\r\n  public getSideAdminMenuOptions(): MenuItem[] {\r\n    return this.menuOptions\r\n      .filter(\r\n        (menu) => menu.view === View.ADMIN && !menu.hidden && this.profileService.userHasPermission(menu.permission)\r\n      )\r\n      .map((menu) => this.removeHiddenChildren(menu))\r\n      .filter((menu) => !menu.hidden)\r\n      .map((menu, index) => this.generateId(menu, index));\r\n  }\r\n\r\n  public navigateToPortal(params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean }): void {\r\n    this.authService.generateTokenGuid().subscribe((tokenGuid) => {\r\n      const userId = this.storageService.getUserId();\r\n      switch (this.appName) {\r\n        case AppName.FINTECH:\r\n          this.handleFintechRedirects(params, tokenGuid, userId);\r\n          break;\r\n        case AppName.MARKETPLACE:\r\n          this.handleMarketplaceRedirects(params, tokenGuid, userId);\r\n          break;\r\n        case AppName.LOGTECH:\r\n          this.handleLogtechRedirects(params, tokenGuid, userId);\r\n          break;\r\n      }\r\n      this.storageService.clear();\r\n    });\r\n  }\r\n\r\n  public addMenuNotification(menuId: string) {\r\n    this.updateMenuNotifications(menuId, (this.menuNotifications[menuId] || 0) + 1);\r\n  }\r\n\r\n  public subtractMenuNotification(menuId: string) {\r\n    this.updateMenuNotifications(menuId, this.menuNotifications[menuId] ? this.menuNotifications[menuId] - 1 : 0);\r\n  }\r\n\r\n  public updateMenuNotifications(menuId: string, notificationsCount: number): void {\r\n    this.menuNotifications[menuId] = notificationsCount;\r\n  }\r\n\r\n  private removeHiddenChildren(menu: MenuItem) {\r\n    const newMenu = { ...menu };\r\n    const hadChildren = !!newMenu.children?.length;\r\n    newMenu.children = newMenu.children\r\n      ?.filter((child) => !child.hidden && this.profileService.userHasPermission(child.permission))\r\n      .map((menu) => this.removeHiddenChildren(menu))\r\n      .filter((child) => !child.hidden);\r\n    if (\r\n      hadChildren &&\r\n      !newMenu.children?.length &&\r\n      !newMenu.route &&\r\n      !newMenu.frameUrl &&\r\n      !newMenu.externalUrl &&\r\n      !newMenu.command\r\n    ) {\r\n      newMenu.hidden = true;\r\n    }\r\n    return newMenu;\r\n  }\r\n\r\n  private generateId(menu: MenuItem, index: number, parentId: string = '') {\r\n    menu.id = `${parentId}${index}`;\r\n    menu.children = menu.children?.map((child, childIndex) => this.generateId(child, childIndex, menu.id));\r\n    return menu;\r\n  }\r\n\r\n  private handleFintechRedirects(\r\n    params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean },\r\n    tokenGuid: string,\r\n    userId: number\r\n  ) {\r\n    if (params.portal === 'fintech') {\r\n      this.router.navigate([''], {\r\n        queryParams: { Token: tokenGuid, role: params.admin ? btoa('ADMIN') : '', userId },\r\n      });\r\n    } else {\r\n      let url = params.portal === 'marketplace' ? this.environment.MARKETPLACE_URL : this.environment.LOGITECH_URL;\r\n      url += `?Token=${tokenGuid}&userId=${userId}`;\r\n      if (params.admin) {\r\n        url += `&role=${btoa('ADMIN')}`;\r\n      }\r\n      window.location.href = url;\r\n    }\r\n  }\r\n\r\n  private handleMarketplaceRedirects(\r\n    params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean },\r\n    tokenGuid: string,\r\n    userId: number\r\n  ) {\r\n    if (params.portal === 'marketplace') {\r\n      this.router.navigate([''], {\r\n        queryParams: { Token: tokenGuid, role: params.admin ? btoa('ADMIN') : '', userId: btoa(`${userId}`) },\r\n      });\r\n    } else {\r\n      let url = params.portal === 'fintech' ? this.environment.FINTECH_URL : this.environment.LOGITECH_URL;\r\n      url += `?Token=${tokenGuid}&userId=${userId}`;\r\n      if (params.admin) {\r\n        url += `&role=${btoa('ADMIN')}`;\r\n      }\r\n      window.location.href = url;\r\n    }\r\n  }\r\n\r\n  private handleLogtechRedirects(\r\n    params: { portal: 'fintech' | 'logtech' | 'marketplace'; admin: boolean },\r\n    tokenGuid: string,\r\n    userId: number\r\n  ) {\r\n    if (params.portal === 'logtech') {\r\n      this.router.navigate([''], {\r\n        queryParams: { Token: tokenGuid, userId: btoa(`${userId}`) },\r\n      });\r\n    } else {\r\n      let url = params.portal === 'fintech' ? this.environment.FINTECH_URL : this.environment.MARKETPLACE_URL;\r\n      url += `?Token=${tokenGuid}&userId=${userId}`;\r\n      if (params.admin) {\r\n        url += `&role=${btoa('ADMIN')}`;\r\n      }\r\n      window.location.href = url;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -2477,7 +2477,7 @@ class DataTableComponent {
|
|
|
2477
2477
|
: [{ column: 0, dir: 'desc' }], columns: columns });
|
|
2478
2478
|
}
|
|
2479
2479
|
else {
|
|
2480
|
-
this._lastLazyLoadEvent = Object.assign(Object.assign({}, this._lastLazyLoadEvent), params.data);
|
|
2480
|
+
this._lastLazyLoadEvent = Object.assign(Object.assign(Object.assign({}, this._lastLazyLoadEvent), params.data), { start: 0 });
|
|
2481
2481
|
if (this._tabSelected) {
|
|
2482
2482
|
this._lastLazyLoadEvent = Object.assign(Object.assign({}, (this._lastLazyLoadEvent || {})), { Status: this._tabSelected.code });
|
|
2483
2483
|
}
|