spiderly 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -0
- package/esm2022/lib/components/auth/auth.module.mjs +65 -0
- package/esm2022/lib/components/auth/login/login.component.mjs +60 -0
- package/esm2022/lib/components/auth/partials/auth.component.mjs +53 -0
- package/esm2022/lib/components/auth/partials/login-verification.component.mjs +39 -0
- package/esm2022/lib/components/auth/partials/registration-verification.component.mjs +37 -0
- package/esm2022/lib/components/auth/partials/verification-wrapper.component.mjs +74 -0
- package/esm2022/lib/components/auth/registration/registration.component.mjs +59 -0
- package/esm2022/lib/components/base-details/role-base-details.component.mjs +171 -0
- package/esm2022/lib/components/base-form/base-form copy.mjs +247 -0
- package/esm2022/lib/components/card-skeleton/card-skeleton.component.mjs +25 -0
- package/esm2022/lib/components/footer/footer.component.mjs +16 -0
- package/esm2022/lib/components/index-card/index-card.component.mjs +57 -0
- package/esm2022/lib/components/info-card/info-card.component.mjs +29 -0
- package/esm2022/lib/components/layout/layout-base.component.mjs +120 -0
- package/esm2022/lib/components/layout/sidebar/menuitem.component.mjs +161 -0
- package/esm2022/lib/components/layout/sidebar/sidebar-menu.component.mjs +34 -0
- package/esm2022/lib/components/layout/sidebar/sidebar-menu.service.mjs +26 -0
- package/esm2022/lib/components/layout/sidebar/sidebar.component.mjs +21 -0
- package/esm2022/lib/components/layout/topbar/topbar.component.mjs +115 -0
- package/esm2022/lib/components/not-found/not-found.component.mjs +20 -0
- package/esm2022/lib/components/required/required.component.mjs +12 -0
- package/esm2022/lib/components/spiderly-buttons/google-button/google-button.component.mjs +43 -0
- package/esm2022/lib/components/spiderly-buttons/return-button/return-button.component.mjs +37 -0
- package/esm2022/lib/components/spiderly-buttons/spiderly-button/spiderly-button.component.mjs +20 -0
- package/esm2022/lib/components/spiderly-buttons/spiderly-button-base/spiderly-button-base.mjs +68 -0
- package/esm2022/lib/components/spiderly-buttons/spiderly-split-button/spiderly-split-button.component.mjs +22 -0
- package/esm2022/lib/components/spiderly-data-table/spiderly-data-table.component.mjs +502 -0
- package/esm2022/lib/components/spiderly-delete-dialog/spiderly-delete-confirmation.component.mjs +42 -0
- package/esm2022/lib/components/spiderly-form-control/spiderly-form-control.mjs +36 -0
- package/esm2022/lib/components/spiderly-panels/panel-body/panel-body.component.mjs +19 -0
- package/esm2022/lib/components/spiderly-panels/panel-footer/panel-footer.component.mjs +14 -0
- package/esm2022/lib/components/spiderly-panels/panel-header/panel-header.component.mjs +49 -0
- package/esm2022/lib/components/spiderly-panels/spiderly-card/spiderly-card.component.mjs +20 -0
- package/esm2022/lib/components/spiderly-panels/spiderly-panel/spiderly-panel.component.mjs +63 -0
- package/esm2022/lib/components/spiderly-panels/spiderly-panels.module.mjs +49 -0
- package/esm2022/lib/controls/base-autocomplete-control.mjs +18 -0
- package/esm2022/lib/controls/base-control.mjs +62 -0
- package/esm2022/lib/controls/base-dropdown-control.mjs +37 -0
- package/esm2022/lib/controls/spiderly-autocomplete/spiderly-autocomplete.component.mjs +60 -0
- package/esm2022/lib/controls/spiderly-calendar/spiderly-calendar.component.mjs +39 -0
- package/esm2022/lib/controls/spiderly-checkbox/spiderly-checkbox.component.mjs +45 -0
- package/esm2022/lib/controls/spiderly-colorpick/spiderly-colorpick.component.mjs +40 -0
- package/esm2022/lib/controls/spiderly-controls.module.mjs +112 -0
- package/esm2022/lib/controls/spiderly-dropdown/spiderly-dropdown.component.mjs +40 -0
- package/esm2022/lib/controls/spiderly-editor/spiderly-editor.component.mjs +59 -0
- package/esm2022/lib/controls/spiderly-file/spiderly-file.component.mjs +106 -0
- package/esm2022/lib/controls/spiderly-multiautocomplete/spiderly-multiautocomplete.component.mjs +38 -0
- package/esm2022/lib/controls/spiderly-multiselect/spiderly-multiselect.component.mjs +34 -0
- package/esm2022/lib/controls/spiderly-number/spiderly-number.component.mjs +44 -0
- package/esm2022/lib/controls/spiderly-password/spiderly-password.component.mjs +37 -0
- package/esm2022/lib/controls/spiderly-textarea/spiderly-textarea.component.mjs +34 -0
- package/esm2022/lib/controls/spiderly-textbox/spiderly-textbox.component.mjs +45 -0
- package/esm2022/lib/entities/base-entity.mjs +18 -0
- package/esm2022/lib/entities/codebook.mjs +10 -0
- package/esm2022/lib/entities/init-company-auth-dialog-details.mjs +9 -0
- package/esm2022/lib/entities/init-top-bar-data.mjs +12 -0
- package/esm2022/lib/entities/is-authorized-for-save-event.mjs +9 -0
- package/esm2022/lib/entities/last-menu-icon-index-clicked.mjs +8 -0
- package/esm2022/lib/entities/lazy-load-selected-ids-result.mjs +11 -0
- package/esm2022/lib/entities/menuchangeevent.mjs +3 -0
- package/esm2022/lib/entities/mime-type.mjs +15 -0
- package/esm2022/lib/entities/namebook.mjs +9 -0
- package/esm2022/lib/entities/primeng-option.mjs +9 -0
- package/esm2022/lib/entities/security-entities.mjs +169 -0
- package/esm2022/lib/entities/simple-save-result.mjs +9 -0
- package/esm2022/lib/entities/spiderly-button.mjs +11 -0
- package/esm2022/lib/entities/table-filter-context.mjs +3 -0
- package/esm2022/lib/entities/table-filter-sort-meta.mjs +3 -0
- package/esm2022/lib/entities/table-filter.mjs +15 -0
- package/esm2022/lib/entities/table-response.mjs +3 -0
- package/esm2022/lib/enums/security-enums.mjs +26 -0
- package/esm2022/lib/enums/verification-type-codes.mjs +6 -0
- package/esm2022/lib/guards/auth.guard.mjs +40 -0
- package/esm2022/lib/guards/not-auth.guard.mjs +32 -0
- package/esm2022/lib/handlers/spiderly-error-handler.mjs +30 -0
- package/esm2022/lib/handlers/spiderly-transloco-fallback-strategy.mjs +24 -0
- package/esm2022/lib/interceptors/http-loading.interceptor.mjs +27 -0
- package/esm2022/lib/interceptors/json-parser.interceptor.mjs +47 -0
- package/esm2022/lib/interceptors/jwt.interceptor.mjs +27 -0
- package/esm2022/lib/interceptors/unauthorized.interceptor.mjs +64 -0
- package/esm2022/lib/modules/core.module.mjs +140 -0
- package/esm2022/lib/modules/primeng.module.mjs +278 -0
- package/esm2022/lib/modules/spiderly-transloco.module.mjs +44 -0
- package/esm2022/lib/services/api.service.security.mjs +86 -0
- package/esm2022/lib/services/app-initializer.mjs +6 -0
- package/esm2022/lib/services/app-layout-base.service.mjs +132 -0
- package/esm2022/lib/services/auth-base.service.mjs +220 -0
- package/esm2022/lib/services/base-form.service.mjs +124 -0
- package/esm2022/lib/services/config-base.service.mjs +33 -0
- package/esm2022/lib/services/helper-functions.mjs +229 -0
- package/esm2022/lib/services/spiderly-message.service.mjs +64 -0
- package/esm2022/lib/services/spiderly-transloco-loader.mjs +20 -0
- package/esm2022/lib/services/translate-labels-abstract.service.mjs +15 -0
- package/esm2022/lib/services/validator-abstract.service.mjs +51 -0
- package/esm2022/public-api.mjs +94 -0
- package/esm2022/spiderly.mjs +5 -0
- package/fesm2022/spiderly.mjs +4807 -0
- package/fesm2022/spiderly.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/auth/auth.module.d.ts +17 -0
- package/lib/components/auth/login/login.component.d.ts +35 -0
- package/lib/components/auth/partials/auth.component.d.ts +21 -0
- package/lib/components/auth/partials/login-verification.component.d.ts +18 -0
- package/lib/components/auth/partials/registration-verification.component.d.ts +17 -0
- package/lib/components/auth/partials/verification-wrapper.component.d.ts +31 -0
- package/lib/components/auth/registration/registration.component.d.ts +34 -0
- package/lib/components/base-details/role-base-details.component.d.ts +50 -0
- package/lib/components/base-form/base-form copy.d.ts +54 -0
- package/lib/components/card-skeleton/card-skeleton.component.d.ts +12 -0
- package/lib/components/footer/footer.component.d.ts +9 -0
- package/lib/components/index-card/index-card.component.d.ts +22 -0
- package/lib/components/info-card/info-card.component.d.ts +11 -0
- package/lib/components/layout/layout-base.component.d.ts +37 -0
- package/lib/components/layout/sidebar/menuitem.component.d.ts +43 -0
- package/lib/components/layout/sidebar/sidebar-menu.component.d.ts +23 -0
- package/lib/components/layout/sidebar/sidebar-menu.service.d.ts +12 -0
- package/lib/components/layout/sidebar/sidebar.component.d.ts +11 -0
- package/lib/components/layout/topbar/topbar.component.d.ts +45 -0
- package/lib/components/not-found/not-found.component.d.ts +9 -0
- package/lib/components/required/required.component.d.ts +6 -0
- package/lib/components/spiderly-buttons/google-button/google-button.component.d.ts +17 -0
- package/lib/components/spiderly-buttons/return-button/return-button.component.d.ts +10 -0
- package/lib/components/spiderly-buttons/spiderly-button/spiderly-button.component.d.ts +6 -0
- package/lib/components/spiderly-buttons/spiderly-button-base/spiderly-button-base.d.ts +27 -0
- package/lib/components/spiderly-buttons/spiderly-split-button/spiderly-split-button.component.d.ts +8 -0
- package/lib/components/spiderly-data-table/spiderly-data-table.component.d.ts +157 -0
- package/lib/components/spiderly-delete-dialog/spiderly-delete-confirmation.component.d.ts +11 -0
- package/lib/components/spiderly-form-control/spiderly-form-control.d.ts +37 -0
- package/lib/components/spiderly-panels/panel-body/panel-body.component.d.ts +9 -0
- package/lib/components/spiderly-panels/panel-footer/panel-footer.component.d.ts +8 -0
- package/lib/components/spiderly-panels/panel-header/panel-header.component.d.ts +29 -0
- package/lib/components/spiderly-panels/spiderly-card/spiderly-card.component.d.ts +10 -0
- package/lib/components/spiderly-panels/spiderly-panel/spiderly-panel.component.d.ts +25 -0
- package/lib/components/spiderly-panels/spiderly-panels.module.d.ts +13 -0
- package/lib/controls/base-autocomplete-control.d.ts +9 -0
- package/lib/controls/base-control.d.ts +23 -0
- package/lib/controls/base-dropdown-control.d.ts +18 -0
- package/lib/controls/spiderly-autocomplete/spiderly-autocomplete.component.d.ts +18 -0
- package/lib/controls/spiderly-calendar/spiderly-calendar.component.d.ts +13 -0
- package/lib/controls/spiderly-checkbox/spiderly-checkbox.component.d.ts +14 -0
- package/lib/controls/spiderly-colorpick/spiderly-colorpick.component.d.ts +11 -0
- package/lib/controls/spiderly-controls.module.d.ts +22 -0
- package/lib/controls/spiderly-dropdown/spiderly-dropdown.component.d.ts +14 -0
- package/lib/controls/spiderly-editor/spiderly-editor.component.d.ts +16 -0
- package/lib/controls/spiderly-file/spiderly-file.component.d.ts +36 -0
- package/lib/controls/spiderly-multiautocomplete/spiderly-multiautocomplete.component.d.ts +13 -0
- package/lib/controls/spiderly-multiselect/spiderly-multiselect.component.d.ts +11 -0
- package/lib/controls/spiderly-number/spiderly-number.component.d.ts +15 -0
- package/lib/controls/spiderly-password/spiderly-password.component.d.ts +12 -0
- package/lib/controls/spiderly-textarea/spiderly-textarea.component.d.ts +11 -0
- package/lib/controls/spiderly-textbox/spiderly-textbox.component.d.ts +15 -0
- package/lib/entities/base-entity.d.ts +14 -0
- package/lib/entities/codebook.d.ts +9 -0
- package/lib/entities/init-company-auth-dialog-details.d.ts +9 -0
- package/lib/entities/init-top-bar-data.d.ts +16 -0
- package/lib/entities/is-authorized-for-save-event.d.ts +9 -0
- package/lib/entities/last-menu-icon-index-clicked.d.ts +7 -0
- package/lib/entities/lazy-load-selected-ids-result.d.ts +9 -0
- package/lib/entities/menuchangeevent.d.ts +4 -0
- package/lib/entities/mime-type.d.ts +11 -0
- package/lib/entities/namebook.d.ts +9 -0
- package/lib/entities/primeng-option.d.ts +9 -0
- package/lib/entities/security-entities.d.ts +211 -0
- package/lib/entities/simple-save-result.d.ts +7 -0
- package/lib/entities/spiderly-button.d.ts +13 -0
- package/lib/entities/table-filter-context.d.ts +5 -0
- package/lib/entities/table-filter-sort-meta.d.ts +4 -0
- package/lib/entities/table-filter.d.ts +23 -0
- package/lib/entities/table-response.d.ts +4 -0
- package/lib/enums/security-enums.d.ts +22 -0
- package/lib/enums/verification-type-codes.d.ts +4 -0
- package/lib/guards/auth.guard.d.ts +15 -0
- package/lib/guards/not-auth.guard.d.ts +12 -0
- package/lib/handlers/spiderly-error-handler.d.ts +14 -0
- package/lib/handlers/spiderly-transloco-fallback-strategy.d.ts +13 -0
- package/lib/interceptors/http-loading.interceptor.d.ts +11 -0
- package/lib/interceptors/json-parser.interceptor.d.ts +11 -0
- package/lib/interceptors/jwt.interceptor.d.ts +11 -0
- package/lib/interceptors/unauthorized.interceptor.d.ts +16 -0
- package/lib/modules/core.module.d.ts +13 -0
- package/lib/modules/primeng.module.d.ts +42 -0
- package/lib/modules/spiderly-transloco.module.d.ts +9 -0
- package/lib/services/api.service.security.d.ts +35 -0
- package/lib/services/app-initializer.d.ts +4 -0
- package/lib/services/app-layout-base.service.d.ts +60 -0
- package/lib/services/auth-base.service.d.ts +55 -0
- package/lib/services/base-form.service.d.ts +27 -0
- package/lib/services/config-base.service.d.ts +24 -0
- package/lib/services/helper-functions.d.ts +37 -0
- package/lib/services/spiderly-message.service.d.ts +17 -0
- package/lib/services/spiderly-transloco-loader.d.ts +10 -0
- package/lib/services/translate-labels-abstract.service.d.ts +7 -0
- package/lib/services/validator-abstract.service.d.ts +13 -0
- package/package.json +60 -0
- package/public-api.d.ts +90 -0
- package/styles/components/spiderly-data-table/spiderly-data-table.component.scss +34 -0
- package/styles/components/spiderly-panels/panel-footer/panel-footer.component.scss +10 -0
- package/styles/styles/layout/_config.scss +42 -0
- package/styles/styles/layout/_content.scss +12 -0
- package/styles/styles/layout/_footer.scss +9 -0
- package/styles/styles/layout/_main.scss +28 -0
- package/styles/styles/layout/_menu.scss +135 -0
- package/styles/styles/layout/_mixins.scss +13 -0
- package/styles/styles/layout/_preloading.scss +47 -0
- package/styles/styles/layout/_responsive.scss +100 -0
- package/styles/styles/layout/_spiderly-controls.scss +12 -0
- package/styles/styles/layout/_topbar.scss +231 -0
- package/styles/styles/layout/_typography.scss +63 -0
- package/styles/styles/layout/_utils.scss +20 -0
- package/styles/styles/layout/_variables.scss +903 -0
- package/styles/styles/layout/layout.scss +13 -0
- package/styles/styles/shared.scss +519 -0
- package/styles/styles/styles.scss +6 -0
- package/styles/styles/theme/base/_colors.scss +18 -0
- package/styles/styles/theme/base/_common.scss +75 -0
- package/styles/styles/theme/base/_components.scss +106 -0
- package/styles/styles/theme/base/_mixins.scss +343 -0
- package/styles/styles/theme/base/components/button/_button.scss +564 -0
- package/styles/styles/theme/base/components/button/_speeddial.scss +96 -0
- package/styles/styles/theme/base/components/button/_splitbutton.scss +381 -0
- package/styles/styles/theme/base/components/data/_carousel.scss +37 -0
- package/styles/styles/theme/base/components/data/_datatable.scss +338 -0
- package/styles/styles/theme/base/components/data/_dataview.scss +55 -0
- package/styles/styles/theme/base/components/data/_filter.scss +138 -0
- package/styles/styles/theme/base/components/data/_orderlist.scss +103 -0
- package/styles/styles/theme/base/components/data/_organizationchart.scss +50 -0
- package/styles/styles/theme/base/components/data/_paginator.scss +92 -0
- package/styles/styles/theme/base/components/data/_picklist.scss +103 -0
- package/styles/styles/theme/base/components/data/_timeline.scss +81 -0
- package/styles/styles/theme/base/components/data/_tree.scss +149 -0
- package/styles/styles/theme/base/components/data/_treetable.scss +256 -0
- package/styles/styles/theme/base/components/data/_virtualscroller.scss +28 -0
- package/styles/styles/theme/base/components/file/_fileupload.scss +64 -0
- package/styles/styles/theme/base/components/input/_autocomplete.scss +118 -0
- package/styles/styles/theme/base/components/input/_calendar.scss +263 -0
- package/styles/styles/theme/base/components/input/_cascadeselect.scss +130 -0
- package/styles/styles/theme/base/components/input/_checkbox.scss +90 -0
- package/styles/styles/theme/base/components/input/_chips.scss +55 -0
- package/styles/styles/theme/base/components/input/_colorpicker.scss +26 -0
- package/styles/styles/theme/base/components/input/_dropdown.scss +152 -0
- package/styles/styles/theme/base/components/input/_editor.scss +122 -0
- package/styles/styles/theme/base/components/input/_inputgroup.scss +75 -0
- package/styles/styles/theme/base/components/input/_inputmask.scss +16 -0
- package/styles/styles/theme/base/components/input/_inputnumber.scss +28 -0
- package/styles/styles/theme/base/components/input/_inputswitch.scss +60 -0
- package/styles/styles/theme/base/components/input/_inputtext.scss +100 -0
- package/styles/styles/theme/base/components/input/_listbox.scss +82 -0
- package/styles/styles/theme/base/components/input/_multiselect.scss +173 -0
- package/styles/styles/theme/base/components/input/_password.scss +52 -0
- package/styles/styles/theme/base/components/input/_radiobutton.scss +78 -0
- package/styles/styles/theme/base/components/input/_rating.scss +55 -0
- package/styles/styles/theme/base/components/input/_selectbutton.scss +50 -0
- package/styles/styles/theme/base/components/input/_slider.scss +71 -0
- package/styles/styles/theme/base/components/input/_togglebutton.scss +48 -0
- package/styles/styles/theme/base/components/input/_treeselect.scss +139 -0
- package/styles/styles/theme/base/components/menu/_breadcrumb.scss +42 -0
- package/styles/styles/theme/base/components/menu/_contextmenu.scss +39 -0
- package/styles/styles/theme/base/components/menu/_dock.scss +95 -0
- package/styles/styles/theme/base/components/menu/_megamenu.scss +55 -0
- package/styles/styles/theme/base/components/menu/_menu.scss +37 -0
- package/styles/styles/theme/base/components/menu/_menubar.scss +141 -0
- package/styles/styles/theme/base/components/menu/_panelmenu.scss +153 -0
- package/styles/styles/theme/base/components/menu/_slidemenu.scss +59 -0
- package/styles/styles/theme/base/components/menu/_steps.scss +56 -0
- package/styles/styles/theme/base/components/menu/_tabmenu.scss +74 -0
- package/styles/styles/theme/base/components/menu/_tieredmenu.scss +43 -0
- package/styles/styles/theme/base/components/messages/_inlinemessage.scss +69 -0
- package/styles/styles/theme/base/components/messages/_message.scss +107 -0
- package/styles/styles/theme/base/components/messages/_toast.scss +103 -0
- package/styles/styles/theme/base/components/misc/_avatar.scss +30 -0
- package/styles/styles/theme/base/components/misc/_badge.scss +48 -0
- package/styles/styles/theme/base/components/misc/_blockui.scss +0 -0
- package/styles/styles/theme/base/components/misc/_chip.scss +42 -0
- package/styles/styles/theme/base/components/misc/_inplace.scss +17 -0
- package/styles/styles/theme/base/components/misc/_progressbar.scss +17 -0
- package/styles/styles/theme/base/components/misc/_scrolltop.scss +25 -0
- package/styles/styles/theme/base/components/misc/_skeleton.scss +8 -0
- package/styles/styles/theme/base/components/misc/_tag.scss +40 -0
- package/styles/styles/theme/base/components/misc/_terminal.scss +12 -0
- package/styles/styles/theme/base/components/multimedia/_galleria.scss +155 -0
- package/styles/styles/theme/base/components/multimedia/_image.scss +49 -0
- package/styles/styles/theme/base/components/overlay/_confirmpopup.scss +72 -0
- package/styles/styles/theme/base/components/overlay/_dialog.scss +73 -0
- package/styles/styles/theme/base/components/overlay/_overlaypanel.scss +64 -0
- package/styles/styles/theme/base/components/overlay/_sidebar.scss +27 -0
- package/styles/styles/theme/base/components/overlay/_tooltip.scss +33 -0
- package/styles/styles/theme/base/components/panel/_accordion.scss +119 -0
- package/styles/styles/theme/base/components/panel/_card.scss +30 -0
- package/styles/styles/theme/base/components/panel/_divider.scss +31 -0
- package/styles/styles/theme/base/components/panel/_fieldset.scss +47 -0
- package/styles/styles/theme/base/components/panel/_panel.scss +58 -0
- package/styles/styles/theme/base/components/panel/_scrollpanel.scss +6 -0
- package/styles/styles/theme/base/components/panel/_splitter.scss +19 -0
- package/styles/styles/theme/base/components/panel/_tabview.scss +82 -0
- package/styles/styles/theme/base/components/panel/_toolbar.scss +11 -0
- package/styles/styles/theme/saga/_extensions.scss +27 -0
- package/styles/styles/theme/saga/_variables.scss +1 -0
- package/styles/styles/theme/saga/saga-blue/_extensions.scss +2 -0
- package/styles/styles/theme/saga/saga-blue/_fonts.scss +1 -0
- package/styles/styles/theme/saga/saga-blue/_variables.scss +1 -0
- package/styles/styles/theme/saga/saga-blue/theme.scss +4 -0
|
@@ -0,0 +1,502 @@
|
|
|
1
|
+
import { Component, EventEmitter, Inject, Input, LOCALE_ID, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { SpiderlyDeleteConfirmationComponent } from '../spiderly-delete-dialog/spiderly-delete-confirmation.component';
|
|
3
|
+
import { CommonModule, formatDate } from '@angular/common';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { firstValueFrom } from 'rxjs';
|
|
6
|
+
import { TranslocoDirective } from '@jsverse/transloco';
|
|
7
|
+
import { SpiderlyControlsModule } from '../../controls/spiderly-controls.module';
|
|
8
|
+
import { exportListToExcel } from '../../services/helper-functions';
|
|
9
|
+
import { PrimengModule } from '../../modules/primeng.module';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/router";
|
|
12
|
+
import * as i2 from "primeng/dynamicdialog";
|
|
13
|
+
import * as i3 from "../../services/spiderly-message.service";
|
|
14
|
+
import * as i4 from "@jsverse/transloco";
|
|
15
|
+
import * as i5 from "@angular/forms";
|
|
16
|
+
import * as i6 from "@angular/common";
|
|
17
|
+
import * as i7 from "primeng/table";
|
|
18
|
+
import * as i8 from "primeng/api";
|
|
19
|
+
import * as i9 from "primeng/button";
|
|
20
|
+
import * as i10 from "primeng/multiselect";
|
|
21
|
+
import * as i11 from "primeng/tooltip";
|
|
22
|
+
import * as i12 from "primeng/checkbox";
|
|
23
|
+
import * as i13 from "../spiderly-buttons/spiderly-button/spiderly-button.component";
|
|
24
|
+
import * as i14 from "../../controls/spiderly-number/spiderly-number.component";
|
|
25
|
+
export class SpiderlyDataTableComponent {
|
|
26
|
+
;
|
|
27
|
+
constructor(router, dialogService, route, messageService, translocoService, locale) {
|
|
28
|
+
this.router = router;
|
|
29
|
+
this.dialogService = dialogService;
|
|
30
|
+
this.route = route;
|
|
31
|
+
this.messageService = messageService;
|
|
32
|
+
this.translocoService = translocoService;
|
|
33
|
+
this.locale = locale;
|
|
34
|
+
this.tableIcon = 'pi pi-list';
|
|
35
|
+
this.rows = 10;
|
|
36
|
+
this.showPaginator = true; // FT: Pass only when hasLazyLoad === false
|
|
37
|
+
this.showCardWrapper = true;
|
|
38
|
+
this.readonly = false;
|
|
39
|
+
this.onTotalRecordsChange = new EventEmitter();
|
|
40
|
+
this.loading = true;
|
|
41
|
+
this.newlySelectedItems = [];
|
|
42
|
+
this.fakeSelectedItems = []; // FT: Only for showing checkboxes, we will not send this to the backend
|
|
43
|
+
this.currentPageSelectedItemsFromDb = []; // FT: Made so we can add only newly selected items to the newlySelectedItems
|
|
44
|
+
this.unselectedItems = [];
|
|
45
|
+
this.onLazyLoad = new EventEmitter();
|
|
46
|
+
this.rowsSelectedNumber = 0;
|
|
47
|
+
this.isAllSelected = null;
|
|
48
|
+
this.fakeIsAllSelected = false; // FT: Only for showing checkboxes, we will not send this to the backend
|
|
49
|
+
this.isFirstTimeLazyLoad = true;
|
|
50
|
+
this.onIsAllSelectedChange = new EventEmitter();
|
|
51
|
+
this.matchModeDateOptions = [];
|
|
52
|
+
this.matchModeNumberOptions = [];
|
|
53
|
+
this.showAddButton = true;
|
|
54
|
+
this.showExportToExcelButton = true;
|
|
55
|
+
this.showReloadTableButton = false;
|
|
56
|
+
this.hasLazyLoad = true;
|
|
57
|
+
this.selectedItemIds = []; // FT: Pass only when hasLazyLoad === false, it's enough if the M2M association hasn't additional fields
|
|
58
|
+
this.selectedItems = []; // FT: Pass only when hasLazyLoad === false
|
|
59
|
+
this.onRowSelect = new EventEmitter();
|
|
60
|
+
this.onRowUnselect = new EventEmitter();
|
|
61
|
+
this.clientFilterCount = 0;
|
|
62
|
+
}
|
|
63
|
+
ngOnInit() {
|
|
64
|
+
this.matchModeDateOptions = [
|
|
65
|
+
{ label: this.translocoService.translate('OnDate'), value: 'equals' },
|
|
66
|
+
{ label: this.translocoService.translate('DatesBefore'), value: 'dateBefore' },
|
|
67
|
+
{ label: this.translocoService.translate('DatesAfter'), value: 'dateAfter' },
|
|
68
|
+
];
|
|
69
|
+
this.matchModeNumberOptions = [
|
|
70
|
+
{ label: this.translocoService.translate('Equals'), value: 'equals' },
|
|
71
|
+
{ label: this.translocoService.translate('MoreThan'), value: 'gte' },
|
|
72
|
+
{ label: this.translocoService.translate('LessThan'), value: 'lte' },
|
|
73
|
+
];
|
|
74
|
+
if (this.hasLazyLoad === false) {
|
|
75
|
+
this.clientLoad();
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
lazyLoad(event) {
|
|
79
|
+
this.lastLazyLoadEvent = event;
|
|
80
|
+
let tableFilter = event;
|
|
81
|
+
tableFilter.additionalFilterIdLong = this.additionalFilterIdLong;
|
|
82
|
+
this.onLazyLoad.next(tableFilter);
|
|
83
|
+
this.getTableDataObservableMethod(tableFilter).subscribe({
|
|
84
|
+
next: async (res) => {
|
|
85
|
+
this.items = res.data;
|
|
86
|
+
this.totalRecords = res.totalRecords;
|
|
87
|
+
this.onTotalRecordsChange.next(res.totalRecords);
|
|
88
|
+
if (this.selectedLazyLoadObservableMethod != null) {
|
|
89
|
+
let selectedRowsMethodResult = await firstValueFrom(this.selectedLazyLoadObservableMethod(tableFilter));
|
|
90
|
+
this.currentPageSelectedItemsFromDb = [...selectedRowsMethodResult.selectedIds];
|
|
91
|
+
if (this.isFirstTimeLazyLoad == true) {
|
|
92
|
+
this.rowsSelectedNumber = selectedRowsMethodResult.totalRecordsSelected;
|
|
93
|
+
this.setFakeIsAllSelected();
|
|
94
|
+
this.isFirstTimeLazyLoad = false;
|
|
95
|
+
}
|
|
96
|
+
if (this.isAllSelected == true) {
|
|
97
|
+
let idsToInsert = [...this.items.map(x => x.id)];
|
|
98
|
+
idsToInsert = idsToInsert.filter(x => this.unselectedItems.includes(x) == false);
|
|
99
|
+
this.fakeSelectedItems = [...idsToInsert]; // FT: Only for showing checkboxes, we will not send this to the backend
|
|
100
|
+
}
|
|
101
|
+
else if (this.isAllSelected == false) {
|
|
102
|
+
this.fakeSelectedItems = [...this.newlySelectedItems]; // FT: Only for showing checkboxes, we will not send this to the backend
|
|
103
|
+
}
|
|
104
|
+
else if (this.isAllSelected == null) {
|
|
105
|
+
let idsToInsert = [...selectedRowsMethodResult.selectedIds, ...this.newlySelectedItems];
|
|
106
|
+
idsToInsert = idsToInsert.filter(x => this.unselectedItems.includes(x) == false);
|
|
107
|
+
this.fakeSelectedItems = [...idsToInsert];
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
this.loading = false;
|
|
111
|
+
},
|
|
112
|
+
error: () => {
|
|
113
|
+
this.loading = false;
|
|
114
|
+
},
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
clientLoad() {
|
|
118
|
+
this.loading = false;
|
|
119
|
+
this.loadFormArrayItems();
|
|
120
|
+
this.totalRecords = this.items.length;
|
|
121
|
+
this.onTotalRecordsChange.next(this.items.length);
|
|
122
|
+
if (this.getAlreadySelectedItemIds) {
|
|
123
|
+
this.selectedItemIds = this.getAlreadySelectedItemIds(this.additionalIndexes);
|
|
124
|
+
}
|
|
125
|
+
if (this.getAlreadySelectedItems) {
|
|
126
|
+
this.selectedItems = this.getAlreadySelectedItems(this.additionalIndexes);
|
|
127
|
+
}
|
|
128
|
+
this.rowsSelectedNumber = this.selectedItemIds.length;
|
|
129
|
+
this.setFakeIsAllSelected();
|
|
130
|
+
}
|
|
131
|
+
filter(event) {
|
|
132
|
+
if (this.hasLazyLoad && this.selectionMode === 'multiple')
|
|
133
|
+
this.selectAll(false); // FT: We need to do it like this because: totalRecords: 1 -> selectedRecords from earlyer selection 2 -> unselect current -> all checkbox is set to true
|
|
134
|
+
if (this.hasLazyLoad === false && this.selectionMode === 'multiple') {
|
|
135
|
+
if (this.clientFilterCount === 0) {
|
|
136
|
+
this.loadFormArrayItems();
|
|
137
|
+
this.clientFilterCount++;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
this.clientFilterCount--;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
loadFormArrayItems() {
|
|
145
|
+
this.items = this.getFormArrayItems(this.additionalIndexes);
|
|
146
|
+
this.items.forEach((item, index) => {
|
|
147
|
+
item.index = index;
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
getColHeaderWidth(filterType) {
|
|
151
|
+
switch (filterType) {
|
|
152
|
+
case 'text':
|
|
153
|
+
return 'min-width: 12rem;';
|
|
154
|
+
case 'date':
|
|
155
|
+
return 'min-width: 10rem;';
|
|
156
|
+
case 'multiselect':
|
|
157
|
+
return 'min-width: 12rem;';
|
|
158
|
+
case 'boolean':
|
|
159
|
+
return 'min-width: 8rem;';
|
|
160
|
+
case 'numeric':
|
|
161
|
+
return 'min-width: 12rem;';
|
|
162
|
+
default:
|
|
163
|
+
return 'width: 0rem;'; // fitting content of the row like this
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
getColMatchModeOptions(filterType) {
|
|
167
|
+
switch (filterType) {
|
|
168
|
+
case 'text':
|
|
169
|
+
return null;
|
|
170
|
+
case 'date':
|
|
171
|
+
return this.matchModeDateOptions;
|
|
172
|
+
case 'multiselect':
|
|
173
|
+
return null;
|
|
174
|
+
case 'boolean':
|
|
175
|
+
return null;
|
|
176
|
+
case 'numeric':
|
|
177
|
+
return this.matchModeNumberOptions;
|
|
178
|
+
default:
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
getColMatchMode(filterType) {
|
|
183
|
+
switch (filterType) {
|
|
184
|
+
case 'text':
|
|
185
|
+
return 'contains';
|
|
186
|
+
case 'date':
|
|
187
|
+
return null;
|
|
188
|
+
case 'multiselect':
|
|
189
|
+
return 'in';
|
|
190
|
+
case 'boolean':
|
|
191
|
+
return 'equals';
|
|
192
|
+
case 'numeric':
|
|
193
|
+
return null;
|
|
194
|
+
default:
|
|
195
|
+
return null;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
isDropOrMulti(filterType) {
|
|
199
|
+
if (filterType == 'dropdown' || filterType == 'multiselect') {
|
|
200
|
+
return true;
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
navigateToDetails(rowId) {
|
|
207
|
+
this.router.navigate([rowId], { relativeTo: this.route });
|
|
208
|
+
}
|
|
209
|
+
deleteObject(rowId) {
|
|
210
|
+
this.deleteRef = this.dialogService.open(SpiderlyDeleteConfirmationComponent, {
|
|
211
|
+
header: this.translocoService.translate('AreYouSure'),
|
|
212
|
+
width: '400px',
|
|
213
|
+
data: { deleteItemFromTableObservableMethod: this.deleteItemFromTableObservableMethod, id: rowId, }
|
|
214
|
+
});
|
|
215
|
+
this.deleteRef.onClose.subscribe((deletedSuccessfully) => {
|
|
216
|
+
if (deletedSuccessfully === true) {
|
|
217
|
+
this.messageService.successMessage(this.translocoService.translate('SuccessfullyDeletedMessage'));
|
|
218
|
+
this.reload();
|
|
219
|
+
}
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
reload() {
|
|
223
|
+
this.loading = true;
|
|
224
|
+
this.items = null;
|
|
225
|
+
this.lazyLoad(this.lastLazyLoadEvent);
|
|
226
|
+
}
|
|
227
|
+
showActions() {
|
|
228
|
+
return this.cols.some(x => x.actions?.length > 0);
|
|
229
|
+
}
|
|
230
|
+
getStyleForBodyColumn(col) {
|
|
231
|
+
switch (col.filterType) {
|
|
232
|
+
case 'numeric':
|
|
233
|
+
return 'text-align: right;';
|
|
234
|
+
default:
|
|
235
|
+
return null;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
getClassForAction(action) {
|
|
239
|
+
switch (action.field) {
|
|
240
|
+
case 'Details':
|
|
241
|
+
return 'pi pi-pencil text-lg cursor-pointer primary-color';
|
|
242
|
+
case 'Delete':
|
|
243
|
+
return 'pi pi-trash text-lg text-red-500 cursor-pointer';
|
|
244
|
+
default:
|
|
245
|
+
return `${action.icon} ${action.style} text-lg cursor-pointer`;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
getMethodForAction(action, rowData) {
|
|
249
|
+
switch (action.field) {
|
|
250
|
+
case 'Details':
|
|
251
|
+
return this.navigateToDetails(rowData.id);
|
|
252
|
+
case 'Delete':
|
|
253
|
+
return this.deleteObject(rowData.id);
|
|
254
|
+
default:
|
|
255
|
+
return action.onClick(rowData.id);
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
getRowData(rowData, col) {
|
|
259
|
+
switch (col.filterType) {
|
|
260
|
+
case 'text':
|
|
261
|
+
return rowData[col.field];
|
|
262
|
+
case 'date':
|
|
263
|
+
if (rowData[col.field] == null)
|
|
264
|
+
return null;
|
|
265
|
+
if (col.showTime)
|
|
266
|
+
return formatDate(rowData[col.field], 'dd.MM.yyyy. HH:mm', this.locale);
|
|
267
|
+
else
|
|
268
|
+
return formatDate(rowData[col.field], 'dd.MM.yyyy.', this.locale);
|
|
269
|
+
case 'multiselect':
|
|
270
|
+
return rowData[col.field];
|
|
271
|
+
case 'boolean':
|
|
272
|
+
return rowData[col.field] == true ? this.translocoService.translate('Yes') : this.translocoService.translate('No');
|
|
273
|
+
case 'numeric':
|
|
274
|
+
// TODO FT: make decimal pipe
|
|
275
|
+
return rowData[col.field];
|
|
276
|
+
default:
|
|
277
|
+
return null;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
colTrackByFn(index, item) {
|
|
281
|
+
return item.field;
|
|
282
|
+
}
|
|
283
|
+
actionTrackByFn(index, item) {
|
|
284
|
+
return `${index}${item.field}`;
|
|
285
|
+
}
|
|
286
|
+
exportListToExcel() {
|
|
287
|
+
let tableFilter = this.lastLazyLoadEvent;
|
|
288
|
+
tableFilter.additionalFilterIdLong = this.additionalFilterIdLong;
|
|
289
|
+
exportListToExcel(this.exportTableDataToExcelObservableMethod, tableFilter);
|
|
290
|
+
}
|
|
291
|
+
clear(table) {
|
|
292
|
+
table.clear();
|
|
293
|
+
}
|
|
294
|
+
//#region Selection
|
|
295
|
+
setFakeIsAllSelected() {
|
|
296
|
+
if (this.rowsSelectedNumber == this.totalRecords)
|
|
297
|
+
this.fakeIsAllSelected = true;
|
|
298
|
+
else
|
|
299
|
+
this.fakeIsAllSelected = false;
|
|
300
|
+
}
|
|
301
|
+
selectAll(checked) {
|
|
302
|
+
this.unselectedItems.length = 0;
|
|
303
|
+
this.newlySelectedItems.length = 0;
|
|
304
|
+
if (checked == true) {
|
|
305
|
+
this.isAllSelected = true;
|
|
306
|
+
this.fakeIsAllSelected = true;
|
|
307
|
+
this.onIsAllSelectedChange.next(new AllClickEvent({ checked: true, additionalIndexes: this.additionalIndexes }));
|
|
308
|
+
this.rowsSelectedNumber = this.totalRecords;
|
|
309
|
+
this.fakeSelectedItems = [...this.items.map(x => x.id)];
|
|
310
|
+
this.selectedItemIds = [...this.items.map(x => x.id)];
|
|
311
|
+
}
|
|
312
|
+
else {
|
|
313
|
+
this.isAllSelected = false;
|
|
314
|
+
this.fakeIsAllSelected = false;
|
|
315
|
+
this.onIsAllSelectedChange.next(new AllClickEvent({ checked: false, additionalIndexes: this.additionalIndexes }));
|
|
316
|
+
this.rowsSelectedNumber = 0;
|
|
317
|
+
this.fakeSelectedItems = [];
|
|
318
|
+
this.selectedItemIds = [];
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
selectRow(id, index) {
|
|
322
|
+
if (this.isRowSelected(id)) {
|
|
323
|
+
this.rowUnselect(id);
|
|
324
|
+
this.onRowUnselect.next(new RowClickEvent({ index: index, id: id, additionalIndexes: this.additionalIndexes }));
|
|
325
|
+
}
|
|
326
|
+
else {
|
|
327
|
+
this.rowSelect(id);
|
|
328
|
+
this.onRowSelect.next(new RowClickEvent({ index: index, id: id, additionalIndexes: this.additionalIndexes }));
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
isRowSelected(id) {
|
|
332
|
+
if (this.hasLazyLoad) {
|
|
333
|
+
return this.fakeSelectedItems.find(x => x === id) != undefined;
|
|
334
|
+
}
|
|
335
|
+
else {
|
|
336
|
+
return this.selectedItemIds.find(x => x === id) != undefined;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
rowSelect(id) {
|
|
340
|
+
if (this.isAllSelected == false || this.currentPageSelectedItemsFromDb.includes(id) == false) {
|
|
341
|
+
this.newlySelectedItems.push(id);
|
|
342
|
+
}
|
|
343
|
+
if (this.hasLazyLoad) {
|
|
344
|
+
this.fakeSelectedItems.push(id);
|
|
345
|
+
}
|
|
346
|
+
else {
|
|
347
|
+
this.selectedItemIds.push(id);
|
|
348
|
+
}
|
|
349
|
+
this.rowsSelectedNumber++;
|
|
350
|
+
const index = this.unselectedItems.indexOf(id);
|
|
351
|
+
if (index !== -1) {
|
|
352
|
+
this.unselectedItems.splice(index, 1); // FT: Splice is mutating the array
|
|
353
|
+
}
|
|
354
|
+
this.setFakeIsAllSelected();
|
|
355
|
+
}
|
|
356
|
+
rowUnselect(id) {
|
|
357
|
+
if (this.isAllSelected == true || this.currentPageSelectedItemsFromDb.includes(id) == true) {
|
|
358
|
+
this.unselectedItems.push(id);
|
|
359
|
+
}
|
|
360
|
+
this.rowsSelectedNumber--;
|
|
361
|
+
const index = this.newlySelectedItems.indexOf(id);
|
|
362
|
+
const fakeIndex = this.fakeSelectedItems.indexOf(id);
|
|
363
|
+
const nonLazyLoadIndex = this.selectedItemIds.indexOf(id);
|
|
364
|
+
if (index !== -1) {
|
|
365
|
+
this.newlySelectedItems.splice(index, 1); // FT: Splice is mutating the array
|
|
366
|
+
}
|
|
367
|
+
if (fakeIndex !== -1) {
|
|
368
|
+
this.fakeSelectedItems.splice(fakeIndex, 1); // FT: Splice is mutating the array
|
|
369
|
+
}
|
|
370
|
+
if (nonLazyLoadIndex !== -1) {
|
|
371
|
+
this.selectedItemIds.splice(nonLazyLoadIndex, 1); // FT: Splice is mutating the array
|
|
372
|
+
}
|
|
373
|
+
this.setFakeIsAllSelected();
|
|
374
|
+
}
|
|
375
|
+
//#endregion
|
|
376
|
+
//#region Client side table
|
|
377
|
+
// FT: Can do it with Id also, because we are never adding the new record in the table at the same page.
|
|
378
|
+
getFormArrayControlByIndex(formControlName, index) {
|
|
379
|
+
if (this.getFormControl) {
|
|
380
|
+
return this.getFormControl(formControlName, index, this.additionalIndexes);
|
|
381
|
+
}
|
|
382
|
+
else {
|
|
383
|
+
return null;
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpiderlyDataTableComponent, deps: [{ token: i1.Router }, { token: i2.DialogService }, { token: i1.ActivatedRoute }, { token: i3.SpiderlyMessageService }, { token: i4.TranslocoService }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
387
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SpiderlyDataTableComponent, isStandalone: true, selector: "spiderly-data-table", inputs: { tableTitle: "tableTitle", tableIcon: "tableIcon", items: "items", rows: "rows", cols: "cols", showPaginator: "showPaginator", showCardWrapper: "showCardWrapper", readonly: "readonly", getTableDataObservableMethod: "getTableDataObservableMethod", exportTableDataToExcelObservableMethod: "exportTableDataToExcelObservableMethod", deleteItemFromTableObservableMethod: "deleteItemFromTableObservableMethod", newlySelectedItems: "newlySelectedItems", unselectedItems: "unselectedItems", selectionMode: "selectionMode", selectedLazyLoadObservableMethod: "selectedLazyLoadObservableMethod", additionalFilterIdLong: "additionalFilterIdLong", showAddButton: "showAddButton", showExportToExcelButton: "showExportToExcelButton", showReloadTableButton: "showReloadTableButton", getFormArrayItems: "getFormArrayItems", hasLazyLoad: "hasLazyLoad", getAlreadySelectedItemIds: "getAlreadySelectedItemIds", getAlreadySelectedItems: "getAlreadySelectedItems", getFormControl: "getFormControl", additionalIndexes: "additionalIndexes" }, outputs: { onTotalRecordsChange: "onTotalRecordsChange", onLazyLoad: "onLazyLoad", onIsAllSelectedChange: "onIsAllSelectedChange", onRowSelect: "onRowSelect", onRowUnselect: "onRowUnselect" }, viewQueries: [{ propertyName: "table", first: true, predicate: ["dt"], descendants: true }], ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <div [class]=\"showCardWrapper ? 'card responsive-card-padding overflow-auto' : ''\">\r\n <p-table #dt [value]=\"items\" [rows]=\"rows\" [rowHover]=\"true\" styleClass=\"p-datatable-gridlines\" [paginator]=\"showPaginator\" responsiveLayout=\"scroll\" [lazy]=\"hasLazyLoad\"\r\n (onLazyLoad)=\"lazyLoad($event)\" [totalRecords]=\"totalRecords\" class=\"spiderly-table\" [loading]=\"(items === undefined || loading === true)\" [selectionMode]=\"selectionMode\" dataKey=\"id\" \r\n (onFilter)=\"filter($event)\"> \r\n <ng-template pTemplate=\"caption\">\r\n <div class=\"table-header overflow-auto\">\r\n <div style=\"display: flex; align-items: center; gap: 8px;\">\r\n <i class=\"{{tableIcon}} text-2xl primary-color\"></i>\r\n <h5 style=\"margin: 0px;\">{{tableTitle}}</h5>\r\n </div>\r\n <div style=\"display: flex; gap: 8px;\">\r\n <button pButton [label]=\"t('ClearFilters')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-filter-slash\" (click)=\"clear(dt)\"></button>\r\n <button pButton *ngIf=\"showExportToExcelButton\" [label]=\"t('ExportToExcel')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-download\" (click)=\"exportListToExcel()\"></button>\r\n <button pButton *ngIf=\"showReloadTableButton\" [label]=\"t('Reload')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-refresh\" (click)=\"reload()\"></button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th style=\"width: 0rem;\" *ngIf=\"selectionMode == 'multiple'\">\r\n <div style=\"display: flex; gap: 8px;\">\r\n <p-checkbox [disabled]=\"readonly\" (onChange)=\"selectAll($event.checked)\" [(ngModel)]=\"fakeIsAllSelected\" [binary]=\"true\"></p-checkbox> ({{rowsSelectedNumber}})\r\n </div>\r\n </th>\r\n <ng-container *ngFor=\"let col of cols; trackBy: colTrackByFn\">\r\n <th [style]=\"getColHeaderWidth(col.filterType)\">\r\n <div style=\"display: flex; justify-content: space-between; align-items: center;\">\r\n {{col.name}}\r\n <!-- <p-sortIcon field=\"\"></p-sortIcon> -->\r\n <!-- <p-columnFilter type=\"date\" field=\"date\" display=\"menu\"></p-columnFilter> -->\r\n <p-columnFilter *ngIf=\"col.filterType != null\" [type]=\"col.filterType\" [field]=\"col.filterField ?? col.field\" display=\"menu\" [placeholder]=\"col.filterPlaceholder\" \r\n [showOperator]=\"false\" [showMatchModes]=\"col.showMatchModes\" [showAddButton]=\"col.showAddButton\" [matchModeOptions]=\"getColMatchModeOptions(col.filterType)\"\r\n [matchMode]=\"getColMatchMode(col.filterType)\"\r\n >\r\n <ng-container *ngIf=\"isDropOrMulti(col.filterType)\">\r\n <ng-template pTemplate=\"filter\" let-value let-filter=\"filterCallback\">\r\n <p-multiSelect [ngModel]=\"value\" [options]=\"col.dropdownOrMultiselectValues\" [placeholder]=\"t('All')\" (onChange)=\"filter($event.value)\" optionLabel=\"label\" optionValue=\"value\" [style]=\"{'width':'240px'}\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <div class=\"p-multiselect-representative-option\">\r\n <span class=\"ml-2\">{{ item.label }}</span>\r\n </div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </ng-template>\r\n </ng-container>\r\n </p-columnFilter>\r\n </div>\r\n </th>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-index=\"rowIndex\" let-editing=\"editing\">\r\n <tr>\r\n <td *ngIf=\"selectionMode == 'multiple'\">\r\n <p-checkbox [disabled]=\"readonly\" (onChange)=\"selectRow(rowData.id, rowData.index)\" [ngModel]=\"isRowSelected(rowData.id)\" [binary]=\"true\"></p-checkbox>\r\n </td>\r\n <ng-container *ngFor=\"let col of cols; trackBy: colTrackByFn\">\r\n <td [pTooltip]=\"getRowData(rowData, col)\" [style]=\"getStyleForBodyColumn(col)\" *ngIf=\"!col.editable\">\r\n <div style=\"display: flex; align-items: center; justify-content: center; gap: 18px;\">\r\n <ng-container *ngFor=\"let action of col.actions; trackBy: actionTrackByFn\" >\r\n <span [pTooltip]=\"action.name\" [class]=\"getClassForAction(action)\" (click)=\"getMethodForAction(action, rowData)\"></span>\r\n </ng-container>\r\n </div>\r\n {{getRowData(rowData, col)}}\r\n </td>\r\n <td *ngIf=\"col.editable\">\r\n <spiderly-number [control]=\"getFormArrayControlByIndex(col.field, rowData.index)\" [showLabel]=\"false\"></spiderly-number>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"emptymessage\">\r\n <tr>\r\n <td [attr.colspan]=\"cols?.length + (selectionMode === 'multiple' ? 1 : 0)\">{{t('NoRecordsFound')}}</td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"loadingbody\">\r\n <tr>\r\n <td [attr.colspan]=\"cols?.length + (selectionMode === 'multiple' ? 1 : 0)\">{{t('Loading')}}...</td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"paginatorleft\">\r\n {{t('TotalRecords')}}: {{totalRecords}}\r\n </ng-template>\r\n <ng-template pTemplate=\"paginatorright\">\r\n <div style=\"display: flex; justify-content: end; gap: 10px;\">\r\n <spiderly-button *ngIf=\"showAddButton\" [label]=\"t('AddNew')\" icon=\"pi pi-plus\" (onClick)=\"navigateToDetails(0)\"></spiderly-button>\r\n </div>\r\n </ng-template>\r\n </p-table>\r\n </div>\r\n</ng-container>", styles: [".table-header{display:flex;justify-content:space-between;align-items:center}@media (max-width: 640px){.table-header{display:flex;flex-direction:column;align-items:start;gap:14px}}.spiderly-table .p-paginator{padding:1rem}@media (min-width: 1400px){.spiderly-table .p-paginator-left-content{position:absolute;padding:14px;left:0}}@media (min-width: 1400px){.spiderly-table .p-paginator-right-content{position:absolute;padding:14px;right:0}}\n", ":is() :is(.remove-button-border-focus:focus,.remove-button-border-focus:enabled:focus){box-shadow:none;-webkit-box-shadow:none;-moz-box-shadow:none;background-color:var(--gray-200)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: PrimengModule }, { kind: "component", type: i7.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i8.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i7.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping", "showButtons", "ariaLabel"], outputs: ["onShow", "onHide"] }, { kind: "directive", type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i10.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "directive", type: i11.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i12.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "autofocus", "trueValue", "falseValue", "variant"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "ngmodule", type: SpiderlyControlsModule }, { kind: "component", type: i13.SpiderlyButtonComponent, selector: "spiderly-button" }, { kind: "component", type: i14.SpiderlyNumberComponent, selector: "spiderly-number", inputs: ["prefix", "showButtons", "decimal", "maxFractionDigits"] }] }); }
|
|
388
|
+
}
|
|
389
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpiderlyDataTableComponent, decorators: [{
|
|
390
|
+
type: Component,
|
|
391
|
+
args: [{ selector: 'spiderly-data-table', imports: [
|
|
392
|
+
FormsModule,
|
|
393
|
+
CommonModule,
|
|
394
|
+
PrimengModule,
|
|
395
|
+
TranslocoDirective,
|
|
396
|
+
SpiderlyControlsModule,
|
|
397
|
+
], standalone: true, template: "<ng-container *transloco=\"let t\">\r\n <div [class]=\"showCardWrapper ? 'card responsive-card-padding overflow-auto' : ''\">\r\n <p-table #dt [value]=\"items\" [rows]=\"rows\" [rowHover]=\"true\" styleClass=\"p-datatable-gridlines\" [paginator]=\"showPaginator\" responsiveLayout=\"scroll\" [lazy]=\"hasLazyLoad\"\r\n (onLazyLoad)=\"lazyLoad($event)\" [totalRecords]=\"totalRecords\" class=\"spiderly-table\" [loading]=\"(items === undefined || loading === true)\" [selectionMode]=\"selectionMode\" dataKey=\"id\" \r\n (onFilter)=\"filter($event)\"> \r\n <ng-template pTemplate=\"caption\">\r\n <div class=\"table-header overflow-auto\">\r\n <div style=\"display: flex; align-items: center; gap: 8px;\">\r\n <i class=\"{{tableIcon}} text-2xl primary-color\"></i>\r\n <h5 style=\"margin: 0px;\">{{tableTitle}}</h5>\r\n </div>\r\n <div style=\"display: flex; gap: 8px;\">\r\n <button pButton [label]=\"t('ClearFilters')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-filter-slash\" (click)=\"clear(dt)\"></button>\r\n <button pButton *ngIf=\"showExportToExcelButton\" [label]=\"t('ExportToExcel')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-download\" (click)=\"exportListToExcel()\"></button>\r\n <button pButton *ngIf=\"showReloadTableButton\" [label]=\"t('Reload')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-refresh\" (click)=\"reload()\"></button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th style=\"width: 0rem;\" *ngIf=\"selectionMode == 'multiple'\">\r\n <div style=\"display: flex; gap: 8px;\">\r\n <p-checkbox [disabled]=\"readonly\" (onChange)=\"selectAll($event.checked)\" [(ngModel)]=\"fakeIsAllSelected\" [binary]=\"true\"></p-checkbox> ({{rowsSelectedNumber}})\r\n </div>\r\n </th>\r\n <ng-container *ngFor=\"let col of cols; trackBy: colTrackByFn\">\r\n <th [style]=\"getColHeaderWidth(col.filterType)\">\r\n <div style=\"display: flex; justify-content: space-between; align-items: center;\">\r\n {{col.name}}\r\n <!-- <p-sortIcon field=\"\"></p-sortIcon> -->\r\n <!-- <p-columnFilter type=\"date\" field=\"date\" display=\"menu\"></p-columnFilter> -->\r\n <p-columnFilter *ngIf=\"col.filterType != null\" [type]=\"col.filterType\" [field]=\"col.filterField ?? col.field\" display=\"menu\" [placeholder]=\"col.filterPlaceholder\" \r\n [showOperator]=\"false\" [showMatchModes]=\"col.showMatchModes\" [showAddButton]=\"col.showAddButton\" [matchModeOptions]=\"getColMatchModeOptions(col.filterType)\"\r\n [matchMode]=\"getColMatchMode(col.filterType)\"\r\n >\r\n <ng-container *ngIf=\"isDropOrMulti(col.filterType)\">\r\n <ng-template pTemplate=\"filter\" let-value let-filter=\"filterCallback\">\r\n <p-multiSelect [ngModel]=\"value\" [options]=\"col.dropdownOrMultiselectValues\" [placeholder]=\"t('All')\" (onChange)=\"filter($event.value)\" optionLabel=\"label\" optionValue=\"value\" [style]=\"{'width':'240px'}\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <div class=\"p-multiselect-representative-option\">\r\n <span class=\"ml-2\">{{ item.label }}</span>\r\n </div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </ng-template>\r\n </ng-container>\r\n </p-columnFilter>\r\n </div>\r\n </th>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-index=\"rowIndex\" let-editing=\"editing\">\r\n <tr>\r\n <td *ngIf=\"selectionMode == 'multiple'\">\r\n <p-checkbox [disabled]=\"readonly\" (onChange)=\"selectRow(rowData.id, rowData.index)\" [ngModel]=\"isRowSelected(rowData.id)\" [binary]=\"true\"></p-checkbox>\r\n </td>\r\n <ng-container *ngFor=\"let col of cols; trackBy: colTrackByFn\">\r\n <td [pTooltip]=\"getRowData(rowData, col)\" [style]=\"getStyleForBodyColumn(col)\" *ngIf=\"!col.editable\">\r\n <div style=\"display: flex; align-items: center; justify-content: center; gap: 18px;\">\r\n <ng-container *ngFor=\"let action of col.actions; trackBy: actionTrackByFn\" >\r\n <span [pTooltip]=\"action.name\" [class]=\"getClassForAction(action)\" (click)=\"getMethodForAction(action, rowData)\"></span>\r\n </ng-container>\r\n </div>\r\n {{getRowData(rowData, col)}}\r\n </td>\r\n <td *ngIf=\"col.editable\">\r\n <spiderly-number [control]=\"getFormArrayControlByIndex(col.field, rowData.index)\" [showLabel]=\"false\"></spiderly-number>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"emptymessage\">\r\n <tr>\r\n <td [attr.colspan]=\"cols?.length + (selectionMode === 'multiple' ? 1 : 0)\">{{t('NoRecordsFound')}}</td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"loadingbody\">\r\n <tr>\r\n <td [attr.colspan]=\"cols?.length + (selectionMode === 'multiple' ? 1 : 0)\">{{t('Loading')}}...</td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"paginatorleft\">\r\n {{t('TotalRecords')}}: {{totalRecords}}\r\n </ng-template>\r\n <ng-template pTemplate=\"paginatorright\">\r\n <div style=\"display: flex; justify-content: end; gap: 10px;\">\r\n <spiderly-button *ngIf=\"showAddButton\" [label]=\"t('AddNew')\" icon=\"pi pi-plus\" (onClick)=\"navigateToDetails(0)\"></spiderly-button>\r\n </div>\r\n </ng-template>\r\n </p-table>\r\n </div>\r\n</ng-container>", styles: [".table-header{display:flex;justify-content:space-between;align-items:center}@media (max-width: 640px){.table-header{display:flex;flex-direction:column;align-items:start;gap:14px}}.spiderly-table .p-paginator{padding:1rem}@media (min-width: 1400px){.spiderly-table .p-paginator-left-content{position:absolute;padding:14px;left:0}}@media (min-width: 1400px){.spiderly-table .p-paginator-right-content{position:absolute;padding:14px;right:0}}\n", ":is() :is(.remove-button-border-focus:focus,.remove-button-border-focus:enabled:focus){box-shadow:none;-webkit-box-shadow:none;-moz-box-shadow:none;background-color:var(--gray-200)}\n"] }]
|
|
398
|
+
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.DialogService }, { type: i1.ActivatedRoute }, { type: i3.SpiderlyMessageService }, { type: i4.TranslocoService }, { type: undefined, decorators: [{
|
|
399
|
+
type: Inject,
|
|
400
|
+
args: [LOCALE_ID]
|
|
401
|
+
}] }], propDecorators: { table: [{
|
|
402
|
+
type: ViewChild,
|
|
403
|
+
args: ['dt']
|
|
404
|
+
}], tableTitle: [{
|
|
405
|
+
type: Input
|
|
406
|
+
}], tableIcon: [{
|
|
407
|
+
type: Input
|
|
408
|
+
}], items: [{
|
|
409
|
+
type: Input
|
|
410
|
+
}], rows: [{
|
|
411
|
+
type: Input
|
|
412
|
+
}], cols: [{
|
|
413
|
+
type: Input
|
|
414
|
+
}], showPaginator: [{
|
|
415
|
+
type: Input
|
|
416
|
+
}], showCardWrapper: [{
|
|
417
|
+
type: Input
|
|
418
|
+
}], readonly: [{
|
|
419
|
+
type: Input
|
|
420
|
+
}], onTotalRecordsChange: [{
|
|
421
|
+
type: Output
|
|
422
|
+
}], getTableDataObservableMethod: [{
|
|
423
|
+
type: Input
|
|
424
|
+
}], exportTableDataToExcelObservableMethod: [{
|
|
425
|
+
type: Input
|
|
426
|
+
}], deleteItemFromTableObservableMethod: [{
|
|
427
|
+
type: Input
|
|
428
|
+
}], newlySelectedItems: [{
|
|
429
|
+
type: Input
|
|
430
|
+
}], unselectedItems: [{
|
|
431
|
+
type: Input
|
|
432
|
+
}], selectionMode: [{
|
|
433
|
+
type: Input
|
|
434
|
+
}], onLazyLoad: [{
|
|
435
|
+
type: Output
|
|
436
|
+
}], onIsAllSelectedChange: [{
|
|
437
|
+
type: Output
|
|
438
|
+
}], selectedLazyLoadObservableMethod: [{
|
|
439
|
+
type: Input
|
|
440
|
+
}], additionalFilterIdLong: [{
|
|
441
|
+
type: Input
|
|
442
|
+
}], showAddButton: [{
|
|
443
|
+
type: Input
|
|
444
|
+
}], showExportToExcelButton: [{
|
|
445
|
+
type: Input
|
|
446
|
+
}], showReloadTableButton: [{
|
|
447
|
+
type: Input
|
|
448
|
+
}], getFormArrayItems: [{
|
|
449
|
+
type: Input
|
|
450
|
+
}], hasLazyLoad: [{
|
|
451
|
+
type: Input
|
|
452
|
+
}], getAlreadySelectedItemIds: [{
|
|
453
|
+
type: Input
|
|
454
|
+
}], getAlreadySelectedItems: [{
|
|
455
|
+
type: Input
|
|
456
|
+
}], getFormControl: [{
|
|
457
|
+
type: Input
|
|
458
|
+
}], additionalIndexes: [{
|
|
459
|
+
type: Input
|
|
460
|
+
}], onRowSelect: [{
|
|
461
|
+
type: Output
|
|
462
|
+
}], onRowUnselect: [{
|
|
463
|
+
type: Output
|
|
464
|
+
}] } });
|
|
465
|
+
export class Action {
|
|
466
|
+
constructor({ name, field, icon, style, onClick, } = {}) {
|
|
467
|
+
this.name = name;
|
|
468
|
+
this.field = field;
|
|
469
|
+
this.icon = icon;
|
|
470
|
+
this.style = style;
|
|
471
|
+
this.onClick = onClick;
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
export class Column {
|
|
475
|
+
constructor({ name, field, filterField, filterType, filterPlaceholder, showMatchModes, showAddButton, dropdownOrMultiselectValues, actions, editable, showTime, } = {}) {
|
|
476
|
+
this.name = name;
|
|
477
|
+
this.field = field;
|
|
478
|
+
this.filterField = filterField;
|
|
479
|
+
this.filterType = filterType;
|
|
480
|
+
this.filterPlaceholder = filterPlaceholder;
|
|
481
|
+
this.showMatchModes = showMatchModes;
|
|
482
|
+
this.showAddButton = showAddButton;
|
|
483
|
+
this.dropdownOrMultiselectValues = dropdownOrMultiselectValues;
|
|
484
|
+
this.actions = actions;
|
|
485
|
+
this.editable = editable;
|
|
486
|
+
this.showTime = showTime;
|
|
487
|
+
}
|
|
488
|
+
}
|
|
489
|
+
export class RowClickEvent {
|
|
490
|
+
constructor({ index, id, additionalIndexes } = {}) {
|
|
491
|
+
this.index = index;
|
|
492
|
+
this.id = id;
|
|
493
|
+
this.additionalIndexes = additionalIndexes;
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
export class AllClickEvent {
|
|
497
|
+
constructor({ checked, additionalIndexes } = {}) {
|
|
498
|
+
this.checked = checked;
|
|
499
|
+
this.additionalIndexes = additionalIndexes;
|
|
500
|
+
}
|
|
501
|
+
}
|
|
502
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spiderly-data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/spiderly/src/lib/components/spiderly-data-table/spiderly-data-table.component.ts","../../../../../../projects/spiderly/src/lib/components/spiderly-data-table/spiderly-data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, LOCALE_ID, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { SelectItem } from 'primeng/api';\r\nimport { Table, TableFilterEvent, TableLazyLoadEvent } from 'primeng/table';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { SpiderlyDeleteConfirmationComponent } from '../spiderly-delete-dialog/spiderly-delete-confirmation.component';\r\nimport { CommonModule, formatDate } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { SpiderlyMessageService } from '../../services/spiderly-message.service';\r\nimport { firstValueFrom, Observable } from 'rxjs';\r\nimport { PrimengOption } from '../../entities/primeng-option';\r\nimport { TranslocoDirective, TranslocoService } from '@jsverse/transloco';\r\nimport { SpiderlyControlsModule } from '../../controls/spiderly-controls.module';\r\nimport { SpiderlyFormControl } from '../spiderly-form-control/spiderly-form-control';\r\nimport { TableResponse } from '../../entities/table-response';\r\nimport { LazyLoadSelectedIdsResult } from '../../entities/lazy-load-selected-ids-result';\r\nimport { exportListToExcel } from '../../services/helper-functions';\r\nimport { TableFilter } from '../../entities/table-filter';\r\nimport { PrimengModule } from '../../modules/primeng.module';\r\n\r\n@Component({\r\n  selector: 'spiderly-data-table',\r\n  templateUrl: './spiderly-data-table.component.html',\r\n  styleUrl: 'spiderly-data-table.component.scss',\r\n  styles: [`\r\n  \t:host {\r\n\t\t  ::ng-deep {\r\n\t\t    .remove-button-border-focus:focus, \r\n        .remove-button-border-focus:enabled:focus {\r\n        box-shadow: none;\r\n        -webkit-box-shadow: none;\r\n        -moz-box-shadow: none;\r\n        background-color: var(--gray-200);\r\n\t\t    }\r\n\t\t  }\r\n\t  }\r\n  `],\r\n  imports: [\r\n    FormsModule,\r\n    CommonModule,\r\n    PrimengModule,\r\n    TranslocoDirective,\r\n    SpiderlyControlsModule,\r\n  ],\r\n  standalone: true,\r\n})\r\nexport class SpiderlyDataTableComponent implements OnInit {\r\n  @ViewChild('dt') table: Table;\r\n  @Input() tableTitle: string;\r\n  @Input() tableIcon: string = 'pi pi-list';\r\n  @Input() items: any[]; // FT: Pass only when hasLazyLoad === false\r\n  @Input() rows: number = 10;\r\n  @Input() cols: Column[];\r\n  @Input() showPaginator: boolean = true; // FT: Pass only when hasLazyLoad === false\r\n  @Input() showCardWrapper: boolean = true;\r\n  @Input() readonly: boolean = false;\r\n  totalRecords: number;\r\n  @Output() onTotalRecordsChange: EventEmitter<number> = new EventEmitter();;\r\n  \r\n  @Input() getTableDataObservableMethod: (tableFilter: TableFilter) => Observable<TableResponse>;\r\n  @Input() exportTableDataToExcelObservableMethod: (tableFilter: TableFilter) => Observable<any>;\r\n  @Input() deleteItemFromTableObservableMethod: (rowId: number) => Observable<any>;\r\n\r\n  lastLazyLoadEvent: TableLazyLoadEvent;\r\n  loading: boolean = true;\r\n  \r\n  @Input() newlySelectedItems: number[] = [];\r\n  fakeSelectedItems: number[] = []; // FT: Only for showing checkboxes, we will not send this to the backend\r\n  currentPageSelectedItemsFromDb: number[] = []; // FT: Made so we can add only newly selected items to the newlySelectedItems\r\n  @Input() unselectedItems: number[] = [];\r\n  @Input() selectionMode: 'single' | 'multiple' | undefined | null;\r\n  @Output() onLazyLoad: EventEmitter<TableFilter> = new EventEmitter();\r\n  rowsSelectedNumber: number = 0;\r\n  isAllSelected: boolean = null;\r\n  fakeIsAllSelected: boolean = false; // FT: Only for showing checkboxes, we will not send this to the backend\r\n  isFirstTimeLazyLoad: boolean = true;\r\n  @Output() onIsAllSelectedChange: EventEmitter<AllClickEvent> = new EventEmitter();\r\n  @Input() selectedLazyLoadObservableMethod: (tableFilter: TableFilter) => Observable<LazyLoadSelectedIdsResult>;\r\n  @Input() additionalFilterIdLong: number;\r\n  \r\n  matchModeDateOptions: SelectItem[] = [];\r\n  matchModeNumberOptions: SelectItem[] = [];\r\n  @Input() showAddButton: boolean = true; \r\n  @Input() showExportToExcelButton: boolean = true;\r\n  @Input() showReloadTableButton: boolean = false;\r\n\r\n  deleteRef: DynamicDialogRef;\r\n\r\n  // Client side table\r\n  // @Input() formArrayItems: any[]; // FT: Pass this only if you have some additional logic for showing data\r\n  @Input() getFormArrayItems: (additionalIndexes?: any) => any[];\r\n  @Input() hasLazyLoad: boolean = true; \r\n  selectedItemIds: number[] = []; // FT: Pass only when hasLazyLoad === false, it's enough if the M2M association hasn't additional fields\r\n  @Input() getAlreadySelectedItemIds: (additionalIndexes?: any) => number[]; // FT: Pass only when hasLazyLoad === false, it's enough if the M2M association hasn't additional fields\r\n  selectedItems: any[] = []; // FT: Pass only when hasLazyLoad === false\r\n  @Input() getAlreadySelectedItems: (additionalIndexes?: any) => any[]; // FT: Pass only when hasLazyLoad === false, it's enough if the M2M association hasn't additional fields\r\n  @Input() getFormControl: (formControlName: string, index: number, additionalIndexes?: any) => SpiderlyFormControl;\r\n  @Input() additionalIndexes: any;\r\n  @Output() onRowSelect: EventEmitter<RowClickEvent> = new EventEmitter();\r\n  @Output() onRowUnselect: EventEmitter<RowClickEvent> = new EventEmitter();\r\n\r\n  constructor(\r\n    private router: Router,\r\n    private dialogService: DialogService,\r\n    private route: ActivatedRoute,\r\n    private messageService: SpiderlyMessageService,\r\n    private translocoService: TranslocoService,\r\n    @Inject(LOCALE_ID) private locale: string\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.matchModeDateOptions = [\r\n      { label: this.translocoService.translate('OnDate'), value: 'equals' },\r\n      { label: this.translocoService.translate('DatesBefore'), value: 'dateBefore' },\r\n      { label: this.translocoService.translate('DatesAfter'), value: 'dateAfter' },\r\n    ];\r\n\r\n    this.matchModeNumberOptions = [\r\n      { label: this.translocoService.translate('Equals'), value: 'equals' },\r\n      { label: this.translocoService.translate('MoreThan'), value: 'gte' },\r\n      { label: this.translocoService.translate('LessThan'), value: 'lte' },\r\n    ];\r\n\r\n    if (this.hasLazyLoad === false) {\r\n      this.clientLoad();\r\n    }\r\n  }\r\n  \r\n  lazyLoad(event: TableLazyLoadEvent) {\r\n    this.lastLazyLoadEvent = event;\r\n\r\n    let tableFilter: TableFilter = event as unknown as TableFilter;\r\n    tableFilter.additionalFilterIdLong = this.additionalFilterIdLong;\r\n\r\n    this.onLazyLoad.next(tableFilter);\r\n    \r\n    this.getTableDataObservableMethod(tableFilter).subscribe({\r\n      next: async (res) => { \r\n        this.items = res.data;\r\n        this.totalRecords = res.totalRecords;\r\n        this.onTotalRecordsChange.next(res.totalRecords);\r\n        \r\n        if (this.selectedLazyLoadObservableMethod != null) {\r\n          let selectedRowsMethodResult: LazyLoadSelectedIdsResult = await firstValueFrom(this.selectedLazyLoadObservableMethod(tableFilter));\r\n  \r\n          this.currentPageSelectedItemsFromDb = [...selectedRowsMethodResult.selectedIds];\r\n\r\n          if (this.isFirstTimeLazyLoad == true) {\r\n            this.rowsSelectedNumber = selectedRowsMethodResult.totalRecordsSelected;\r\n            this.setFakeIsAllSelected();\r\n            this.isFirstTimeLazyLoad = false;\r\n          }\r\n  \r\n          if (this.isAllSelected == true) {\r\n            let idsToInsert = [...this.items.map(x => x.id)];\r\n            idsToInsert = idsToInsert.filter(x => this.unselectedItems.includes(x) == false);\r\n            this.fakeSelectedItems = [...idsToInsert]; // FT: Only for showing checkboxes, we will not send this to the backend\r\n          }\r\n          else if (this.isAllSelected == false) {\r\n            this.fakeSelectedItems = [...this.newlySelectedItems]; // FT: Only for showing checkboxes, we will not send this to the backend\r\n          }\r\n          else if (this.isAllSelected == null) {\r\n            let idsToInsert = [...selectedRowsMethodResult.selectedIds, ...this.newlySelectedItems];\r\n            idsToInsert = idsToInsert.filter(x => this.unselectedItems.includes(x) == false);\r\n            this.fakeSelectedItems = [...idsToInsert];\r\n          }\r\n        }\r\n\r\n        this.loading = false;\r\n      },\r\n      error: () => {\r\n        this.loading = false;\r\n      },\r\n    });\r\n  }\r\n\r\n  clientLoad(){\r\n    this.loading = false;\r\n\r\n    this.loadFormArrayItems();\r\n    this.totalRecords = this.items.length;\r\n    this.onTotalRecordsChange.next(this.items.length);\r\n\r\n    if (this.getAlreadySelectedItemIds) {\r\n      this.selectedItemIds = this.getAlreadySelectedItemIds(this.additionalIndexes);\r\n    }\r\n    if (this.getAlreadySelectedItems) {\r\n      this.selectedItems = this.getAlreadySelectedItems(this.additionalIndexes);\r\n    }\r\n    this.rowsSelectedNumber = this.selectedItemIds.length;\r\n    this.setFakeIsAllSelected();\r\n  }\r\n\r\n  private clientFilterCount = 0;\r\n\r\n  filter(event: TableFilterEvent){\r\n    if (this.hasLazyLoad && this.selectionMode === 'multiple')\r\n      this.selectAll(false); // FT: We need to do it like this because: totalRecords: 1 -> selectedRecords from earlyer selection 2 -> unselect current -> all checkbox is set to true\r\n\r\n    if (this.hasLazyLoad === false && this.selectionMode === 'multiple') {\r\n      if (this.clientFilterCount === 0) {\r\n        this.loadFormArrayItems();\r\n        this.clientFilterCount++;\r\n      }else{\r\n        this.clientFilterCount--;\r\n      }\r\n    }\r\n  }\r\n\r\n  private loadFormArrayItems(){\r\n    this.items = this.getFormArrayItems(this.additionalIndexes);\r\n    this.items.forEach((item, index) => {\r\n      item.index = index;\r\n    });\r\n  }\r\n  \r\n  getColHeaderWidth(filterType: string) {\r\n    switch (filterType) {\r\n      case 'text':\r\n        return 'min-width: 12rem;';\r\n      case 'date':\r\n        return 'min-width: 10rem;';\r\n      case 'multiselect':\r\n        return 'min-width: 12rem;';\r\n      case 'boolean':\r\n        return 'min-width: 8rem;';\r\n      case 'numeric':\r\n        return 'min-width: 12rem;';\r\n      default:\r\n        return 'width: 0rem;'; // fitting content of the row like this\r\n    }\r\n  }\r\n\r\n  getColMatchModeOptions(filterType: string){\r\n    switch (filterType) {\r\n        case 'text':\r\n          return null;\r\n        case 'date':\r\n          return this.matchModeDateOptions;\r\n        case 'multiselect':\r\n          return null;\r\n        case 'boolean':\r\n          return null;\r\n        case 'numeric':\r\n          return this.matchModeNumberOptions;\r\n        default:\r\n          return null;\r\n      }\r\n  }\r\n  \r\n  getColMatchMode(filterType: string){\r\n    switch (filterType) {\r\n        case 'text':\r\n          return 'contains';\r\n        case 'date':\r\n          return null;\r\n        case 'multiselect':\r\n          return 'in';\r\n        case 'boolean':\r\n          return 'equals';\r\n        case 'numeric':\r\n          return null;\r\n        default:\r\n          return null;\r\n      }\r\n  }\r\n\r\n  isDropOrMulti(filterType: string){\r\n    if (filterType == 'dropdown' || filterType == 'multiselect') {\r\n        return true;\r\n    } \r\n    else {\r\n        return false;\r\n    }\r\n  }\r\n\r\n  navigateToDetails(rowId: number){\r\n    this.router.navigate([rowId], {relativeTo: this.route});\r\n  }\r\n\r\n  deleteObject(rowId: number){\r\n    this.deleteRef = this.dialogService.open(SpiderlyDeleteConfirmationComponent, \r\n      { \r\n        header: this.translocoService.translate('AreYouSure'),\r\n        width: '400px',\r\n        data:{ deleteItemFromTableObservableMethod: this.deleteItemFromTableObservableMethod, id: rowId, } \r\n      });\r\n\r\n      this.deleteRef.onClose.subscribe((deletedSuccessfully: boolean)=>{\r\n        if(deletedSuccessfully === true){\r\n          this.messageService.successMessage(this.translocoService.translate('SuccessfullyDeletedMessage'));\r\n          this.reload();\r\n        }\r\n      });\r\n  }\r\n\r\n  reload(){\r\n    this.loading = true;\r\n    this.items = null;\r\n    this.lazyLoad(this.lastLazyLoadEvent);\r\n  }\r\n\r\n  showActions(): boolean {\r\n    return this.cols.some(x => x.actions?.length > 0);\r\n  }\r\n\r\n  getStyleForBodyColumn(col: Column<any>) {\r\n    switch(col.filterType){\r\n      case 'numeric':\r\n        return 'text-align: right;';\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  getClassForAction(action: Action): string{\r\n    switch(action.field){\r\n      case 'Details':\r\n        return 'pi pi-pencil text-lg cursor-pointer primary-color';\r\n      case 'Delete':\r\n        return 'pi pi-trash text-lg text-red-500 cursor-pointer';\r\n      default:\r\n        return `${action.icon} ${action.style} text-lg cursor-pointer`;\r\n    }\r\n  }\r\n\r\n  getMethodForAction(action: Action, rowData: any){\r\n    switch(action.field){\r\n      case 'Details':\r\n        return this.navigateToDetails(rowData.id);\r\n      case 'Delete':\r\n        return this.deleteObject(rowData.id);\r\n      default:\r\n        return action.onClick(rowData.id);\r\n    }\r\n  }\r\n\r\n  getRowData(rowData: any, col: Column): string{\r\n      switch (col.filterType) {\r\n        case 'text':\r\n          return rowData[col.field];\r\n        case 'date':\r\n          if (rowData[col.field] == null)\r\n            return null;\r\n          \r\n          if (col.showTime)\r\n            return formatDate(rowData[col.field], 'dd.MM.yyyy. HH:mm', this.locale);\r\n          else\r\n            return formatDate(rowData[col.field], 'dd.MM.yyyy.', this.locale);\r\n        case 'multiselect':\r\n          return rowData[col.field];\r\n        case 'boolean':\r\n          return rowData[col.field] == true ? this.translocoService.translate('Yes') : this.translocoService.translate('No');\r\n        case 'numeric':\r\n          // TODO FT: make decimal pipe\r\n          return rowData[col.field];\r\n        default:\r\n          return null;\r\n      }\r\n  }\r\n\r\n  colTrackByFn(index, item){\r\n    return item.field;\r\n  }\r\n\r\n  actionTrackByFn(index, item: Action){\r\n    return `${index}${item.field}`\r\n  }\r\n\r\n  exportListToExcel() {\r\n    let tableFilter: TableFilter = this.lastLazyLoadEvent as unknown as TableFilter;\r\n    tableFilter.additionalFilterIdLong = this.additionalFilterIdLong;\r\n\r\n    exportListToExcel(this.exportTableDataToExcelObservableMethod, tableFilter);\r\n  }\r\n\r\n  clear(table: Table) {\r\n    table.clear();\r\n  }\r\n\r\n  //#region Selection\r\n\r\n  setFakeIsAllSelected(){\r\n    if(this.rowsSelectedNumber == this.totalRecords)\r\n      this.fakeIsAllSelected = true;\r\n    else\r\n      this.fakeIsAllSelected = false;\r\n  }\r\n\r\n  selectAll(checked: boolean){\r\n    this.unselectedItems.length = 0;\r\n    this.newlySelectedItems.length = 0;\r\n\r\n    if (checked == true) {\r\n      this.isAllSelected = true;\r\n      this.fakeIsAllSelected = true;\r\n      this.onIsAllSelectedChange.next(new AllClickEvent({checked: true, additionalIndexes: this.additionalIndexes}));\r\n      this.rowsSelectedNumber = this.totalRecords;\r\n      this.fakeSelectedItems = [...this.items.map(x => x.id)];\r\n      this.selectedItemIds = [...this.items.map(x => x.id)]\r\n    }\r\n    else{\r\n      this.isAllSelected = false;\r\n      this.fakeIsAllSelected = false;\r\n      this.onIsAllSelectedChange.next(new AllClickEvent({checked: false, additionalIndexes: this.additionalIndexes}));\r\n      this.rowsSelectedNumber = 0;\r\n      this.fakeSelectedItems = [];\r\n      this.selectedItemIds = [];\r\n    }\r\n  }\r\n\r\n  selectRow(id: number, index: number) {\r\n    if (this.isRowSelected(id)) {\r\n      this.rowUnselect(id);\r\n      this.onRowUnselect.next(new RowClickEvent({ index: index, id: id, additionalIndexes: this.additionalIndexes }));\r\n    } else {\r\n      this.rowSelect(id);\r\n      this.onRowSelect.next(new RowClickEvent({ index: index, id: id, additionalIndexes: this.additionalIndexes }));\r\n    }\r\n  }\r\n\r\n  isRowSelected(id: number){\r\n    if (this.hasLazyLoad){\r\n      return this.fakeSelectedItems.find(x => x === id) != undefined;\r\n    }\r\n    else {\r\n      return this.selectedItemIds.find(x => x === id) != undefined;\r\n    }\r\n  }\r\n\r\n  rowSelect(id: number){\r\n    if (this.isAllSelected == false || this.currentPageSelectedItemsFromDb.includes(id) == false) {\r\n      this.newlySelectedItems.push(id);\r\n    }\r\n\r\n    if (this.hasLazyLoad){\r\n      this.fakeSelectedItems.push(id);\r\n    }\r\n    else {\r\n      this.selectedItemIds.push(id);\r\n    }\r\n    \r\n    this.rowsSelectedNumber++;\r\n\r\n    const index = this.unselectedItems.indexOf(id);\r\n    if (index !== -1) {\r\n      this.unselectedItems.splice(index, 1); // FT: Splice is mutating the array\r\n    }\r\n\r\n    this.setFakeIsAllSelected();\r\n  }\r\n  \r\n  rowUnselect(id: number) {\r\n    if (this.isAllSelected == true || this.currentPageSelectedItemsFromDb.includes(id) == true) {\r\n      this.unselectedItems.push(id);\r\n    }\r\n\r\n    this.rowsSelectedNumber--;\r\n\r\n    const index = this.newlySelectedItems.indexOf(id);\r\n    const fakeIndex = this.fakeSelectedItems.indexOf(id);\r\n    const nonLazyLoadIndex = this.selectedItemIds.indexOf(id);\r\n\r\n    if (index !== -1) {\r\n      this.newlySelectedItems.splice(index, 1); // FT: Splice is mutating the array\r\n    }\r\n    if (fakeIndex !== -1) {\r\n      this.fakeSelectedItems.splice(fakeIndex, 1); // FT: Splice is mutating the array\r\n    }\r\n    if (nonLazyLoadIndex !== -1) {\r\n      this.selectedItemIds.splice(nonLazyLoadIndex, 1); // FT: Splice is mutating the array\r\n    }\r\n\r\n    this.setFakeIsAllSelected();\r\n  }\r\n  //#endregion\r\n\r\n  //#region Client side table\r\n\r\n  // FT: Can do it with Id also, because we are never adding the new record in the table at the same page.\r\n  getFormArrayControlByIndex(formControlName: string, index: number): SpiderlyFormControl{\r\n    if (this.getFormControl) {\r\n      return this.getFormControl(formControlName, index, this.additionalIndexes);\r\n    }\r\n    else{\r\n      return null;\r\n    }\r\n  }\r\n\r\n  //#endregion\r\n}\r\n\r\nexport class Action {\r\n  name?: string;\r\n  field?: string;\r\n  icon?: string;\r\n  style?: string;\r\n  onClick?: (id: number) => void;\r\n\r\n  constructor(\r\n    {\r\n      name,\r\n      field,\r\n      icon,\r\n      style,\r\n      onClick,\r\n    }:{\r\n      name?: string;\r\n      field?: string;\r\n      icon?: string;\r\n      style?: string;\r\n      onClick?: () => void;\r\n    } = {}\r\n    ) {\r\n      this.name = name;\r\n      this.field = field;\r\n      this.icon = icon;\r\n      this.style = style;\r\n      this.onClick = onClick;\r\n  }\r\n}\r\n\r\nexport class Column<T = any> {\r\n  name: string;\r\n  field?: string & keyof T;\r\n  filterField?: string & keyof T; // FT: Made specificaly for multiautocomplete, maybe for something more in the future\r\n  filterType?: 'text' | 'date' | 'multiselect' | 'boolean' | 'numeric';\r\n  filterPlaceholder?: string;\r\n  showMatchModes?: boolean;\r\n  showAddButton?: boolean;\r\n  dropdownOrMultiselectValues?: PrimengOption[];\r\n  actions?: Action[];\r\n  editable?: boolean;\r\n  showTime?: boolean;\r\n\r\n  constructor(\r\n    {\r\n      name,\r\n      field,\r\n      filterField,\r\n      filterType,\r\n      filterPlaceholder,\r\n      showMatchModes,\r\n      showAddButton,\r\n      dropdownOrMultiselectValues,\r\n      actions,\r\n      editable,\r\n      showTime,\r\n    }:{\r\n      name?: string;\r\n      field?: string & keyof T;\r\n      filterField?: string & keyof T; // FT: Made specificaly for multiautocomplete, maybe for something more in the future;\r\n      filterType?: 'text' | 'date' | 'multiselect' | 'boolean' | 'numeric';\r\n      filterPlaceholder?: string;\r\n      showMatchModes?: boolean;\r\n      showAddButton?: boolean;\r\n      dropdownOrMultiselectValues?: PrimengOption[];\r\n      actions?: Action[];\r\n      editable?: boolean;\r\n      showTime?: boolean;\r\n    } = {}\r\n    ) {\r\n      this.name = name;\r\n      this.field = field;\r\n      this.filterField = filterField;\r\n      this.filterType = filterType;\r\n      this.filterPlaceholder = filterPlaceholder;\r\n      this.showMatchModes = showMatchModes;\r\n      this.showAddButton = showAddButton;\r\n      this.dropdownOrMultiselectValues = dropdownOrMultiselectValues;\r\n      this.actions = actions;\r\n      this.editable = editable;\r\n      this.showTime = showTime;\r\n  }\r\n}\r\n\r\nexport class RowClickEvent {\r\n  index?: number;\r\n  id?: number;\r\n  additionalIndexes?: any;\r\n\r\n  constructor(\r\n    {\r\n      index, \r\n      id, \r\n      additionalIndexes\r\n    }:{\r\n      index?: number; \r\n      id?: number; \r\n      additionalIndexes?: any;\r\n    } = {}\r\n    ) {\r\n    this.index = index;\r\n    this.id = id;\r\n    this.additionalIndexes = additionalIndexes;\r\n  }\r\n}\r\n\r\nexport class AllClickEvent {\r\n  checked?: boolean;\r\n  additionalIndexes?: any;\r\n\r\n  constructor(\r\n    {\r\n      checked, \r\n      additionalIndexes\r\n    }:{\r\n      checked?: boolean; \r\n      additionalIndexes?: any;\r\n    } = {}\r\n    ) {\r\n    this.checked = checked;\r\n    this.additionalIndexes = additionalIndexes;\r\n  }\r\n}","<ng-container *transloco=\"let t\">\r\n  <div [class]=\"showCardWrapper ? 'card responsive-card-padding overflow-auto' : ''\">\r\n    <p-table #dt [value]=\"items\" [rows]=\"rows\" [rowHover]=\"true\" styleClass=\"p-datatable-gridlines\" [paginator]=\"showPaginator\" responsiveLayout=\"scroll\" [lazy]=\"hasLazyLoad\"\r\n    (onLazyLoad)=\"lazyLoad($event)\" [totalRecords]=\"totalRecords\" class=\"spiderly-table\" [loading]=\"(items === undefined || loading === true)\" [selectionMode]=\"selectionMode\" dataKey=\"id\" \r\n    (onFilter)=\"filter($event)\"> \r\n      <ng-template pTemplate=\"caption\">\r\n        <div class=\"table-header overflow-auto\">\r\n          <div style=\"display: flex; align-items: center; gap: 8px;\">\r\n            <i class=\"{{tableIcon}} text-2xl primary-color\"></i>\r\n            <h5 style=\"margin: 0px;\">{{tableTitle}}</h5>\r\n          </div>\r\n          <div style=\"display: flex; gap: 8px;\">\r\n            <button pButton [label]=\"t('ClearFilters')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-filter-slash\" (click)=\"clear(dt)\"></button>\r\n            <button pButton *ngIf=\"showExportToExcelButton\" [label]=\"t('ExportToExcel')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-download\" (click)=\"exportListToExcel()\"></button>\r\n            <button pButton *ngIf=\"showReloadTableButton\" [label]=\"t('Reload')\" class=\"p-button-outlined remove-button-border-focus\" style=\"flex: none;\" icon=\"pi pi-refresh\" (click)=\"reload()\"></button>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <ng-template pTemplate=\"header\">\r\n        <tr>\r\n          <th style=\"width: 0rem;\" *ngIf=\"selectionMode == 'multiple'\">\r\n            <div style=\"display: flex; gap: 8px;\">\r\n              <p-checkbox [disabled]=\"readonly\" (onChange)=\"selectAll($event.checked)\" [(ngModel)]=\"fakeIsAllSelected\" [binary]=\"true\"></p-checkbox> ({{rowsSelectedNumber}})\r\n            </div>\r\n          </th>\r\n          <ng-container *ngFor=\"let col of cols; trackBy: colTrackByFn\">\r\n            <th [style]=\"getColHeaderWidth(col.filterType)\">\r\n              <div style=\"display: flex; justify-content: space-between; align-items: center;\">\r\n                {{col.name}}\r\n                <!-- <p-sortIcon field=\"\"></p-sortIcon> -->\r\n                <!-- <p-columnFilter type=\"date\" field=\"date\" display=\"menu\"></p-columnFilter> -->\r\n                <p-columnFilter *ngIf=\"col.filterType != null\" [type]=\"col.filterType\" [field]=\"col.filterField ?? col.field\" display=\"menu\" [placeholder]=\"col.filterPlaceholder\" \r\n                [showOperator]=\"false\" [showMatchModes]=\"col.showMatchModes\" [showAddButton]=\"col.showAddButton\" [matchModeOptions]=\"getColMatchModeOptions(col.filterType)\"\r\n                [matchMode]=\"getColMatchMode(col.filterType)\"\r\n                >\r\n                <ng-container *ngIf=\"isDropOrMulti(col.filterType)\">\r\n                  <ng-template pTemplate=\"filter\" let-value let-filter=\"filterCallback\">\r\n                    <p-multiSelect [ngModel]=\"value\" [options]=\"col.dropdownOrMultiselectValues\" [placeholder]=\"t('All')\" (onChange)=\"filter($event.value)\" optionLabel=\"label\" optionValue=\"value\" [style]=\"{'width':'240px'}\">\r\n                      <ng-template let-item pTemplate=\"item\">\r\n                        <div class=\"p-multiselect-representative-option\">\r\n                          <span class=\"ml-2\">{{ item.label }}</span>\r\n                        </div>\r\n                      </ng-template>\r\n                    </p-multiSelect>\r\n                  </ng-template>\r\n                </ng-container>\r\n              </p-columnFilter>\r\n              </div>\r\n            </th>\r\n          </ng-container>\r\n        </tr>\r\n      </ng-template>\r\n      <ng-template pTemplate=\"body\" let-rowData let-index=\"rowIndex\" let-editing=\"editing\">\r\n        <tr>\r\n          <td *ngIf=\"selectionMode == 'multiple'\">\r\n              <p-checkbox [disabled]=\"readonly\" (onChange)=\"selectRow(rowData.id, rowData.index)\" [ngModel]=\"isRowSelected(rowData.id)\" [binary]=\"true\"></p-checkbox>\r\n          </td>\r\n          <ng-container *ngFor=\"let col of cols; trackBy: colTrackByFn\">\r\n            <td [pTooltip]=\"getRowData(rowData, col)\" [style]=\"getStyleForBodyColumn(col)\" *ngIf=\"!col.editable\">\r\n              <div style=\"display: flex; align-items: center; justify-content: center; gap: 18px;\">\r\n                <ng-container *ngFor=\"let action of col.actions; trackBy: actionTrackByFn\" >\r\n                  <span [pTooltip]=\"action.name\" [class]=\"getClassForAction(action)\" (click)=\"getMethodForAction(action, rowData)\"></span>\r\n                </ng-container>\r\n              </div>\r\n              {{getRowData(rowData, col)}}\r\n            </td>\r\n            <td *ngIf=\"col.editable\">\r\n              <spiderly-number [control]=\"getFormArrayControlByIndex(col.field, rowData.index)\" [showLabel]=\"false\"></spiderly-number>\r\n            </td>\r\n          </ng-container>\r\n        </tr>\r\n      </ng-template>\r\n      <ng-template pTemplate=\"emptymessage\">\r\n        <tr>\r\n          <td [attr.colspan]=\"cols?.length + (selectionMode === 'multiple' ? 1 : 0)\">{{t('NoRecordsFound')}}</td>\r\n        </tr>\r\n      </ng-template>\r\n      <ng-template pTemplate=\"loadingbody\">\r\n        <tr>\r\n          <td [attr.colspan]=\"cols?.length + (selectionMode === 'multiple' ? 1 : 0)\">{{t('Loading')}}...</td>\r\n        </tr>\r\n      </ng-template>\r\n      <ng-template pTemplate=\"paginatorleft\">\r\n        {{t('TotalRecords')}}: {{totalRecords}}\r\n      </ng-template>\r\n      <ng-template pTemplate=\"paginatorright\">\r\n        <div style=\"display: flex; justify-content: end; gap: 10px;\">\r\n          <spiderly-button *ngIf=\"showAddButton\" [label]=\"t('AddNew')\" icon=\"pi pi-plus\" (onClick)=\"navigateToDetails(0)\"></spiderly-button>\r\n        </div>\r\n      </ng-template>\r\n    </p-table>\r\n  </div>\r\n</ng-container>"]}
|