@unifylib/ui-lib 1.1.3 → 1.1.4
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/esm2022/iq-ui-lib.mjs +5 -0
- package/esm2022/lib/base-model/SearchStrConfig.mjs +11 -0
- package/esm2022/lib/base-model/api-response.mjs +2 -0
- package/esm2022/lib/base-model/audit-log-entry.mjs +3 -0
- package/esm2022/lib/base-model/button-action-settings.mjs +16 -0
- package/esm2022/lib/base-model/column-def.model.mjs +28 -0
- package/esm2022/lib/base-model/do-action-request.mjs +8 -0
- package/esm2022/lib/base-model/field-action.mjs +6 -0
- package/esm2022/lib/base-model/field-filter.model.mjs +3 -0
- package/esm2022/lib/base-model/field-info.mjs +57 -0
- package/esm2022/lib/base-model/field-predicate.model.mjs +10 -0
- package/esm2022/lib/base-model/filter-request.mjs +13 -0
- package/esm2022/lib/base-model/filter.model.mjs +25 -0
- package/esm2022/lib/base-model/get-items-list.mjs +10 -0
- package/esm2022/lib/base-model/index.mjs +12 -0
- package/esm2022/lib/base-model/items-total.model.mjs +8 -0
- package/esm2022/lib/base-model/line-item.model.mjs +11 -0
- package/esm2022/lib/base-model/lookupItem.mjs +16 -0
- package/esm2022/lib/base-model/page-info.mjs +17 -0
- package/esm2022/lib/base-model/report-request.model.mjs +17 -0
- package/esm2022/lib/base-model/response-envelop.model.mjs +10 -0
- package/esm2022/lib/base-model/snack-message.model.mjs +11 -0
- package/esm2022/lib/base-model/table-column.interface.mjs +2 -0
- package/esm2022/lib/base-model/table-page-user-action.interface.mjs +21 -0
- package/esm2022/lib/base-model/workflow/workflow-steps.model.mjs +9 -0
- package/esm2022/lib/base-model/workflow/workflow.model.mjs +42 -0
- package/esm2022/lib/components/action-comment/action-comment.component.mjs +101 -0
- package/esm2022/lib/components/action-confirmation/action-confirmation.component.mjs +55 -0
- package/esm2022/lib/components/activity-report-form/activity-report-form.component.mjs +499 -0
- package/esm2022/lib/components/advanced-filter/field-filter/field-filter.component.mjs +41 -0
- package/esm2022/lib/components/advanced-filter/filter-builder/filter-builder.component.mjs +162 -0
- package/esm2022/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.mjs +70 -0
- package/esm2022/lib/components/audit-log-list/audit-log.component.mjs +99 -0
- package/esm2022/lib/components/auto-complete/auto-complete.component.mjs +292 -0
- package/esm2022/lib/components/base-form/base-form.component.mjs +297 -0
- package/esm2022/lib/components/base-form-canvas/base-form-canvas.component.mjs +591 -0
- package/esm2022/lib/components/base-input-dialog/base-input-dialog.component.mjs +72 -0
- package/esm2022/lib/components/base-table/base-table.component.mjs +514 -0
- package/esm2022/lib/components/button-actions/button-actions.component.mjs +70 -0
- package/esm2022/lib/components/editable-base-table/editable-base-table.component.mjs +496 -0
- package/esm2022/lib/components/equation-builder/equation-builder.component.mjs +112 -0
- package/esm2022/lib/components/item-line-editor/item-line-editor.component.mjs +299 -0
- package/esm2022/lib/components/multi-auto-complete/multi-auto-complete.component.mjs +278 -0
- package/esm2022/lib/components/paginator/paginator.component.mjs +91 -0
- package/esm2022/lib/components/report-details-dialog/report-details-dialog.component.mjs +102 -0
- package/esm2022/lib/components/report-form/report-form.component.mjs +498 -0
- package/esm2022/lib/components/search-bar/search-bar.component.mjs +62 -0
- package/esm2022/lib/components/section-form-canvas/section-form-canvas.component.mjs +81 -0
- package/esm2022/lib/components/shared/action-button/action-button.component.mjs +59 -0
- package/esm2022/lib/components/shared/action-card/action-card.component.mjs +93 -0
- package/esm2022/lib/components/shared/attachment-uploader/attachment-uploader.component.mjs +70 -0
- package/esm2022/lib/components/shared-list/shared-list.component.mjs +47 -0
- package/esm2022/lib/components/snackbar-static/snackbar-static.component.mjs +43 -0
- package/esm2022/lib/components/title-bar/title-bar.component.mjs +119 -0
- package/esm2022/lib/services/backend-service.mjs +240 -0
- package/esm2022/lib/services/index.mjs +4 -0
- package/esm2022/lib/services/top-panel.mjs +22 -0
- package/esm2022/lib/services/trigger-form.service.mjs +17 -0
- package/esm2022/lib/utils/base-utils.mjs +97 -0
- package/esm2022/lib/validators/date-range-validator.mjs +27 -0
- package/esm2022/lib/validators/index.mjs +4 -0
- package/esm2022/lib/validators/match-list.validator.mjs +9 -0
- package/esm2022/lib/validators/multi-email-validator.mjs +13 -0
- package/esm2022/public-api.mjs +29 -0
- package/esm2022/q-btech-ui-lib.mjs +5 -0
- package/esm2022/unifylib-ui-lib.mjs +5 -0
- package/fesm2022/iq-ui-lib.mjs +5625 -0
- package/fesm2022/iq-ui-lib.mjs.map +1 -0
- package/fesm2022/q-btech-ui-lib.mjs +5619 -0
- package/fesm2022/q-btech-ui-lib.mjs.map +1 -0
- package/fesm2022/unifylib-ui-lib.mjs +5625 -0
- package/fesm2022/unifylib-ui-lib.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/base-model/SearchStrConfig.d.ts +8 -0
- package/{src/lib/base-model/api-response.ts → lib/base-model/api-response.d.ts} +21 -23
- package/lib/base-model/audit-log-entry.d.ts +7 -0
- package/lib/base-model/button-action-settings.d.ts +15 -0
- package/lib/base-model/column-def.model.d.ts +11 -0
- package/lib/base-model/do-action-request.d.ts +10 -0
- package/lib/base-model/field-action.d.ts +6 -0
- package/lib/base-model/field-filter.model.d.ts +7 -0
- package/lib/base-model/field-info.d.ts +53 -0
- package/lib/base-model/field-predicate.model.d.ts +7 -0
- package/lib/base-model/filter-request.d.ts +15 -0
- package/lib/base-model/filter.model.d.ts +22 -0
- package/lib/base-model/get-items-list.d.ts +21 -0
- package/lib/base-model/index.d.ts +11 -0
- package/lib/base-model/items-total.model.d.ts +6 -0
- package/lib/base-model/line-item.model.d.ts +9 -0
- package/lib/base-model/lookupItem.d.ts +13 -0
- package/lib/base-model/page-info.d.ts +52 -0
- package/lib/base-model/report-request.model.d.ts +18 -0
- package/lib/base-model/response-envelop.model.d.ts +8 -0
- package/lib/base-model/snack-message.model.d.ts +7 -0
- package/lib/base-model/table-column.interface.d.ts +28 -0
- package/lib/base-model/table-page-user-action.interface.d.ts +14 -0
- package/lib/base-model/workflow/workflow-steps.model.d.ts +7 -0
- package/lib/base-model/workflow/workflow.model.d.ts +13 -0
- package/lib/components/action-comment/action-comment.component.d.ts +32 -0
- package/lib/components/action-confirmation/action-confirmation.component.d.ts +19 -0
- package/lib/components/activity-report-form/activity-report-form.component.d.ts +93 -0
- package/lib/components/advanced-filter/field-filter/field-filter.component.d.ts +20 -0
- package/lib/components/advanced-filter/filter-builder/filter-builder.component.d.ts +28 -0
- package/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.d.ts +25 -0
- package/lib/components/audit-log-list/audit-log.component.d.ts +36 -0
- package/lib/components/auto-complete/auto-complete.component.d.ts +51 -0
- package/lib/components/base-form/base-form.component.d.ts +59 -0
- package/lib/components/base-form-canvas/base-form-canvas.component.d.ts +124 -0
- package/lib/components/base-input-dialog/base-input-dialog.component.d.ts +23 -0
- package/lib/components/base-table/base-table.component.d.ts +128 -0
- package/lib/components/button-actions/button-actions.component.d.ts +17 -0
- package/lib/components/editable-base-table/editable-base-table.component.d.ts +106 -0
- package/lib/components/equation-builder/equation-builder.component.d.ts +23 -0
- package/lib/components/item-line-editor/item-line-editor.component.d.ts +64 -0
- package/lib/components/multi-auto-complete/multi-auto-complete.component.d.ts +51 -0
- package/lib/components/paginator/paginator.component.d.ts +26 -0
- package/lib/components/report-details-dialog/report-details-dialog.component.d.ts +34 -0
- package/lib/components/report-form/report-form.component.d.ts +92 -0
- package/lib/components/search-bar/search-bar.component.d.ts +29 -0
- package/lib/components/section-form-canvas/section-form-canvas.component.d.ts +27 -0
- package/lib/components/shared/action-button/action-button.component.d.ts +17 -0
- package/lib/components/shared/action-card/action-card.component.d.ts +37 -0
- package/lib/components/shared/attachment-uploader/attachment-uploader.component.d.ts +16 -0
- package/lib/components/shared-list/shared-list.component.d.ts +21 -0
- package/lib/components/snackbar-static/snackbar-static.component.d.ts +15 -0
- package/lib/components/title-bar/title-bar.component.d.ts +42 -0
- package/lib/services/backend-service.d.ts +59 -0
- package/{src/lib/services/index.ts → lib/services/index.d.ts} +3 -3
- package/lib/services/top-panel.d.ts +8 -0
- package/lib/services/trigger-form.service.d.ts +7 -0
- package/lib/utils/base-utils.d.ts +13 -0
- package/lib/validators/date-range-validator.d.ts +2 -0
- package/{src/lib/validators/index.ts → lib/validators/index.d.ts} +3 -3
- package/lib/validators/match-list.validator.d.ts +4 -0
- package/lib/validators/multi-email-validator.d.ts +6 -0
- package/package.json +27 -14
- package/{src/public-api.ts → public-api.d.ts} +25 -29
- package/ng-package.json +0 -7
- package/src/lib/base-model/SearchStrConfig.ts +0 -12
- package/src/lib/base-model/audit-log-entry.ts +0 -7
- package/src/lib/base-model/button-action-settings.ts +0 -29
- package/src/lib/base-model/column-def.model.ts +0 -34
- package/src/lib/base-model/do-action-request.ts +0 -11
- package/src/lib/base-model/feature-item.ts +0 -9
- package/src/lib/base-model/field-action.ts +0 -7
- package/src/lib/base-model/field-filter.model.ts +0 -7
- package/src/lib/base-model/field-info.ts +0 -102
- package/src/lib/base-model/field-predicate.model.ts +0 -7
- package/src/lib/base-model/filter-request.ts +0 -27
- package/src/lib/base-model/filter.model.ts +0 -49
- package/src/lib/base-model/get-items-list.ts +0 -24
- package/src/lib/base-model/index.ts +0 -11
- package/src/lib/base-model/items-total.model.ts +0 -12
- package/src/lib/base-model/line-item.model.ts +0 -18
- package/src/lib/base-model/lookupItem.ts +0 -21
- package/src/lib/base-model/null-snackmessage.ts +0 -9
- package/src/lib/base-model/page-info.ts +0 -54
- package/src/lib/base-model/report-request.model.ts +0 -33
- package/src/lib/base-model/response-envelop.model.ts +0 -15
- package/src/lib/base-model/snack-message.model.ts +0 -14
- package/src/lib/base-model/snackmessage-interface.ts +0 -7
- package/src/lib/base-model/table-column.interface.ts +0 -29
- package/src/lib/base-model/table-page-user-action.interface.ts +0 -33
- package/src/lib/base-model/workflow/workflow-steps.model.ts +0 -9
- package/src/lib/base-model/workflow/workflow.model.ts +0 -52
- package/src/lib/components/action-comment/action-comment.component.css +0 -52
- package/src/lib/components/action-comment/action-comment.component.html +0 -47
- package/src/lib/components/action-comment/action-comment.component.spec.ts +0 -23
- package/src/lib/components/action-comment/action-comment.component.ts +0 -102
- package/src/lib/components/action-confirmation/action-confirmation.component.css +0 -46
- package/src/lib/components/action-confirmation/action-confirmation.component.html +0 -32
- package/src/lib/components/action-confirmation/action-confirmation.component.spec.ts +0 -23
- package/src/lib/components/action-confirmation/action-confirmation.component.ts +0 -58
- package/src/lib/components/activity-report-form/activity-report-form.component.html +0 -110
- package/src/lib/components/activity-report-form/activity-report-form.component.scss +0 -69
- package/src/lib/components/activity-report-form/activity-report-form.component.spec.ts +0 -25
- package/src/lib/components/activity-report-form/activity-report-form.component.ts +0 -616
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.html +0 -8
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.scss +0 -0
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.spec.ts +0 -25
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.ts +0 -55
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.html +0 -36
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.scss +0 -130
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.spec.ts +0 -25
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.ts +0 -186
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.css +0 -51
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.html +0 -23
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.spec.ts +0 -23
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.ts +0 -69
- package/src/lib/components/audit-log-list/audit-log.component.html +0 -26
- package/src/lib/components/audit-log-list/audit-log.component.scss +0 -50
- package/src/lib/components/audit-log-list/audit-log.component.spec.ts +0 -25
- package/src/lib/components/audit-log-list/audit-log.component.ts +0 -114
- package/src/lib/components/auto-complete/auto-complete.component.css +0 -55
- package/src/lib/components/auto-complete/auto-complete.component.html +0 -45
- package/src/lib/components/auto-complete/auto-complete.component.spec.ts +0 -23
- package/src/lib/components/auto-complete/auto-complete.component.ts +0 -331
- package/src/lib/components/base-form/base-form.component.html +0 -59
- package/src/lib/components/base-form/base-form.component.scss +0 -68
- package/src/lib/components/base-form/base-form.component.spec.ts +0 -25
- package/src/lib/components/base-form/base-form.component.ts +0 -323
- package/src/lib/components/base-form-canvas/base-form-canvas.component.css +0 -196
- package/src/lib/components/base-form-canvas/base-form-canvas.component.html +0 -1095
- package/src/lib/components/base-form-canvas/base-form-canvas.component.spec.ts +0 -23
- package/src/lib/components/base-form-canvas/base-form-canvas.component.ts +0 -680
- package/src/lib/components/base-input-dialog/base-input-dialog.component.css +0 -67
- package/src/lib/components/base-input-dialog/base-input-dialog.component.html +0 -47
- package/src/lib/components/base-input-dialog/base-input-dialog.component.spec.ts +0 -23
- package/src/lib/components/base-input-dialog/base-input-dialog.component.ts +0 -77
- package/src/lib/components/base-table/base-table.component.html +0 -268
- package/src/lib/components/base-table/base-table.component.scss +0 -140
- package/src/lib/components/base-table/base-table.component.spec.ts +0 -25
- package/src/lib/components/base-table/base-table.component.ts +0 -621
- package/src/lib/components/button-actions/button-actions.component.html +0 -27
- package/src/lib/components/button-actions/button-actions.component.scss +0 -101
- package/src/lib/components/button-actions/button-actions.component.spec.ts +0 -23
- package/src/lib/components/button-actions/button-actions.component.ts +0 -70
- package/src/lib/components/editable-base-table/editable-base-table.component.html +0 -337
- package/src/lib/components/editable-base-table/editable-base-table.component.scss +0 -126
- package/src/lib/components/editable-base-table/editable-base-table.component.spec.ts +0 -25
- package/src/lib/components/editable-base-table/editable-base-table.component.ts +0 -579
- package/src/lib/components/equation-builder/equation-builder.component.css +0 -39
- package/src/lib/components/equation-builder/equation-builder.component.html +0 -31
- package/src/lib/components/equation-builder/equation-builder.component.spec.ts +0 -23
- package/src/lib/components/equation-builder/equation-builder.component.ts +0 -119
- package/src/lib/components/item-line-editor/item-line-editor.component.html +0 -102
- package/src/lib/components/item-line-editor/item-line-editor.component.scss +0 -152
- package/src/lib/components/item-line-editor/item-line-editor.component.spec.ts +0 -23
- package/src/lib/components/item-line-editor/item-line-editor.component.ts +0 -306
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.css +0 -19
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.html +0 -38
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.spec.ts +0 -23
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.ts +0 -315
- package/src/lib/components/paginator/paginator.component.css +0 -65
- package/src/lib/components/paginator/paginator.component.html +0 -30
- package/src/lib/components/paginator/paginator.component.ts +0 -87
- package/src/lib/components/report-details-dialog/report-details-dialog.component.css +0 -17
- package/src/lib/components/report-details-dialog/report-details-dialog.component.html +0 -16
- package/src/lib/components/report-details-dialog/report-details-dialog.component.spec.ts +0 -23
- package/src/lib/components/report-details-dialog/report-details-dialog.component.ts +0 -111
- package/src/lib/components/report-form/report-form.component.html +0 -92
- package/src/lib/components/report-form/report-form.component.scss +0 -51
- package/src/lib/components/report-form/report-form.component.spec.ts +0 -25
- package/src/lib/components/report-form/report-form.component.ts +0 -599
- package/src/lib/components/search-bar/search-bar.component.html +0 -51
- package/src/lib/components/search-bar/search-bar.component.scss +0 -63
- package/src/lib/components/search-bar/search-bar.component.spec.ts +0 -25
- package/src/lib/components/search-bar/search-bar.component.ts +0 -68
- package/src/lib/components/section-form-canvas/section-form-canvas.component.html +0 -43
- package/src/lib/components/section-form-canvas/section-form-canvas.component.scss +0 -81
- package/src/lib/components/section-form-canvas/section-form-canvas.component.spec.ts +0 -23
- package/src/lib/components/section-form-canvas/section-form-canvas.component.ts +0 -67
- package/src/lib/components/shared/action-button/action-button.component.html +0 -12
- package/src/lib/components/shared/action-button/action-button.component.scss +0 -45
- package/src/lib/components/shared/action-button/action-button.component.ts +0 -51
- package/src/lib/components/shared/action-card/action-card.component.html +0 -78
- package/src/lib/components/shared/action-card/action-card.component.scss +0 -238
- package/src/lib/components/shared/action-card/action-card.component.ts +0 -56
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.css +0 -135
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.html +0 -36
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.spec.ts +0 -23
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.ts +0 -71
- package/src/lib/components/shared-list/shared-list.component.css +0 -0
- package/src/lib/components/shared-list/shared-list.component.html +0 -17
- package/src/lib/components/shared-list/shared-list.component.spec.ts +0 -23
- package/src/lib/components/shared-list/shared-list.component.ts +0 -53
- package/src/lib/components/snackbar-static/snackbar-static.component.html +0 -20
- package/src/lib/components/snackbar-static/snackbar-static.component.scss +0 -135
- package/src/lib/components/snackbar-static/snackbar-static.component.ts +0 -26
- package/src/lib/components/title-bar/title-bar.component.css +0 -0
- package/src/lib/components/title-bar/title-bar.component.css.map +0 -1
- package/src/lib/components/title-bar/title-bar.component.html +0 -35
- package/src/lib/components/title-bar/title-bar.component.scss +0 -126
- package/src/lib/components/title-bar/title-bar.component.spec.ts +0 -23
- package/src/lib/components/title-bar/title-bar.component.ts +0 -126
- package/src/lib/services/backend-service.ts +0 -287
- package/src/lib/services/top-panel.ts +0 -17
- package/src/lib/services/trigger-form.service.ts +0 -11
- package/src/lib/share-module/shared-module.ts +0 -10
- package/src/lib/utils/base-utils.ts +0 -102
- package/src/lib/validators/date-range-validator.ts +0 -31
- package/src/lib/validators/match-list.validator.ts +0 -10
- package/src/lib/validators/multi-email-validator.ts +0 -15
- package/tsconfig.lib.json +0 -15
- package/tsconfig.lib.prod.json +0 -11
- package/tsconfig.spec.json +0 -15
|
@@ -0,0 +1,514 @@
|
|
|
1
|
+
import { Component, effect, EventEmitter, Inject, Input, Output } from "@angular/core";
|
|
2
|
+
import { MatCell, MatCellDef, MatColumnDef, MatHeaderCell, MatHeaderCellDef, MatHeaderRow, MatHeaderRowDef, MatRow, MatRowDef, MatTable, MatTableDataSource } from "@angular/material/table";
|
|
3
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
4
|
+
import { MatSortModule } from "@angular/material/sort";
|
|
5
|
+
import { CurrencyPipe, DatePipe, DecimalPipe, JsonPipe, NgClass, NgForOf, NgIf, NgStyle, NgSwitch, NgSwitchCase, NgSwitchDefault, UpperCasePipe } from "@angular/common";
|
|
6
|
+
import { MatIcon } from "@angular/material/icon";
|
|
7
|
+
import { MatButton, MatButtonModule, MatIconButton } from "@angular/material/button";
|
|
8
|
+
import { NgxPaginationModule } from "ngx-pagination";
|
|
9
|
+
import { ButtonActionsComponent } from "../button-actions/button-actions.component";
|
|
10
|
+
import { BaseUtils } from "../../utils/base-utils";
|
|
11
|
+
import { FilterRequest } from "../../base-model/filter-request";
|
|
12
|
+
import { EMPTY_PAGE_INFO, FRONT_END_COLUMN_TYPES, TABLE_RECORD_ACTION } from "../../base-model";
|
|
13
|
+
import { ReportRequest } from "../../base-model/report-request.model";
|
|
14
|
+
import { ResponseEnvelop } from "../../base-model/response-envelop.model";
|
|
15
|
+
import { MatLabel } from "@angular/material/form-field";
|
|
16
|
+
import { MatChipListbox, MatChipOption } from "@angular/material/chips";
|
|
17
|
+
import { MatButtonToggle, MatButtonToggleGroup } from "@angular/material/button-toggle";
|
|
18
|
+
import { TitleBarComponent } from "../title-bar/title-bar.component";
|
|
19
|
+
import { PaginatorComponent } from "../paginator/paginator.component";
|
|
20
|
+
import { MatCheckbox } from "@angular/material/checkbox";
|
|
21
|
+
import { BaseFormCanvasComponent } from "../base-form-canvas/base-form-canvas.component";
|
|
22
|
+
import { FilterBuilderComponent } from "../advanced-filter/filter-builder/filter-builder.component";
|
|
23
|
+
import { MatMenu, MatMenuItem, MatMenuTrigger } from "@angular/material/menu";
|
|
24
|
+
import * as i0 from "@angular/core";
|
|
25
|
+
import * as i1 from "../../services/backend-service";
|
|
26
|
+
import * as i2 from "@ngx-translate/core";
|
|
27
|
+
import * as i3 from "../../services/trigger-form.service";
|
|
28
|
+
import * as i4 from "@angular/router";
|
|
29
|
+
import * as i5 from "@angular/material/sort";
|
|
30
|
+
import * as i6 from "@angular/material/button";
|
|
31
|
+
export class BaseTableComponent extends BaseUtils {
|
|
32
|
+
constructor(backendService, translateService, shareDataService, securityManager, router) {
|
|
33
|
+
super();
|
|
34
|
+
this.backendService = backendService;
|
|
35
|
+
this.translateService = translateService;
|
|
36
|
+
this.shareDataService = shareDataService;
|
|
37
|
+
this.securityManager = securityManager;
|
|
38
|
+
this.router = router;
|
|
39
|
+
this.types = ["pdf", "csv", "xlsx"];
|
|
40
|
+
this.collection = { count: 60, data: [] };
|
|
41
|
+
this.config = {
|
|
42
|
+
itemsPerPage: 15,
|
|
43
|
+
currentPage: 1,
|
|
44
|
+
totalItems: this.collection.count
|
|
45
|
+
};
|
|
46
|
+
this.maxSize = 7;
|
|
47
|
+
this.directionLinks = true;
|
|
48
|
+
this.autoHide = false;
|
|
49
|
+
this.responsive = true;
|
|
50
|
+
this.labels = {
|
|
51
|
+
previousLabel: '<',
|
|
52
|
+
nextLabel: '>',
|
|
53
|
+
screenReaderPaginationLabel: 'Pagination',
|
|
54
|
+
screenReaderPageLabel: 'page',
|
|
55
|
+
screenReaderCurrentLabel: `You're on page`
|
|
56
|
+
};
|
|
57
|
+
this.noDataFoundIcon = 'close';
|
|
58
|
+
this.noDataFoundTitle = 'noDataFoundTitle';
|
|
59
|
+
this.noDataFoundSubtitle = 'noDataFoundSubtitle';
|
|
60
|
+
this.totalElements = 0;
|
|
61
|
+
this.pagesCount = 0;
|
|
62
|
+
this.pageIndex = 1;
|
|
63
|
+
this.pageSize = 15;
|
|
64
|
+
this.selectedStatusFilter = [];
|
|
65
|
+
this.advancedAppliedFilter = [];
|
|
66
|
+
this.searchStr = '';
|
|
67
|
+
this.filterRequest = new FilterRequest();
|
|
68
|
+
this.pageInfo = EMPTY_PAGE_INFO;
|
|
69
|
+
this.enablePagination = true;
|
|
70
|
+
this.listAction = [];
|
|
71
|
+
this.filters = [];
|
|
72
|
+
this.enforceRefresh = false;
|
|
73
|
+
this.isPending = false;
|
|
74
|
+
this.trigger = false;
|
|
75
|
+
this.reportRequest = new ReportRequest({});
|
|
76
|
+
this.manageablePages = false;
|
|
77
|
+
this.totalPagesCount = 0;
|
|
78
|
+
this.currentPageIndex = 0;
|
|
79
|
+
this.pageChange = new EventEmitter();
|
|
80
|
+
this.userAction = new EventEmitter();
|
|
81
|
+
this.hyperLinkAction = new EventEmitter();
|
|
82
|
+
this.extraAction = new EventEmitter();
|
|
83
|
+
this.selectedColumn = new EventEmitter();
|
|
84
|
+
this.listActionClicked = new EventEmitter();
|
|
85
|
+
this.showDialog = new EventEmitter();
|
|
86
|
+
this.selectedRowIndex = -1;
|
|
87
|
+
this.noDataFound = false;
|
|
88
|
+
this.totalRequiredCountItem = 0;
|
|
89
|
+
this.clickRoutePage = new EventEmitter();
|
|
90
|
+
this.groupNames = [];
|
|
91
|
+
this.groupSpans = new Map();
|
|
92
|
+
this.dataSource = new MatTableDataSource();
|
|
93
|
+
this.columns = [];
|
|
94
|
+
this.filterRequest = new FilterRequest();
|
|
95
|
+
effect(() => {
|
|
96
|
+
if (this.pageInfo.lazyLoadData !== true || this.enforceRefresh === true) {
|
|
97
|
+
this.loadData();
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
ngOnDestroy() {
|
|
102
|
+
}
|
|
103
|
+
ngOnInit() {
|
|
104
|
+
this.backendService.isEmptyItems = this.dataSource.data.length <= 0;
|
|
105
|
+
if (this.customizedData) {
|
|
106
|
+
this.dataSource = this.customizedData;
|
|
107
|
+
}
|
|
108
|
+
if (this.manageablePages) {
|
|
109
|
+
this.pagesCount = this.totalPagesCount;
|
|
110
|
+
this.pageIndex = this.currentPageIndex;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
onPageChange(event) {
|
|
114
|
+
this.pageIndex = event;
|
|
115
|
+
this.getNext(this.pageIndex - 1);
|
|
116
|
+
if (this.manageablePages) {
|
|
117
|
+
this.pageChange.emit(this.pageIndex);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
extractFieldName(element, property) {
|
|
121
|
+
if (property.includes('.')) {
|
|
122
|
+
return property.split('.').reduce((acc, part) => acc && acc[part], element);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
const c = this.columns.find(c => c.property === property);
|
|
126
|
+
if (Array.isArray(element[property]) && c.arraySubProperty) {
|
|
127
|
+
const fieldValues = element[property].map(f => f[c.arraySubProperty]);
|
|
128
|
+
return fieldValues.join(', ');
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
return element[property];
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
get visibleColumns() {
|
|
136
|
+
this.buildGroups();
|
|
137
|
+
return this.columns.filter(column => column.visible).map(column => column.property);
|
|
138
|
+
}
|
|
139
|
+
getNext(pageIndex) {
|
|
140
|
+
this.reportRequest.filterRequest.pageIndex = pageIndex;
|
|
141
|
+
this.reportRequest.filterRequest.pageSize = this.pageSize;
|
|
142
|
+
this.loadData();
|
|
143
|
+
}
|
|
144
|
+
onPageSizeChange(event) {
|
|
145
|
+
this.pageSize = event;
|
|
146
|
+
this.pageIndex = 1; // reset to first page on page size change
|
|
147
|
+
this.reportRequest.filterRequest.pageSize = this.pageSize;
|
|
148
|
+
this.getNext(0);
|
|
149
|
+
}
|
|
150
|
+
loadData() {
|
|
151
|
+
clearTimeout(this.timer);
|
|
152
|
+
if (!this.reportRequest.filterRequest) {
|
|
153
|
+
this.reportRequest.filterRequest = new FilterRequest(this.pageInfo.pageSize);
|
|
154
|
+
this.reportRequest.filterRequest.filters = this.advancedAppliedFilter;
|
|
155
|
+
}
|
|
156
|
+
if (this.separateEndpointData || !this.pageInfo.apiUri || this.pageInfo.apiUri.length === 0) {
|
|
157
|
+
this.dataSource.data = this.separateEndpointData;
|
|
158
|
+
}
|
|
159
|
+
else if (this.reportRequest == undefined) {
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
else if (!this.manageablePages) {
|
|
163
|
+
this.timer = setTimeout(() => {
|
|
164
|
+
this.reportRequest.filterRequest.columns = this.columns?.filter(c => FRONT_END_COLUMN_TYPES.indexOf(c.type) < 0).map(c => c.property) || [];
|
|
165
|
+
this.reportRequest.filterRequest.pendingPage = this.isPending;
|
|
166
|
+
this.reportRequest.filterRequest.filters = this.advancedAppliedFilter;
|
|
167
|
+
this.backendService.getItemsByFilter(this.reportRequest?.filterRequest, this.pageInfo.apiUri).subscribe(resp => {
|
|
168
|
+
const responseEnvelope = new ResponseEnvelop(resp);
|
|
169
|
+
if (responseEnvelope.valid) {
|
|
170
|
+
this.totalRequiredCountItem = this.reportRequest.filterRequest.pageSize;
|
|
171
|
+
this.noDataFound = responseEnvelope.body.length < 1;
|
|
172
|
+
this.dataSource.data = responseEnvelope.body;
|
|
173
|
+
this.backendService.isEmptyItems = this.dataSource.data.length <= 0;
|
|
174
|
+
this.totalElements = responseEnvelope.totalSize || 0;
|
|
175
|
+
this.pagesCount = Math.ceil(this.totalElements / this.pageSize) || 1;
|
|
176
|
+
this.pageIndex = (this.reportRequest.filterRequest.pageIndex || 0) + 1;
|
|
177
|
+
this.config.totalItems = responseEnvelope.totalSize || 0;
|
|
178
|
+
this.config.currentPage = this.pageIndex + 1;
|
|
179
|
+
// this.pageSize = this.reportRequest.filterRequest.pageSize;
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
}, 300);
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
getStatusDescription(element) {
|
|
186
|
+
return this.backendService.getStatusDescription(element, this.usedWorkflow);
|
|
187
|
+
}
|
|
188
|
+
getStateType(element) {
|
|
189
|
+
return element.stateType;
|
|
190
|
+
}
|
|
191
|
+
ngOnChanges(changes) {
|
|
192
|
+
if (changes["customizedData"] && !changes["customizedData"].isFirstChange()) {
|
|
193
|
+
this.dataSource.data = changes["customizedData"].currentValue?.data || []; // Update data source with new data
|
|
194
|
+
this.pagesCount = this.totalPagesCount;
|
|
195
|
+
this.pageIndex = this.currentPageIndex;
|
|
196
|
+
}
|
|
197
|
+
if (changes["enforceRefresh"] && !changes["enforceRefresh"].isFirstChange()) {
|
|
198
|
+
this.loadData();
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
getCroppedText(elementValue, subWidth = 20) {
|
|
202
|
+
return elementValue && elementValue.length > subWidth ? elementValue.substring(0, subWidth) + "..." : elementValue;
|
|
203
|
+
}
|
|
204
|
+
emitEvent(element) {
|
|
205
|
+
this.showDialog.emit(element);
|
|
206
|
+
}
|
|
207
|
+
extractFormat(column) {
|
|
208
|
+
return column?.format || 'd/M/yyyy, h:mm a';
|
|
209
|
+
}
|
|
210
|
+
actionListClicked(listAction, element) {
|
|
211
|
+
this.listActionClicked.emit({ action: listAction, row: element });
|
|
212
|
+
}
|
|
213
|
+
hyperLinkClicked(actionName, element) {
|
|
214
|
+
const action = TABLE_RECORD_ACTION;
|
|
215
|
+
action.actionKey = actionName;
|
|
216
|
+
action.item = element;
|
|
217
|
+
action.pageInfo = this.pageInfo;
|
|
218
|
+
this.hyperLinkAction.emit(action);
|
|
219
|
+
}
|
|
220
|
+
emitRoutePage(element) {
|
|
221
|
+
this.clickRoutePage.emit(element);
|
|
222
|
+
}
|
|
223
|
+
onSelectItem(row) {
|
|
224
|
+
if (this.pageInfo.selfRouting) {
|
|
225
|
+
const mode = this.isPending ? 'pending' : 'view';
|
|
226
|
+
const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;
|
|
227
|
+
const encryptedId = this.backendService.encrypt(String(row.id));
|
|
228
|
+
const encryptedMode = this.backendService.encrypt(mode);
|
|
229
|
+
const encryptedRow = this.backendService.encrypt(JSON.stringify(row));
|
|
230
|
+
this.router.navigate([url], {
|
|
231
|
+
queryParams: { token: encryptedId, mode: encryptedMode },
|
|
232
|
+
state: { raw: encryptedRow },
|
|
233
|
+
});
|
|
234
|
+
return;
|
|
235
|
+
}
|
|
236
|
+
// const action = SELECT_RECORD_ACTION;
|
|
237
|
+
// action.id = row?.id;
|
|
238
|
+
// action.item = row;
|
|
239
|
+
// this.userAction.emit(action)
|
|
240
|
+
}
|
|
241
|
+
openNewTab(row) {
|
|
242
|
+
if (!this.pageInfo.embededTableOnly) {
|
|
243
|
+
const mode = this.isPending ? 'pending' : 'view';
|
|
244
|
+
window.open(`${this.pageInfo.listRoutePath}/${mode}` + '/' + row?.id);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
switchViewMode(b) {
|
|
248
|
+
this.isPending = !this.isPending;
|
|
249
|
+
this.loadData();
|
|
250
|
+
}
|
|
251
|
+
onAddNewAction($event) {
|
|
252
|
+
const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;
|
|
253
|
+
const encryptedId = this.backendService.encrypt("-1");
|
|
254
|
+
const encryptedMode = this.backendService.encrypt("pending");
|
|
255
|
+
this.router.navigate([`${url}`], { queryParams: { token: encryptedId, mode: encryptedMode } });
|
|
256
|
+
// const action = SELECT_RECORD_ACTION;
|
|
257
|
+
// action.id = row?.id;
|
|
258
|
+
// action.item = row;
|
|
259
|
+
// this.userAction.emit(action)
|
|
260
|
+
}
|
|
261
|
+
showAddNew() {
|
|
262
|
+
return this.pageInfo.hasAddButton;
|
|
263
|
+
}
|
|
264
|
+
onExtraButtionAction($event) {
|
|
265
|
+
this.extraAction.emit($event);
|
|
266
|
+
}
|
|
267
|
+
hasGroups() {
|
|
268
|
+
let b = this.columns.findIndex(p => p.group);
|
|
269
|
+
return b >= 0;
|
|
270
|
+
}
|
|
271
|
+
buildGroups() {
|
|
272
|
+
let count = 0;
|
|
273
|
+
this.groupNames = [];
|
|
274
|
+
this.groupSpans.clear();
|
|
275
|
+
if (this.hasGroups() === false) {
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
this.columns
|
|
279
|
+
.filter(column => column.visible === true)
|
|
280
|
+
.forEach((column) => {
|
|
281
|
+
if (column.group === "-") {
|
|
282
|
+
this.groupNames.push(count.toString());
|
|
283
|
+
this.insertInMap(count);
|
|
284
|
+
count++;
|
|
285
|
+
return;
|
|
286
|
+
}
|
|
287
|
+
else if (!this.groupNames.includes(column.group)) {
|
|
288
|
+
this.groupNames.push(column.group);
|
|
289
|
+
this.insertInMap(column.group);
|
|
290
|
+
return;
|
|
291
|
+
}
|
|
292
|
+
this.insertInMap(column.group);
|
|
293
|
+
});
|
|
294
|
+
}
|
|
295
|
+
insertInMap(key) {
|
|
296
|
+
if (this.groupSpans.has(key)) {
|
|
297
|
+
this.groupSpans.set(key.toString(), this.groupSpans.get(key) + 1);
|
|
298
|
+
}
|
|
299
|
+
else {
|
|
300
|
+
this.groupSpans.set(key.toString(), 1);
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
isHumanMade(str) {
|
|
304
|
+
return isNaN(str);
|
|
305
|
+
}
|
|
306
|
+
actionButtonClicked(actionKey, item) {
|
|
307
|
+
if (actionKey === 'navigate') {
|
|
308
|
+
this.handleNavigateAction(item);
|
|
309
|
+
return;
|
|
310
|
+
}
|
|
311
|
+
this.emitTableAction(actionKey, item);
|
|
312
|
+
}
|
|
313
|
+
handleNavigateAction(item) {
|
|
314
|
+
const mode = this.isPending ? 'pending' : 'view';
|
|
315
|
+
const basePath = this.pageInfo.listRoutePath || this.router.url;
|
|
316
|
+
const url = `${basePath}/view`;
|
|
317
|
+
const encryptedId = this.backendService.encrypt(item.id.toString());
|
|
318
|
+
const encryptedMode = this.backendService.encrypt(mode);
|
|
319
|
+
this.router.navigate([url], {
|
|
320
|
+
queryParams: { token: encryptedId, mode: encryptedMode }
|
|
321
|
+
});
|
|
322
|
+
}
|
|
323
|
+
emitTableAction(actionKey, item) {
|
|
324
|
+
const action = TABLE_RECORD_ACTION;
|
|
325
|
+
action.actionKey = actionKey;
|
|
326
|
+
action.item = item;
|
|
327
|
+
action.pageInfo = this.pageInfo;
|
|
328
|
+
this.userAction.emit(action);
|
|
329
|
+
}
|
|
330
|
+
extractReport(reportType) {
|
|
331
|
+
const myFilters = this.reportRequest.filterRequest;
|
|
332
|
+
const reportRequest = this.backendService.buildReportRequest(this.columns, this.pageInfo.labelsSection + '.list_title', myFilters, reportType, this.pageInfo, this.searchStr, 'LANDSCAPE');
|
|
333
|
+
this.backendService.downloadReport(reportRequest, this.pageInfo.apiUri);
|
|
334
|
+
}
|
|
335
|
+
getIcon(status) {
|
|
336
|
+
switch (status) {
|
|
337
|
+
case 'pass': return 'check_circle';
|
|
338
|
+
case 'warning': return 'warning';
|
|
339
|
+
case 'error': return 'error';
|
|
340
|
+
default: return 'help';
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
actionCheckedClicked(property, element) {
|
|
344
|
+
element[property] = !element[property];
|
|
345
|
+
this.actionButtonClicked(property, element);
|
|
346
|
+
}
|
|
347
|
+
isDarkHighlight(row) {
|
|
348
|
+
const groupByProp = this.pageInfo?.groupByProperty;
|
|
349
|
+
const groupByValues = this.pageInfo?.groupByValue;
|
|
350
|
+
if (!groupByProp || !groupByValues || !row[groupByProp]) {
|
|
351
|
+
return false;
|
|
352
|
+
}
|
|
353
|
+
const cellValue = row[groupByProp].toString();
|
|
354
|
+
return groupByValues.some(val => cellValue.includes(val) && cellValue.length > val.length);
|
|
355
|
+
}
|
|
356
|
+
shouldRenderAsHyperLink(element) {
|
|
357
|
+
const groupByProp = this.pageInfo?.groupByProperty;
|
|
358
|
+
const groupByValues = this.pageInfo?.groupByValue;
|
|
359
|
+
if (!groupByProp || !groupByValues || !element[groupByProp]) {
|
|
360
|
+
return false;
|
|
361
|
+
}
|
|
362
|
+
const value = element[groupByProp].toString();
|
|
363
|
+
return !groupByValues.some(v => value.includes(v) && value.length >= v.length);
|
|
364
|
+
}
|
|
365
|
+
onSortAction($event) {
|
|
366
|
+
this.reportRequest.filterRequest.sortKey = $event.active && $event.direction ?
|
|
367
|
+
this.columns.find(c => c.property === $event.active)?.orderByProperty || $event.active
|
|
368
|
+
: 'id';
|
|
369
|
+
this.reportRequest.filterRequest.sortDirection = $event.direction === 'asc' ? 'ASC' : 'DESC';
|
|
370
|
+
this.reportRequest.filterRequest.pageIndex = 0;
|
|
371
|
+
this.selectedColumn.emit($event);
|
|
372
|
+
this.loadData();
|
|
373
|
+
}
|
|
374
|
+
shouldShowButton(element) {
|
|
375
|
+
const groupByProp = this.pageInfo?.groupByProperty;
|
|
376
|
+
const groupByValues = this.pageInfo?.groupByValue;
|
|
377
|
+
if (!groupByProp || !groupByValues || !element[groupByProp]) {
|
|
378
|
+
return true;
|
|
379
|
+
}
|
|
380
|
+
const value = element[groupByProp].toString();
|
|
381
|
+
return !groupByValues.some(v => value.includes(v) && value.length >= v.length);
|
|
382
|
+
}
|
|
383
|
+
doAdvancedSearch($event) {
|
|
384
|
+
this.advancedAppliedFilter = [];
|
|
385
|
+
if ($event.length === 0) {
|
|
386
|
+
this.advancedAppliedFilter = [];
|
|
387
|
+
this.loadData();
|
|
388
|
+
// this.paginator.firstPage();
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
this.advancedAppliedFilter = $event;
|
|
392
|
+
this.loadData();
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
resetData($event) {
|
|
396
|
+
if ($event) {
|
|
397
|
+
this.advancedAppliedFilter = [];
|
|
398
|
+
this.loadData();
|
|
399
|
+
// this.paginator.firstPage();
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseTableComponent, deps: [{ token: i1.BackendService }, { token: i2.TranslateService }, { token: i3.ShareDataService }, { token: 'securityManager' }, { token: i4.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
403
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: BaseTableComponent, isStandalone: true, selector: "app-base-table", inputs: { filterFields: "filterFields", noDataFoundIcon: "noDataFoundIcon", noDataFoundTitle: "noDataFoundTitle", noDataFoundSubtitle: "noDataFoundSubtitle", pageInfo: "pageInfo", enablePagination: "enablePagination", data: "data", listAction: "listAction", columns: "columns", filters: "filters", pathParam: "pathParam", extraButton: "extraButton", enforceRefresh: "enforceRefresh", isPending: "isPending", trigger: "trigger", reportRequest: "reportRequest", separateEndpointData: "separateEndpointData", manageablePages: "manageablePages", totalPagesCount: "totalPagesCount", currentPageIndex: "currentPageIndex", customizedData: "customizedData" }, outputs: { pageChange: "pageChange", userAction: "userAction", hyperLinkAction: "hyperLinkAction", extraAction: "extraAction", selectedColumn: "selectedColumn", listActionClicked: "listActionClicked", showDialog: "showDialog", clickRoutePage: "clickRoutePage" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex-column baseTable\">\r\n <div class=\"flex-row flex-100\" *ngIf=\"!pageInfo.hideTitle\">\r\n <div [class.flex-50]=\"pageInfo.draftSupported\" [class.flex-100]=\"!pageInfo.draftSupported\" class=\"flex-column align-start\">\r\n <app-title-bar\r\n [pageTitle]=\"pageInfo.hideTitle ? '' : pageInfo.labelsSection+'.list_title'\"\r\n [titleMode]=\"''\"\r\n [newAction]=\"showAddNew()\"\r\n [showExtractButton]=\"!pageInfo.hideExtractButton\"\r\n [extraButton]=\"extraButton\"\r\n (newActionClicked)=\"onAddNewAction($event)\"\r\n (extractReport)=\"extractReport($event)\"\r\n [totalElements]=\"pageInfo.hideTitle ? undefined : totalElements\">\r\n </app-title-bar>\r\n </div>\r\n <div class=\"flex-50 flex-column align-end\" *ngIf=\"pageInfo.draftSupported\">\r\n <mat-chip-listbox aria-label=\"Color selection\" [multiple]=\"false\">\r\n <mat-chip-option [selected]=\"!this.isPending\" [color]=\"'accent'\" [value]=\"'COMPLETED'\" (click)=\"switchViewMode(false)\">\r\n {{'finished' | translate}}\r\n </mat-chip-option>\r\n <mat-chip-option [selected]=\"this.isPending\" [color]=\"'accent'\" [value]=\"'PENDING'\" (click)=\"switchViewMode(true)\">\r\n {{'todo' | translate}}\r\n </mat-chip-option>\r\n </mat-chip-listbox>\r\n </div>\r\n </div>\r\n\r\n <div class=\"filter-row\" *ngIf=\"!pageInfo.hideAdvancedFilter\">\r\n <app-filter-builder\r\n *ngIf=\"!pageInfo.hideAdvancedFilter\"\r\n [pageInfo]=\"pageInfo\"\r\n [columns]=\"columns\"\r\n [filterFields]=\"filterFields\"\r\n (filterInformation)=\"doAdvancedSearch($event)\"\r\n (isEmpty)=\"resetData($event)\">\r\n </app-filter-builder>\r\n\r\n <div class=\"button-group\" >\r\n\r\n <button *ngIf=\"!pageInfo.hideExtractButton\"\r\n mat-flat-button\r\n [matMenuTriggerFor]=\"exportMenu\"\r\n color=\"primary\"\r\n class=\"btn-none-background-primary btn-export\"\r\n >\r\n <div class=\"button-text\">\r\n <mat-icon>file_export</mat-icon>\r\n <span>{{ 'export' | translate }}</span>\r\n <mat-icon class=\"arrow-icon\">arrow_drop_down</mat-icon>\r\n </div>\r\n </button>\r\n\r\n <mat-menu #exportMenu=\"matMenu\">\r\n <button\r\n mat-menu-item\r\n *ngFor=\"let type of types\"\r\n (click)=\"extractReport(type)\"\r\n >\r\n <span>{{ type | uppercase }}</span>\r\n </button>\r\n </mat-menu>\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"flex-row flex-100 baseTable__detailsColumn\">\r\n <div class=\"flex-100\">\r\n <div class=\"flex-row flex-100 mainTable\">\r\n <table [dataSource]=\"dataSource\" class=\"flex-fill\" mat-table matSort (matSortChange)=\"onSortAction($event)\">\r\n <ng-container *ngFor=\"let column of this.columns; let last=last\">\r\n <ng-container matColumnDef=\"{{column.property}}\">\r\n <ng-container *ngIf=\"column.enableSorting; else withoutSortingColumn\">\r\n <th *matHeaderCellDef class=\"mainTable__th\" mat-header-cell mat-sort-header>\r\n {{ labelKey(column) | translate }}\r\n </th>\r\n </ng-container>\r\n <ng-template #withoutSortingColumn>\r\n <th *matHeaderCellDef class=\"mainTable__th\" mat-header-cell>{{ labelKey(column) | translate }}</th>\r\n </ng-template>\r\n\r\n <ng-container [ngSwitch]=\"column.type\">\r\n <ng-container *ngSwitchCase=\"'workflowStatus'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <button mat-button class=\"wfStatus {{ getStatusDescription(element)}}\" [attr.id]=\"'table-btn-wf-'+column.property+'-'+(element.id || element.key || '')\">{{ getStatusDescription(element) }}</button>\r\n </td>\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <button mat-button class=\"wfStatus {{ getStatusDescription(element)}}\" [attr.id]=\"'table-btn-wf2-'+column.property+'-'+(element.id || element.key || '')\">{{ getStatusDescription(element) }}</button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"hyperLinkClicked(column.property,element)\" mat-cell>\r\n <mat-label [ngClass]=\"{'hyper-link': shouldRenderAsHyperLink(element)}\">\r\n {{ extractFieldName(element, column.property) }}\r\n </mat-label>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'button'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <button *ngIf=\"shouldShowButton(element)\" mat-button class=\"primary\" (click)=\"$event.stopPropagation(); actionButtonClicked(column.property, element)\" [attr.id]=\"'table-btn-action-'+column.property\">\r\n {{ labelKey(column) + '_title' | translate }}\r\n </button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'icon'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td\" mat-cell>\r\n <mat-icon [ngClass]=\"{\r\n 'mainTable__td__icon-green': element[column.property] === 'pass',\r\n 'mainTable__td__icon-orange': element[column.property] === 'warning',\r\n 'mainTable__td__icon-red': element[column.property] === 'error'\r\n }\">\r\n {{ getIcon(element[column.property]) }}\r\n </mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <mat-checkbox class=\"primary\" [checked]=\"element[column.property]\" (click)=\"$event.stopPropagation();actionCheckedClicked(column.property,element)\"></mat-checkbox>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'stateType'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <button mat-button class=\"stateType {{ element[column.property]}}\" [attr.id]=\"'table-btn-state-'+column.property\">{{ labelKeyByValue(column, element) | translate}}</button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n {{ extractFieldName(element, column.property) | date:'yyyy-MM-dd' }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'croppedText'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n {{ getCroppedText(element[column.property], element[column.width]) }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'download'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" style=\"padding: 0;margin: 0;text-align: center;\" mat-cell>\r\n <mat-icon class=\"mainTable__td__icon-blue\">system_update_alt</mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'onOff'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <mat-icon *ngIf=\"element[column.property] === null\" class=\"mainTable__td__icon-darkorange\">flag</mat-icon>\r\n <mat-icon *ngIf=\"element[column.property] === false\" class=\"mainTable__td__icon-red\">flag</mat-icon>\r\n <mat-icon *ngIf=\"element[column.property] === true\" class=\"mainTable__td__icon-green\">flag</mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'status'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <span *ngIf=\"element[column.property] === null || element[column.property] === false\">\r\n {{ pageInfo.labelsSection + '.' + column.label + 'InActive' | translate }}\r\n </span>\r\n <span *ngIf=\"element[column.property] === true\">\r\n {{ pageInfo.labelsSection + '.' + column.label + 'Active' | translate }}\r\n </span>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'info'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td text-secondary\" mat-cell>\r\n <button mat-icon-button (click)=\"$event.stopPropagation();emitEvent(element)\" [attr.id]=\"'table-btn-info-'+element.id\">\r\n <mat-icon>info</mat-icon>\r\n </button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'netAmount'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <small><sup class=\"mainTable__td__currency\">{{element[column.currency]}}</sup></small>\r\n <span class=\"mainTable__td__property\">{{ extractFieldName(element, column.property) | currency:element[column.currency] :'' }}</span> of\r\n {{ extractFieldName(element, column.additionalProperty) | currency:element[column.currency] :'' }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n {{ extractFieldName(element, column.property) | date : extractFormat(column) }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <small><sup class=\"mainTable__td__currency\">{{element[column.currency]}}</sup></small>\r\n {{ extractFieldName(element, column.property) | number : (column.digitInfo || '1.3-5') }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'listAction'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" style=\"padding: 0!important;\" mat-cell>\r\n <app-button-actions \r\n [buttonsAction]=\"column.viewType === 'buttonsAction'\"\r\n [listAction]=\"listAction\" \r\n [actions]=\"listAction\" \r\n (clickedButton)=\"actionListClicked($event,element)\">\r\n </app-button-actions>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"column.translate; else noTranslate\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"emitRoutePage(element)\" mat-cell>\r\n {{ extractFieldName(element, column.property) | translate }}\r\n </td>\r\n </ng-container>\r\n <ng-template #noTranslate>\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"emitRoutePage(element)\" mat-cell [innerHtml]='extractFieldName(element, column.property)'></td>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"hasGroups()\">\r\n <ng-container *ngFor=\"let groupName of this.groupNames\">\r\n <ng-container matColumnDef=\"{{groupName}}\">\r\n <th mat-header-cell class=\"extra-header\" *matHeaderCellDef [attr.colspan]=\"groupSpans.get(groupName)\">\r\n {{ (isHumanMade(groupName) ? groupName : \"\") | translate }}\r\n </th>\r\n </ng-container>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"this.groupNames\"></tr>\r\n </ng-container>\r\n\r\n <tr *matHeaderRowDef=\"visibleColumns\" mat-header-row></tr>\r\n <tr (auxclick)=\"openNewTab(row)\" (click)=\"$event.stopPropagation(); onSelectItem(row)\" *matRowDef=\"let row; columns: visibleColumns\"\r\n [attr.id]=\"'table-row-' + (row?.id || row?.key || '')\"\r\n [ngClass]=\"{\r\n 'mainTable__highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n 'mainTable__dark_highlight': isDarkHighlight(row)\r\n }\"\r\n mat-row>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n <div *ngIf=\"noDataFound\" class=\"dataNotFound flex-column\">\r\n <mat-icon class=\"dataNotFound__icon\">{{ noDataFoundIcon }}</mat-icon>\r\n <span class=\"dataNotFound__title\">{{ noDataFoundTitle | translate}}</span>\r\n <span class=\"dataNotFound__subtitle\">{{ noDataFoundSubtitle | translate}}</span>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"(dataSource.data?.length > 0 || customizedData) && !pageInfo.hidePagination\" class=\"main-pagination flex-row\">\r\n <ng-container *ngIf=\"enablePagination\">\r\n <div class=\"flex-column flex-100\">\r\n <app-paginator\r\n [currentPage]=\"pageIndex\"\r\n [totalItems]=\"totalElements\"\r\n [pageSize]=\"pageSize\"\r\n [pageSizeOptions]=\"[5, 10, 25, 50]\"\r\n (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\">\r\n </app-paginator>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".flex-row{display:flex;flex-direction:row}.flex-column{display:flex;flex-direction:column}.flex-100{flex:1 1 100%}.flex-49{flex:0 0 49%}.flex-50{flex:0 0 50%}.align-start{justify-content:flex-start;align-items:flex-start}.align-center{justify-content:center;align-items:center}.align-end{justify-content:flex-end;align-items:flex-end}.gap-0{gap:0}.gap-5{gap:5px}.gap-10{gap:10px}.dataNotFound{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;text-align:center}.dataNotFound__icon{color:var(--primary-color-3nd);font-size:40px;height:40px;width:40px;margin-bottom:8px}.dataNotFound__title{color:#6a6a6a;font-size:20px;font-weight:700;margin-bottom:4px}.dataNotFound__subtitle{color:#6a6a6a;font-size:20px;font-weight:400}@media (max-width: 960px){.flex-column-sm{flex-direction:column}.align-center-sm{justify-content:center;align-items:flex-start}}.filter-row{display:flex;align-items:center;width:100%;gap:12px}.filter-row app-filter-builder{flex:1}.button-group{width:15%;display:flex;justify-content:flex-end;gap:8px}.btn-export{height:44px!important}.arrow-icon{font-size:20px;margin-left:4px}@media (max-width: 1024px){.button-group{width:auto}}@media (max-width: 768px){.filter-row{flex-direction:column;align-items:stretch}.button-group{width:100%;justify-content:flex-start}.btn-export{width:100%}}.stateType{font-size:14px!important}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatSortModule }, { kind: "directive", type: i5.MatSort, selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i5.MatSortHeader, selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "directive", type: MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: MatCellDef, selector: "[matCellDef]" }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "pipe", type: CurrencyPipe, name: "currency" }, { kind: "ngmodule", type: NgxPaginationModule }, { kind: "component", type: MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "component", type: MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: ButtonActionsComponent, selector: "app-button-actions", inputs: ["actions", "disabled", "buttonsAction", "listAction"], outputs: ["clickedButton"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "component", type: MatChipListbox, selector: "mat-chip-listbox", inputs: ["multiple", "aria-orientation", "selectable", "compareWith", "required", "hideSingleSelectionIndicator", "value"], outputs: ["change"] }, { kind: "component", type: MatChipOption, selector: "mat-basic-chip-option, [mat-basic-chip-option], mat-chip-option, [mat-chip-option]", inputs: ["selectable", "selected"], outputs: ["selectionChange"] }, { kind: "component", type: TitleBarComponent, selector: "app-title-bar", inputs: ["pageTitle", "showExtractButton", "totalElements", "titleMode", "subTitle", "statusDesc", "newAction", "extraButton", "showDetails", "showImport", "showButton", "extraData", "titleCorporateAdmin", "hideBackButton", "buttons"], outputs: ["newActionClicked", "extraButtonClicked", "extractReport", "buttonClicked"] }, { kind: "component", type: PaginatorComponent, selector: "app-paginator", inputs: ["currentPage", "totalItems", "pageSize", "pageSizeOptions"], outputs: ["pageChange", "pageSizeChange"] }, { kind: "pipe", type: DecimalPipe, name: "number" }, { kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: FilterBuilderComponent, selector: "app-filter-builder", inputs: ["columns", "isChecked", "filterFields", "pageInfo"], outputs: ["filterInformation", "isEmpty"] }, { kind: "directive", type: MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }], animations: [] }); }
|
|
404
|
+
}
|
|
405
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseTableComponent, decorators: [{
|
|
406
|
+
type: Component,
|
|
407
|
+
args: [{ selector: 'app-base-table', standalone: true, animations: [], imports: [
|
|
408
|
+
NgStyle,
|
|
409
|
+
NgClass,
|
|
410
|
+
TranslateModule,
|
|
411
|
+
MatIcon,
|
|
412
|
+
MatSortModule,
|
|
413
|
+
MatColumnDef,
|
|
414
|
+
MatHeaderCellDef,
|
|
415
|
+
NgIf,
|
|
416
|
+
MatTable,
|
|
417
|
+
MatHeaderCell,
|
|
418
|
+
NgSwitch,
|
|
419
|
+
MatButtonModule,
|
|
420
|
+
MatCell,
|
|
421
|
+
MatCellDef,
|
|
422
|
+
DatePipe,
|
|
423
|
+
CurrencyPipe,
|
|
424
|
+
NgxPaginationModule,
|
|
425
|
+
MatRow,
|
|
426
|
+
MatRowDef,
|
|
427
|
+
MatHeaderRow,
|
|
428
|
+
NgSwitchCase,
|
|
429
|
+
NgSwitchDefault,
|
|
430
|
+
MatHeaderRowDef,
|
|
431
|
+
MatIconButton,
|
|
432
|
+
NgForOf,
|
|
433
|
+
JsonPipe,
|
|
434
|
+
MatButton,
|
|
435
|
+
ButtonActionsComponent,
|
|
436
|
+
MatLabel,
|
|
437
|
+
MatChipListbox,
|
|
438
|
+
MatChipOption,
|
|
439
|
+
MatButtonToggleGroup,
|
|
440
|
+
MatButtonToggle,
|
|
441
|
+
TitleBarComponent,
|
|
442
|
+
PaginatorComponent,
|
|
443
|
+
DecimalPipe,
|
|
444
|
+
MatCheckbox,
|
|
445
|
+
BaseFormCanvasComponent,
|
|
446
|
+
FilterBuilderComponent,
|
|
447
|
+
MatMenuTrigger,
|
|
448
|
+
MatMenu,
|
|
449
|
+
MatMenuItem,
|
|
450
|
+
UpperCasePipe,
|
|
451
|
+
], template: "<div class=\"flex-column baseTable\">\r\n <div class=\"flex-row flex-100\" *ngIf=\"!pageInfo.hideTitle\">\r\n <div [class.flex-50]=\"pageInfo.draftSupported\" [class.flex-100]=\"!pageInfo.draftSupported\" class=\"flex-column align-start\">\r\n <app-title-bar\r\n [pageTitle]=\"pageInfo.hideTitle ? '' : pageInfo.labelsSection+'.list_title'\"\r\n [titleMode]=\"''\"\r\n [newAction]=\"showAddNew()\"\r\n [showExtractButton]=\"!pageInfo.hideExtractButton\"\r\n [extraButton]=\"extraButton\"\r\n (newActionClicked)=\"onAddNewAction($event)\"\r\n (extractReport)=\"extractReport($event)\"\r\n [totalElements]=\"pageInfo.hideTitle ? undefined : totalElements\">\r\n </app-title-bar>\r\n </div>\r\n <div class=\"flex-50 flex-column align-end\" *ngIf=\"pageInfo.draftSupported\">\r\n <mat-chip-listbox aria-label=\"Color selection\" [multiple]=\"false\">\r\n <mat-chip-option [selected]=\"!this.isPending\" [color]=\"'accent'\" [value]=\"'COMPLETED'\" (click)=\"switchViewMode(false)\">\r\n {{'finished' | translate}}\r\n </mat-chip-option>\r\n <mat-chip-option [selected]=\"this.isPending\" [color]=\"'accent'\" [value]=\"'PENDING'\" (click)=\"switchViewMode(true)\">\r\n {{'todo' | translate}}\r\n </mat-chip-option>\r\n </mat-chip-listbox>\r\n </div>\r\n </div>\r\n\r\n <div class=\"filter-row\" *ngIf=\"!pageInfo.hideAdvancedFilter\">\r\n <app-filter-builder\r\n *ngIf=\"!pageInfo.hideAdvancedFilter\"\r\n [pageInfo]=\"pageInfo\"\r\n [columns]=\"columns\"\r\n [filterFields]=\"filterFields\"\r\n (filterInformation)=\"doAdvancedSearch($event)\"\r\n (isEmpty)=\"resetData($event)\">\r\n </app-filter-builder>\r\n\r\n <div class=\"button-group\" >\r\n\r\n <button *ngIf=\"!pageInfo.hideExtractButton\"\r\n mat-flat-button\r\n [matMenuTriggerFor]=\"exportMenu\"\r\n color=\"primary\"\r\n class=\"btn-none-background-primary btn-export\"\r\n >\r\n <div class=\"button-text\">\r\n <mat-icon>file_export</mat-icon>\r\n <span>{{ 'export' | translate }}</span>\r\n <mat-icon class=\"arrow-icon\">arrow_drop_down</mat-icon>\r\n </div>\r\n </button>\r\n\r\n <mat-menu #exportMenu=\"matMenu\">\r\n <button\r\n mat-menu-item\r\n *ngFor=\"let type of types\"\r\n (click)=\"extractReport(type)\"\r\n >\r\n <span>{{ type | uppercase }}</span>\r\n </button>\r\n </mat-menu>\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"flex-row flex-100 baseTable__detailsColumn\">\r\n <div class=\"flex-100\">\r\n <div class=\"flex-row flex-100 mainTable\">\r\n <table [dataSource]=\"dataSource\" class=\"flex-fill\" mat-table matSort (matSortChange)=\"onSortAction($event)\">\r\n <ng-container *ngFor=\"let column of this.columns; let last=last\">\r\n <ng-container matColumnDef=\"{{column.property}}\">\r\n <ng-container *ngIf=\"column.enableSorting; else withoutSortingColumn\">\r\n <th *matHeaderCellDef class=\"mainTable__th\" mat-header-cell mat-sort-header>\r\n {{ labelKey(column) | translate }}\r\n </th>\r\n </ng-container>\r\n <ng-template #withoutSortingColumn>\r\n <th *matHeaderCellDef class=\"mainTable__th\" mat-header-cell>{{ labelKey(column) | translate }}</th>\r\n </ng-template>\r\n\r\n <ng-container [ngSwitch]=\"column.type\">\r\n <ng-container *ngSwitchCase=\"'workflowStatus'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <button mat-button class=\"wfStatus {{ getStatusDescription(element)}}\" [attr.id]=\"'table-btn-wf-'+column.property+'-'+(element.id || element.key || '')\">{{ getStatusDescription(element) }}</button>\r\n </td>\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <button mat-button class=\"wfStatus {{ getStatusDescription(element)}}\" [attr.id]=\"'table-btn-wf2-'+column.property+'-'+(element.id || element.key || '')\">{{ getStatusDescription(element) }}</button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"hyperLinkClicked(column.property,element)\" mat-cell>\r\n <mat-label [ngClass]=\"{'hyper-link': shouldRenderAsHyperLink(element)}\">\r\n {{ extractFieldName(element, column.property) }}\r\n </mat-label>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'button'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <button *ngIf=\"shouldShowButton(element)\" mat-button class=\"primary\" (click)=\"$event.stopPropagation(); actionButtonClicked(column.property, element)\" [attr.id]=\"'table-btn-action-'+column.property\">\r\n {{ labelKey(column) + '_title' | translate }}\r\n </button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'icon'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td\" mat-cell>\r\n <mat-icon [ngClass]=\"{\r\n 'mainTable__td__icon-green': element[column.property] === 'pass',\r\n 'mainTable__td__icon-orange': element[column.property] === 'warning',\r\n 'mainTable__td__icon-red': element[column.property] === 'error'\r\n }\">\r\n {{ getIcon(element[column.property]) }}\r\n </mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <mat-checkbox class=\"primary\" [checked]=\"element[column.property]\" (click)=\"$event.stopPropagation();actionCheckedClicked(column.property,element)\"></mat-checkbox>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'stateType'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n <button mat-button class=\"stateType {{ element[column.property]}}\" [attr.id]=\"'table-btn-state-'+column.property\">{{ labelKeyByValue(column, element) | translate}}</button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n {{ extractFieldName(element, column.property) | date:'yyyy-MM-dd' }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'croppedText'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n {{ getCroppedText(element[column.property], element[column.width]) }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'download'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" style=\"padding: 0;margin: 0;text-align: center;\" mat-cell>\r\n <mat-icon class=\"mainTable__td__icon-blue\">system_update_alt</mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'onOff'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <mat-icon *ngIf=\"element[column.property] === null\" class=\"mainTable__td__icon-darkorange\">flag</mat-icon>\r\n <mat-icon *ngIf=\"element[column.property] === false\" class=\"mainTable__td__icon-red\">flag</mat-icon>\r\n <mat-icon *ngIf=\"element[column.property] === true\" class=\"mainTable__td__icon-green\">flag</mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'status'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <span *ngIf=\"element[column.property] === null || element[column.property] === false\">\r\n {{ pageInfo.labelsSection + '.' + column.label + 'InActive' | translate }}\r\n </span>\r\n <span *ngIf=\"element[column.property] === true\">\r\n {{ pageInfo.labelsSection + '.' + column.label + 'Active' | translate }}\r\n </span>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'info'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td text-secondary\" mat-cell>\r\n <button mat-icon-button (click)=\"$event.stopPropagation();emitEvent(element)\" [attr.id]=\"'table-btn-info-'+element.id\">\r\n <mat-icon>info</mat-icon>\r\n </button>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'netAmount'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <small><sup class=\"mainTable__td__currency\">{{element[column.currency]}}</sup></small>\r\n <span class=\"mainTable__td__property\">{{ extractFieldName(element, column.property) | currency:element[column.currency] :'' }}</span> of\r\n {{ extractFieldName(element, column.additionalProperty) | currency:element[column.currency] :'' }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n {{ extractFieldName(element, column.property) | date : extractFormat(column) }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n <small><sup class=\"mainTable__td__currency\">{{element[column.currency]}}</sup></small>\r\n {{ extractFieldName(element, column.property) | number : (column.digitInfo || '1.3-5') }}\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'listAction'\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" style=\"padding: 0!important;\" mat-cell>\r\n <app-button-actions \r\n [buttonsAction]=\"column.viewType === 'buttonsAction'\"\r\n [listAction]=\"listAction\" \r\n [actions]=\"listAction\" \r\n (clickedButton)=\"actionListClicked($event,element)\">\r\n </app-button-actions>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"column.translate; else noTranslate\">\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"emitRoutePage(element)\" mat-cell>\r\n {{ extractFieldName(element, column.property) | translate }}\r\n </td>\r\n </ng-container>\r\n <ng-template #noTranslate>\r\n <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"emitRoutePage(element)\" mat-cell [innerHtml]='extractFieldName(element, column.property)'></td>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"hasGroups()\">\r\n <ng-container *ngFor=\"let groupName of this.groupNames\">\r\n <ng-container matColumnDef=\"{{groupName}}\">\r\n <th mat-header-cell class=\"extra-header\" *matHeaderCellDef [attr.colspan]=\"groupSpans.get(groupName)\">\r\n {{ (isHumanMade(groupName) ? groupName : \"\") | translate }}\r\n </th>\r\n </ng-container>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"this.groupNames\"></tr>\r\n </ng-container>\r\n\r\n <tr *matHeaderRowDef=\"visibleColumns\" mat-header-row></tr>\r\n <tr (auxclick)=\"openNewTab(row)\" (click)=\"$event.stopPropagation(); onSelectItem(row)\" *matRowDef=\"let row; columns: visibleColumns\"\r\n [attr.id]=\"'table-row-' + (row?.id || row?.key || '')\"\r\n [ngClass]=\"{\r\n 'mainTable__highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n 'mainTable__dark_highlight': isDarkHighlight(row)\r\n }\"\r\n mat-row>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n <div *ngIf=\"noDataFound\" class=\"dataNotFound flex-column\">\r\n <mat-icon class=\"dataNotFound__icon\">{{ noDataFoundIcon }}</mat-icon>\r\n <span class=\"dataNotFound__title\">{{ noDataFoundTitle | translate}}</span>\r\n <span class=\"dataNotFound__subtitle\">{{ noDataFoundSubtitle | translate}}</span>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"(dataSource.data?.length > 0 || customizedData) && !pageInfo.hidePagination\" class=\"main-pagination flex-row\">\r\n <ng-container *ngIf=\"enablePagination\">\r\n <div class=\"flex-column flex-100\">\r\n <app-paginator\r\n [currentPage]=\"pageIndex\"\r\n [totalItems]=\"totalElements\"\r\n [pageSize]=\"pageSize\"\r\n [pageSizeOptions]=\"[5, 10, 25, 50]\"\r\n (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\">\r\n </app-paginator>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".flex-row{display:flex;flex-direction:row}.flex-column{display:flex;flex-direction:column}.flex-100{flex:1 1 100%}.flex-49{flex:0 0 49%}.flex-50{flex:0 0 50%}.align-start{justify-content:flex-start;align-items:flex-start}.align-center{justify-content:center;align-items:center}.align-end{justify-content:flex-end;align-items:flex-end}.gap-0{gap:0}.gap-5{gap:5px}.gap-10{gap:10px}.dataNotFound{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;text-align:center}.dataNotFound__icon{color:var(--primary-color-3nd);font-size:40px;height:40px;width:40px;margin-bottom:8px}.dataNotFound__title{color:#6a6a6a;font-size:20px;font-weight:700;margin-bottom:4px}.dataNotFound__subtitle{color:#6a6a6a;font-size:20px;font-weight:400}@media (max-width: 960px){.flex-column-sm{flex-direction:column}.align-center-sm{justify-content:center;align-items:flex-start}}.filter-row{display:flex;align-items:center;width:100%;gap:12px}.filter-row app-filter-builder{flex:1}.button-group{width:15%;display:flex;justify-content:flex-end;gap:8px}.btn-export{height:44px!important}.arrow-icon{font-size:20px;margin-left:4px}@media (max-width: 1024px){.button-group{width:auto}}@media (max-width: 768px){.filter-row{flex-direction:column;align-items:stretch}.button-group{width:100%;justify-content:flex-start}.btn-export{width:100%}}.stateType{font-size:14px!important}\n"] }]
|
|
452
|
+
}], ctorParameters: () => [{ type: i1.BackendService }, { type: i2.TranslateService }, { type: i3.ShareDataService }, { type: undefined, decorators: [{
|
|
453
|
+
type: Inject,
|
|
454
|
+
args: ['securityManager']
|
|
455
|
+
}] }, { type: i4.Router }], propDecorators: { filterFields: [{
|
|
456
|
+
type: Input
|
|
457
|
+
}], noDataFoundIcon: [{
|
|
458
|
+
type: Input
|
|
459
|
+
}], noDataFoundTitle: [{
|
|
460
|
+
type: Input
|
|
461
|
+
}], noDataFoundSubtitle: [{
|
|
462
|
+
type: Input
|
|
463
|
+
}], pageInfo: [{
|
|
464
|
+
type: Input
|
|
465
|
+
}], enablePagination: [{
|
|
466
|
+
type: Input
|
|
467
|
+
}], data: [{
|
|
468
|
+
type: Input
|
|
469
|
+
}], listAction: [{
|
|
470
|
+
type: Input
|
|
471
|
+
}], columns: [{
|
|
472
|
+
type: Input
|
|
473
|
+
}], filters: [{
|
|
474
|
+
type: Input
|
|
475
|
+
}], pathParam: [{
|
|
476
|
+
type: Input
|
|
477
|
+
}], extraButton: [{
|
|
478
|
+
type: Input
|
|
479
|
+
}], enforceRefresh: [{
|
|
480
|
+
type: Input
|
|
481
|
+
}], isPending: [{
|
|
482
|
+
type: Input
|
|
483
|
+
}], trigger: [{
|
|
484
|
+
type: Input
|
|
485
|
+
}], reportRequest: [{
|
|
486
|
+
type: Input
|
|
487
|
+
}], separateEndpointData: [{
|
|
488
|
+
type: Input
|
|
489
|
+
}], manageablePages: [{
|
|
490
|
+
type: Input
|
|
491
|
+
}], totalPagesCount: [{
|
|
492
|
+
type: Input
|
|
493
|
+
}], currentPageIndex: [{
|
|
494
|
+
type: Input
|
|
495
|
+
}], pageChange: [{
|
|
496
|
+
type: Output
|
|
497
|
+
}], userAction: [{
|
|
498
|
+
type: Output
|
|
499
|
+
}], hyperLinkAction: [{
|
|
500
|
+
type: Output
|
|
501
|
+
}], extraAction: [{
|
|
502
|
+
type: Output
|
|
503
|
+
}], selectedColumn: [{
|
|
504
|
+
type: Output
|
|
505
|
+
}], listActionClicked: [{
|
|
506
|
+
type: Output
|
|
507
|
+
}], showDialog: [{
|
|
508
|
+
type: Output
|
|
509
|
+
}], customizedData: [{
|
|
510
|
+
type: Input
|
|
511
|
+
}], clickRoutePage: [{
|
|
512
|
+
type: Output
|
|
513
|
+
}] } });
|
|
514
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-table/base-table.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-table/base-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  effect,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnChanges, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges\r\n} from \"@angular/core\";\r\nimport {\r\n  MatCell,\r\n  MatCellDef,\r\n  MatColumnDef,\r\n  MatHeaderCell,\r\n  MatHeaderCellDef,\r\n  MatHeaderRow,\r\n  MatHeaderRowDef,\r\n  MatRow,\r\n  MatRowDef,\r\n  MatTable,\r\n  MatTableDataSource\r\n} from \"@angular/material/table\";\r\nimport {TranslateModule, TranslateService} from \"@ngx-translate/core\";\r\nimport {MatSortModule, Sort} from \"@angular/material/sort\";\r\nimport {\r\n  CurrencyPipe,\r\n  DatePipe, DecimalPipe,\r\n  JsonPipe,\r\n  NgClass,\r\n  NgForOf,\r\n  NgIf,\r\n  NgStyle,\r\n  NgSwitch,\r\n  NgSwitchCase,\r\n  NgSwitchDefault, UpperCasePipe\r\n} from \"@angular/common\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\nimport {MatButton, MatButtonModule, MatIconButton} from \"@angular/material/button\";\r\nimport {NgxPaginationModule} from \"ngx-pagination\";\r\nimport {ButtonActionsComponent} from \"../button-actions/button-actions.component\";\r\nimport {ShareDataService} from \"../../services/trigger-form.service\";\r\nimport {BaseUtils} from \"../../utils/base-utils\";\r\nimport {BackendService} from \"../../services/backend-service\";\r\nimport {Filter} from \"../../base-model/filter.model\";\r\nimport {FilterRequest} from \"../../base-model/filter-request\";\r\nimport {\r\n  ADD_NEW_RECORD_ACTION,\r\n  ButtonActionSettings,\r\n  EMPTY_PAGE_INFO, FieldInfo,\r\n  FRONT_END_COLUMN_TYPES,\r\n  PageInfo,\r\n  SELECT_RECORD_ACTION, TABLE_RECORD_ACTION,\r\n  TableColumn\r\n} from \"../../base-model\";\r\nimport {ReportRequest} from \"../../base-model/report-request.model\";\r\nimport {TablePageUserAction} from \"../../base-model/table-page-user-action.interface\";\r\nimport {Workflow} from \"../../base-model/workflow/workflow.model\";\r\nimport {ResponseEnvelop} from \"../../base-model/response-envelop.model\";\r\nimport {Router} from \"@angular/router\";\r\nimport {MatLabel} from \"@angular/material/form-field\";\r\nimport {MatChipListbox, MatChipOption} from \"@angular/material/chips\";\r\nimport {MatButtonToggle, MatButtonToggleGroup} from \"@angular/material/button-toggle\";\r\nimport {TitleBarComponent} from \"../title-bar/title-bar.component\";\r\nimport {PaginatorComponent} from \"../paginator/paginator.component\";\r\nimport {MatCheckbox} from \"@angular/material/checkbox\";\r\nimport {BaseFormCanvasComponent} from \"../base-form-canvas/base-form-canvas.component\";\r\nimport {FilterBuilderComponent} from \"../advanced-filter/filter-builder/filter-builder.component\";\r\nimport {FieldFilter} from \"../../base-model/field-filter.model\";\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from \"@angular/material/menu\";\r\n\r\n@Component({\r\n  selector: 'app-base-table',\r\n  standalone: true,\r\n  templateUrl: './base-table.component.html',\r\n  styleUrls: ['./base-table.component.scss'],\r\n  animations: [],\r\n  imports: [\r\n    NgStyle,\r\n    NgClass,\r\n    TranslateModule,\r\n    MatIcon,\r\n    MatSortModule,\r\n    MatColumnDef,\r\n    MatHeaderCellDef,\r\n    NgIf,\r\n    MatTable,\r\n    MatHeaderCell,\r\n    NgSwitch,\r\n    MatButtonModule,\r\n    MatCell,\r\n    MatCellDef,\r\n    DatePipe,\r\n    CurrencyPipe,\r\n    NgxPaginationModule,\r\n    MatRow,\r\n    MatRowDef,\r\n    MatHeaderRow,\r\n    NgSwitchCase,\r\n    NgSwitchDefault,\r\n    MatHeaderRowDef,\r\n    MatIconButton,\r\n    NgForOf,\r\n    JsonPipe,\r\n    MatButton,\r\n    ButtonActionsComponent,\r\n    MatLabel,\r\n    MatChipListbox,\r\n    MatChipOption,\r\n    MatButtonToggleGroup,\r\n    MatButtonToggle,\r\n    TitleBarComponent,\r\n    PaginatorComponent,\r\n    DecimalPipe,\r\n    MatCheckbox,\r\n    BaseFormCanvasComponent,\r\n    FilterBuilderComponent,\r\n    MatMenuTrigger,\r\n    MatMenu,\r\n    MatMenuItem,\r\n    UpperCasePipe,\r\n  ]\r\n})\r\nexport class BaseTableComponent extends BaseUtils implements OnInit, OnChanges, OnDestroy {\r\n  types: string[] = [\"pdf\", \"csv\", \"xlsx\"]\r\n  collection = {count: 60, data: []};\r\n  config = {\r\n    itemsPerPage: 15,\r\n    currentPage: 1,\r\n    totalItems: this.collection.count\r\n  };\r\n  public maxSize: number = 7;\r\n  public directionLinks: boolean = true;\r\n  public autoHide: boolean = false;\r\n  public responsive: boolean = true;\r\n  public labels: any = {\r\n    previousLabel: '<',\r\n    nextLabel: '>',\r\n    screenReaderPaginationLabel: 'Pagination',\r\n    screenReaderPageLabel: 'page',\r\n    screenReaderCurrentLabel: `You're on page`\r\n  };\r\n\r\n  @Input()\r\n  filterFields: FieldInfo[];\r\n  @Input() noDataFoundIcon = 'close';\r\n  @Input() noDataFoundTitle = 'noDataFoundTitle';\r\n  @Input() noDataFoundSubtitle = 'noDataFoundSubtitle';\r\n  totalElements = 0;\r\n  pagesCount = 0;\r\n  pageIndex = 1;\r\n  pageSize = 15;\r\n  private selectedStatusFilter: Filter[] = [];\r\n  advancedAppliedFilter: any[] = [];\r\n  searchStr: string = '';\r\n  private filterRequest: FilterRequest = new FilterRequest();\r\n  private timer: any;\r\n  @Input()\r\n  override pageInfo: PageInfo = EMPTY_PAGE_INFO;\r\n\r\n  @Input()\r\n  enablePagination: boolean = true;\r\n\r\n  @Input() data?: MatTableDataSource<any>;\r\n  @Input()\r\n  listAction: ButtonActionSettings[] = [];\r\n\r\n  @Input()\r\n  columns: TableColumn<any>[];\r\n\r\n  @Input()\r\n  filters: Filter[] = [];\r\n\r\n  @Input() //@ts-ignore\r\n  pathParam: number;\r\n\r\n  @Input() //@ts-ignore\r\n  extraButton: string;\r\n\r\n  @Input() //@ts-ignore\r\n  enforceRefresh: boolean = false;\r\n\r\n  @Input()\r\n  isPending: boolean = false;\r\n\r\n  @Input()\r\n  trigger: boolean = false;\r\n\r\n  @Input()\r\n  reportRequest: ReportRequest = new ReportRequest({});\r\n\r\n  @Input()\r\n  separateEndpointData: any;\r\n  @Input()\r\n  manageablePages: boolean = false;\r\n  @Input()\r\n  totalPagesCount: number = 0;\r\n  @Input()\r\n  currentPageIndex: number = 0;\r\n\r\n  @Output()\r\n  pageChange: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  @Output()\r\n  userAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n  @Output()\r\n  hyperLinkAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n\r\n  @Output()\r\n  extraAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n\r\n  @Output()\r\n  selectedColumn: EventEmitter<Sort> = new EventEmitter<Sort>();\r\n\r\n  @Output()\r\n  listActionClicked: EventEmitter<{ action: ButtonActionSettings, row: any }> = new EventEmitter<{\r\n    action: ButtonActionSettings,\r\n    row: any\r\n  }>();\r\n\r\n  @Output()\r\n  showDialog: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  usedWorkflow!: Workflow;\r\n\r\n  mode:any;\r\n\r\n  @Input()\r\n  customizedData?: MatTableDataSource<any>;\r\n  dataSource: MatTableDataSource<any>;\r\n  selectedRowIndex = -1;\r\n  noDataFound = false;\r\n  totalRequiredCountItem = 0;\r\n\r\n\r\n  @Output()\r\n  clickRoutePage: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  constructor(\r\n      private backendService: BackendService,\r\n      public translateService: TranslateService,\r\n      public shareDataService: ShareDataService,\r\n      @Inject('securityManager') private securityManager: any,\r\n      private router: Router,\r\n  ) {\r\n    super();\r\n    this.dataSource = new MatTableDataSource();\r\n    this.columns = [];\r\n    this.filterRequest = new FilterRequest();\r\n\r\n    effect(() => {\r\n      if (this.pageInfo.lazyLoadData !== true || this.enforceRefresh === true) {\r\n        this.loadData();\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.backendService.isEmptyItems = this.dataSource.data.length <= 0;\r\n    if (this.customizedData) {\r\n      this.dataSource = this.customizedData;\r\n    }\r\n    if(this.manageablePages) {\r\n      this.pagesCount = this.totalPagesCount;\r\n      this.pageIndex = this.currentPageIndex;\r\n    }\r\n\r\n  }\r\n\r\n  onPageChange(event: number) {\r\n    this.pageIndex = event;\r\n    this.getNext(this.pageIndex - 1);\r\n    if (this.manageablePages) {\r\n      this.pageChange.emit(this.pageIndex);\r\n    }\r\n  }\r\n\r\n\r\n  extractFieldName(element: any, property: string) {\r\n    if (property.includes('.')) {\r\n      return property.split('.').reduce((acc, part) => acc && acc[part], element);\r\n    } else {\r\n      const c = this.columns.find(c => c.property === property);\r\n      if (Array.isArray(element[property]) && c.arraySubProperty ) {\r\n        const fieldValues = element[property].map(f => f[c.arraySubProperty]);\r\n        return  fieldValues.join(', ');\r\n      }else {\r\n        return element[property];\r\n      }\r\n    }\r\n  }\r\n\r\n  get visibleColumns() {\r\n    this.buildGroups()\r\n    return this.columns.filter(column => column.visible).map(column => column.property);\r\n  }\r\n\r\n  getNext(pageIndex: number) {\r\n    this.reportRequest.filterRequest.pageIndex = pageIndex;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.loadData();\r\n  }\r\n  onPageSizeChange(event: number) {\r\n    this.pageSize = event;\r\n    this.pageIndex = 1; // reset to first page on page size change\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.getNext(0);\r\n  }\r\n\r\n\r\n\r\n  private loadData() {\r\n    clearTimeout(this.timer);\r\n    if (!this.reportRequest.filterRequest) {\r\n      this.reportRequest.filterRequest = new FilterRequest(this.pageInfo.pageSize);\r\n      this.reportRequest.filterRequest.filters = this.advancedAppliedFilter;\r\n    }\r\n    if (this.separateEndpointData || !this.pageInfo.apiUri || this.pageInfo.apiUri.length === 0) {\r\n      this.dataSource.data = this.separateEndpointData;\r\n    } else if(this.reportRequest == undefined){\r\n      return;\r\n    } else if(!this.manageablePages)  {\r\n      this.timer = setTimeout(() => {\r\n          this.reportRequest.filterRequest.columns = this.columns?.filter(c => FRONT_END_COLUMN_TYPES.indexOf(c.type) < 0 ).map(c => c.property) || [];\r\n          this.reportRequest.filterRequest.pendingPage = this.isPending;\r\n          this.reportRequest.filterRequest.filters = this.advancedAppliedFilter;\r\n            this.backendService.getItemsByFilter(this.reportRequest?.filterRequest, this.pageInfo.apiUri).subscribe(resp => {\r\n              const responseEnvelope = new ResponseEnvelop(resp);\r\n              if (responseEnvelope.valid) {\r\n                this.totalRequiredCountItem = this.reportRequest.filterRequest.pageSize\r\n                this.noDataFound = responseEnvelope.body.length < 1;\r\n                this.dataSource.data = responseEnvelope.body;\r\n                this.backendService.isEmptyItems = this.dataSource.data.length <= 0;\r\n                this.totalElements = responseEnvelope.totalSize || 0;\r\n                this.pagesCount = Math.ceil(this.totalElements / this.pageSize) || 1;\r\n                this.pageIndex = (this.reportRequest.filterRequest.pageIndex || 0) + 1;\r\n                this.config.totalItems = responseEnvelope.totalSize || 0;\r\n                this.config.currentPage = this.pageIndex + 1;\r\n                // this.pageSize = this.reportRequest.filterRequest.pageSize;\r\n              }\r\n            });\r\n          }\r\n          , 300);\r\n    }\r\n  }\r\n\r\n  getStatusDescription(element: any) {\r\n    return this.backendService.getStatusDescription(element, this.usedWorkflow);\r\n  }\r\n\r\n  getStateType(element: any) {\r\n    return element.stateType\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"customizedData\"] && !changes[\"customizedData\"].isFirstChange()) {\r\n      this.dataSource.data = changes[\"customizedData\"].currentValue?.data || [];  // Update data source with new data\r\n      this.pagesCount=this.totalPagesCount;\r\n      this.pageIndex=this.currentPageIndex;\r\n    }\r\n    if (changes[\"enforceRefresh\"] && !changes[\"enforceRefresh\"].isFirstChange()) {\r\n      this.loadData();\r\n    }\r\n  }\r\n  getCroppedText(elementValue: any, subWidth: number = 20) {\r\n    return elementValue && elementValue.length > subWidth ? elementValue.substring(0, subWidth) + \"...\" : elementValue;\r\n  }\r\n\r\n  emitEvent(element: any) {\r\n    this.showDialog.emit(element);\r\n  }\r\n\r\n  extractFormat(column: TableColumn<any>) {\r\n    return column?.format || 'd/M/yyyy, h:mm a';\r\n  }\r\n\r\n  actionListClicked(listAction: ButtonActionSettings, element: any) {\r\n    this.listActionClicked.emit({action:listAction, row: element});\r\n  }\r\n\r\n  hyperLinkClicked(actionName: string, element: any) {\r\n    const action = TABLE_RECORD_ACTION;\r\n    action.actionKey = actionName;\r\n    action.item = element;\r\n    action.pageInfo = this.pageInfo;\r\n    this.hyperLinkAction.emit(action)\r\n  }\r\n\r\n\r\n  emitRoutePage(element: any){\r\n    this.clickRoutePage.emit(element);\r\n  }\r\n\r\n  onSelectItem(row: any) {\r\n    if (this.pageInfo.selfRouting) {\r\n      const mode = this.isPending ? 'pending' : 'view';\r\n      const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;\r\n\r\n      const encryptedId = this.backendService.encrypt(String(row.id));\r\n      const encryptedMode = this.backendService.encrypt(mode);\r\n\r\n      const encryptedRow = this.backendService.encrypt(JSON.stringify(row));\r\n\r\n      this.router.navigate([url], {\r\n        queryParams: { token: encryptedId, mode: encryptedMode },\r\n        state: { raw: encryptedRow },\r\n      });\r\n      return;\r\n    }\r\n    // const action = SELECT_RECORD_ACTION;\r\n    // action.id = row?.id;\r\n    // action.item = row;\r\n    // this.userAction.emit(action)\r\n  }\r\n\r\n  openNewTab(row) {\r\n    if (!this.pageInfo.embededTableOnly) {\r\n      const mode = this.isPending ? 'pending' : 'view';\r\n      window.open(`${this.pageInfo.listRoutePath}/${mode}` + '/' + row?.id);\r\n    }\r\n  }\r\n\r\n  switchViewMode(b: boolean) {\r\n    this.isPending = !this.isPending;\r\n    this.loadData();\r\n  }\r\n\r\n  onAddNewAction($event: any) {\r\n    const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;\r\n    const encryptedId = this.backendService.encrypt(\"-1\");\r\n    const encryptedMode = this.backendService.encrypt(\"pending\");\r\n    this.router.navigate([`${url}`],\r\n      { queryParams: { token: encryptedId , mode : encryptedMode } });\r\n\r\n    // const action = SELECT_RECORD_ACTION;\r\n    // action.id = row?.id;\r\n    // action.item = row;\r\n    // this.userAction.emit(action)\r\n  }\r\n\r\n  showAddNew() {\r\n    return this.pageInfo.hasAddButton ;\r\n  }\r\n\r\n  onExtraButtionAction($event: any) {\r\n    this.extraAction.emit($event);\r\n\r\n  }\r\n\r\n  hasGroups() {\r\n    let b = this.columns.findIndex(p => p.group);\r\n    return b >= 0;\r\n  }\r\n  groupNames: any = []\r\n  groupSpans: Map<string, number> = new Map();\r\n\r\n  buildGroups(){\r\n    let count = 0;\r\n    this.groupNames = [];\r\n    this.groupSpans.clear();\r\n    if(this.hasGroups() === false){\r\n      return;\r\n    }\r\n    this.columns\r\n      .filter(column => column.visible === true)\r\n      .forEach((column) => {\r\n        if (column.group === \"-\") {\r\n          this.groupNames.push(count.toString());\r\n          this.insertInMap(count);\r\n          count++;\r\n          return;\r\n        } else if (!this.groupNames.includes(column.group)) {\r\n          this.groupNames.push(column.group);\r\n          this.insertInMap(column.group);\r\n          return;\r\n        }\r\n        this.insertInMap(column.group);\r\n      });\r\n  }\r\n\r\n  insertInMap(key){\r\n    if(this.groupSpans.has(key)){\r\n      this.groupSpans.set(key.toString(), this.groupSpans.get(key) + 1);\r\n    } else {\r\n      this.groupSpans.set(key.toString(), 1);\r\n    }\r\n  }\r\n\r\n  isHumanMade(str){\r\n    return isNaN(str);\r\n  }\r\n\r\n  actionButtonClicked(actionKey: string, item: any): void {\r\n    if (actionKey === 'navigate') {\r\n      this.handleNavigateAction(item);\r\n      return;\r\n    }\r\n\r\n    this.emitTableAction(actionKey, item);\r\n  }\r\n\r\n  private handleNavigateAction(item: any): void {\r\n    const mode = this.isPending ? 'pending' : 'view';\r\n    const basePath = this.pageInfo.listRoutePath || this.router.url;\r\n    const url = `${basePath}/view`;\r\n\r\n    const encryptedId = this.backendService.encrypt(item.id.toString());\r\n    const encryptedMode = this.backendService.encrypt(mode);\r\n\r\n    this.router.navigate([url], {\r\n      queryParams: { token: encryptedId, mode: encryptedMode }\r\n    });\r\n  }\r\n\r\n  private emitTableAction(actionKey: string, item: any): void {\r\n    const action = TABLE_RECORD_ACTION;\r\n    action.actionKey = actionKey;\r\n    action.item = item;\r\n    action.pageInfo = this.pageInfo;\r\n    this.userAction.emit(action);\r\n  }\r\n\r\n  extractReport(reportType: any) {\r\n    const myFilters = this.reportRequest.filterRequest;\r\n    const reportRequest = this.backendService.buildReportRequest(this.columns, this.pageInfo.labelsSection + '.list_title',\r\n      myFilters, reportType, this.pageInfo, this.searchStr, 'LANDSCAPE');\r\n    this.backendService.downloadReport(reportRequest, this.pageInfo.apiUri);\r\n  }\r\n\r\n  getIcon(status: string): string {\r\n    switch (status) {\r\n      case 'pass': return 'check_circle';\r\n      case 'warning': return 'warning';\r\n      case 'error': return 'error';\r\n      default: return 'help';\r\n    }\r\n  }\r\n\r\n  actionCheckedClicked(property: string, element) {\r\n    element[property]= !element[property];\r\n    this.actionButtonClicked(property, element);\r\n  }\r\n\r\n\r\n  isDarkHighlight(row: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !row[groupByProp]) {\r\n      return false;\r\n    }\r\n\r\n    const cellValue = row[groupByProp].toString();\r\n\r\n    return groupByValues.some(val =>\r\n      cellValue.includes(val) && cellValue.length > val.length\r\n    );\r\n  }\r\n\r\n  shouldRenderAsHyperLink(element: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !element[groupByProp]) {\r\n      return false;\r\n    }\r\n\r\n    const value = element[groupByProp].toString();\r\n\r\n    return !groupByValues.some(v => value.includes(v) && value.length >= v.length);\r\n  }\r\n\r\n\r\n  onSortAction($event: Sort) {\r\n    this.reportRequest.filterRequest.sortKey = $event.active && $event.direction ?\r\n      this.columns.find(c => c.property === $event.active)?.orderByProperty || $event.active\r\n      : 'id';\r\n    this.reportRequest.filterRequest.sortDirection = $event.direction === 'asc' ? 'ASC' : 'DESC';\r\n    this.reportRequest.filterRequest.pageIndex = 0;\r\n      this.selectedColumn.emit($event);\r\n      this.loadData();\r\n  }\r\n\r\n  shouldShowButton(element: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !element[groupByProp]) {\r\n      return true;\r\n    }\r\n\r\n    const value = element[groupByProp].toString();\r\n\r\n    return !groupByValues.some(v => value.includes(v) && value.length >= v.length);\r\n  }\r\n  doAdvancedSearch($event: FieldFilter[]) {\r\n    this.advancedAppliedFilter = [];\r\n    if ($event.length === 0) {\r\n      this.advancedAppliedFilter = [];\r\n      this.loadData();\r\n      // this.paginator.firstPage();\r\n    } else {\r\n      this.advancedAppliedFilter = $event;\r\n      this.loadData();\r\n    }\r\n  }\r\n  resetData($event: boolean) {\r\n    if ($event) {\r\n      this.advancedAppliedFilter = [];\r\n      this.loadData();\r\n      // this.paginator.firstPage();\r\n    }\r\n  }\r\n}\r\n","<div class=\"flex-column baseTable\">\r\n  <div class=\"flex-row flex-100\" *ngIf=\"!pageInfo.hideTitle\">\r\n    <div [class.flex-50]=\"pageInfo.draftSupported\" [class.flex-100]=\"!pageInfo.draftSupported\" class=\"flex-column align-start\">\r\n      <app-title-bar\r\n        [pageTitle]=\"pageInfo.hideTitle ? '' : pageInfo.labelsSection+'.list_title'\"\r\n        [titleMode]=\"''\"\r\n        [newAction]=\"showAddNew()\"\r\n        [showExtractButton]=\"!pageInfo.hideExtractButton\"\r\n        [extraButton]=\"extraButton\"\r\n        (newActionClicked)=\"onAddNewAction($event)\"\r\n        (extractReport)=\"extractReport($event)\"\r\n        [totalElements]=\"pageInfo.hideTitle ? undefined : totalElements\">\r\n      </app-title-bar>\r\n    </div>\r\n    <div class=\"flex-50 flex-column align-end\" *ngIf=\"pageInfo.draftSupported\">\r\n      <mat-chip-listbox aria-label=\"Color selection\" [multiple]=\"false\">\r\n        <mat-chip-option [selected]=\"!this.isPending\" [color]=\"'accent'\" [value]=\"'COMPLETED'\" (click)=\"switchViewMode(false)\">\r\n          {{'finished' | translate}}\r\n        </mat-chip-option>\r\n        <mat-chip-option [selected]=\"this.isPending\" [color]=\"'accent'\" [value]=\"'PENDING'\" (click)=\"switchViewMode(true)\">\r\n          {{'todo' | translate}}\r\n        </mat-chip-option>\r\n      </mat-chip-listbox>\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"filter-row\" *ngIf=\"!pageInfo.hideAdvancedFilter\">\r\n    <app-filter-builder\r\n      *ngIf=\"!pageInfo.hideAdvancedFilter\"\r\n      [pageInfo]=\"pageInfo\"\r\n      [columns]=\"columns\"\r\n      [filterFields]=\"filterFields\"\r\n      (filterInformation)=\"doAdvancedSearch($event)\"\r\n      (isEmpty)=\"resetData($event)\">\r\n    </app-filter-builder>\r\n\r\n    <div class=\"button-group\" >\r\n\r\n      <button *ngIf=\"!pageInfo.hideExtractButton\"\r\n        mat-flat-button\r\n        [matMenuTriggerFor]=\"exportMenu\"\r\n        color=\"primary\"\r\n        class=\"btn-none-background-primary btn-export\"\r\n      >\r\n        <div class=\"button-text\">\r\n          <mat-icon>file_export</mat-icon>\r\n          <span>{{ 'export' | translate }}</span>\r\n          <mat-icon class=\"arrow-icon\">arrow_drop_down</mat-icon>\r\n        </div>\r\n      </button>\r\n\r\n      <mat-menu #exportMenu=\"matMenu\">\r\n        <button\r\n          mat-menu-item\r\n          *ngFor=\"let type of types\"\r\n          (click)=\"extractReport(type)\"\r\n        >\r\n          <span>{{ type | uppercase }}</span>\r\n        </button>\r\n      </mat-menu>\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <div class=\"flex-row flex-100 baseTable__detailsColumn\">\r\n    <div class=\"flex-100\">\r\n      <div class=\"flex-row flex-100 mainTable\">\r\n        <table [dataSource]=\"dataSource\" class=\"flex-fill\" mat-table matSort (matSortChange)=\"onSortAction($event)\">\r\n          <ng-container *ngFor=\"let column of this.columns; let last=last\">\r\n            <ng-container matColumnDef=\"{{column.property}}\">\r\n              <ng-container *ngIf=\"column.enableSorting; else withoutSortingColumn\">\r\n                <th *matHeaderCellDef class=\"mainTable__th\" mat-header-cell mat-sort-header>\r\n                  {{ labelKey(column) | translate }}\r\n                </th>\r\n              </ng-container>\r\n              <ng-template #withoutSortingColumn>\r\n                <th *matHeaderCellDef class=\"mainTable__th\" mat-header-cell>{{ labelKey(column) | translate }}</th>\r\n              </ng-template>\r\n\r\n              <ng-container [ngSwitch]=\"column.type\">\r\n                <ng-container *ngSwitchCase=\"'workflowStatus'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n                    <button mat-button class=\"wfStatus {{ getStatusDescription(element)}}\" [attr.id]=\"'table-btn-wf-'+column.property+'-'+(element.id || element.key || '')\">{{ getStatusDescription(element) }}</button>\r\n                  </td>\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    <button mat-button class=\"wfStatus {{ getStatusDescription(element)}}\" [attr.id]=\"'table-btn-wf2-'+column.property+'-'+(element.id || element.key || '')\">{{ getStatusDescription(element) }}</button>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"hyperLinkClicked(column.property,element)\" mat-cell>\r\n                    <mat-label [ngClass]=\"{'hyper-link': shouldRenderAsHyperLink(element)}\">\r\n                      {{ extractFieldName(element, column.property) }}\r\n                    </mat-label>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'button'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n                    <button *ngIf=\"shouldShowButton(element)\" mat-button class=\"primary\" (click)=\"$event.stopPropagation(); actionButtonClicked(column.property, element)\" [attr.id]=\"'table-btn-action-'+column.property\">\r\n                      {{ labelKey(column) + '_title' | translate }}\r\n                    </button>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'icon'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td\" mat-cell>\r\n                    <mat-icon [ngClass]=\"{\r\n                      'mainTable__td__icon-green': element[column.property] === 'pass',\r\n                      'mainTable__td__icon-orange': element[column.property] === 'warning',\r\n                      'mainTable__td__icon-red': element[column.property] === 'error'\r\n                    }\">\r\n                      {{ getIcon(element[column.property]) }}\r\n                    </mat-icon>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n                    <mat-checkbox class=\"primary\" [checked]=\"element[column.property]\" (click)=\"$event.stopPropagation();actionCheckedClicked(column.property,element)\"></mat-checkbox>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'stateType'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary\" mat-cell>\r\n                    <button mat-button class=\"stateType {{ element[column.property]}}\" [attr.id]=\"'table-btn-state-'+column.property\">{{ labelKeyByValue(column, element) | translate}}</button>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'date'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    {{ extractFieldName(element, column.property) | date:'yyyy-MM-dd' }}\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'croppedText'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    {{ getCroppedText(element[column.property], element[column.width]) }}\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'download'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" style=\"padding: 0;margin: 0;text-align: center;\" mat-cell>\r\n                    <mat-icon class=\"mainTable__td__icon-blue\">system_update_alt</mat-icon>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'onOff'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    <mat-icon *ngIf=\"element[column.property] === null\" class=\"mainTable__td__icon-darkorange\">flag</mat-icon>\r\n                    <mat-icon *ngIf=\"element[column.property] === false\" class=\"mainTable__td__icon-red\">flag</mat-icon>\r\n                    <mat-icon *ngIf=\"element[column.property] === true\" class=\"mainTable__td__icon-green\">flag</mat-icon>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'status'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    <span *ngIf=\"element[column.property] === null || element[column.property] === false\">\r\n                      {{ pageInfo.labelsSection + '.' + column.label + 'InActive' | translate }}\r\n                    </span>\r\n                    <span *ngIf=\"element[column.property] === true\">\r\n                      {{ pageInfo.labelsSection + '.' + column.label + 'Active' | translate }}\r\n                    </span>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'info'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td text-secondary\" mat-cell>\r\n                    <button mat-icon-button (click)=\"$event.stopPropagation();emitEvent(element)\" [attr.id]=\"'table-btn-info-'+element.id\">\r\n                      <mat-icon>info</mat-icon>\r\n                    </button>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'netAmount'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    <small><sup class=\"mainTable__td__currency\">{{element[column.currency]}}</sup></small>\r\n                    <span class=\"mainTable__td__property\">{{ extractFieldName(element, column.property) | currency:element[column.currency] :'' }}</span> of\r\n                    {{ extractFieldName(element, column.additionalProperty) | currency:element[column.currency] :'' }}\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    {{ extractFieldName(element, column.property) | date : extractFormat(column) }}\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" mat-cell>\r\n                    <small><sup class=\"mainTable__td__currency\">{{element[column.currency]}}</sup></small>\r\n                    {{ extractFieldName(element, column.property) | number : (column.digitInfo || '1.3-5') }}\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'listAction'\">\r\n                  <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" style=\"padding: 0!important;\" mat-cell>\r\n                    <app-button-actions \r\n                      [buttonsAction]=\"column.viewType === 'buttonsAction'\"\r\n                      [listAction]=\"listAction\" \r\n                      [actions]=\"listAction\" \r\n                      (clickedButton)=\"actionListClicked($event,element)\">\r\n                    </app-button-actions>\r\n                  </td>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchDefault>\r\n                  <ng-container *ngIf=\"column.translate; else noTranslate\">\r\n                    <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"emitRoutePage(element)\" mat-cell>\r\n                      {{ extractFieldName(element, column.property) | translate }}\r\n                    </td>\r\n                  </ng-container>\r\n                  <ng-template #noTranslate>\r\n                    <td *matCellDef=\"let element\" class=\"mainTable__td mainTable__td__text-secondary__td\" (click)=\"emitRoutePage(element)\" mat-cell [innerHtml]='extractFieldName(element, column.property)'></td>\r\n                  </ng-template>\r\n                </ng-container>\r\n              </ng-container>\r\n            </ng-container>\r\n          </ng-container>\r\n\r\n          <ng-container *ngIf=\"hasGroups()\">\r\n            <ng-container *ngFor=\"let groupName of this.groupNames\">\r\n              <ng-container matColumnDef=\"{{groupName}}\">\r\n                <th mat-header-cell class=\"extra-header\" *matHeaderCellDef [attr.colspan]=\"groupSpans.get(groupName)\">\r\n                  {{ (isHumanMade(groupName) ? groupName : \"\") | translate }}\r\n                </th>\r\n              </ng-container>\r\n            </ng-container>\r\n            <tr mat-header-row *matHeaderRowDef=\"this.groupNames\"></tr>\r\n          </ng-container>\r\n\r\n          <tr *matHeaderRowDef=\"visibleColumns\" mat-header-row></tr>\r\n          <tr (auxclick)=\"openNewTab(row)\" (click)=\"$event.stopPropagation(); onSelectItem(row)\" *matRowDef=\"let row; columns: visibleColumns\"\r\n              [attr.id]=\"'table-row-' + (row?.id || row?.key || '')\"\r\n              [ngClass]=\"{\r\n                'mainTable__highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n                'mainTable__dark_highlight': isDarkHighlight(row)\r\n              }\"\r\n              mat-row>\r\n          </tr>\r\n        </table>\r\n      </div>\r\n\r\n      <div *ngIf=\"noDataFound\" class=\"dataNotFound flex-column\">\r\n        <mat-icon class=\"dataNotFound__icon\">{{ noDataFoundIcon }}</mat-icon>\r\n        <span class=\"dataNotFound__title\">{{ noDataFoundTitle | translate}}</span>\r\n        <span class=\"dataNotFound__subtitle\">{{ noDataFoundSubtitle | translate}}</span>\r\n      </div>\r\n\r\n\r\n      <div  *ngIf=\"(dataSource.data?.length > 0 || customizedData) && !pageInfo.hidePagination\" class=\"main-pagination flex-row\">\r\n        <ng-container *ngIf=\"enablePagination\">\r\n          <div class=\"flex-column flex-100\">\r\n            <app-paginator\r\n              [currentPage]=\"pageIndex\"\r\n              [totalItems]=\"totalElements\"\r\n              [pageSize]=\"pageSize\"\r\n              [pageSizeOptions]=\"[5, 10, 25, 50]\"\r\n              (pageChange)=\"onPageChange($event)\"\r\n              (pageSizeChange)=\"onPageSizeChange($event)\">\r\n            </app-paginator>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|