@impartner/design-components 1.2.0 → 2.0.0
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 +5 -4
- package/constants/fontawesome-icons.d.ts +2 -2
- package/{esm2020 → esm2022}/constants/fontawesome-icons.mjs +1 -1
- package/{esm2020 → esm2022}/lib/alert/alert.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/alert/alert.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/avatar/avatar.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/avatar/avatar.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/avatar-group/avatar-group.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/avatar-group/avatar-group.module.mjs +5 -5
- package/esm2022/lib/backdrop/backdrop.component.mjs +52 -0
- package/{esm2020 → esm2022}/lib/backdrop/backdrop.module.mjs +6 -6
- package/esm2022/lib/badge/badge.component.mjs +105 -0
- package/{esm2020 → esm2022}/lib/badge/badge.module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/badge/types/badge-size.mjs +1 -1
- package/{esm2020 → esm2022}/lib/branding/branded.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/branding/branding.module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb-item.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/button/button.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/button/button.module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/button-group/button-group.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/button-group/button-group.module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/card-heading/card-heading.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/card-heading/card-heading.module.mjs +6 -6
- package/esm2022/lib/data-card/data-card.component.mjs +123 -0
- package/esm2022/lib/data-card/data-card.module.mjs +21 -0
- package/{esm2020 → esm2022}/lib/design-components.module.mjs +61 -61
- package/{esm2020 → esm2022}/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +4 -4
- package/esm2022/lib/dropdown/dropdown.component.mjs +143 -0
- package/{esm2020 → esm2022}/lib/dropdown/dropdown.module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/file-upload/directives/file-drop.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/file-upload/file-upload.component.mjs +30 -30
- package/{esm2020 → esm2022}/lib/file-upload/file-upload.module.mjs +8 -8
- package/{esm2020 → esm2022}/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/checkbox.component.mjs +49 -49
- package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/checkbox.module.mjs +5 -5
- package/esm2022/lib/form-field/controls/input/input.directive.mjs +233 -0
- package/esm2022/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
- package/esm2022/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +289 -0
- package/{esm2020 → esm2022}/lib/form-field/controls/radio/radio.module.mjs +5 -5
- package/esm2022/lib/form-field/controls/select/option/select-option.component.mjs +139 -0
- package/esm2022/lib/form-field/controls/select/select-model.mjs +150 -0
- package/esm2022/lib/form-field/controls/select/select.component.mjs +522 -0
- package/{esm2020 → esm2022}/lib/form-field/controls/select/select.module.mjs +9 -9
- package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +4 -4
- package/esm2022/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
- package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/toggle.module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/form-field/directives/corner-hint.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/directives/error.directive.mjs +4 -4
- package/esm2022/lib/form-field/directives/form-root.directive.mjs +91 -0
- package/{esm2020 → esm2022}/lib/form-field/directives/hint.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/directives/label.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/directives/prefix.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/directives/suffix.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/form-field.component.mjs +11 -11
- package/{esm2020 → esm2022}/lib/form-field/impdc-forms.module.mjs +28 -28
- package/{esm2020 → esm2022}/lib/form-field/services/error-state-matcher.service.mjs +7 -7
- package/{esm2020 → esm2022}/lib/form-field/services/unique-selection-dispatcher.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/shared/disabled.mixin.mjs +5 -5
- package/esm2022/lib/form-field/shared/error-state.mixin.mjs +24 -0
- package/{esm2020 → esm2022}/lib/form-field/shared/form-field-control.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form-field/shared/tab-index.mixin.mjs +6 -6
- package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/icon/icon.module.mjs +6 -6
- package/esm2022/lib/modal/modal.component.mjs +260 -0
- package/{esm2020 → esm2022}/lib/modal/modal.module.mjs +14 -14
- package/{esm2020 → esm2022}/lib/modal/types/modal-component-sizes.mjs +1 -1
- package/{esm2020 → esm2022}/lib/modal/types/modal-theme.mjs +1 -1
- package/esm2022/lib/pagination/pagination.component.mjs +176 -0
- package/{esm2020 → esm2022}/lib/pagination/pagination.module.mjs +16 -16
- package/{esm2020 → esm2022}/lib/progress-bar/progress-bar.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/progress-bar/progress-bar.module.mjs +5 -5
- package/esm2022/lib/scrollable/scrollable.component.mjs +186 -0
- package/{esm2020 → esm2022}/lib/scrollable/scrollable.module.mjs +6 -6
- package/esm2022/lib/select-icon/select-icon.component.mjs +308 -0
- package/{esm2020 → esm2022}/lib/select-icon/select-icon.module.mjs +13 -13
- package/{esm2020 → esm2022}/lib/size-detection/directive/size-detector.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/size-detection/size-detection.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/spinner/spinner.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/spinner/spinner.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/table/components/bulk-actions/bulk-actions.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/table/components/column-heading/column-heading.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/table/components/index.mjs +2 -1
- package/esm2022/lib/table/components/row-actions/row-actions.component.mjs +61 -0
- package/esm2022/lib/table/containers/table.component.mjs +403 -0
- package/esm2022/lib/table/directives/table-inject-component.directive.mjs +46 -0
- package/{esm2020 → esm2022}/lib/table/directives/table.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/table/enumerations/table-column-type.mjs +2 -1
- package/{esm2020 → esm2022}/lib/table/helpers/table-theme.helper.mjs +3 -3
- package/esm2022/lib/table/interfaces/index.mjs +11 -0
- package/esm2022/lib/table/interfaces/table-column-defs.type.mjs +2 -0
- package/esm2022/lib/table/interfaces/table-row-action-payload.interface.mjs +2 -0
- package/esm2022/lib/table/interfaces/table-row-action.interface.mjs +2 -0
- package/esm2022/lib/table/table.module.mjs +96 -0
- package/{esm2020 → esm2022}/lib/text-highlight/text-highlight.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/text-highlight/text-highlight.module.mjs +6 -6
- package/{esm2020 → esm2022}/services/index.mjs +1 -1
- package/esm2022/services/interaction.service.mjs +88 -0
- package/{esm2020 → esm2022}/types/component-theme.mjs +1 -1
- package/{fesm2020 → fesm2022}/impartner-design-components.mjs +1197 -1032
- package/fesm2022/impartner-design-components.mjs.map +1 -0
- package/lib/alert/alert.component.d.ts +1 -1
- package/lib/alert/theme/alert-theme.d.ts +1 -1
- package/lib/avatar/avatar.component.d.ts +1 -1
- package/lib/avatar-group/avatar-group.component.d.ts +1 -1
- package/lib/backdrop/backdrop.component.d.ts +9 -6
- package/lib/badge/badge.component.d.ts +3 -2
- package/lib/badge/types/badge-icon.d.ts +1 -1
- package/lib/badge/types/badge-size.d.ts +1 -1
- package/lib/branding/branded.directive.d.ts +1 -1
- package/lib/breadcrumb/breadcrumb-item.component.d.ts +1 -1
- package/lib/breadcrumb/breadcrumb.component.d.ts +1 -1
- package/lib/button/button.component.d.ts +1 -1
- package/lib/button/themes/button-theme.d.ts +1 -1
- package/lib/button-group/button-group.component.d.ts +1 -1
- package/lib/card-heading/card-heading.component.d.ts +1 -1
- package/lib/data-card/data-card.component.d.ts +14 -18
- package/lib/data-card/data-card.module.d.ts +2 -1
- package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +1 -1
- package/lib/dropdown/dropdown.component.d.ts +6 -5
- package/lib/dropdown/types/dropdown-position.d.ts +1 -1
- package/lib/file-upload/directives/file-drop.directive.d.ts +1 -1
- package/lib/file-upload/file-upload.component.d.ts +1 -1
- package/lib/form-field/controls/checkbox/checkbox.component.d.ts +1 -1
- package/lib/form-field/controls/input/input.directive.d.ts +1 -1
- package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +1 -1
- package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +1 -1
- package/lib/form-field/controls/select/option/select-option.component.d.ts +4 -4
- package/lib/form-field/controls/select/select.component.d.ts +1 -1
- package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +1 -1
- package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +1 -1
- package/lib/form-field/directives/corner-hint.directive.d.ts +1 -1
- package/lib/form-field/directives/error.directive.d.ts +1 -1
- package/lib/form-field/directives/form-root.directive.d.ts +2 -2
- package/lib/form-field/directives/hint.directive.d.ts +1 -1
- package/lib/form-field/directives/label.directive.d.ts +1 -1
- package/lib/form-field/directives/prefix.directive.d.ts +1 -1
- package/lib/form-field/directives/suffix.directive.d.ts +1 -1
- package/lib/form-field/form-field.component.d.ts +1 -1
- package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +1 -1
- package/lib/form-field/shared/constructors.type.d.ts +2 -2
- package/lib/form-field/shared/disabled.mixin.d.ts +1 -1
- package/lib/form-field/shared/error-state.mixin.d.ts +1 -1
- package/lib/form-field/shared/form-field-control.d.ts +1 -1
- package/lib/form-field/shared/tab-index.mixin.d.ts +1 -1
- package/lib/icon/icon.component.d.ts +1 -1
- package/lib/modal/modal.component.d.ts +17 -10
- package/lib/modal/types/modal-component-sizes.d.ts +1 -1
- package/lib/modal/types/modal-theme.d.ts +1 -1
- package/lib/pagination/pagination.component.d.ts +1 -1
- package/lib/progress-bar/progress-bar.component.d.ts +1 -1
- package/lib/scrollable/scrollable.component.d.ts +1 -1
- package/lib/select-icon/select-icon.component.d.ts +1 -1
- package/lib/size-detection/directive/size-detector.directive.d.ts +1 -1
- package/lib/spinner/spinner.component.d.ts +1 -1
- package/lib/table/components/bulk-actions/bulk-actions.component.d.ts +1 -1
- package/lib/table/components/column-heading/column-heading.component.d.ts +1 -1
- package/lib/table/components/index.d.ts +1 -0
- package/lib/table/components/row-actions/row-actions.component.d.ts +21 -0
- package/lib/table/containers/table.component.d.ts +12 -6
- package/lib/table/directives/table-inject-component.directive.d.ts +3 -3
- package/lib/table/directives/table.directive.d.ts +1 -1
- package/lib/table/enumerations/table-column-type.d.ts +2 -1
- package/lib/table/helpers/table-theme.helper.d.ts +4 -4
- package/lib/table/interfaces/custom-cell-renderer-components.type.d.ts +1 -1
- package/lib/table/interfaces/index.d.ts +3 -1
- package/lib/table/interfaces/{table-column-def.interface.d.ts → table-column-defs.type.d.ts} +8 -1
- package/lib/table/interfaces/table-row-action-payload.interface.d.ts +6 -0
- package/lib/table/interfaces/table-row-action.interface.d.ts +9 -0
- package/lib/table/interfaces/table-row-item.interface.d.ts +3 -3
- package/lib/table/table.module.d.ts +12 -10
- package/lib/text-highlight/text-highlight.component.d.ts +1 -1
- package/package.json +16 -22
- package/services/index.d.ts +1 -1
- package/services/interaction.service.d.ts +20 -10
- package/types/component-size.d.ts +2 -2
- package/types/component-theme.d.ts +1 -1
- package/utilities/boolean-props.d.ts +1 -1
- package/utilities/number-props.d.ts +1 -1
- package/esm2020/lib/backdrop/backdrop.component.mjs +0 -40
- package/esm2020/lib/badge/badge.component.mjs +0 -99
- package/esm2020/lib/data-card/data-card.component.mjs +0 -128
- package/esm2020/lib/data-card/data-card.module.mjs +0 -20
- package/esm2020/lib/dropdown/dropdown.component.mjs +0 -142
- package/esm2020/lib/form-field/controls/input/input.directive.mjs +0 -233
- package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +0 -260
- package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +0 -289
- package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +0 -139
- package/esm2020/lib/form-field/controls/select/select-model.mjs +0 -150
- package/esm2020/lib/form-field/controls/select/select.component.mjs +0 -522
- package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +0 -96
- package/esm2020/lib/form-field/directives/form-root.directive.mjs +0 -91
- package/esm2020/lib/form-field/shared/error-state.mixin.mjs +0 -24
- package/esm2020/lib/modal/modal.component.mjs +0 -187
- package/esm2020/lib/pagination/pagination.component.mjs +0 -176
- package/esm2020/lib/scrollable/scrollable.component.mjs +0 -186
- package/esm2020/lib/select-icon/select-icon.component.mjs +0 -308
- package/esm2020/lib/table/containers/table.component.mjs +0 -386
- package/esm2020/lib/table/directives/table-inject-component.directive.mjs +0 -46
- package/esm2020/lib/table/interfaces/index.mjs +0 -9
- package/esm2020/lib/table/interfaces/table-column-def.interface.mjs +0 -2
- package/esm2020/lib/table/table.module.mjs +0 -88
- package/esm2020/services/interaction.service.mjs +0 -81
- package/fesm2015/impartner-design-components.mjs +0 -9214
- package/fesm2015/impartner-design-components.mjs.map +0 -1
- package/fesm2020/impartner-design-components.mjs.map +0 -1
- /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
- /package/{esm2020 → esm2022}/impartner-design-components.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/alert/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/alert/theme/alert-theme.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/alert/theme/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/avatar/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/avatar-group/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/backdrop/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/badge/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/badge/types/badge-icon.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/badge/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/branding/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/breadcrumb/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/button/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/button/themes/button-theme.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/button/themes/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/button-group/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/card-heading/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-card/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/dropdown/components/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/dropdown/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/dropdown/types/dropdown-position.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/dropdown/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/file-upload/directives/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/file-upload/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/file-upload/pipes/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/input/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/radio/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/radio/injection-tokens.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/select/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/select/option/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/select/option-parent.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/shared/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/components/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/directives/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/form-field-errors.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/impdc-forms.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/services/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/shared/constructors.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form-field/shared/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/icon/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modal/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modal/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pagination/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/progress-bar/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/scrollable/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/select-icon/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/size-detection/directive/element-size.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/size-detection/directive/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/size-detection/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/spinner/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/constants/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/constants/public-table.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/constants/table.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/containers/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/directives/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/enumerations/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/helpers/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/interfaces/cell-renderer.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/interfaces/custom-cell-renderer-components.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/interfaces/sort-by-payload.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/interfaces/table-cell-option.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/interfaces/table-event-payload.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/table/interfaces/table-row-item.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/text-highlight/index.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/types/component-size.mjs +0 -0
- /package/{esm2020 → esm2022}/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/boolean-props.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/dc.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/lc.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/number-props.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/sanitize.mjs +0 -0
|
@@ -0,0 +1,403 @@
|
|
|
1
|
+
import { Component, ContentChild, EventEmitter, Host, Input, Optional, Output } from '@angular/core';
|
|
2
|
+
import { get as getNestedValue, set as setNestedValue } from 'lodash';
|
|
3
|
+
import { debounceTime } from 'rxjs/operators';
|
|
4
|
+
import { DEBOUNCE_TIME, SORT_COLUMN_INDEX } from '../constants/index';
|
|
5
|
+
import { TableColumnType } from '../enumerations/index';
|
|
6
|
+
import { TableThemeHelper } from '../helpers';
|
|
7
|
+
import { ComponentTheme } from '../../../types';
|
|
8
|
+
import { PaginationComponent } from '../../pagination';
|
|
9
|
+
import { TableBulkActionsComponent } from '../components';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/common";
|
|
12
|
+
import * as i2 from "../../branding";
|
|
13
|
+
import * as i3 from "../../branding/branded.directive";
|
|
14
|
+
import * as i4 from "../../icon/icon.component";
|
|
15
|
+
import * as i5 from "../../form-field/controls/checkbox/checkbox.component";
|
|
16
|
+
import * as i6 from "../../form-field/controls/select/option/select-option.component";
|
|
17
|
+
import * as i7 from "../../form-field/controls/select/select.component";
|
|
18
|
+
import * as i8 from "../../form-field/controls/input/input.directive";
|
|
19
|
+
import * as i9 from "@angular/forms";
|
|
20
|
+
import * as i10 from "../../spinner/spinner.component";
|
|
21
|
+
import * as i11 from "../../badge/badge.component";
|
|
22
|
+
import * as i12 from "../directives/table.directive";
|
|
23
|
+
import * as i13 from "../components/column-heading/column-heading.component";
|
|
24
|
+
import * as i14 from "../directives/table-inject-component.directive";
|
|
25
|
+
import * as i15 from "../components/row-actions/row-actions.component";
|
|
26
|
+
/**
|
|
27
|
+
* The `TableComponent` (`<impdc-table`) is a data table component.
|
|
28
|
+
* To use, import `TableModule` from `@impartner/design-components`.
|
|
29
|
+
*/
|
|
30
|
+
export class TableComponent {
|
|
31
|
+
/**
|
|
32
|
+
* Whether individual rows can be selected. Will be `true` if explicitly set to `true` or `canSelectAllRows` is `true`.
|
|
33
|
+
*/
|
|
34
|
+
set canSelectRows(value) {
|
|
35
|
+
this._canSelectRows = value;
|
|
36
|
+
}
|
|
37
|
+
get canSelectRows() {
|
|
38
|
+
return this.canSelectAllRows || this._canSelectRows || !!this.bulkActions;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Whether all rows can be selected at once. Will be `true` if explicitly set to `true` or if `TableBulkActionsComponent` is content projected.
|
|
42
|
+
*/
|
|
43
|
+
set canSelectAllRows(value) {
|
|
44
|
+
this._canSelectAllRows = value;
|
|
45
|
+
}
|
|
46
|
+
get canSelectAllRows() {
|
|
47
|
+
return this._canSelectAllRows || !!this.bulkActions;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* An array of currently selected IDs from the `tableData` input. Array must be of type `(string | number)[]`.
|
|
51
|
+
*/
|
|
52
|
+
set selectedRowIds(value) {
|
|
53
|
+
this._selectedRowIds = [...value];
|
|
54
|
+
}
|
|
55
|
+
get selectedRowIds() {
|
|
56
|
+
return [...this._selectedRowIds];
|
|
57
|
+
}
|
|
58
|
+
/** @ignore */
|
|
59
|
+
get someSelected() {
|
|
60
|
+
return (!!this._selectedRowIds &&
|
|
61
|
+
this._selectedRowIds.length > 0 &&
|
|
62
|
+
!!this.tableData &&
|
|
63
|
+
this.tableData.length > 0 &&
|
|
64
|
+
this._selectedRowIds.length < this.tableData.length);
|
|
65
|
+
}
|
|
66
|
+
/** @ignore */
|
|
67
|
+
get tableSpan() {
|
|
68
|
+
return this.canSelectRows
|
|
69
|
+
? this.columnDefs.length + 1
|
|
70
|
+
: this.columnDefs.length;
|
|
71
|
+
}
|
|
72
|
+
constructor(_datePipe, _percentPipe, _decmialPipe, _changeDetectorRef, _branded) {
|
|
73
|
+
this._datePipe = _datePipe;
|
|
74
|
+
this._percentPipe = _percentPipe;
|
|
75
|
+
this._decmialPipe = _decmialPipe;
|
|
76
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
77
|
+
this._branded = _branded;
|
|
78
|
+
/**
|
|
79
|
+
* Whether the table data is currently being loaded. The `<impdc-spinner>` will show if data is loading.
|
|
80
|
+
*/
|
|
81
|
+
this.loading = false;
|
|
82
|
+
/**
|
|
83
|
+
* The visible columns of the table. Each `ITableColumnDef` defines properties regarding the display, formatting and interaction of the column's cells.
|
|
84
|
+
* Column/cell color precedence is:
|
|
85
|
+
* 1) `fieldColor` - allows an `ITableColumnDef` to delegate the responsibility of cell color to an `ITableRowItem` property.
|
|
86
|
+
* 2) `colorGetter`- allows an `ITableColumnDef` to delegate the responsibility of cell color to a function of the `ITableRowItem` determined by the developer.
|
|
87
|
+
* 3) `color` - a property of an `ITableColumnDef`.
|
|
88
|
+
*/
|
|
89
|
+
this.columnDefs = [];
|
|
90
|
+
/**
|
|
91
|
+
* Whether the table is striped.
|
|
92
|
+
*/
|
|
93
|
+
this.striped = true;
|
|
94
|
+
/**
|
|
95
|
+
* The placeholder text and empty value display text for `<impdc-select>` instances in cells with a `ITableColumnDef` `columnType` = `SingleSelect` or `MultiSelect`.
|
|
96
|
+
*/
|
|
97
|
+
this.selectPlaceholder = '';
|
|
98
|
+
/**
|
|
99
|
+
* The `columnDefs` index of the currently sorted column.
|
|
100
|
+
*/
|
|
101
|
+
this.sortColumnIndex = SORT_COLUMN_INDEX;
|
|
102
|
+
/**
|
|
103
|
+
* The direction of the currently sorted column.
|
|
104
|
+
*/
|
|
105
|
+
this.sortDirection = 'asc';
|
|
106
|
+
/**
|
|
107
|
+
* The table row data as an array of `ITableRowItem`.
|
|
108
|
+
*/
|
|
109
|
+
this.tableData = [];
|
|
110
|
+
/**
|
|
111
|
+
* Event emitted when one or multiple rows are selected. Emits `(string | number)[]` payload.
|
|
112
|
+
*/
|
|
113
|
+
this.rowSelect = new EventEmitter();
|
|
114
|
+
/**
|
|
115
|
+
* Event emitted when a column is sorted. Emits `ISortByPayload` payload.
|
|
116
|
+
*/
|
|
117
|
+
this.sortBy = new EventEmitter();
|
|
118
|
+
/**
|
|
119
|
+
* Event emitted when a row link is clicked. Emits `ITableEventPayload` payload.
|
|
120
|
+
*/
|
|
121
|
+
this.linkClick = new EventEmitter();
|
|
122
|
+
/**
|
|
123
|
+
* Event emitted when a row action is clicked. Emits an `ITableRowActionPayload` payload.
|
|
124
|
+
*/
|
|
125
|
+
this.rowActionClick = new EventEmitter();
|
|
126
|
+
/** @ignore */
|
|
127
|
+
this.paginationComponent = undefined;
|
|
128
|
+
/** @ignore */
|
|
129
|
+
this.bulkActions = undefined;
|
|
130
|
+
/**
|
|
131
|
+
* Event emitted when a row input value is changed. Emitted cells of `columnType` `SinglSelect`, `MultiSelect`, `Input`, `Boolean` or `Icon`.
|
|
132
|
+
* Not emitted if column definition property `disabled` = `true`. Emits `ITableEventPayload` payload.
|
|
133
|
+
*/
|
|
134
|
+
this.inputChange = new EventEmitter();
|
|
135
|
+
/** @ignore */
|
|
136
|
+
this.cellType = TableColumnType;
|
|
137
|
+
/** @ignore */
|
|
138
|
+
this.allSelected = true;
|
|
139
|
+
/** @ignore */
|
|
140
|
+
this.branded = false;
|
|
141
|
+
this._canSelectRows = false;
|
|
142
|
+
this._canSelectAllRows = false;
|
|
143
|
+
this._selectedRowIds = [];
|
|
144
|
+
this._inputChange = new EventEmitter();
|
|
145
|
+
this.branded = _branded ? true : false;
|
|
146
|
+
this._inputChange
|
|
147
|
+
.pipe(debounceTime(DEBOUNCE_TIME))
|
|
148
|
+
.subscribe(this.inputChange);
|
|
149
|
+
}
|
|
150
|
+
ngOnChanges(changes) {
|
|
151
|
+
if (changes['selectedRowIds'] || changes['tableData']) {
|
|
152
|
+
if (!this.tableData ||
|
|
153
|
+
!this.tableData.length ||
|
|
154
|
+
!this.selectedRowIds ||
|
|
155
|
+
!this.selectedRowIds.length) {
|
|
156
|
+
this.allSelected = false;
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
this.allSelected = this.selectedRowIds.length >= this.tableData.length;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
getMailToValue(columnIndex, currentRow) {
|
|
164
|
+
const { columnType, truncated: truncated } = this._getColumnDefByIndex(columnIndex);
|
|
165
|
+
let value = this._getValue(columnIndex, currentRow);
|
|
166
|
+
if (columnType !== TableColumnType.Email) {
|
|
167
|
+
return String(value);
|
|
168
|
+
}
|
|
169
|
+
value = value ? `mailto:${value}` : value;
|
|
170
|
+
return String(value);
|
|
171
|
+
}
|
|
172
|
+
getStringValue(columnIndex, currentRow) {
|
|
173
|
+
const value = this.getValue(columnIndex, currentRow);
|
|
174
|
+
if (Array.isArray(value)) {
|
|
175
|
+
return value.join(';');
|
|
176
|
+
}
|
|
177
|
+
return String(value);
|
|
178
|
+
}
|
|
179
|
+
getValue(columnIndex, currentRow) {
|
|
180
|
+
const { columnType, truncated: truncated } = this._getColumnDefByIndex(columnIndex);
|
|
181
|
+
let value = this._getValue(columnIndex, currentRow);
|
|
182
|
+
switch (columnType) {
|
|
183
|
+
case TableColumnType.Decimal: {
|
|
184
|
+
value = this._decmialPipe.transform(Number(value) || 0) || '';
|
|
185
|
+
break;
|
|
186
|
+
}
|
|
187
|
+
case TableColumnType.Date: {
|
|
188
|
+
const date = new Date(String(value));
|
|
189
|
+
const validDate = date instanceof Date && !isNaN(date.getTime());
|
|
190
|
+
value = validDate
|
|
191
|
+
? this._datePipe.transform(date, 'MM/dd/yyyy') || ''
|
|
192
|
+
: String(value);
|
|
193
|
+
break;
|
|
194
|
+
}
|
|
195
|
+
case TableColumnType.DateTime: {
|
|
196
|
+
const dateTime = new Date(String(value));
|
|
197
|
+
const validDateTime = dateTime instanceof Date && !isNaN(dateTime.getTime());
|
|
198
|
+
value = validDateTime
|
|
199
|
+
? this._datePipe.transform(dateTime, 'MM/dd/yyyy h:mm:ss a') || ''
|
|
200
|
+
: String(value);
|
|
201
|
+
break;
|
|
202
|
+
}
|
|
203
|
+
case TableColumnType.Link: {
|
|
204
|
+
value = String(value).replace(/(^\w+:|^)\/\//, '');
|
|
205
|
+
break;
|
|
206
|
+
}
|
|
207
|
+
case TableColumnType.Percentage: {
|
|
208
|
+
value = this._percentPipe.transform(Number(value) || 0) || '';
|
|
209
|
+
break;
|
|
210
|
+
}
|
|
211
|
+
case TableColumnType.Url: {
|
|
212
|
+
if (!/(http(s?)):\/\//i.test(String(value))) {
|
|
213
|
+
value = `https://${value}`;
|
|
214
|
+
}
|
|
215
|
+
break;
|
|
216
|
+
}
|
|
217
|
+
case TableColumnType.Text: {
|
|
218
|
+
if (Array.isArray(value)) {
|
|
219
|
+
value = value.join('; ');
|
|
220
|
+
}
|
|
221
|
+
if (!truncated) {
|
|
222
|
+
return value;
|
|
223
|
+
}
|
|
224
|
+
const truncateString = (string = '', maxLength = truncated) => string.length > maxLength
|
|
225
|
+
? `${string.substring(0, maxLength)}…`
|
|
226
|
+
: string;
|
|
227
|
+
!!truncated
|
|
228
|
+
? (value = truncateString(String(value), truncated))
|
|
229
|
+
: value;
|
|
230
|
+
break;
|
|
231
|
+
}
|
|
232
|
+
case TableColumnType.MultiSelect:
|
|
233
|
+
if (typeof value === 'string') {
|
|
234
|
+
value = value.split(';')?.map(v => v.trim()) || [];
|
|
235
|
+
}
|
|
236
|
+
return value;
|
|
237
|
+
}
|
|
238
|
+
return String(value);
|
|
239
|
+
}
|
|
240
|
+
getRawValue(columnIndex, currentRow) {
|
|
241
|
+
const { field } = this._getColumnDefByIndex(columnIndex);
|
|
242
|
+
if (!field) {
|
|
243
|
+
return '';
|
|
244
|
+
}
|
|
245
|
+
return currentRow[field] || '';
|
|
246
|
+
}
|
|
247
|
+
getCellColor(columnDefinition, item) {
|
|
248
|
+
return TableThemeHelper.getCellColor(columnDefinition, item);
|
|
249
|
+
}
|
|
250
|
+
getTheme(columnDefinition, item) {
|
|
251
|
+
return (TableThemeHelper.getTheme(columnDefinition, item) ||
|
|
252
|
+
ComponentTheme.Primary);
|
|
253
|
+
}
|
|
254
|
+
isSortedColumn(columnIndex) {
|
|
255
|
+
return columnIndex === this.sortColumnIndex;
|
|
256
|
+
}
|
|
257
|
+
isRowSelected(id) {
|
|
258
|
+
return this.selectedRowIds.includes(id);
|
|
259
|
+
}
|
|
260
|
+
handleSelectAll(event) {
|
|
261
|
+
if (!this.canSelectAllRows || !this.tableData) {
|
|
262
|
+
return;
|
|
263
|
+
}
|
|
264
|
+
if (event.checked) {
|
|
265
|
+
this._selectedRowIds = this.tableData?.map(row => row.id) || [];
|
|
266
|
+
}
|
|
267
|
+
else {
|
|
268
|
+
this._selectedRowIds = [];
|
|
269
|
+
}
|
|
270
|
+
this._selectedRowIds.sort();
|
|
271
|
+
this.allSelected = this.selectedRowIds.length >= this.tableData.length;
|
|
272
|
+
this.rowSelect.emit(this.selectedRowIds);
|
|
273
|
+
}
|
|
274
|
+
handleSort(columnIndex) {
|
|
275
|
+
if (columnIndex === this.sortColumnIndex) {
|
|
276
|
+
this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';
|
|
277
|
+
}
|
|
278
|
+
else {
|
|
279
|
+
this.sortColumnIndex = columnIndex;
|
|
280
|
+
this.sortDirection = 'asc';
|
|
281
|
+
}
|
|
282
|
+
const field = this._getColumnDefByIndex(columnIndex).field || '';
|
|
283
|
+
this.sortBy.emit({
|
|
284
|
+
columnIndex,
|
|
285
|
+
field,
|
|
286
|
+
direction: this.sortDirection
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
handleRowSelect(event, rowId) {
|
|
290
|
+
if (!this.canSelectRows) {
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
if (event.checked && !this._selectedRowIds.includes(rowId)) {
|
|
294
|
+
this._selectedRowIds.push(rowId);
|
|
295
|
+
}
|
|
296
|
+
else if (!event.checked && this._selectedRowIds.includes(rowId)) {
|
|
297
|
+
const idx = this._selectedRowIds.indexOf(rowId);
|
|
298
|
+
if (idx > -1) {
|
|
299
|
+
this._selectedRowIds.splice(idx, 1);
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
if (this._selectedRowIds.length) {
|
|
303
|
+
this._selectedRowIds.sort();
|
|
304
|
+
}
|
|
305
|
+
this.allSelected = this.selectedRowIds.length >= this.tableData.length;
|
|
306
|
+
this.rowSelect.emit(this.selectedRowIds);
|
|
307
|
+
}
|
|
308
|
+
handleCellValueChange(columnIndex, rowIndex, value) {
|
|
309
|
+
const { field, columnType } = this._getColumnDefByIndex(columnIndex);
|
|
310
|
+
let currentValue = value;
|
|
311
|
+
if (columnType !== TableColumnType.Boolean && !Array.isArray(value)) {
|
|
312
|
+
currentValue = isNaN(Number(value)) ? value : Number(value);
|
|
313
|
+
}
|
|
314
|
+
const item = this.tableData[rowIndex];
|
|
315
|
+
setNestedValue(item, String(field), currentValue);
|
|
316
|
+
this._inputChange.emit({
|
|
317
|
+
columnIndex,
|
|
318
|
+
item,
|
|
319
|
+
value: currentValue
|
|
320
|
+
});
|
|
321
|
+
this._changeDetectorRef.detectChanges();
|
|
322
|
+
}
|
|
323
|
+
handleLinkClick(columnIndex, item) {
|
|
324
|
+
this.linkClick.emit({
|
|
325
|
+
item,
|
|
326
|
+
columnIndex
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
handleActionClick(columnIndex, item, actionApiName) {
|
|
330
|
+
this.rowActionClick.emit({
|
|
331
|
+
item,
|
|
332
|
+
columnIndex,
|
|
333
|
+
actionApiName
|
|
334
|
+
});
|
|
335
|
+
}
|
|
336
|
+
columnDefIsActions(columnDef) {
|
|
337
|
+
return columnDef.columnType === TableColumnType.Actions;
|
|
338
|
+
}
|
|
339
|
+
_getColumnDefByIndex(columnIndex) {
|
|
340
|
+
return this.columnDefs[columnIndex];
|
|
341
|
+
}
|
|
342
|
+
_getValue(columnIndex, currentRow) {
|
|
343
|
+
try {
|
|
344
|
+
const { field, valueGetter } = this._getColumnDefByIndex(columnIndex);
|
|
345
|
+
const value = valueGetter
|
|
346
|
+
? valueGetter(currentRow)
|
|
347
|
+
: getNestedValue(currentRow, String(field), '');
|
|
348
|
+
return value || '';
|
|
349
|
+
}
|
|
350
|
+
catch (e) {
|
|
351
|
+
return '';
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableComponent, deps: [{ token: i1.DatePipe }, { token: i1.PercentPipe }, { token: i1.DecimalPipe }, { token: i0.ChangeDetectorRef }, { token: i2.BrandedDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
355
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.1", type: TableComponent, selector: "impdc-table", inputs: { loading: "loading", columnDefs: "columnDefs", striped: "striped", canSelectRows: "canSelectRows", canSelectAllRows: "canSelectAllRows", selectPlaceholder: "selectPlaceholder", sortColumnIndex: "sortColumnIndex", sortDirection: "sortDirection", tableData: "tableData", selectedRowIds: "selectedRowIds", customCellComponents: "customCellComponents" }, outputs: { rowSelect: "rowSelect", sortBy: "sortBy", linkClick: "linkClick", rowActionClick: "rowActionClick", inputChange: "inputChange" }, queries: [{ propertyName: "paginationComponent", first: true, predicate: PaginationComponent, descendants: true }, { propertyName: "bulkActions", first: true, predicate: TableBulkActionsComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (tableData) {\n<table impdcTable [striped]=\"striped\">\n <thead>\n @if (!!bulkActions) {\n <tr>\n <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n </th>\n </tr>\n }\n <tr>\n @if (canSelectRows) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'heading-below-bulk-actions': !!bulkActions\n }\">\n @if (canSelectAllRows) {\n <div>\n <impdc-checkbox\n ngModel\n [checked]=\"allSelected\"\n [indeterminate]=\"someSelected\"\n (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n </div>\n }\n </th>\n } @for (columnDef of columnDefs; track columnDef; let columnIndex =\n $index) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'sorted-column': isSortedColumn(columnIndex),\n 'sortable-column': columnDef.sorted,\n 'heading-below-bulk-actions': !!bulkActions\n }\"\n (click)=\"handleSort(columnIndex)\">\n <impdc-column-heading\n [isSortable]=\"columnDef.sorted || false\"\n [columnIndex]=\"columnIndex\"\n [sortColumnIndex]=\"sortColumnIndex\"\n [direction]=\"sortDirection\"\n [text]=\"columnDef.title\"\n (sort)=\"handleSort($event)\">\n </impdc-column-heading>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @if (loading) {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n <impdc-spinner></impdc-spinner>\n </td>\n </tr>\n } @else { @for (row of tableData; track row; let rowIndex = $index) {\n <tr>\n @if (canSelectRows) {\n <td>\n <div class=\"select-column\">\n <impdc-checkbox\n [ngModel]=\"isRowSelected(row.id)\"\n (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n </div>\n </td>\n }\n <td\n *ngFor=\"let columnDef of columnDefs; index as colIndex; last as isLast\"\n [ngClass]=\"{\n 'col-no-padding': !!columnDef.noPadding,\n 'actions-column': columnDef.columnType === cellType.Actions\n }\">\n <div>\n @switch (columnDef.columnType) { @case (cellType.Badge) {\n <span>\n <impdc-badge\n [text]=\"getStringValue(colIndex, row)\"\n [theme]=\"getTheme(columnDef, row)\">\n </impdc-badge>\n </span>\n } @case (cellType.Link) {\n <span (click)=\"handleLinkClick(colIndex, row)\">\n @if (!branded) {\n <a>\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded>\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Url) {\n <span>\n @if (!branded) {\n <a target=\"_blank\" [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a\n impdcBranded\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Email) {\n <span>\n @if (!branded) {\n <a\n target=\"_blank\"\n [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded [attr.href]=\"getMailToValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Input) {\n <span>\n <input\n impdcInput\n type=\"text\"\n class=\"{{ getCellColor(columnDef, row) }}\"\n [ngModel]=\"getValue(colIndex, row)\"\n (ngModelChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event)\n \" />\n </span>\n } @case (cellType.Boolean) {\n <span>\n @if (columnDef.disabled && getValue(colIndex, row) === 'true') {\n <span\n impdc-icon\n name=\"check\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n } @else if (!columnDef.disabled) {\n <impdc-checkbox\n [checked]=\"getValue(colIndex, row) === 'true'\"\n [isSwitch]=\"true\"\n (change)=\"\n handleCellValueChange(colIndex, rowIndex, $event.checked)\n \"></impdc-checkbox>\n }\n </span>\n } @case (cellType.SingleSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @if (selectPlaceholder) {\n <impdc-select-option value [label]=\"selectPlaceholder\">\n </impdc-select-option>\n } @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.MultiSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n multiple=\"true\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.CellRender) {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n <ng-template\n impdcTableInjectComponent\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [customCellComponents]=\"customCellComponents || {}\"\n [value]=\"getRawValue(colIndex, row)\"></ng-template>\n </span>\n } @case (cellType.Icon) {\n <span>\n <span\n impdc-icon\n [name]=\"columnDef.iconName\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n </span>\n } @case (cellType.Actions) {\n <span>\n <!-- will always return 'true', but needed to satisfy the type engine -->\n @if (columnDefIsActions(columnDef)) {\n <impdc-row-actions\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [lastColumn]=\"isLast\"\n (actionClick)=\"\n handleActionClick(colIndex, row, $event)\n \"></impdc-row-actions>\n }\n </span>\n } @default {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n {{ getValue(colIndex, row) }}\n </span>\n } }\n </div>\n </td>\n </tr>\n } @empty {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n <ng-content select=\"[noData]\"></ng-content>\n </td>\n </tr>\n } }\n </tbody>\n <tfoot>\n @if (paginationComponent) {\n <tr>\n <td [attr.colspan]=\"tableSpan\">\n <ng-content\n select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n </td>\n </tr>\n }\n </tfoot>\n</table>\n}\n", styles: [".bulk-action-container{display:flex;flex-direction:row;border:1px solid var(--impd-color-gray-200);border-top-left-radius:.6rem;border-top-right-radius:.6rem;border-bottom:0px}.bulk-action-container .bulk-action-checkbox{padding:1.6rem 2rem}.bulk-action-container .bulk-actions{display:flex;flex-direction:row;gap:.4rem}.col-no-padding{padding:0!important}.data-loading{height:var(--impd-size-80);vertical-align:middle;text-align:center}.no-data{vertical-align:middle;text-align:center}.select-row{display:flex;height:var(--impd-size-4);align-items:center;justify-items:end;border-radius:var(--impd-border-radius-default)}.heading-with-checkbox{padding-left:5px;padding-right:10px}.actions-column{width:.1%;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.BrandedDirective, selector: "[impdcBranded]" }, { kind: "component", type: i4.IconComponent, selector: "impdc-icon, [impdc-icon]", inputs: ["name", "theme", "size"] }, { kind: "component", type: i5.CheckboxComponent, selector: "impdc-checkbox", inputs: ["tabIndex", "id", "label", "description", "isSwitch", "switchIcons", "inline", "checked", "indeterminate", "disabled", "errorStateMatcher", "required"], outputs: ["change", "indeterminateChange"], exportAs: ["impdcCheckControl"] }, { kind: "component", type: i6.SelectOptionComponent, selector: "impdc-select-option", inputs: ["value", "label", "id", "disabled"], outputs: ["onSelectionChange"] }, { kind: "component", type: i7.SelectComponent, selector: "impdc-select", inputs: ["disabled", "tabIndex", "placeholder", "required", "multiple", "compareWith", "errorStateMatcher", "value", "id"], outputs: ["selectionChange", "valueChange"], exportAs: ["impdcSelect"] }, { kind: "directive", type: i8.InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }, { kind: "directive", type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i10.SpinnerComponent, selector: "impdc-spinner, div[impdc-spinner]", inputs: ["accessibilityText"] }, { kind: "component", type: i11.BadgeComponent, selector: "impdc-badge, [impdc-badge]", inputs: ["text", "icon", "theme", "size", "hideBg", "rounded", "dismissable"], outputs: ["dismiss"] }, { kind: "directive", type: i12.TableDirective, selector: "table[impdcTable]", inputs: ["striped"] }, { kind: "component", type: i13.ColumnHeadingComponent, selector: "impdc-column-heading", inputs: ["isSortable", "columnIndex", "sortColumnIndex", "direction", "text"], outputs: ["sort"] }, { kind: "directive", type: i14.TableInjectComponentDirective, selector: "[impdcTableInjectComponent]", inputs: ["columnDef", "value", "rowItem", "customCellComponents"] }, { kind: "component", type: i15.RowActionsComponent, selector: "impdc-row-actions", inputs: ["columnDef", "rowItem", "lastColumn"], outputs: ["actionClick"] }] }); }
|
|
356
|
+
}
|
|
357
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableComponent, decorators: [{
|
|
358
|
+
type: Component,
|
|
359
|
+
args: [{ selector: 'impdc-table', template: "@if (tableData) {\n<table impdcTable [striped]=\"striped\">\n <thead>\n @if (!!bulkActions) {\n <tr>\n <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n </th>\n </tr>\n }\n <tr>\n @if (canSelectRows) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'heading-below-bulk-actions': !!bulkActions\n }\">\n @if (canSelectAllRows) {\n <div>\n <impdc-checkbox\n ngModel\n [checked]=\"allSelected\"\n [indeterminate]=\"someSelected\"\n (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n </div>\n }\n </th>\n } @for (columnDef of columnDefs; track columnDef; let columnIndex =\n $index) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'sorted-column': isSortedColumn(columnIndex),\n 'sortable-column': columnDef.sorted,\n 'heading-below-bulk-actions': !!bulkActions\n }\"\n (click)=\"handleSort(columnIndex)\">\n <impdc-column-heading\n [isSortable]=\"columnDef.sorted || false\"\n [columnIndex]=\"columnIndex\"\n [sortColumnIndex]=\"sortColumnIndex\"\n [direction]=\"sortDirection\"\n [text]=\"columnDef.title\"\n (sort)=\"handleSort($event)\">\n </impdc-column-heading>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @if (loading) {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n <impdc-spinner></impdc-spinner>\n </td>\n </tr>\n } @else { @for (row of tableData; track row; let rowIndex = $index) {\n <tr>\n @if (canSelectRows) {\n <td>\n <div class=\"select-column\">\n <impdc-checkbox\n [ngModel]=\"isRowSelected(row.id)\"\n (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n </div>\n </td>\n }\n <td\n *ngFor=\"let columnDef of columnDefs; index as colIndex; last as isLast\"\n [ngClass]=\"{\n 'col-no-padding': !!columnDef.noPadding,\n 'actions-column': columnDef.columnType === cellType.Actions\n }\">\n <div>\n @switch (columnDef.columnType) { @case (cellType.Badge) {\n <span>\n <impdc-badge\n [text]=\"getStringValue(colIndex, row)\"\n [theme]=\"getTheme(columnDef, row)\">\n </impdc-badge>\n </span>\n } @case (cellType.Link) {\n <span (click)=\"handleLinkClick(colIndex, row)\">\n @if (!branded) {\n <a>\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded>\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Url) {\n <span>\n @if (!branded) {\n <a target=\"_blank\" [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a\n impdcBranded\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Email) {\n <span>\n @if (!branded) {\n <a\n target=\"_blank\"\n [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded [attr.href]=\"getMailToValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Input) {\n <span>\n <input\n impdcInput\n type=\"text\"\n class=\"{{ getCellColor(columnDef, row) }}\"\n [ngModel]=\"getValue(colIndex, row)\"\n (ngModelChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event)\n \" />\n </span>\n } @case (cellType.Boolean) {\n <span>\n @if (columnDef.disabled && getValue(colIndex, row) === 'true') {\n <span\n impdc-icon\n name=\"check\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n } @else if (!columnDef.disabled) {\n <impdc-checkbox\n [checked]=\"getValue(colIndex, row) === 'true'\"\n [isSwitch]=\"true\"\n (change)=\"\n handleCellValueChange(colIndex, rowIndex, $event.checked)\n \"></impdc-checkbox>\n }\n </span>\n } @case (cellType.SingleSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @if (selectPlaceholder) {\n <impdc-select-option value [label]=\"selectPlaceholder\">\n </impdc-select-option>\n } @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.MultiSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n multiple=\"true\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.CellRender) {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n <ng-template\n impdcTableInjectComponent\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [customCellComponents]=\"customCellComponents || {}\"\n [value]=\"getRawValue(colIndex, row)\"></ng-template>\n </span>\n } @case (cellType.Icon) {\n <span>\n <span\n impdc-icon\n [name]=\"columnDef.iconName\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n </span>\n } @case (cellType.Actions) {\n <span>\n <!-- will always return 'true', but needed to satisfy the type engine -->\n @if (columnDefIsActions(columnDef)) {\n <impdc-row-actions\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [lastColumn]=\"isLast\"\n (actionClick)=\"\n handleActionClick(colIndex, row, $event)\n \"></impdc-row-actions>\n }\n </span>\n } @default {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n {{ getValue(colIndex, row) }}\n </span>\n } }\n </div>\n </td>\n </tr>\n } @empty {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n <ng-content select=\"[noData]\"></ng-content>\n </td>\n </tr>\n } }\n </tbody>\n <tfoot>\n @if (paginationComponent) {\n <tr>\n <td [attr.colspan]=\"tableSpan\">\n <ng-content\n select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n </td>\n </tr>\n }\n </tfoot>\n</table>\n}\n", styles: [".bulk-action-container{display:flex;flex-direction:row;border:1px solid var(--impd-color-gray-200);border-top-left-radius:.6rem;border-top-right-radius:.6rem;border-bottom:0px}.bulk-action-container .bulk-action-checkbox{padding:1.6rem 2rem}.bulk-action-container .bulk-actions{display:flex;flex-direction:row;gap:.4rem}.col-no-padding{padding:0!important}.data-loading{height:var(--impd-size-80);vertical-align:middle;text-align:center}.no-data{vertical-align:middle;text-align:center}.select-row{display:flex;height:var(--impd-size-4);align-items:center;justify-items:end;border-radius:var(--impd-border-radius-default)}.heading-with-checkbox{padding-left:5px;padding-right:10px}.actions-column{width:.1%;white-space:nowrap}\n"] }]
|
|
360
|
+
}], ctorParameters: () => [{ type: i1.DatePipe }, { type: i1.PercentPipe }, { type: i1.DecimalPipe }, { type: i0.ChangeDetectorRef }, { type: i2.BrandedDirective, decorators: [{
|
|
361
|
+
type: Optional
|
|
362
|
+
}, {
|
|
363
|
+
type: Host
|
|
364
|
+
}] }], propDecorators: { loading: [{
|
|
365
|
+
type: Input
|
|
366
|
+
}], columnDefs: [{
|
|
367
|
+
type: Input
|
|
368
|
+
}], striped: [{
|
|
369
|
+
type: Input
|
|
370
|
+
}], canSelectRows: [{
|
|
371
|
+
type: Input
|
|
372
|
+
}], canSelectAllRows: [{
|
|
373
|
+
type: Input
|
|
374
|
+
}], selectPlaceholder: [{
|
|
375
|
+
type: Input
|
|
376
|
+
}], sortColumnIndex: [{
|
|
377
|
+
type: Input
|
|
378
|
+
}], sortDirection: [{
|
|
379
|
+
type: Input
|
|
380
|
+
}], tableData: [{
|
|
381
|
+
type: Input
|
|
382
|
+
}], selectedRowIds: [{
|
|
383
|
+
type: Input
|
|
384
|
+
}], customCellComponents: [{
|
|
385
|
+
type: Input
|
|
386
|
+
}], rowSelect: [{
|
|
387
|
+
type: Output
|
|
388
|
+
}], sortBy: [{
|
|
389
|
+
type: Output
|
|
390
|
+
}], linkClick: [{
|
|
391
|
+
type: Output
|
|
392
|
+
}], rowActionClick: [{
|
|
393
|
+
type: Output
|
|
394
|
+
}], paginationComponent: [{
|
|
395
|
+
type: ContentChild,
|
|
396
|
+
args: [PaginationComponent]
|
|
397
|
+
}], bulkActions: [{
|
|
398
|
+
type: ContentChild,
|
|
399
|
+
args: [TableBulkActionsComponent]
|
|
400
|
+
}], inputChange: [{
|
|
401
|
+
type: Output
|
|
402
|
+
}] } });
|
|
403
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-components/src/lib/table/containers/table.component.ts","../../../../../../../projects/design-components/src/lib/table/containers/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe, PercentPipe } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { get as getNestedValue, set as setNestedValue } from 'lodash';\nimport { debounceTime } from 'rxjs/operators';\n\nimport { DEBOUNCE_TIME, SORT_COLUMN_INDEX } from '../constants/index';\nimport { TableColumnType } from '../enumerations/index';\nimport {\n  ICustomCellRendererComponents,\n  ISortByPayload,\n  ITableActionsColumnDef,\n  ITableEventPayload,\n  ITableRowActionPayload,\n  ITableRowItem,\n  ITableRowItemValue,\n  ITableRowItemValueTypes,\n  TableColumnDef\n} from '../interfaces/index';\nimport { CheckboxChangeEvent } from '../../form-field';\nimport { TableThemeHelper } from '../helpers';\nimport { ComponentTheme } from '../../../types';\nimport { BrandedDirective } from '../../branding';\nimport { PaginationComponent } from '../../pagination';\nimport { TableBulkActionsComponent } from '../components';\n\n/**\n * The `TableComponent` (`<impdc-table`) is a data table component.\n * To use, import `TableModule` from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-table',\n  styleUrls: ['./table.component.scss'],\n  templateUrl: './table.component.html'\n})\nexport class TableComponent implements OnChanges {\n  /**\n   * Whether the table data is currently being loaded. The `<impdc-spinner>` will show if data is loading.\n   */\n  @Input() public loading = false;\n\n  /**\n   * The visible columns of the table.  Each `ITableColumnDef` defines properties regarding the display, formatting and interaction of the column's cells.\n   * Column/cell color precedence is:\n   * 1) `fieldColor` - allows an `ITableColumnDef` to delegate the responsibility of cell color to an `ITableRowItem` property.\n   * 2) `colorGetter`- allows an `ITableColumnDef` to delegate the responsibility of cell color to a function of the `ITableRowItem` determined by the developer.\n   * 3) `color` - a property of an `ITableColumnDef`.\n   */\n  @Input() public columnDefs: TableColumnDef[] = [];\n\n  /**\n   * Whether the table is striped.\n   */\n  @Input() public striped = true;\n\n  /**\n   * Whether individual rows can be selected. Will be `true` if explicitly set to `true` or `canSelectAllRows` is `true`.\n   */\n  @Input() public set canSelectRows(value: boolean) {\n    this._canSelectRows = value;\n  }\n  public get canSelectRows(): boolean {\n    return this.canSelectAllRows || this._canSelectRows || !!this.bulkActions;\n  }\n\n  /**\n   * Whether all rows can be selected at once. Will be `true` if explicitly set to `true` or if `TableBulkActionsComponent` is content projected.\n   */\n  @Input()\n  public set canSelectAllRows(value: boolean) {\n    this._canSelectAllRows = value;\n  }\n\n  public get canSelectAllRows(): boolean {\n    return this._canSelectAllRows || !!this.bulkActions;\n  }\n\n  /**\n   * The placeholder text and empty value display text for `<impdc-select>` instances in cells with a `ITableColumnDef` `columnType` = `SingleSelect` or `MultiSelect`.\n   */\n  @Input() public selectPlaceholder = '';\n\n  /**\n   * The `columnDefs` index of the currently sorted column.\n   */\n  @Input() public sortColumnIndex = SORT_COLUMN_INDEX;\n\n  /**\n   * The direction of the currently sorted column.\n   */\n  @Input() public sortDirection: 'asc' | 'desc' = 'asc';\n\n  /**\n   * The table row data as an array of `ITableRowItem`.\n   */\n  @Input() public tableData: ITableRowItem[] = [];\n\n  /**\n   * An array of currently selected IDs from the `tableData` input.  Array must be of type `(string | number)[]`.\n   */\n  @Input()\n  public set selectedRowIds(value: (string | number)[]) {\n    this._selectedRowIds = [...value];\n  }\n  public get selectedRowIds(): (string | number)[] {\n    return [...this._selectedRowIds];\n  }\n\n  /**\n   * The registered custom cell renderer components available to be used in the table instance.\n   * For a given `ITableColumnDef` in the `columnDefs` input, the `cellRendererComponent` property should be set to the key of the registered component in this input.\n   */\n  @Input() public customCellComponents?: ICustomCellRendererComponents;\n\n  /**\n   * Event emitted when one or multiple rows are selected. Emits `(string | number)[]` payload.\n   */\n  @Output() public readonly rowSelect = new EventEmitter<(string | number)[]>();\n\n  /**\n   * Event emitted when a column is sorted. Emits `ISortByPayload` payload.\n   */\n  @Output() public readonly sortBy = new EventEmitter<ISortByPayload>();\n\n  /**\n   * Event emitted when a row link is clicked. Emits `ITableEventPayload` payload.\n   */\n  @Output() public readonly linkClick = new EventEmitter<ITableEventPayload>();\n\n  /**\n   * Event emitted when a row action is clicked. Emits an `ITableRowActionPayload` payload.\n   */\n  @Output() public readonly rowActionClick =\n    new EventEmitter<ITableRowActionPayload>();\n\n  /** @ignore */\n  @ContentChild(PaginationComponent)\n  public paginationComponent?: PaginationComponent = undefined;\n\n  /** @ignore */\n  @ContentChild(TableBulkActionsComponent)\n  public bulkActions?: TableBulkActionsComponent = undefined;\n\n  /**\n   * Event emitted when a row input value is changed. Emitted cells of `columnType` `SinglSelect`, `MultiSelect`, `Input`, `Boolean` or `Icon`.\n   * Not emitted if column definition property `disabled` = `true`. Emits `ITableEventPayload` payload.\n   */\n  @Output() public readonly inputChange =\n    new EventEmitter<ITableEventPayload>();\n\n  /** @ignore */\n  public readonly cellType = TableColumnType;\n  /** @ignore */\n  public allSelected = true;\n  /** @ignore */\n  public get someSelected(): boolean {\n    return (\n      !!this._selectedRowIds &&\n      this._selectedRowIds.length > 0 &&\n      !!this.tableData &&\n      this.tableData.length > 0 &&\n      this._selectedRowIds.length < this.tableData.length\n    );\n  }\n  /** @ignore */\n  public readonly branded: boolean = false;\n\n  /** @ignore */\n  public get tableSpan(): number {\n    return this.canSelectRows\n      ? this.columnDefs.length + 1\n      : this.columnDefs.length;\n  }\n\n  private _canSelectRows = false;\n  private _canSelectAllRows = false;\n  private _selectedRowIds: (string | number)[] = [];\n  private readonly _inputChange = new EventEmitter<ITableEventPayload>();\n\n  constructor(\n    private readonly _datePipe: DatePipe,\n    private readonly _percentPipe: PercentPipe,\n    private readonly _decmialPipe: DecimalPipe,\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Host() private _branded: BrandedDirective\n  ) {\n    this.branded = _branded ? true : false;\n    this._inputChange\n      .pipe(debounceTime(DEBOUNCE_TIME))\n      .subscribe(this.inputChange);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['selectedRowIds'] || changes['tableData']) {\n      if (\n        !this.tableData ||\n        !this.tableData.length ||\n        !this.selectedRowIds ||\n        !this.selectedRowIds.length\n      ) {\n        this.allSelected = false;\n      } else {\n        this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n      }\n    }\n  }\n\n  public getMailToValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string {\n    const { columnType, truncated: truncated } =\n      this._getColumnDefByIndex(columnIndex);\n    let value = this._getValue(columnIndex, currentRow);\n\n    if (columnType !== TableColumnType.Email) {\n      return String(value);\n    }\n    value = value ? `mailto:${value}` : value;\n\n    return String(value);\n  }\n\n  public getStringValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string {\n    const value = this.getValue(columnIndex, currentRow);\n\n    if (Array.isArray(value)) {\n      return value.join(';');\n    }\n\n    return String(value);\n  }\n\n  public getValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string | string[] {\n    const { columnType, truncated: truncated } =\n      this._getColumnDefByIndex(columnIndex);\n    let value = this._getValue(columnIndex, currentRow);\n\n    switch (columnType) {\n      case TableColumnType.Decimal: {\n        value = this._decmialPipe.transform(Number(value) || 0) || '';\n        break;\n      }\n      case TableColumnType.Date: {\n        const date = new Date(String(value));\n        const validDate = date instanceof Date && !isNaN(date.getTime());\n        value = validDate\n          ? this._datePipe.transform(date, 'MM/dd/yyyy') || ''\n          : String(value);\n        break;\n      }\n      case TableColumnType.DateTime: {\n        const dateTime = new Date(String(value));\n        const validDateTime =\n          dateTime instanceof Date && !isNaN(dateTime.getTime());\n        value = validDateTime\n          ? this._datePipe.transform(dateTime, 'MM/dd/yyyy h:mm:ss a') || ''\n          : String(value);\n        break;\n      }\n      case TableColumnType.Link: {\n        value = String(value).replace(/(^\\w+:|^)\\/\\//, '');\n        break;\n      }\n      case TableColumnType.Percentage: {\n        value = this._percentPipe.transform(Number(value) || 0) || '';\n        break;\n      }\n      case TableColumnType.Url: {\n        if (!/(http(s?)):\\/\\//i.test(String(value))) {\n          value = `https://${value}`;\n        }\n        break;\n      }\n      case TableColumnType.Text: {\n        if (Array.isArray(value)) {\n          value = value.join('; ');\n        }\n\n        if (!truncated) {\n          return value;\n        }\n\n        const truncateString = (string = '', maxLength = truncated) =>\n          string.length > maxLength\n            ? `${string.substring(0, maxLength)}…`\n            : string;\n\n        !!truncated\n          ? (value = truncateString(String(value), truncated))\n          : value;\n        break;\n      }\n      case TableColumnType.MultiSelect:\n        if (typeof value === 'string') {\n          value = value.split(';')?.map(v => v.trim()) || [];\n        }\n        return value;\n    }\n\n    return String(value);\n  }\n\n  public getRawValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): ITableRowItemValueTypes<ITableRowItemValue> {\n    const { field } = this._getColumnDefByIndex(columnIndex);\n\n    if (!field) {\n      return '';\n    }\n\n    return currentRow[field] || '';\n  }\n\n  public getCellColor(\n    columnDefinition: TableColumnDef,\n    item: ITableRowItem\n  ): string {\n    return TableThemeHelper.getCellColor(columnDefinition, item);\n  }\n\n  public getTheme(\n    columnDefinition: TableColumnDef,\n    item: ITableRowItem\n  ): ComponentTheme {\n    return (\n      TableThemeHelper.getTheme(columnDefinition, item) ||\n      ComponentTheme.Primary\n    );\n  }\n\n  public isSortedColumn(columnIndex: number): boolean {\n    return columnIndex === this.sortColumnIndex;\n  }\n\n  public isRowSelected(id: string | number): boolean {\n    return this.selectedRowIds.includes(id);\n  }\n\n  public handleSelectAll(event: CheckboxChangeEvent): void {\n    if (!this.canSelectAllRows || !this.tableData) {\n      return;\n    }\n\n    if (event.checked) {\n      this._selectedRowIds = this.tableData?.map(row => row.id) || [];\n    } else {\n      this._selectedRowIds = [];\n    }\n\n    this._selectedRowIds.sort();\n    this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n\n    this.rowSelect.emit(this.selectedRowIds);\n  }\n\n  public handleSort(columnIndex: number): void {\n    if (columnIndex === this.sortColumnIndex) {\n      this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';\n    } else {\n      this.sortColumnIndex = columnIndex;\n      this.sortDirection = 'asc';\n    }\n\n    const field = this._getColumnDefByIndex(columnIndex).field || '';\n\n    this.sortBy.emit({\n      columnIndex,\n      field,\n      direction: this.sortDirection\n    });\n  }\n\n  public handleRowSelect(\n    event: CheckboxChangeEvent,\n    rowId: number | string\n  ): void {\n    if (!this.canSelectRows) {\n      return;\n    }\n\n    if (event.checked && !this._selectedRowIds.includes(rowId)) {\n      this._selectedRowIds.push(rowId);\n    } else if (!event.checked && this._selectedRowIds.includes(rowId)) {\n      const idx = this._selectedRowIds.indexOf(rowId);\n      if (idx > -1) {\n        this._selectedRowIds.splice(idx, 1);\n      }\n    }\n\n    if (this._selectedRowIds.length) {\n      this._selectedRowIds.sort();\n    }\n\n    this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n    this.rowSelect.emit(this.selectedRowIds);\n  }\n\n  public handleCellValueChange(\n    columnIndex: number,\n    rowIndex: number,\n    value: string | number | boolean | string[]\n  ): void {\n    const { field, columnType } = this._getColumnDefByIndex(columnIndex);\n    let currentValue: string | number | boolean | string[] = value;\n\n    if (columnType !== TableColumnType.Boolean && !Array.isArray(value)) {\n      currentValue = isNaN(Number(value)) ? value : Number(value);\n    }\n    const item = this.tableData[rowIndex];\n\n    setNestedValue(item, String(field), currentValue);\n\n    this._inputChange.emit({\n      columnIndex,\n      item,\n      value: currentValue\n    });\n\n    this._changeDetectorRef.detectChanges();\n  }\n\n  public handleLinkClick(columnIndex: number, item: ITableRowItem): void {\n    this.linkClick.emit({\n      item,\n      columnIndex\n    });\n  }\n\n  public handleActionClick(\n    columnIndex: number,\n    item: ITableRowItem,\n    actionApiName: string\n  ) {\n    this.rowActionClick.emit({\n      item,\n      columnIndex,\n      actionApiName\n    });\n  }\n\n  protected columnDefIsActions(\n    columnDef: TableColumnDef<any>\n  ): columnDef is ITableActionsColumnDef<any> {\n    return columnDef.columnType === TableColumnType.Actions;\n  }\n\n  private _getColumnDefByIndex(columnIndex: number): TableColumnDef {\n    return this.columnDefs[columnIndex];\n  }\n\n  private _getValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string | string[] {\n    try {\n      const { field, valueGetter } = this._getColumnDefByIndex(columnIndex);\n\n      const value: string | string[] = valueGetter\n        ? valueGetter(currentRow)\n        : (getNestedValue(currentRow, String(field), '') as string | string[]);\n\n      return value || '';\n    } catch (e) {\n      return '';\n    }\n  }\n}\n","@if (tableData) {\n<table impdcTable [striped]=\"striped\">\n  <thead>\n    @if (!!bulkActions) {\n    <tr>\n      <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n        <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n        <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n      </th>\n    </tr>\n    }\n    <tr>\n      @if (canSelectRows) {\n      <th\n        scope=\"col\"\n        [ngClass]=\"{\n          'heading-below-bulk-actions': !!bulkActions\n        }\">\n        @if (canSelectAllRows) {\n        <div>\n          <impdc-checkbox\n            ngModel\n            [checked]=\"allSelected\"\n            [indeterminate]=\"someSelected\"\n            (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n        </div>\n        }\n      </th>\n      } @for (columnDef of columnDefs; track columnDef; let columnIndex =\n      $index) {\n      <th\n        scope=\"col\"\n        [ngClass]=\"{\n          'sorted-column': isSortedColumn(columnIndex),\n          'sortable-column': columnDef.sorted,\n          'heading-below-bulk-actions': !!bulkActions\n        }\"\n        (click)=\"handleSort(columnIndex)\">\n        <impdc-column-heading\n          [isSortable]=\"columnDef.sorted || false\"\n          [columnIndex]=\"columnIndex\"\n          [sortColumnIndex]=\"sortColumnIndex\"\n          [direction]=\"sortDirection\"\n          [text]=\"columnDef.title\"\n          (sort)=\"handleSort($event)\">\n        </impdc-column-heading>\n      </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    @if (loading) {\n    <tr>\n      <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n        <impdc-spinner></impdc-spinner>\n      </td>\n    </tr>\n    } @else { @for (row of tableData; track row; let rowIndex = $index) {\n    <tr>\n      @if (canSelectRows) {\n      <td>\n        <div class=\"select-column\">\n          <impdc-checkbox\n            [ngModel]=\"isRowSelected(row.id)\"\n            (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n        </div>\n      </td>\n      }\n      <td\n        *ngFor=\"let columnDef of columnDefs; index as colIndex; last as isLast\"\n        [ngClass]=\"{\n          'col-no-padding': !!columnDef.noPadding,\n          'actions-column': columnDef.columnType === cellType.Actions\n        }\">\n        <div>\n          @switch (columnDef.columnType) { @case (cellType.Badge) {\n          <span>\n            <impdc-badge\n              [text]=\"getStringValue(colIndex, row)\"\n              [theme]=\"getTheme(columnDef, row)\">\n            </impdc-badge>\n          </span>\n          } @case (cellType.Link) {\n          <span (click)=\"handleLinkClick(colIndex, row)\">\n            @if (!branded) {\n            <a>\n              {{ getValue(colIndex, row) }}\n            </a>\n            } @else {\n            <a impdcBranded>\n              {{ getValue(colIndex, row) }}\n            </a>\n            }\n          </span>\n          } @case (cellType.Url) {\n          <span>\n            @if (!branded) {\n            <a target=\"_blank\" [attr.href]=\"getValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            } @else {\n            <a\n              impdcBranded\n              target=\"_blank\"\n              [attr.href]=\"getValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            }\n          </span>\n          } @case (cellType.Email) {\n          <span>\n            @if (!branded) {\n            <a\n              target=\"_blank\"\n              [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            } @else {\n            <a impdcBranded [attr.href]=\"getMailToValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            }\n          </span>\n          } @case (cellType.Input) {\n          <span>\n            <input\n              impdcInput\n              type=\"text\"\n              class=\"{{ getCellColor(columnDef, row) }}\"\n              [ngModel]=\"getValue(colIndex, row)\"\n              (ngModelChange)=\"\n                handleCellValueChange(colIndex, rowIndex, $event)\n              \" />\n          </span>\n          } @case (cellType.Boolean) {\n          <span>\n            @if (columnDef.disabled && getValue(colIndex, row) === 'true') {\n            <span\n              impdc-icon\n              name=\"check\"\n              class=\"{{ getCellColor(columnDef, row) }}\"></span>\n            } @else if (!columnDef.disabled) {\n            <impdc-checkbox\n              [checked]=\"getValue(colIndex, row) === 'true'\"\n              [isSwitch]=\"true\"\n              (change)=\"\n                handleCellValueChange(colIndex, rowIndex, $event.checked)\n              \"></impdc-checkbox>\n            }\n          </span>\n          } @case (cellType.SingleSelect) {\n          <span>\n            <impdc-select\n              [ngModel]=\"getValue(colIndex, row)\"\n              [disabled]=\"columnDef.disabled || false\"\n              [placeholder]=\"selectPlaceholder\"\n              (selectionChange)=\"\n                handleCellValueChange(colIndex, rowIndex, $event.value)\n              \">\n              @if (selectPlaceholder) {\n              <impdc-select-option value [label]=\"selectPlaceholder\">\n              </impdc-select-option>\n              } @for (value of (columnDef.values || []); track value) {\n              <impdc-select-option\n                [value]=\"value.value\"\n                [label]=\"value.label\"></impdc-select-option>\n              }\n            </impdc-select>\n          </span>\n          } @case (cellType.MultiSelect) {\n          <span>\n            <impdc-select\n              [ngModel]=\"getValue(colIndex, row)\"\n              [disabled]=\"columnDef.disabled || false\"\n              [placeholder]=\"selectPlaceholder\"\n              multiple=\"true\"\n              (selectionChange)=\"\n                handleCellValueChange(colIndex, rowIndex, $event.value)\n              \">\n              @for (value of (columnDef.values || []); track value) {\n              <impdc-select-option\n                [value]=\"value.value\"\n                [label]=\"value.label\"></impdc-select-option>\n              }\n            </impdc-select>\n          </span>\n          } @case (cellType.CellRender) {\n          <span class=\"{{ getCellColor(columnDef, row) }}\">\n            <ng-template\n              impdcTableInjectComponent\n              [columnDef]=\"columnDef\"\n              [rowItem]=\"row\"\n              [customCellComponents]=\"customCellComponents || {}\"\n              [value]=\"getRawValue(colIndex, row)\"></ng-template>\n          </span>\n          } @case (cellType.Icon) {\n          <span>\n            <span\n              impdc-icon\n              [name]=\"columnDef.iconName\"\n              class=\"{{ getCellColor(columnDef, row) }}\"></span>\n          </span>\n          } @case (cellType.Actions) {\n          <span>\n            <!-- will always return 'true', but needed to satisfy the type engine -->\n            @if (columnDefIsActions(columnDef)) {\n            <impdc-row-actions\n              [columnDef]=\"columnDef\"\n              [rowItem]=\"row\"\n              [lastColumn]=\"isLast\"\n              (actionClick)=\"\n                handleActionClick(colIndex, row, $event)\n              \"></impdc-row-actions>\n            }\n          </span>\n          } @default {\n          <span class=\"{{ getCellColor(columnDef, row) }}\">\n            {{ getValue(colIndex, row) }}\n          </span>\n          } }\n        </div>\n      </td>\n    </tr>\n    } @empty {\n    <tr>\n      <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n        <ng-content select=\"[noData]\"></ng-content>\n      </td>\n    </tr>\n    } }\n  </tbody>\n  <tfoot>\n    @if (paginationComponent) {\n    <tr>\n      <td [attr.colspan]=\"tableSpan\">\n        <ng-content\n          select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n      </td>\n    </tr>\n    }\n  </tfoot>\n</table>\n}\n"]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TableInjectComponentDirective {
|
|
4
|
+
constructor(_viewContainerRef, _componentFactoryResolver) {
|
|
5
|
+
this._viewContainerRef = _viewContainerRef;
|
|
6
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
|
7
|
+
this.value = '';
|
|
8
|
+
this.rowItem = { id: 0 };
|
|
9
|
+
this.customCellComponents = {};
|
|
10
|
+
}
|
|
11
|
+
ngOnInit() {
|
|
12
|
+
this._renderCustomCell();
|
|
13
|
+
}
|
|
14
|
+
_renderCustomCell() {
|
|
15
|
+
const { cellRendererComponent, cellRendererParams } = this.columnDef;
|
|
16
|
+
if (!cellRendererComponent) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const item = this.rowItem;
|
|
20
|
+
const customCellComponent = this.customCellComponents[cellRendererComponent];
|
|
21
|
+
this._viewContainerRef.clear();
|
|
22
|
+
const componentFactory = this._componentFactoryResolver.resolveComponentFactory(customCellComponent);
|
|
23
|
+
const componentRef = this._viewContainerRef.createComponent(componentFactory);
|
|
24
|
+
componentRef.instance.value = this.value;
|
|
25
|
+
componentRef.instance.rowItem = item;
|
|
26
|
+
componentRef.instance.params = cellRendererParams;
|
|
27
|
+
}
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableInjectComponentDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
29
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: TableInjectComponentDirective, selector: "[impdcTableInjectComponent]", inputs: { columnDef: "columnDef", value: "value", rowItem: "rowItem", customCellComponents: "customCellComponents" }, ngImport: i0 }); }
|
|
30
|
+
}
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableInjectComponentDirective, decorators: [{
|
|
32
|
+
type: Directive,
|
|
33
|
+
args: [{
|
|
34
|
+
selector: '[impdcTableInjectComponent]'
|
|
35
|
+
}]
|
|
36
|
+
}], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: { columnDef: [{
|
|
37
|
+
type: Input,
|
|
38
|
+
args: [{ required: true }]
|
|
39
|
+
}], value: [{
|
|
40
|
+
type: Input
|
|
41
|
+
}], rowItem: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], customCellComponents: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}] } });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtaW5qZWN0LWNvbXBvbmVudC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3RhYmxlL2RpcmVjdGl2ZXMvdGFibGUtaW5qZWN0LWNvbXBvbmVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFDVCxLQUFLLEVBR04sTUFBTSxlQUFlLENBQUM7O0FBY3ZCLE1BQU0sT0FBTyw2QkFBNkI7SUFNeEMsWUFDbUIsaUJBQW1DLEVBQ25DLHlCQUFtRDtRQURuRCxzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO1FBQ25DLDhCQUF5QixHQUF6Qix5QkFBeUIsQ0FBMEI7UUFOdEQsVUFBSyxHQUFnRCxFQUFFLENBQUM7UUFDeEQsWUFBTyxHQUFrQixFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUNuQyx5QkFBb0IsR0FBa0MsRUFBRSxDQUFDO0lBS3RFLENBQUM7SUFFRyxRQUFRO1FBQ2IsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVPLGlCQUFpQjtRQUN2QixNQUFNLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ3JFLElBQUksQ0FBQyxxQkFBcUIsRUFBRTtZQUMxQixPQUFPO1NBQ1I7UUFFRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO1FBQzFCLE1BQU0sbUJBQW1CLEdBQ3ZCLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBRW5ELElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUUvQixNQUFNLGdCQUFnQixHQUNwQixJQUFJLENBQUMseUJBQXlCLENBQUMsdUJBQXVCLENBQ3BELG1CQUFtQixDQUNwQixDQUFDO1FBQ0osTUFBTSxZQUFZLEdBQ2hCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLENBQWdCLGdCQUFnQixDQUFDLENBQUM7UUFFMUUsWUFBWSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUN6QyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDckMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsa0JBQWtCLENBQUM7SUFDcEQsQ0FBQzs4R0FyQ1UsNkJBQTZCO2tHQUE3Qiw2QkFBNkI7OzJGQUE3Qiw2QkFBNkI7a0JBSHpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDZCQUE2QjtpQkFDeEM7NEhBRW1DLFNBQVM7c0JBQTFDLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUNULEtBQUs7c0JBQXBCLEtBQUs7Z0JBQ1UsT0FBTztzQkFBdEIsS0FBSztnQkFDVSxvQkFBb0I7c0JBQW5DLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgSUNlbGxSZW5kZXJlcixcbiAgSUN1c3RvbUNlbGxSZW5kZXJlckNvbXBvbmVudHMsXG4gIElUYWJsZVJvd0l0ZW0sXG4gIElUYWJsZVJvd0l0ZW1WYWx1ZSxcbiAgSVRhYmxlUm93SXRlbVZhbHVlVHlwZXMsXG4gIFRhYmxlQ29sdW1uRGVmXG59IGZyb20gJy4uL2ludGVyZmFjZXMvaW5kZXgnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbaW1wZGNUYWJsZUluamVjdENvbXBvbmVudF0nXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlSW5qZWN0Q29tcG9uZW50RGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgcHVibGljIGNvbHVtbkRlZiE6IFRhYmxlQ29sdW1uRGVmO1xuICBASW5wdXQoKSBwdWJsaWMgdmFsdWU6IElUYWJsZVJvd0l0ZW1WYWx1ZVR5cGVzPElUYWJsZVJvd0l0ZW1WYWx1ZT4gPSAnJztcbiAgQElucHV0KCkgcHVibGljIHJvd0l0ZW06IElUYWJsZVJvd0l0ZW0gPSB7IGlkOiAwIH07XG4gIEBJbnB1dCgpIHB1YmxpYyBjdXN0b21DZWxsQ29tcG9uZW50czogSUN1c3RvbUNlbGxSZW5kZXJlckNvbXBvbmVudHMgPSB7fTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IF92aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyXG4gICkge31cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fcmVuZGVyQ3VzdG9tQ2VsbCgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfcmVuZGVyQ3VzdG9tQ2VsbCgpOiB2b2lkIHtcbiAgICBjb25zdCB7IGNlbGxSZW5kZXJlckNvbXBvbmVudCwgY2VsbFJlbmRlcmVyUGFyYW1zIH0gPSB0aGlzLmNvbHVtbkRlZjtcbiAgICBpZiAoIWNlbGxSZW5kZXJlckNvbXBvbmVudCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGl0ZW0gPSB0aGlzLnJvd0l0ZW07XG4gICAgY29uc3QgY3VzdG9tQ2VsbENvbXBvbmVudCA9XG4gICAgICB0aGlzLmN1c3RvbUNlbGxDb21wb25lbnRzW2NlbGxSZW5kZXJlckNvbXBvbmVudF07XG5cbiAgICB0aGlzLl92aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG5cbiAgICBjb25zdCBjb21wb25lbnRGYWN0b3J5ID1cbiAgICAgIHRoaXMuX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeTxJQ2VsbFJlbmRlcmVyPihcbiAgICAgICAgY3VzdG9tQ2VsbENvbXBvbmVudFxuICAgICAgKTtcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPVxuICAgICAgdGhpcy5fdmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQ8SUNlbGxSZW5kZXJlcj4oY29tcG9uZW50RmFjdG9yeSk7XG5cbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UudmFsdWUgPSB0aGlzLnZhbHVlO1xuICAgIGNvbXBvbmVudFJlZi5pbnN0YW5jZS5yb3dJdGVtID0gaXRlbTtcbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UucGFyYW1zID0gY2VsbFJlbmRlcmVyUGFyYW1zO1xuICB9XG59XG4iXX0=
|
|
@@ -15,10 +15,10 @@ export class TableDirective {
|
|
|
15
15
|
get classTableStriped() {
|
|
16
16
|
return this.striped;
|
|
17
17
|
}
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
19
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: TableDirective, selector: "table[impdcTable]", inputs: { striped: "striped" }, host: { properties: { "class.table": "this.classTable", "class.table-striped": "this.classTableStriped" } }, ngImport: i0 }); }
|
|
18
20
|
}
|
|
19
|
-
|
|
20
|
-
TableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TableDirective, selector: "table[impdcTable]", inputs: { striped: "striped" }, host: { properties: { "class.table": "this.classTable", "class.table-striped": "this.classTableStriped" } }, ngImport: i0 });
|
|
21
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableDirective, decorators: [{
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableDirective, decorators: [{
|
|
22
22
|
type: Directive,
|
|
23
23
|
args: [{
|
|
24
24
|
selector: 'table[impdcTable]'
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
32
32
|
type: HostBinding,
|
|
33
33
|
args: ['class.table-striped']
|
|
34
34
|
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi90YWJsZS9kaXJlY3RpdmVzL3RhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTlEOzs7R0FHRztBQUlILE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBSUU7O1dBRUc7UUFFSCxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRW9CLGVBQVUsR0FBRyxJQUFJLENBQUM7S0FLdkQ7SUFIQyxJQUFnRCxpQkFBaUI7UUFDL0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7OEdBWFUsY0FBYztrR0FBZCxjQUFjOzsyRkFBZCxjQUFjO2tCQUgxQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCOzhCQU1DLE9BQU87c0JBRE4sS0FBSztnQkFHOEIsVUFBVTtzQkFBN0MsV0FBVzt1QkFBQyxhQUFhO2dCQUVzQixpQkFBaUI7c0JBQWhFLFdBQVc7dUJBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBUaGUgYFRhYmxlRGlyZWN0aXZlYCAoYDx0YWJsZSBpbXBkY1RhYmxlYCkgdGhhdCBhZGRzIEhleCBzdHlsaW5nIHRvIGEgYHRhYmxlYCBlbGVtZW50LlxuICogVG8gdXNlLCBpbXBvcnQgYFRhYmxlTW9kdWxlYCBvciBhbm90aGVyIG1vZHVsZSB0aGF0IGltcG9ydHMgYW5kIGV4cG9ydHMgdGhhdCBtb2R1bGUgZnJvbSBgQGltcGFydG5lci9kZXNpZ24tY29tcG9uZW50c2AuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RhYmxlW2ltcGRjVGFibGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBUYWJsZURpcmVjdGl2ZSB7XG4gIC8qKlxuICAgKiBTdHJpcGVzIGV2ZXJ5IG90aGVyIHJvdyBpbiBhIHNsaWdodGx5IGRhcmtlciBiYWNrZ3JvdW5kIGNvbG9yLlxuICAgKi9cbiAgQElucHV0KClcbiAgc3RyaXBlZCA9IGZhbHNlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUnKSBwcml2YXRlIGNsYXNzVGFibGUgPSB0cnVlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUtc3RyaXBlZCcpIHByaXZhdGUgZ2V0IGNsYXNzVGFibGVTdHJpcGVkKCkge1xuICAgIHJldHVybiB0aGlzLnN0cmlwZWQ7XG4gIH1cbn1cbiJdfQ==
|