@impartner/design-components 1.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/LICENSE.txt +11 -0
- package/README.md +22 -0
- package/constants/fontawesome-icons.d.ts +6 -0
- package/constants/index.d.ts +1 -0
- package/esm2020/constants/fontawesome-icons.mjs +3012 -0
- package/esm2020/constants/index.mjs +2 -0
- package/esm2020/impartner-design-components.mjs +5 -0
- package/esm2020/lib/alert/alert.component.mjs +57 -0
- package/esm2020/lib/alert/alert.module.mjs +18 -0
- package/esm2020/lib/alert/index.mjs +4 -0
- package/esm2020/lib/alert/theme/alert-theme.mjs +2 -0
- package/esm2020/lib/alert/theme/index.mjs +2 -0
- package/esm2020/lib/avatar/avatar.component.mjs +47 -0
- package/esm2020/lib/avatar/avatar.module.mjs +18 -0
- package/esm2020/lib/avatar/index.mjs +3 -0
- package/esm2020/lib/avatar-group/avatar-group.component.mjs +16 -0
- package/esm2020/lib/avatar-group/avatar-group.module.mjs +19 -0
- package/esm2020/lib/avatar-group/index.mjs +3 -0
- package/esm2020/lib/backdrop/backdrop.component.mjs +34 -0
- package/esm2020/lib/backdrop/backdrop.module.mjs +19 -0
- package/esm2020/lib/backdrop/index.mjs +3 -0
- package/esm2020/lib/badge/badge.component.mjs +98 -0
- package/esm2020/lib/badge/badge.module.mjs +19 -0
- package/esm2020/lib/badge/index.mjs +4 -0
- package/esm2020/lib/badge/types/badge-icon.mjs +2 -0
- package/esm2020/lib/badge/types/badge-size.mjs +7 -0
- package/esm2020/lib/badge/types/index.mjs +2 -0
- package/esm2020/lib/branding/branded.directive.mjs +19 -0
- package/esm2020/lib/branding/branding.module.mjs +19 -0
- package/esm2020/lib/branding/index.mjs +3 -0
- package/esm2020/lib/breadcrumb/breadcrumb-item.component.mjs +25 -0
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +33 -0
- package/esm2020/lib/breadcrumb/breadcrumb.module.mjs +19 -0
- package/esm2020/lib/breadcrumb/index.mjs +4 -0
- package/esm2020/lib/button/button.component.mjs +116 -0
- package/esm2020/lib/button/button.module.mjs +21 -0
- package/esm2020/lib/button/index.mjs +4 -0
- package/esm2020/lib/button/themes/button-theme.mjs +2 -0
- package/esm2020/lib/button/themes/index.mjs +2 -0
- package/esm2020/lib/button-group/button-group.component.mjs +52 -0
- package/esm2020/lib/button-group/button-group.module.mjs +20 -0
- package/esm2020/lib/button-group/index.mjs +3 -0
- package/esm2020/lib/card-heading/card-heading.component.mjs +30 -0
- package/esm2020/lib/card-heading/card-heading.module.mjs +19 -0
- package/esm2020/lib/card-heading/index.mjs +3 -0
- package/esm2020/lib/design-components.module.mjs +119 -0
- package/esm2020/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +22 -0
- package/esm2020/lib/dropdown/components/index.mjs +2 -0
- package/esm2020/lib/dropdown/dropdown.component.mjs +140 -0
- package/esm2020/lib/dropdown/dropdown.module.mjs +21 -0
- package/esm2020/lib/dropdown/index.mjs +5 -0
- package/esm2020/lib/dropdown/types/dropdown-position.mjs +2 -0
- package/esm2020/lib/dropdown/types/index.mjs +2 -0
- package/esm2020/lib/file-upload/directives/file-drop.directive.mjs +50 -0
- package/esm2020/lib/file-upload/directives/index.mjs +2 -0
- package/esm2020/lib/file-upload/file-upload.component.mjs +334 -0
- package/esm2020/lib/file-upload/file-upload.module.mjs +29 -0
- package/esm2020/lib/file-upload/index.mjs +5 -0
- package/esm2020/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +23 -0
- package/esm2020/lib/file-upload/pipes/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/checkbox/checkbox.component.mjs +337 -0
- package/esm2020/lib/form-field/controls/checkbox/checkbox.module.mjs +19 -0
- package/esm2020/lib/form-field/controls/checkbox/index.mjs +3 -0
- package/esm2020/lib/form-field/controls/index.mjs +5 -0
- package/esm2020/lib/form-field/controls/input/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/input/input.directive.mjs +233 -0
- package/esm2020/lib/form-field/controls/radio/index.mjs +6 -0
- package/esm2020/lib/form-field/controls/radio/injection-tokens.mjs +4 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/index.mjs +4 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +2 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +11 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +2 -0
- package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
- package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +288 -0
- package/esm2020/lib/form-field/controls/radio/radio.module.mjs +20 -0
- package/esm2020/lib/form-field/controls/select/index.mjs +6 -0
- package/esm2020/lib/form-field/controls/select/option/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +138 -0
- package/esm2020/lib/form-field/controls/select/option-parent.mjs +3 -0
- package/esm2020/lib/form-field/controls/select/select-model.mjs +149 -0
- package/esm2020/lib/form-field/controls/select/select.component.mjs +522 -0
- package/esm2020/lib/form-field/controls/select/select.module.mjs +20 -0
- package/esm2020/lib/form-field/controls/shared/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/shared/toggle/components/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +17 -0
- package/esm2020/lib/form-field/controls/shared/toggle/index.mjs +4 -0
- package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
- package/esm2020/lib/form-field/controls/shared/toggle/toggle.module.mjs +20 -0
- package/esm2020/lib/form-field/directives/corner-hint.directive.mjs +14 -0
- package/esm2020/lib/form-field/directives/error.directive.mjs +26 -0
- package/esm2020/lib/form-field/directives/form-root.directive.mjs +91 -0
- package/esm2020/lib/form-field/directives/hint.directive.mjs +24 -0
- package/esm2020/lib/form-field/directives/index.mjs +8 -0
- package/esm2020/lib/form-field/directives/label.directive.mjs +14 -0
- package/esm2020/lib/form-field/directives/prefix.directive.mjs +24 -0
- package/esm2020/lib/form-field/directives/suffix.directive.mjs +24 -0
- package/esm2020/lib/form-field/form-field-errors.mjs +5 -0
- package/esm2020/lib/form-field/form-field.component.mjs +132 -0
- package/esm2020/lib/form-field/impdc-forms.mjs +8 -0
- package/esm2020/lib/form-field/impdc-forms.module.mjs +68 -0
- package/esm2020/lib/form-field/index.mjs +2 -0
- package/esm2020/lib/form-field/services/error-state-matcher.service.mjs +28 -0
- package/esm2020/lib/form-field/services/index.mjs +3 -0
- package/esm2020/lib/form-field/services/unique-selection-dispatcher.service.mjs +48 -0
- package/esm2020/lib/form-field/shared/constructors.type.mjs +2 -0
- package/esm2020/lib/form-field/shared/disabled.mixin.mjs +15 -0
- package/esm2020/lib/form-field/shared/error-state.mixin.mjs +24 -0
- package/esm2020/lib/form-field/shared/form-field-control.mjs +10 -0
- package/esm2020/lib/form-field/shared/index.mjs +5 -0
- package/esm2020/lib/form-field/shared/tab-index.mixin.mjs +19 -0
- package/esm2020/lib/icon/icon.component.mjs +70 -0
- package/esm2020/lib/icon/icon.module.mjs +19 -0
- package/esm2020/lib/icon/index.mjs +3 -0
- package/esm2020/lib/index.mjs +26 -0
- package/esm2020/lib/modal/index.mjs +4 -0
- package/esm2020/lib/modal/modal.component.mjs +141 -0
- package/esm2020/lib/modal/modal.module.mjs +37 -0
- package/esm2020/lib/modal/types/index.mjs +3 -0
- package/esm2020/lib/modal/types/modal-component-sizes.mjs +9 -0
- package/esm2020/lib/modal/types/modal-theme.mjs +12 -0
- package/esm2020/lib/pagination/index.mjs +3 -0
- package/esm2020/lib/pagination/pagination.component.mjs +134 -0
- package/esm2020/lib/pagination/pagination.module.mjs +21 -0
- package/esm2020/lib/progress-bar/index.mjs +3 -0
- package/esm2020/lib/progress-bar/progress-bar.component.mjs +35 -0
- package/esm2020/lib/progress-bar/progress-bar.module.mjs +18 -0
- package/esm2020/lib/scrollable/index.mjs +3 -0
- package/esm2020/lib/scrollable/scrollable.component.mjs +193 -0
- package/esm2020/lib/scrollable/scrollable.module.mjs +21 -0
- package/esm2020/lib/select-icon/index.mjs +3 -0
- package/esm2020/lib/select-icon/select-icon.component.mjs +307 -0
- package/esm2020/lib/select-icon/select-icon.module.mjs +35 -0
- package/esm2020/lib/size-detection/directive/element-size.interface.mjs +2 -0
- package/esm2020/lib/size-detection/directive/index.mjs +3 -0
- package/esm2020/lib/size-detection/directive/size-detector.directive.mjs +43 -0
- package/esm2020/lib/size-detection/index.mjs +3 -0
- package/esm2020/lib/size-detection/size-detection.module.mjs +18 -0
- package/esm2020/lib/spinner/index.mjs +3 -0
- package/esm2020/lib/spinner/spinner.component.mjs +24 -0
- package/esm2020/lib/spinner/spinner.module.mjs +18 -0
- package/esm2020/lib/table/index.mjs +3 -0
- package/esm2020/lib/table/table.component.mjs +33 -0
- package/esm2020/lib/table/table.module.mjs +19 -0
- package/esm2020/lib/text-highlight/index.mjs +3 -0
- package/esm2020/lib/text-highlight/text-highlight.component.mjs +81 -0
- package/esm2020/lib/text-highlight/text-highlight.module.mjs +19 -0
- package/esm2020/public-api.mjs +9 -0
- package/esm2020/services/index.mjs +2 -0
- package/esm2020/services/interaction.service.mjs +54 -0
- package/esm2020/types/component-size.mjs +12 -0
- package/esm2020/types/component-theme.mjs +22 -0
- package/esm2020/types/index.mjs +3 -0
- package/esm2020/utilities/boolean-props.mjs +7 -0
- package/esm2020/utilities/dc.mjs +9 -0
- package/esm2020/utilities/index.mjs +6 -0
- package/esm2020/utilities/lc.mjs +9 -0
- package/esm2020/utilities/number-props.mjs +18 -0
- package/esm2020/utilities/sanitize.mjs +7 -0
- package/fesm2015/impartner-design-components.mjs +8295 -0
- package/fesm2015/impartner-design-components.mjs.map +1 -0
- package/fesm2020/impartner-design-components.mjs +8264 -0
- package/fesm2020/impartner-design-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/alert/alert.component.d.ts +29 -0
- package/lib/alert/alert.module.d.ts +8 -0
- package/lib/alert/index.d.ts +3 -0
- package/lib/alert/theme/alert-theme.d.ts +1 -0
- package/lib/alert/theme/index.d.ts +1 -0
- package/lib/avatar/avatar.component.d.ts +28 -0
- package/lib/avatar/avatar.module.d.ts +8 -0
- package/lib/avatar/index.d.ts +2 -0
- package/lib/avatar-group/avatar-group.component.d.ts +10 -0
- package/lib/avatar-group/avatar-group.module.d.ts +9 -0
- package/lib/avatar-group/index.d.ts +2 -0
- package/lib/backdrop/backdrop.component.d.ts +19 -0
- package/lib/backdrop/backdrop.module.d.ts +9 -0
- package/lib/backdrop/index.d.ts +2 -0
- package/lib/badge/badge.component.d.ts +48 -0
- package/lib/badge/badge.module.d.ts +9 -0
- package/lib/badge/index.d.ts +3 -0
- package/lib/badge/types/badge-icon.d.ts +1 -0
- package/lib/badge/types/badge-size.d.ts +6 -0
- package/lib/badge/types/index.d.ts +2 -0
- package/lib/branding/branded.directive.d.ts +6 -0
- package/lib/branding/branding.module.d.ts +9 -0
- package/lib/branding/index.d.ts +2 -0
- package/lib/breadcrumb/breadcrumb-item.component.d.ts +7 -0
- package/lib/breadcrumb/breadcrumb.component.d.ts +18 -0
- package/lib/breadcrumb/breadcrumb.module.d.ts +9 -0
- package/lib/breadcrumb/index.d.ts +3 -0
- package/lib/button/button.component.d.ts +47 -0
- package/lib/button/button.module.d.ts +11 -0
- package/lib/button/index.d.ts +3 -0
- package/lib/button/themes/button-theme.d.ts +1 -0
- package/lib/button/themes/index.d.ts +1 -0
- package/lib/button-group/button-group.component.d.ts +22 -0
- package/lib/button-group/button-group.module.d.ts +10 -0
- package/lib/button-group/index.d.ts +2 -0
- package/lib/card-heading/card-heading.component.d.ts +18 -0
- package/lib/card-heading/card-heading.module.d.ts +9 -0
- package/lib/card-heading/index.d.ts +2 -0
- package/lib/design-components.module.d.ts +22 -0
- package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +11 -0
- package/lib/dropdown/components/index.d.ts +1 -0
- package/lib/dropdown/dropdown.component.d.ts +65 -0
- package/lib/dropdown/dropdown.module.d.ts +11 -0
- package/lib/dropdown/index.d.ts +4 -0
- package/lib/dropdown/types/dropdown-position.d.ts +1 -0
- package/lib/dropdown/types/index.d.ts +1 -0
- package/lib/file-upload/directives/file-drop.directive.d.ts +11 -0
- package/lib/file-upload/directives/index.d.ts +1 -0
- package/lib/file-upload/file-upload.component.d.ts +105 -0
- package/lib/file-upload/file-upload.module.d.ts +13 -0
- package/lib/file-upload/index.d.ts +4 -0
- package/lib/file-upload/pipes/human-readable-byte-size.pipe.d.ts +7 -0
- package/lib/file-upload/pipes/index.d.ts +1 -0
- package/lib/form-field/controls/checkbox/checkbox.component.d.ts +133 -0
- package/lib/form-field/controls/checkbox/checkbox.module.d.ts +9 -0
- package/lib/form-field/controls/checkbox/index.d.ts +2 -0
- package/lib/form-field/controls/index.d.ts +4 -0
- package/lib/form-field/controls/input/index.d.ts +1 -0
- package/lib/form-field/controls/input/input.directive.d.ts +84 -0
- package/lib/form-field/controls/radio/index.d.ts +5 -0
- package/lib/form-field/controls/radio/injection-tokens.d.ts +4 -0
- package/lib/form-field/controls/radio/interfaces/index.d.ts +3 -0
- package/lib/form-field/controls/radio/interfaces/radio-button.interface.d.ts +6 -0
- package/lib/form-field/controls/radio/interfaces/radio-change-event.interface.d.ts +12 -0
- package/lib/form-field/controls/radio/interfaces/radio-group.interface.d.ts +13 -0
- package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +98 -0
- package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +104 -0
- package/lib/form-field/controls/radio/radio.module.d.ts +10 -0
- package/lib/form-field/controls/select/index.d.ts +5 -0
- package/lib/form-field/controls/select/option/index.d.ts +1 -0
- package/lib/form-field/controls/select/option/select-option.component.d.ts +60 -0
- package/lib/form-field/controls/select/option-parent.d.ts +5 -0
- package/lib/form-field/controls/select/select-model.d.ts +36 -0
- package/lib/form-field/controls/select/select.component.d.ts +170 -0
- package/lib/form-field/controls/select/select.module.d.ts +10 -0
- package/lib/form-field/controls/shared/index.d.ts +1 -0
- package/lib/form-field/controls/shared/toggle/components/index.d.ts +1 -0
- package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +6 -0
- package/lib/form-field/controls/shared/toggle/index.d.ts +3 -0
- package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +26 -0
- package/lib/form-field/controls/shared/toggle/toggle.module.d.ts +10 -0
- package/lib/form-field/directives/corner-hint.directive.d.ts +5 -0
- package/lib/form-field/directives/error.directive.d.ts +8 -0
- package/lib/form-field/directives/form-root.directive.d.ts +26 -0
- package/lib/form-field/directives/hint.directive.d.ts +6 -0
- package/lib/form-field/directives/index.d.ts +7 -0
- package/lib/form-field/directives/label.directive.d.ts +5 -0
- package/lib/form-field/directives/prefix.directive.d.ts +9 -0
- package/lib/form-field/directives/suffix.directive.d.ts +9 -0
- package/lib/form-field/form-field-errors.d.ts +2 -0
- package/lib/form-field/form-field.component.d.ts +39 -0
- package/lib/form-field/impdc-forms.d.ts +7 -0
- package/lib/form-field/impdc-forms.module.d.ts +19 -0
- package/lib/form-field/index.d.ts +1 -0
- package/lib/form-field/services/error-state-matcher.service.d.ts +12 -0
- package/lib/form-field/services/index.d.ts +2 -0
- package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +29 -0
- package/lib/form-field/shared/constructors.type.d.ts +7 -0
- package/lib/form-field/shared/disabled.mixin.d.ts +10 -0
- package/lib/form-field/shared/error-state.mixin.d.ts +31 -0
- package/lib/form-field/shared/form-field-control.d.ts +24 -0
- package/lib/form-field/shared/index.d.ts +5 -0
- package/lib/form-field/shared/tab-index.mixin.d.ts +13 -0
- package/lib/icon/icon.component.d.ts +30 -0
- package/lib/icon/icon.module.d.ts +9 -0
- package/lib/icon/index.d.ts +2 -0
- package/lib/index.d.ts +25 -0
- package/lib/modal/index.d.ts +3 -0
- package/lib/modal/modal.component.d.ts +80 -0
- package/lib/modal/modal.module.d.ts +13 -0
- package/lib/modal/types/index.d.ts +2 -0
- package/lib/modal/types/modal-component-sizes.d.ts +3 -0
- package/lib/modal/types/modal-theme.d.ts +7 -0
- package/lib/pagination/index.d.ts +2 -0
- package/lib/pagination/pagination.component.d.ts +41 -0
- package/lib/pagination/pagination.module.d.ts +11 -0
- package/lib/progress-bar/index.d.ts +2 -0
- package/lib/progress-bar/progress-bar.component.d.ts +22 -0
- package/lib/progress-bar/progress-bar.module.d.ts +8 -0
- package/lib/scrollable/index.d.ts +2 -0
- package/lib/scrollable/scrollable.component.d.ts +39 -0
- package/lib/scrollable/scrollable.module.d.ts +11 -0
- package/lib/select-icon/index.d.ts +2 -0
- package/lib/select-icon/select-icon.component.d.ts +123 -0
- package/lib/select-icon/select-icon.module.d.ts +11 -0
- package/lib/size-detection/directive/element-size.interface.d.ts +4 -0
- package/lib/size-detection/directive/index.d.ts +2 -0
- package/lib/size-detection/directive/size-detector.directive.d.ts +14 -0
- package/lib/size-detection/index.d.ts +3 -0
- package/lib/size-detection/size-detection.module.d.ts +8 -0
- package/lib/spinner/index.d.ts +2 -0
- package/lib/spinner/spinner.component.d.ts +13 -0
- package/lib/spinner/spinner.module.d.ts +8 -0
- package/lib/table/index.d.ts +2 -0
- package/lib/table/table.component.d.ts +15 -0
- package/lib/table/table.module.d.ts +9 -0
- package/lib/text-highlight/index.d.ts +2 -0
- package/lib/text-highlight/text-highlight.component.d.ts +31 -0
- package/lib/text-highlight/text-highlight.module.d.ts +9 -0
- package/package.json +51 -0
- package/public-api.d.ts +4 -0
- package/services/index.d.ts +1 -0
- package/services/interaction.service.d.ts +14 -0
- package/types/component-size.d.ts +12 -0
- package/types/component-theme.d.ts +12 -0
- package/types/index.d.ts +2 -0
- package/utilities/boolean-props.d.ts +8 -0
- package/utilities/dc.d.ts +6 -0
- package/utilities/index.d.ts +5 -0
- package/utilities/lc.d.ts +6 -0
- package/utilities/number-props.d.ts +15 -0
- package/utilities/sanitize.d.ts +1 -0
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../size-detection/directive/size-detector.directive";
|
|
5
|
+
/**
|
|
6
|
+
* The `ScrollableComponent` (`<impdc-scrollable` or `<div impdc-scrollable`) is a container that hides items that wouldn't fit
|
|
7
|
+
* with arrows on the left and right to slide between them.
|
|
8
|
+
* To use, import `ScrollableModule` or another module that imports and exports that module from `@impartner/design-components`.
|
|
9
|
+
* `ScrollableModule` also imports and exports [BrandingModule](./?path=/docs/design-components-directives-impdcbranded).
|
|
10
|
+
*/
|
|
11
|
+
export class ScrollableComponent {
|
|
12
|
+
constructor(_cd) {
|
|
13
|
+
this._cd = _cd;
|
|
14
|
+
/**
|
|
15
|
+
* The base amount to scroll.
|
|
16
|
+
*/
|
|
17
|
+
this.scrollUnit = 20;
|
|
18
|
+
/**
|
|
19
|
+
* Used in combination with `scrollUnit` to determine how far the Scrollable scrolls when directional arrows are clicked.
|
|
20
|
+
*/
|
|
21
|
+
this.clickScrollMultiplier = 5;
|
|
22
|
+
this._scrollableBgColor = null;
|
|
23
|
+
this._width = 0;
|
|
24
|
+
}
|
|
25
|
+
get canScrollLeft() {
|
|
26
|
+
if (!this._contentElement) {
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
return Math.floor(this._contentElement.scrollLeft) > 0;
|
|
30
|
+
}
|
|
31
|
+
get canScrollRight() {
|
|
32
|
+
if (!this._contentElement) {
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
return (Math.ceil(this._contentElement.scrollLeft + this._width) <
|
|
36
|
+
this._contentElement.scrollWidth);
|
|
37
|
+
}
|
|
38
|
+
get _containerElement() {
|
|
39
|
+
if (!this.containerRef) {
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
return this.containerRef.nativeElement;
|
|
43
|
+
}
|
|
44
|
+
get _contentElement() {
|
|
45
|
+
if (!this.contentRef) {
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
return this.contentRef.nativeElement;
|
|
49
|
+
}
|
|
50
|
+
ngOnChanges(changes) {
|
|
51
|
+
if (changes['scrollUnit'] || changes['clickScrollMultiplier']) {
|
|
52
|
+
if (this._containerElement) {
|
|
53
|
+
this._width = this._containerElement?.clientWidth;
|
|
54
|
+
this._cd.detectChanges();
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
this._getBackgroundColorForButtons();
|
|
58
|
+
}
|
|
59
|
+
ngAfterViewInit() {
|
|
60
|
+
this._width = this.contentRef?.nativeElement.width;
|
|
61
|
+
this._getBackgroundColorForButtons();
|
|
62
|
+
this._cd.detectChanges();
|
|
63
|
+
}
|
|
64
|
+
async scroll(direction) {
|
|
65
|
+
if (!this._contentElement) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
let pixels = direction * this.scrollUnit * this.clickScrollMultiplier;
|
|
69
|
+
let position = 0;
|
|
70
|
+
if (!pixels) {
|
|
71
|
+
if (direction === 1) {
|
|
72
|
+
position = this._contentElement.scrollWidth;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
position = this._contentElement.scrollLeft + pixels;
|
|
77
|
+
}
|
|
78
|
+
await this._scrollToPosition(this._contentElement, position);
|
|
79
|
+
this._cd.detectChanges();
|
|
80
|
+
}
|
|
81
|
+
widthChanged(elementSize) {
|
|
82
|
+
if (!elementSize || !elementSize.width) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
this._width = elementSize.width;
|
|
86
|
+
this._cd.detectChanges();
|
|
87
|
+
}
|
|
88
|
+
async _scrollToPosition(container, position) {
|
|
89
|
+
position = Math.round(position);
|
|
90
|
+
if (container.scrollLeft === position) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
let resolveFn;
|
|
94
|
+
let scrollListener;
|
|
95
|
+
let timeoutId;
|
|
96
|
+
const promise = new Promise(resolve => {
|
|
97
|
+
resolveFn = resolve;
|
|
98
|
+
});
|
|
99
|
+
const finished = () => {
|
|
100
|
+
container.removeEventListener('scroll', scrollListener);
|
|
101
|
+
resolveFn(null);
|
|
102
|
+
};
|
|
103
|
+
scrollListener = () => {
|
|
104
|
+
clearTimeout(timeoutId);
|
|
105
|
+
// scroll is finished when either the position has been reached, or 100ms have elapsed since the last scroll event
|
|
106
|
+
if (container.scrollLeft === position) {
|
|
107
|
+
finished();
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
timeoutId = setTimeout(finished, 100);
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
container.addEventListener('scroll', scrollListener);
|
|
114
|
+
container.scrollTo({
|
|
115
|
+
left: position,
|
|
116
|
+
behavior: 'smooth'
|
|
117
|
+
});
|
|
118
|
+
return promise;
|
|
119
|
+
}
|
|
120
|
+
_getBackgroundColorForButtons() {
|
|
121
|
+
if (!this.contentRef) {
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
const projectedElementCollection = this.contentRef.nativeElement.children;
|
|
125
|
+
if (!projectedElementCollection || !projectedElementCollection.length) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
const firstElement = projectedElementCollection[0];
|
|
129
|
+
let backgroundColor = this._getBackGroundColor(firstElement);
|
|
130
|
+
if (!backgroundColor) {
|
|
131
|
+
backgroundColor = this._getAncestorBackgroundColor();
|
|
132
|
+
}
|
|
133
|
+
this._scrollableBgColor = backgroundColor;
|
|
134
|
+
}
|
|
135
|
+
_getAncestorBackgroundColor() {
|
|
136
|
+
if (!this.contentRef) {
|
|
137
|
+
return null;
|
|
138
|
+
}
|
|
139
|
+
let result = {
|
|
140
|
+
parent: this.contentRef.nativeElement.parentElement,
|
|
141
|
+
backgroundColor: null
|
|
142
|
+
};
|
|
143
|
+
let count = 6;
|
|
144
|
+
function getParentBackgroundColor(currentContext, getBackgroundColor) {
|
|
145
|
+
const result = { parent: null, backgroundColor: null };
|
|
146
|
+
if (currentContext && currentContext.parent) {
|
|
147
|
+
result.backgroundColor = getBackgroundColor(currentContext.parent);
|
|
148
|
+
if (!result.backgroundColor) {
|
|
149
|
+
result.parent = currentContext.parent.parentElement;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
return result;
|
|
153
|
+
}
|
|
154
|
+
while (count > 0) {
|
|
155
|
+
if (result.backgroundColor) {
|
|
156
|
+
break;
|
|
157
|
+
}
|
|
158
|
+
result = getParentBackgroundColor(result, this._getBackGroundColor);
|
|
159
|
+
if (!result.parent) {
|
|
160
|
+
break;
|
|
161
|
+
}
|
|
162
|
+
count = count - 1;
|
|
163
|
+
}
|
|
164
|
+
return result.backgroundColor;
|
|
165
|
+
}
|
|
166
|
+
_getBackGroundColor(element) {
|
|
167
|
+
const computedBackgroundColor = getComputedStyle(element)['backgroundColor'];
|
|
168
|
+
if (computedBackgroundColor !== 'rgba(0, 0, 0, 0)') {
|
|
169
|
+
return computedBackgroundColor;
|
|
170
|
+
}
|
|
171
|
+
return element.style.backgroundColor;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
ScrollableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
175
|
+
ScrollableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ScrollableComponent, selector: "impdc-scrollable, div[impdc-scrollable]", inputs: { scrollUnit: "scrollUnit", clickScrollMultiplier: "clickScrollMultiplier" }, host: { properties: { "style.--impdc-scrollable-bg": "this._scrollableBgColor" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }, { propertyName: "contentRef", first: true, predicate: ["content"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"impdc-scrollable\"\n #container\n impdcSizeDetector\n (resized)=\"widthChanged($event)\">\n <a class=\"impdc-scrollable-left\" (click)=\"scroll(-1)\" *ngIf=\"canScrollLeft\">\n <i class=\"fas fa-chevron-left default\"></i>\n </a>\n <div #content class=\"content-container\">\n <ng-content></ng-content>\n </div>\n <a class=\"impdc-scrollable-right\" (click)=\"scroll(1)\" *ngIf=\"canScrollRight\">\n <i class=\"fas fa-chevron-right default\"></i>\n </a>\n</div>\n", styles: [".impdc-scrollable{position:relative;overflow-y:hidden}.impdc-scrollable .impdc-scrollable-base,.impdc-scrollable .impdc-scrollable-right,.impdc-scrollable .impdc-scrollable-left{position:absolute;top:0px;bottom:0px;display:flex;align-items:center;text-align:center;width:6.9rem;z-index:1;color:var(--impd-color-motion-blue-600, #01606d)}.impdc-scrollable .impdc-scrollable-left{justify-content:left;padding-left:1.5rem;background-image:linear-gradient(to right,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .impdc-scrollable-right{right:0;padding-right:1.5rem;justify-content:right;background-image:linear-gradient(to left,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .content-container{overflow-x:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap}:host(.branded) .impdc-scrollable .impdc-scrollable-left,:host(.branded) .impdc-scrollable .impdc-scrollable-right{color:var(--px-primary-color, var(--impd-color-motion-blue-600, #01606d))}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.SizeDetectorDirective, selector: "[impdcSizeDetector]", outputs: ["resized"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
176
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableComponent, decorators: [{
|
|
177
|
+
type: Component,
|
|
178
|
+
args: [{ selector: 'impdc-scrollable, div[impdc-scrollable]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"impdc-scrollable\"\n #container\n impdcSizeDetector\n (resized)=\"widthChanged($event)\">\n <a class=\"impdc-scrollable-left\" (click)=\"scroll(-1)\" *ngIf=\"canScrollLeft\">\n <i class=\"fas fa-chevron-left default\"></i>\n </a>\n <div #content class=\"content-container\">\n <ng-content></ng-content>\n </div>\n <a class=\"impdc-scrollable-right\" (click)=\"scroll(1)\" *ngIf=\"canScrollRight\">\n <i class=\"fas fa-chevron-right default\"></i>\n </a>\n</div>\n", styles: [".impdc-scrollable{position:relative;overflow-y:hidden}.impdc-scrollable .impdc-scrollable-base,.impdc-scrollable .impdc-scrollable-right,.impdc-scrollable .impdc-scrollable-left{position:absolute;top:0px;bottom:0px;display:flex;align-items:center;text-align:center;width:6.9rem;z-index:1;color:var(--impd-color-motion-blue-600, #01606d)}.impdc-scrollable .impdc-scrollable-left{justify-content:left;padding-left:1.5rem;background-image:linear-gradient(to right,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .impdc-scrollable-right{right:0;padding-right:1.5rem;justify-content:right;background-image:linear-gradient(to left,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .content-container{overflow-x:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap}:host(.branded) .impdc-scrollable .impdc-scrollable-left,:host(.branded) .impdc-scrollable .impdc-scrollable-right{color:var(--px-primary-color, var(--impd-color-motion-blue-600, #01606d))}\n"] }]
|
|
179
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { scrollUnit: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], clickScrollMultiplier: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], _scrollableBgColor: [{
|
|
184
|
+
type: HostBinding,
|
|
185
|
+
args: ['style.--impdc-scrollable-bg']
|
|
186
|
+
}], containerRef: [{
|
|
187
|
+
type: ViewChild,
|
|
188
|
+
args: ['container', { static: false }]
|
|
189
|
+
}], contentRef: [{
|
|
190
|
+
type: ViewChild,
|
|
191
|
+
args: ['content', { static: false }]
|
|
192
|
+
}] } });
|
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/scrollable/scrollable.component.ts","../../../../../../projects/design-components/src/lib/scrollable/scrollable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { IElementSize } from '../size-detection';\n\n/**\n * The `ScrollableComponent` (`<impdc-scrollable` or `<div impdc-scrollable`) is a container that hides items that wouldn't fit\n * with arrows on the left and right to slide between them.\n * To use, import `ScrollableModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ScrollableModule` also imports and exports [BrandingModule](./?path=/docs/design-components-directives-impdcbranded).\n */\n@Component({\n  selector: 'impdc-scrollable, div[impdc-scrollable]',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScrollableComponent implements OnChanges, AfterViewInit {\n  /**\n   * The base amount to scroll.\n   */\n  @Input()\n  public scrollUnit: number = 20;\n\n  /**\n   * Used in combination with `scrollUnit` to determine how far the Scrollable scrolls when directional arrows are clicked.\n   */\n  @Input()\n  public clickScrollMultiplier = 5;\n\n  @HostBinding('style.--impdc-scrollable-bg')\n  private _scrollableBgColor: string | null = null;\n\n  public get canScrollLeft(): boolean {\n    if (!this._contentElement) {\n      return false;\n    }\n\n    return Math.floor(this._contentElement.scrollLeft) > 0;\n  }\n\n  public get canScrollRight(): boolean {\n    if (!this._contentElement) {\n      return false;\n    }\n\n    return (\n      Math.ceil(this._contentElement.scrollLeft + this._width) <\n      this._contentElement.scrollWidth\n    );\n  }\n\n  private _width: number = 0;\n\n  @ViewChild('container', { static: false })\n  public containerRef: ElementRef | undefined;\n\n  private get _containerElement(): HTMLDivElement | null {\n    if (!this.containerRef) {\n      return null;\n    }\n\n    return this.containerRef.nativeElement;\n  }\n\n  @ViewChild('content', { static: false })\n  public contentRef: ElementRef | undefined;\n\n  private get _contentElement(): HTMLDivElement | null {\n    if (!this.contentRef) {\n      return null;\n    }\n\n    return this.contentRef.nativeElement;\n  }\n\n  constructor(private _cd: ChangeDetectorRef) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['scrollUnit'] || changes['clickScrollMultiplier']) {\n      if (this._containerElement) {\n        this._width = this._containerElement?.clientWidth;\n        this._cd.detectChanges();\n      }\n    }\n    this._getBackgroundColorForButtons();\n  }\n\n  public ngAfterViewInit(): void {\n    this._width = this.contentRef?.nativeElement.width;\n    this._getBackgroundColorForButtons();\n    this._cd.detectChanges();\n  }\n\n  public async scroll(direction: number): Promise<void> {\n    if (!this._contentElement) {\n      return;\n    }\n\n    let pixels = direction * this.scrollUnit * this.clickScrollMultiplier;\n    let position = 0;\n\n    if (!pixels) {\n      if (direction === 1) {\n        position = this._contentElement.scrollWidth;\n      }\n    } else {\n      position = this._contentElement.scrollLeft + pixels;\n    }\n\n    await this._scrollToPosition(this._contentElement, position);\n\n    this._cd.detectChanges();\n  }\n\n  public widthChanged(elementSize: IElementSize): void {\n    if (!elementSize || !elementSize.width) {\n      return;\n    }\n    this._width = elementSize.width;\n    this._cd.detectChanges();\n  }\n\n  private async _scrollToPosition(container: HTMLDivElement, position: number) {\n    position = Math.round(position);\n\n    if (container.scrollLeft === position) {\n      return;\n    }\n\n    let resolveFn: (value: unknown) => void;\n    let scrollListener: () => void;\n    let timeoutId: any;\n\n    const promise = new Promise(resolve => {\n      resolveFn = resolve;\n    });\n\n    const finished = () => {\n      container.removeEventListener('scroll', scrollListener);\n      resolveFn(null);\n    };\n\n    scrollListener = () => {\n      clearTimeout(timeoutId);\n\n      // scroll is finished when either the position has been reached, or 100ms have elapsed since the last scroll event\n      if (container.scrollLeft === position) {\n        finished();\n      } else {\n        timeoutId = setTimeout(finished, 100);\n      }\n    };\n\n    container.addEventListener('scroll', scrollListener);\n\n    container.scrollTo({\n      left: position,\n      behavior: 'smooth'\n    });\n\n    return promise;\n  }\n\n  private _getBackgroundColorForButtons(): void {\n    if (!this.contentRef) {\n      return;\n    }\n\n    const projectedElementCollection: HTMLCollection =\n      this.contentRef.nativeElement.children;\n\n    if (!projectedElementCollection || !projectedElementCollection.length) {\n      return;\n    }\n\n    const firstElement = projectedElementCollection[0] as HTMLElement;\n    let backgroundColor: string | null = this._getBackGroundColor(firstElement);\n\n    if (!backgroundColor) {\n      backgroundColor = this._getAncestorBackgroundColor();\n    }\n\n    this._scrollableBgColor = backgroundColor;\n  }\n\n  private _getAncestorBackgroundColor(): string | null {\n    if (!this.contentRef) {\n      return null;\n    }\n\n    type parentBgResult = {\n      parent: HTMLElement | null;\n      backgroundColor: string | null;\n    };\n\n    let result: parentBgResult = {\n      parent: (this.contentRef.nativeElement as HTMLElement).parentElement,\n      backgroundColor: null\n    };\n\n    let count = 6;\n\n    function getParentBackgroundColor(\n      currentContext: parentBgResult,\n      getBackgroundColor: (element: HTMLElement) => string | null\n    ): parentBgResult {\n      const result: parentBgResult = { parent: null, backgroundColor: null };\n      if (currentContext && currentContext.parent) {\n        result.backgroundColor = getBackgroundColor(currentContext.parent);\n\n        if (!result.backgroundColor) {\n          result.parent = currentContext.parent.parentElement;\n        }\n      }\n\n      return result;\n    }\n\n    while (count > 0) {\n      if (result.backgroundColor) {\n        break;\n      }\n      result = getParentBackgroundColor(result, this._getBackGroundColor);\n\n      if (!result.parent) {\n        break;\n      }\n      count = count - 1;\n    }\n\n    return result.backgroundColor;\n  }\n\n  private _getBackGroundColor(element: HTMLElement): string | null {\n    const computedBackgroundColor =\n      getComputedStyle(element)['backgroundColor'];\n\n    if (computedBackgroundColor !== 'rgba(0, 0, 0, 0)') {\n      return computedBackgroundColor;\n    }\n\n    return element.style.backgroundColor;\n  }\n}\n","<div\n  class=\"impdc-scrollable\"\n  #container\n  impdcSizeDetector\n  (resized)=\"widthChanged($event)\">\n  <a class=\"impdc-scrollable-left\" (click)=\"scroll(-1)\" *ngIf=\"canScrollLeft\">\n    <i class=\"fas fa-chevron-left default\"></i>\n  </a>\n  <div #content class=\"content-container\">\n    <ng-content></ng-content>\n  </div>\n  <a class=\"impdc-scrollable-right\" (click)=\"scroll(1)\" *ngIf=\"canScrollRight\">\n    <i class=\"fas fa-chevron-right default\"></i>\n  </a>\n</div>\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { BrandingModule } from '../branding';
|
|
4
|
+
import { SizeDetectionModule } from '../size-detection';
|
|
5
|
+
import { ScrollableComponent } from './scrollable.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class ScrollableModule {
|
|
8
|
+
constructor() { }
|
|
9
|
+
}
|
|
10
|
+
ScrollableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
ScrollableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, declarations: [ScrollableComponent], imports: [CommonModule, SizeDetectionModule, BrandingModule], exports: [ScrollableComponent, BrandingModule] });
|
|
12
|
+
ScrollableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, imports: [CommonModule, SizeDetectionModule, BrandingModule, BrandingModule] });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: [CommonModule, SizeDetectionModule, BrandingModule],
|
|
17
|
+
declarations: [ScrollableComponent],
|
|
18
|
+
exports: [ScrollableComponent, BrandingModule]
|
|
19
|
+
}]
|
|
20
|
+
}], ctorParameters: function () { return []; } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsYWJsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3Njcm9sbGFibGUvc2Nyb2xsYWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFPN0QsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQixnQkFBZSxDQUFDOzs4R0FETCxnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFIWixtQkFBbUIsYUFEeEIsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGNBQWMsYUFFakQsbUJBQW1CLEVBQUUsY0FBYzsrR0FFbEMsZ0JBQWdCLFlBSmpCLFlBQVksRUFBRSxtQkFBbUIsRUFBRSxjQUFjLEVBRTVCLGNBQWM7NEZBRWxDLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsbUJBQW1CLEVBQUUsY0FBYyxDQUFDO29CQUM1RCxZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDbkMsT0FBTyxFQUFFLENBQUMsbUJBQW1CLEVBQUUsY0FBYyxDQUFDO2lCQUMvQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnJhbmRpbmdNb2R1bGUgfSBmcm9tICcuLi9icmFuZGluZyc7XG5pbXBvcnQgeyBTaXplRGV0ZWN0aW9uTW9kdWxlIH0gZnJvbSAnLi4vc2l6ZS1kZXRlY3Rpb24nO1xuaW1wb3J0IHsgU2Nyb2xsYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vc2Nyb2xsYWJsZS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBTaXplRGV0ZWN0aW9uTW9kdWxlLCBCcmFuZGluZ01vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1Njcm9sbGFibGVDb21wb25lbnRdLFxuICBleHBvcnRzOiBbU2Nyb2xsYWJsZUNvbXBvbmVudCwgQnJhbmRpbmdNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIFNjcm9sbGFibGVNb2R1bGUge1xuICBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './select-icon.component';
|
|
2
|
+
export * from './select-icon.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3NlbGVjdC1pY29uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LWljb24ubW9kdWxlJztcbiJdfQ==
|
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
/* eslint-disable @angular-eslint/no-conflicting-lifecycle */
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Input, Optional, Output, Self, ViewChild } from '@angular/core';
|
|
3
|
+
import { FormControl, Validators } from '@angular/forms';
|
|
4
|
+
import { nanoid } from 'nanoid';
|
|
5
|
+
import { BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, map, startWith, Subject } from 'rxjs';
|
|
6
|
+
import { FontAwesomeIcons } from '../../constants';
|
|
7
|
+
import { coerceBooleanPropertyValue } from '../../utilities';
|
|
8
|
+
import { ImpdcFormFieldControl, IMPDC_FORM_ROOT, mixinDisabled, mixinErrorState, mixinTabIndex } from '../form-field';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../form-field";
|
|
11
|
+
import * as i2 from "@angular/forms";
|
|
12
|
+
import * as i3 from "@angular/common";
|
|
13
|
+
import * as i4 from "@ng-bootstrap/ng-bootstrap";
|
|
14
|
+
import * as i5 from "../form-field/form-field.component";
|
|
15
|
+
import * as i6 from "../form-field/controls/input/input.directive";
|
|
16
|
+
import * as i7 from "../form-field/directives/prefix.directive";
|
|
17
|
+
export class ImpdcSelectIconChange {
|
|
18
|
+
constructor(source, value) {
|
|
19
|
+
this.source = source;
|
|
20
|
+
this.value = value;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
const _SelectIconComponentBase = mixinTabIndex(mixinDisabled(mixinErrorState(class {
|
|
24
|
+
constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
|
|
25
|
+
this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
|
|
26
|
+
this._formRoot = _formRoot;
|
|
27
|
+
this._parentForm = _parentForm;
|
|
28
|
+
this._parentFormGroup = _parentFormGroup;
|
|
29
|
+
this.ngControl = ngControl;
|
|
30
|
+
this.stateChanges = new Subject();
|
|
31
|
+
}
|
|
32
|
+
})));
|
|
33
|
+
/**
|
|
34
|
+
* The `SelectIconComponent` (`<impdc-select-icon`) is a select dropdown with search that shows all standard icons from Bootstrap 5.
|
|
35
|
+
* To use, import `SelectIconModule` or another module that imports and exports that module from `@impartner/design-components`.
|
|
36
|
+
*/
|
|
37
|
+
export class SelectIconComponent extends _SelectIconComponentBase {
|
|
38
|
+
constructor(_changeDetector, _defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
|
|
39
|
+
super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
|
|
40
|
+
this._changeDetector = _changeDetector;
|
|
41
|
+
this.searchControl = new FormControl('');
|
|
42
|
+
this._uid = `impdc-select-icon-${nanoid()}`;
|
|
43
|
+
this._dropdownOpen = false;
|
|
44
|
+
this._iconOptionsSubject = new BehaviorSubject(FontAwesomeIcons);
|
|
45
|
+
this._cvaOnChange = () => { };
|
|
46
|
+
this._cvaOnTouched = () => { };
|
|
47
|
+
this._placeholder = '- Select -';
|
|
48
|
+
/** Events fire when selection has been changed by the user. */
|
|
49
|
+
this.selectionChange = new EventEmitter();
|
|
50
|
+
/**
|
|
51
|
+
* Events fire when raw value of select changes. Mainly exists to handle
|
|
52
|
+
* two-way binding of `value` input property.
|
|
53
|
+
* @ignore
|
|
54
|
+
*/
|
|
55
|
+
this.valueChange = new EventEmitter();
|
|
56
|
+
this._value = null;
|
|
57
|
+
this._focused = false;
|
|
58
|
+
this.controlType = 'impdc-select-icon';
|
|
59
|
+
this.supportsAffixes = true;
|
|
60
|
+
this.allowSearch = false;
|
|
61
|
+
this.showText = true;
|
|
62
|
+
this.showSelectedText = true;
|
|
63
|
+
const debouncedSearchValues = this.searchControl.valueChanges.pipe(startWith(''), debounceTime(200), distinctUntilChanged());
|
|
64
|
+
this.filteredOptions$ = combineLatest([
|
|
65
|
+
debouncedSearchValues,
|
|
66
|
+
this._iconOptionsSubject.asObservable()
|
|
67
|
+
]).pipe(map(([searchTerm, iconOptions]) => {
|
|
68
|
+
if (!searchTerm) {
|
|
69
|
+
return [...iconOptions];
|
|
70
|
+
}
|
|
71
|
+
const searchTermLowerCase = searchTerm.toLowerCase();
|
|
72
|
+
return iconOptions.filter(option => option.toLowerCase().indexOf(searchTermLowerCase) > -1);
|
|
73
|
+
}));
|
|
74
|
+
if (this.ngControl) {
|
|
75
|
+
this.ngControl.valueAccessor = this;
|
|
76
|
+
}
|
|
77
|
+
this.id = this.id;
|
|
78
|
+
}
|
|
79
|
+
get iconOptions() {
|
|
80
|
+
return [...this._iconOptionsSubject.value];
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Set to override the default set of FontAwesome icon options.
|
|
84
|
+
*/
|
|
85
|
+
set iconOptions(iconOptions) {
|
|
86
|
+
if (iconOptions) {
|
|
87
|
+
this._iconOptionsSubject.next([...iconOptions]);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* The placeholder text that will be displayed when no selection has been made.
|
|
92
|
+
*
|
|
93
|
+
* @default \- Select -
|
|
94
|
+
*/
|
|
95
|
+
get placeholder() {
|
|
96
|
+
return this._placeholder;
|
|
97
|
+
}
|
|
98
|
+
set placeholder(value) {
|
|
99
|
+
this._placeholder = value;
|
|
100
|
+
this.stateChanges.next();
|
|
101
|
+
}
|
|
102
|
+
get empty() {
|
|
103
|
+
return !this.value;
|
|
104
|
+
}
|
|
105
|
+
/** @ignore */
|
|
106
|
+
focus(options) {
|
|
107
|
+
this._toggleButtonRef.nativeElement.focus(options);
|
|
108
|
+
}
|
|
109
|
+
/* Lifecycle Hooks */
|
|
110
|
+
/** @ignore */
|
|
111
|
+
ngDoCheck() {
|
|
112
|
+
const ngControl = this.ngControl;
|
|
113
|
+
if (!ngControl) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
if (this._previousControl !== ngControl.control) {
|
|
117
|
+
if (this._previousControl !== undefined &&
|
|
118
|
+
ngControl.disabled !== null &&
|
|
119
|
+
ngControl.disabled !== this.disabled) {
|
|
120
|
+
this.disabled = ngControl?.disabled;
|
|
121
|
+
}
|
|
122
|
+
this._previousControl = ngControl.control;
|
|
123
|
+
}
|
|
124
|
+
this.updateErrorState();
|
|
125
|
+
}
|
|
126
|
+
/** @ignore */
|
|
127
|
+
ngOnChanges(changes) {
|
|
128
|
+
// Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal
|
|
129
|
+
// to the parent form field so it can run change detection when disabled state is changed.
|
|
130
|
+
if (changes['disabled']) {
|
|
131
|
+
this.stateChanges.next();
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
/** @ignore */
|
|
135
|
+
ngOnDestroy() {
|
|
136
|
+
this.stateChanges.complete();
|
|
137
|
+
}
|
|
138
|
+
/* ControlValueAccessor */
|
|
139
|
+
/** @ignore */
|
|
140
|
+
writeValue(value) {
|
|
141
|
+
this.value = value;
|
|
142
|
+
this._changeDetector.markForCheck();
|
|
143
|
+
}
|
|
144
|
+
/** @ignore */
|
|
145
|
+
registerOnChange(fn) {
|
|
146
|
+
this._cvaOnChange = fn;
|
|
147
|
+
}
|
|
148
|
+
/** @ignore */
|
|
149
|
+
registerOnTouched(fn) {
|
|
150
|
+
this._cvaOnTouched = fn;
|
|
151
|
+
}
|
|
152
|
+
/** @ignore */
|
|
153
|
+
setDisabledState(isDisabled) {
|
|
154
|
+
this.disabled = isDisabled;
|
|
155
|
+
this._changeDetector.markForCheck();
|
|
156
|
+
}
|
|
157
|
+
/* ImpdcFormFieldControl */
|
|
158
|
+
get value() {
|
|
159
|
+
return this._value;
|
|
160
|
+
}
|
|
161
|
+
set value(value) {
|
|
162
|
+
const newValue = (value && this.iconOptions.find(opt => opt === value)) || null;
|
|
163
|
+
if (newValue !== this._value) {
|
|
164
|
+
this._value = newValue;
|
|
165
|
+
this.stateChanges.next();
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
get id() {
|
|
169
|
+
return this._id;
|
|
170
|
+
}
|
|
171
|
+
set id(value) {
|
|
172
|
+
this._id = value || this._uid;
|
|
173
|
+
this.stateChanges.next();
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Used to set requiredness of control in a template-based manner;
|
|
177
|
+
* not necessary when using the Angular reactive forms API and `required` validator.
|
|
178
|
+
*
|
|
179
|
+
* @default false
|
|
180
|
+
*/
|
|
181
|
+
get required() {
|
|
182
|
+
return (this._required ??
|
|
183
|
+
this.ngControl?.control?.hasValidator(Validators.required) ??
|
|
184
|
+
false);
|
|
185
|
+
}
|
|
186
|
+
set required(value) {
|
|
187
|
+
this._required = coerceBooleanPropertyValue(value);
|
|
188
|
+
this.stateChanges.next();
|
|
189
|
+
}
|
|
190
|
+
get focused() {
|
|
191
|
+
return this._focused || this._dropdownOpen;
|
|
192
|
+
}
|
|
193
|
+
/* Internals */
|
|
194
|
+
handleOpenChange(isOpen) {
|
|
195
|
+
this._dropdownOpen = isOpen;
|
|
196
|
+
this.searchControl.reset();
|
|
197
|
+
if (isOpen) {
|
|
198
|
+
this._onFocus();
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
this._onBlur();
|
|
202
|
+
}
|
|
203
|
+
this.stateChanges.next();
|
|
204
|
+
}
|
|
205
|
+
selectIcon(iconName) {
|
|
206
|
+
if (iconName !== this.value) {
|
|
207
|
+
this.value = iconName;
|
|
208
|
+
this.valueChange.emit(this.value);
|
|
209
|
+
this._cvaOnChange(this.value);
|
|
210
|
+
this.selectionChange.emit(this._buildChangeEvent(this.value));
|
|
211
|
+
this._changeDetector.markForCheck();
|
|
212
|
+
}
|
|
213
|
+
if (this._dropdownOpen) {
|
|
214
|
+
this.focus();
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
_onFocus() {
|
|
218
|
+
if (!this.disabled) {
|
|
219
|
+
this._focused = true;
|
|
220
|
+
this.stateChanges.next();
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Calls the CVA touched callback only if the dropdown is closed.
|
|
225
|
+
*/
|
|
226
|
+
_onBlur() {
|
|
227
|
+
this._focused = false;
|
|
228
|
+
if (!this.disabled && !this._dropdownOpen) {
|
|
229
|
+
this._cvaOnTouched();
|
|
230
|
+
this._changeDetector.markForCheck();
|
|
231
|
+
this.stateChanges.next();
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
_buildChangeEvent(value) {
|
|
235
|
+
return new ImpdcSelectIconChange(this, value);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
SelectIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectIconComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ErrorStateMatcher }, { token: IMPDC_FORM_ROOT, optional: true }, { token: i2.NgForm, optional: true }, { token: i2.FormGroupDirective, optional: true }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
239
|
+
SelectIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: SelectIconComponent, selector: "impdc-select-icon", inputs: { disabled: "disabled", tabIndex: "tabIndex", allowSearch: "allowSearch", iconOptions: "iconOptions", showText: "showText", showSelectedText: "showSelectedText", placeholder: "placeholder", errorStateMatcher: "errorStateMatcher", value: "value", id: "id", required: "required" }, outputs: { selectionChange: "selectionChange", valueChange: "valueChange" }, host: { listeners: { "focus": "_onFocus(); focus()" }, properties: { "attr.id": "id", "attr.tabindex": "tabIndex", "attr.aria-required": "required.toString()", "attr.aria-disabled": "disabled.toString()", "attr.aria-invalid": "errorState", "class.form-select": "true", "class.is-invalid": "errorState", "class.impdc-form-field-control": "true", "class.impdc-select-icon--required": "required", "class.impdc-select-icon--disabled": "disabled", "class.impdc-select-icon--invalid": "errorState", "class.impdc-select-icon--empty": "empty" }, classAttribute: "impdc-select-icon" }, providers: [
|
|
240
|
+
{
|
|
241
|
+
provide: ImpdcFormFieldControl,
|
|
242
|
+
useExisting: SelectIconComponent
|
|
243
|
+
}
|
|
244
|
+
], viewQueries: [{ propertyName: "_toggleButtonRef", first: true, predicate: ["toggleButton"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\n ngbDropdown\n autoClose=\"outside\"\n container=\"body\"\n dropdownClass=\"impartner-hex\"\n (openChange)=\"handleOpenChange($event)\"\n class=\"w-100\">\n <button\n #toggleButton\n class=\"impdc-select-icon--toggle btn border-0 text-start\"\n type=\"button\"\n role=\"combobox\"\n [disabled]=\"disabled\"\n ngbDropdownToggle>\n <ng-container [ngSwitch]=\"empty\">\n <span\n class=\"impdc-select-icon--text impdc-select-icon--placeholder\"\n *ngSwitchCase=\"true\">\n {{ placeholder }}\n </span>\n <div\n class=\"impdc-select-icon--text impdc-select-icon--value-text\"\n *ngSwitchCase=\"false\">\n <i class=\"fas fa-{{ value }}\"></i>\n <span *ngIf=\"showSelectedText\" class=\"ms-2\">{{ value }}</span>\n </div>\n </ng-container>\n </button>\n <div ngbDropdownMenu class=\"select-icon-dropdown-menu\" tabindex=\"-1\">\n <div *ngIf=\"allowSearch\" class=\"select-icon-search\">\n <impdc-form-field>\n <span impdcTextPrefix><i class=\"fas fa-search\"></i></span>\n <input\n impdcInput\n [formControl]=\"searchControl\"\n class=\"select-icon-search-input\"\n type=\"search\" />\n </impdc-form-field>\n </div>\n <div class=\"select-icon-grid\">\n <button\n *ngFor=\"let iconName of filteredOptions$ | async\"\n type=\"button\"\n (click)=\"selectIcon(iconName)\"\n class=\"icon-option\"\n [class.selected]=\"value === iconName\"\n [title]=\"iconName\"\n [attr.aria-labelledby]=\"showText ? id + '_' + iconName : null\">\n <div class=\"icon-container\">\n <i class=\"fs-2xl fas fa-{{ iconName }}\"></i>\n </div>\n <div\n id=\"{{ id }}_{{ iconName }}\"\n class=\"icon-label\"\n [class.sr-only]=\"!showText\">\n {{ iconName }}\n </div>\n </button>\n </div>\n </div>\n</div>\n", styles: [":host{padding:0!important;position:relative}:host.impdc-select-icon--disabled{background-color:var(--impd-color-gray-100)}.impdc-select-icon--toggle{font-weight:inherit;padding-right:3.6rem;-webkit-user-select:none;user-select:none;width:100%}:host-context(.is-invalid) .impdc-select-icon--toggle{padding-right:6.6rem}.impdc-select-icon--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.select-icon-dropdown-menu{background-color:var(--impd-color-white);color:var(--impd-color-gray-600);max-width:51.2rem;min-width:32rem;overflow:hidden;width:100%}.select-icon-search{margin:var(--impd-size-2);font-size:var(--impd-font-size-sm)}.select-icon-grid{display:grid;align-items:start;grid-template-columns:repeat(auto-fit,minmax(4.8rem,1fr));gap:var(--impd-size-4);width:100%;max-height:var(--impd-size-40);overflow-y:auto;overflow-x:hidden;padding:var(--impd-size-4);-webkit-user-select:none;user-select:none}button[ngbDropdownToggle].dropdown-toggle:after{display:none}.icon-option{padding:0;background:unset;border:none}.icon-option:focus{outline:0}.icon-container{height:4rem;width:4rem;margin-left:auto;margin-right:auto;display:flex;align-items:center;justify-content:center;border-radius:50%;justify-items:center}.selected>.icon-container,:hover>.icon-container,:focus>.icon-container{background-color:var(--impartner-hex-primary);color:var(--impartner-hex-white)}.icon-label{text-align:center;font-size:1rem}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i4.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i4.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "component", type: i5.FormFieldComponent, selector: "impdc-form-field", exportAs: ["impdcFormField"] }, { kind: "directive", type: i6.InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }, { kind: "directive", type: i7.PrefixDirective, selector: "[impdcPrefix], [impdcTextPrefix]", inputs: ["impdcTextPrefix"] }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
245
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectIconComponent, decorators: [{
|
|
246
|
+
type: Component,
|
|
247
|
+
args: [{ selector: 'impdc-select-icon', inputs: ['disabled', 'tabIndex'], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
248
|
+
class: 'impdc-select-icon',
|
|
249
|
+
'[attr.id]': 'id',
|
|
250
|
+
'[attr.tabindex]': 'tabIndex',
|
|
251
|
+
'[attr.aria-required]': 'required.toString()',
|
|
252
|
+
'[attr.aria-disabled]': 'disabled.toString()',
|
|
253
|
+
'[attr.aria-invalid]': 'errorState',
|
|
254
|
+
'[class.form-select]': 'true',
|
|
255
|
+
'[class.is-invalid]': 'errorState',
|
|
256
|
+
'[class.impdc-form-field-control]': 'true',
|
|
257
|
+
'[class.impdc-select-icon--required]': 'required',
|
|
258
|
+
'[class.impdc-select-icon--disabled]': 'disabled',
|
|
259
|
+
'[class.impdc-select-icon--invalid]': 'errorState',
|
|
260
|
+
'[class.impdc-select-icon--empty]': 'empty',
|
|
261
|
+
'(focus)': '_onFocus(); focus()'
|
|
262
|
+
}, providers: [
|
|
263
|
+
{
|
|
264
|
+
provide: ImpdcFormFieldControl,
|
|
265
|
+
useExisting: SelectIconComponent
|
|
266
|
+
}
|
|
267
|
+
], template: "<div\n ngbDropdown\n autoClose=\"outside\"\n container=\"body\"\n dropdownClass=\"impartner-hex\"\n (openChange)=\"handleOpenChange($event)\"\n class=\"w-100\">\n <button\n #toggleButton\n class=\"impdc-select-icon--toggle btn border-0 text-start\"\n type=\"button\"\n role=\"combobox\"\n [disabled]=\"disabled\"\n ngbDropdownToggle>\n <ng-container [ngSwitch]=\"empty\">\n <span\n class=\"impdc-select-icon--text impdc-select-icon--placeholder\"\n *ngSwitchCase=\"true\">\n {{ placeholder }}\n </span>\n <div\n class=\"impdc-select-icon--text impdc-select-icon--value-text\"\n *ngSwitchCase=\"false\">\n <i class=\"fas fa-{{ value }}\"></i>\n <span *ngIf=\"showSelectedText\" class=\"ms-2\">{{ value }}</span>\n </div>\n </ng-container>\n </button>\n <div ngbDropdownMenu class=\"select-icon-dropdown-menu\" tabindex=\"-1\">\n <div *ngIf=\"allowSearch\" class=\"select-icon-search\">\n <impdc-form-field>\n <span impdcTextPrefix><i class=\"fas fa-search\"></i></span>\n <input\n impdcInput\n [formControl]=\"searchControl\"\n class=\"select-icon-search-input\"\n type=\"search\" />\n </impdc-form-field>\n </div>\n <div class=\"select-icon-grid\">\n <button\n *ngFor=\"let iconName of filteredOptions$ | async\"\n type=\"button\"\n (click)=\"selectIcon(iconName)\"\n class=\"icon-option\"\n [class.selected]=\"value === iconName\"\n [title]=\"iconName\"\n [attr.aria-labelledby]=\"showText ? id + '_' + iconName : null\">\n <div class=\"icon-container\">\n <i class=\"fs-2xl fas fa-{{ iconName }}\"></i>\n </div>\n <div\n id=\"{{ id }}_{{ iconName }}\"\n class=\"icon-label\"\n [class.sr-only]=\"!showText\">\n {{ iconName }}\n </div>\n </button>\n </div>\n </div>\n</div>\n", styles: [":host{padding:0!important;position:relative}:host.impdc-select-icon--disabled{background-color:var(--impd-color-gray-100)}.impdc-select-icon--toggle{font-weight:inherit;padding-right:3.6rem;-webkit-user-select:none;user-select:none;width:100%}:host-context(.is-invalid) .impdc-select-icon--toggle{padding-right:6.6rem}.impdc-select-icon--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.select-icon-dropdown-menu{background-color:var(--impd-color-white);color:var(--impd-color-gray-600);max-width:51.2rem;min-width:32rem;overflow:hidden;width:100%}.select-icon-search{margin:var(--impd-size-2);font-size:var(--impd-font-size-sm)}.select-icon-grid{display:grid;align-items:start;grid-template-columns:repeat(auto-fit,minmax(4.8rem,1fr));gap:var(--impd-size-4);width:100%;max-height:var(--impd-size-40);overflow-y:auto;overflow-x:hidden;padding:var(--impd-size-4);-webkit-user-select:none;user-select:none}button[ngbDropdownToggle].dropdown-toggle:after{display:none}.icon-option{padding:0;background:unset;border:none}.icon-option:focus{outline:0}.icon-container{height:4rem;width:4rem;margin-left:auto;margin-right:auto;display:flex;align-items:center;justify-content:center;border-radius:50%;justify-items:center}.selected>.icon-container,:hover>.icon-container,:focus>.icon-container{background-color:var(--impartner-hex-primary);color:var(--impartner-hex-white)}.icon-label{text-align:center;font-size:1rem}\n"] }]
|
|
268
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
|
|
269
|
+
type: Optional
|
|
270
|
+
}, {
|
|
271
|
+
type: Inject,
|
|
272
|
+
args: [IMPDC_FORM_ROOT]
|
|
273
|
+
}] }, { type: i2.NgForm, decorators: [{
|
|
274
|
+
type: Optional
|
|
275
|
+
}] }, { type: i2.FormGroupDirective, decorators: [{
|
|
276
|
+
type: Optional
|
|
277
|
+
}] }, { type: i2.NgControl, decorators: [{
|
|
278
|
+
type: Self
|
|
279
|
+
}, {
|
|
280
|
+
type: Optional
|
|
281
|
+
}] }]; }, propDecorators: { _toggleButtonRef: [{
|
|
282
|
+
type: ViewChild,
|
|
283
|
+
args: ['toggleButton', { static: true, read: ElementRef }]
|
|
284
|
+
}], allowSearch: [{
|
|
285
|
+
type: Input
|
|
286
|
+
}], iconOptions: [{
|
|
287
|
+
type: Input
|
|
288
|
+
}], showText: [{
|
|
289
|
+
type: Input
|
|
290
|
+
}], showSelectedText: [{
|
|
291
|
+
type: Input
|
|
292
|
+
}], placeholder: [{
|
|
293
|
+
type: Input
|
|
294
|
+
}], errorStateMatcher: [{
|
|
295
|
+
type: Input
|
|
296
|
+
}], selectionChange: [{
|
|
297
|
+
type: Output
|
|
298
|
+
}], valueChange: [{
|
|
299
|
+
type: Output
|
|
300
|
+
}], value: [{
|
|
301
|
+
type: Input
|
|
302
|
+
}], id: [{
|
|
303
|
+
type: Input
|
|
304
|
+
}], required: [{
|
|
305
|
+
type: Input
|
|
306
|
+
}] } });
|
|
307
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-icon.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/select-icon/select-icon.component.ts","../../../../../../projects/design-components/src/lib/select-icon/select-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-conflicting-lifecycle */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  Validators\n} from '@angular/forms';\nimport { nanoid } from 'nanoid';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  distinctUntilChanged,\n  map,\n  Observable,\n  startWith,\n  Subject\n} from 'rxjs';\nimport { FontAwesomeIcons } from '../../constants';\nimport { BooleanInput, coerceBooleanPropertyValue } from '../../utilities';\nimport {\n  ErrorStateMatcher,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  ImpdcFormRoot,\n  IMPDC_FORM_ROOT,\n  mixinDisabled,\n  mixinErrorState,\n  mixinTabIndex\n} from '../form-field';\n\nexport class ImpdcSelectIconChange {\n  constructor(public source: SelectIconComponent, public value: any) {}\n}\n\nconst _SelectIconComponentBase = mixinTabIndex(\n  mixinDisabled(\n    mixinErrorState(\n      class {\n        public readonly stateChanges = new Subject<void>();\n\n        constructor(\n          public _defaultErrorStateMatcher: ErrorStateMatcher,\n          public _formRoot: ImpdcFormRoot,\n          public _parentForm: NgForm,\n          public _parentFormGroup: FormGroupDirective,\n          public ngControl: NgControl | null\n        ) {}\n      }\n    )\n  )\n);\n\n/**\n * The `SelectIconComponent` (`<impdc-select-icon`) is a select dropdown with search that shows all standard icons from Bootstrap 5.\n * To use, import `SelectIconModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-select-icon',\n  templateUrl: './select-icon.component.html',\n  styleUrls: ['./select-icon.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['disabled', 'tabIndex'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-select-icon',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'tabIndex',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.form-select]': 'true',\n    '[class.is-invalid]': 'errorState',\n    '[class.impdc-form-field-control]': 'true',\n    '[class.impdc-select-icon--required]': 'required',\n    '[class.impdc-select-icon--disabled]': 'disabled',\n    '[class.impdc-select-icon--invalid]': 'errorState',\n    '[class.impdc-select-icon--empty]': 'empty',\n    '(focus)': '_onFocus(); focus()'\n  },\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: SelectIconComponent\n    }\n  ]\n})\nexport class SelectIconComponent\n  extends _SelectIconComponentBase\n  implements\n    ControlValueAccessor,\n    ImpdcFormFieldControl<string | null>,\n    ICanUpdateErrorState,\n    IHasErrorState,\n    DoCheck,\n    OnChanges,\n    OnDestroy\n{\n  @ViewChild('toggleButton', { static: true, read: ElementRef })\n  protected _toggleButtonRef!: ElementRef<HTMLButtonElement>;\n\n  protected readonly filteredOptions$: Observable<string[]>;\n  protected readonly searchControl = new FormControl<string>('');\n  protected readonly _uid = `impdc-select-icon-${nanoid()}`;\n  protected _dropdownOpen = false;\n\n  private readonly _iconOptionsSubject = new BehaviorSubject<readonly string[]>(\n    FontAwesomeIcons\n  );\n  private _previousControl?: AbstractControl | null;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  /**\n   * Set whether or not an input field will appear for searching and\n   * filtering icon options.\n   * @default true\n   */\n  @Input()\n  public allowSearch: boolean;\n\n  public get iconOptions(): string[] {\n    return [...this._iconOptionsSubject.value];\n  }\n\n  /**\n   * Set to override the default set of FontAwesome icon options.\n   */\n  @Input()\n  public set iconOptions(iconOptions: string[]) {\n    if (iconOptions) {\n      this._iconOptionsSubject.next([...iconOptions]);\n    }\n  }\n\n  /**\n   * Set whether or not to show the icon names as labels for icon options.\n   * @default true\n   */\n  @Input()\n  public showText: boolean;\n\n  /**\n   * Set whether or not to show the name of the selected icon inside the control.\n   * @default true\n   */\n  @Input()\n  public showSelectedText: boolean;\n\n  /**\n   * The placeholder text that will be displayed when no selection has been made.\n   *\n   * @default \\- Select -\n   */\n  @Input()\n  public get placeholder(): string {\n    return this._placeholder;\n  }\n  public set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n  private _placeholder: string = '- Select -';\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /** Events fire when selection has been changed by the user. */\n  @Output()\n  public readonly selectionChange: EventEmitter<ImpdcSelectIconChange> = new EventEmitter<ImpdcSelectIconChange>();\n\n  /**\n   * Events fire when raw value of select changes. Mainly exists to handle\n   * two-way binding of `value` input property.\n   * @ignore\n   */\n  @Output()\n  public readonly valueChange = new EventEmitter<string | null>();\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    _defaultErrorStateMatcher: ErrorStateMatcher,\n    @Optional() @Inject(IMPDC_FORM_ROOT) _formRoot: ImpdcFormRoot,\n    @Optional() _parentForm: NgForm,\n    @Optional() _parentFormGroup: FormGroupDirective,\n    @Self() @Optional() ngControl: NgControl\n  ) {\n    super(\n      _defaultErrorStateMatcher,\n      _formRoot,\n      _parentForm,\n      _parentFormGroup,\n      ngControl\n    );\n\n    this.allowSearch = false;\n    this.showText = true;\n    this.showSelectedText = true;\n\n    const debouncedSearchValues = this.searchControl.valueChanges.pipe(\n      startWith(''),\n      debounceTime(200),\n      distinctUntilChanged()\n    );\n    this.filteredOptions$ = combineLatest([\n      debouncedSearchValues,\n      this._iconOptionsSubject.asObservable()\n    ]).pipe(\n      map(([searchTerm, iconOptions]) => {\n        if (!searchTerm) {\n          return [...iconOptions];\n        }\n\n        const searchTermLowerCase = searchTerm.toLowerCase();\n        return iconOptions.filter(\n          option => option.toLowerCase().indexOf(searchTermLowerCase) > -1\n        );\n      })\n    );\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    this.id = this.id;\n  }\n\n  public get empty(): boolean {\n    return !this.value;\n  }\n\n  /** @ignore */\n  public focus(options?: FocusOptions): void {\n    this._toggleButtonRef.nativeElement.focus(options);\n  }\n\n  /* Lifecycle Hooks */\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (this._previousControl !== ngControl.control) {\n      if (\n        this._previousControl !== undefined &&\n        ngControl.disabled !== null &&\n        ngControl.disabled !== this.disabled\n      ) {\n        this.disabled = ngControl?.disabled;\n      }\n\n      this._previousControl = ngControl.control;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnChanges(changes: SimpleChanges): void {\n    // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal\n    // to the parent form field so it can run change detection when disabled state is changed.\n    if (changes['disabled']) {\n      this.stateChanges.next();\n    }\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /* ControlValueAccessor */\n\n  /** @ignore */\n  public writeValue(value: string): void {\n    this.value = value;\n    this._changeDetector.markForCheck();\n  }\n\n  /** @ignore */\n  public registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  public registerOnTouched(fn: () => {}): void {\n    this._cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  public setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this._changeDetector.markForCheck();\n  }\n\n  /* ImpdcFormFieldControl */\n\n  @Input()\n  public get value(): string | null {\n    return this._value;\n  }\n  public set value(value: string | null) {\n    const newValue =\n      (value && this.iconOptions.find(opt => opt === value)) || null;\n\n    if (newValue !== this._value) {\n      this._value = newValue;\n      this.stateChanges.next();\n    }\n  }\n  private _value: string | null = null;\n\n  @Input()\n  public get id(): string {\n    return this._id;\n  }\n  public set id(value: string) {\n    this._id = value || this._uid;\n    this.stateChanges.next();\n  }\n  protected _id!: string;\n\n  /**\n   * Used to set requiredness of control in a template-based manner;\n   * not necessary when using the Angular reactive forms API and `required` validator.\n   *\n   * @default false\n   */\n  @Input()\n  public get required(): boolean {\n    return (\n      this._required ??\n      this.ngControl?.control?.hasValidator(Validators.required) ??\n      false\n    );\n  }\n  public set required(value: BooleanInput) {\n    this._required = coerceBooleanPropertyValue(value);\n    this.stateChanges.next();\n  }\n  private _required: boolean | undefined;\n\n  public get focused(): boolean {\n    return this._focused || this._dropdownOpen;\n  }\n  protected _focused = false;\n\n  public readonly controlType: string = 'impdc-select-icon';\n  public readonly supportsAffixes: boolean = true;\n\n  /* Internals */\n\n  protected handleOpenChange(isOpen: boolean): void {\n    this._dropdownOpen = isOpen;\n    this.searchControl.reset();\n\n    if (isOpen) {\n      this._onFocus();\n    } else {\n      this._onBlur();\n    }\n\n    this.stateChanges.next();\n  }\n\n  protected selectIcon(iconName: string): void {\n    if (iconName !== this.value) {\n      this.value = iconName;\n      this.valueChange.emit(this.value);\n      this._cvaOnChange(this.value);\n      this.selectionChange.emit(this._buildChangeEvent(this.value));\n      this._changeDetector.markForCheck();\n    }\n\n    if (this._dropdownOpen) {\n      this.focus();\n    }\n  }\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  /**\n   * Calls the CVA touched callback only if the dropdown is closed.\n   */\n  protected _onBlur(): void {\n    this._focused = false;\n\n    if (!this.disabled && !this._dropdownOpen) {\n      this._cvaOnTouched();\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n\n  private _buildChangeEvent(value: string | null): ImpdcSelectIconChange {\n    return new ImpdcSelectIconChange(this, value);\n  }\n}\n","<div\n  ngbDropdown\n  autoClose=\"outside\"\n  container=\"body\"\n  dropdownClass=\"impartner-hex\"\n  (openChange)=\"handleOpenChange($event)\"\n  class=\"w-100\">\n  <button\n    #toggleButton\n    class=\"impdc-select-icon--toggle btn border-0 text-start\"\n    type=\"button\"\n    role=\"combobox\"\n    [disabled]=\"disabled\"\n    ngbDropdownToggle>\n    <ng-container [ngSwitch]=\"empty\">\n      <span\n        class=\"impdc-select-icon--text impdc-select-icon--placeholder\"\n        *ngSwitchCase=\"true\">\n        {{ placeholder }}\n      </span>\n      <div\n        class=\"impdc-select-icon--text impdc-select-icon--value-text\"\n        *ngSwitchCase=\"false\">\n        <i class=\"fas fa-{{ value }}\"></i>\n        <span *ngIf=\"showSelectedText\" class=\"ms-2\">{{ value }}</span>\n      </div>\n    </ng-container>\n  </button>\n  <div ngbDropdownMenu class=\"select-icon-dropdown-menu\" tabindex=\"-1\">\n    <div *ngIf=\"allowSearch\" class=\"select-icon-search\">\n      <impdc-form-field>\n        <span impdcTextPrefix><i class=\"fas fa-search\"></i></span>\n        <input\n          impdcInput\n          [formControl]=\"searchControl\"\n          class=\"select-icon-search-input\"\n          type=\"search\" />\n      </impdc-form-field>\n    </div>\n    <div class=\"select-icon-grid\">\n      <button\n        *ngFor=\"let iconName of filteredOptions$ | async\"\n        type=\"button\"\n        (click)=\"selectIcon(iconName)\"\n        class=\"icon-option\"\n        [class.selected]=\"value === iconName\"\n        [title]=\"iconName\"\n        [attr.aria-labelledby]=\"showText ? id + '_' + iconName : null\">\n        <div class=\"icon-container\">\n          <i class=\"fs-2xl fas fa-{{ iconName }}\"></i>\n        </div>\n        <div\n          id=\"{{ id }}_{{ iconName }}\"\n          class=\"icon-label\"\n          [class.sr-only]=\"!showText\">\n          {{ iconName }}\n        </div>\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|