@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,337 @@
|
|
|
1
|
+
import { Attribute, ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Input, Optional, Output, Self, ViewChild } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
import { nanoid } from 'nanoid';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { coerceBooleanPropertyValue } from '../../../../utilities';
|
|
6
|
+
import { IMPDC_FORM_ROOT } from '../../directives';
|
|
7
|
+
import { ImpdcFormFieldControl, mixinErrorState, mixinTabIndex } from '../../shared';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../services";
|
|
10
|
+
import * as i2 from "@angular/forms";
|
|
11
|
+
import * as i3 from "../shared/toggle/toggle.component";
|
|
12
|
+
import * as i4 from "../shared/toggle/components/toggle-input/toggle-input.component";
|
|
13
|
+
export class CheckboxChangeEvent {
|
|
14
|
+
constructor(
|
|
15
|
+
/** The specific checkbox that changed. */
|
|
16
|
+
source,
|
|
17
|
+
/** Whether the changed checkbox was checked or unchecked at the time of the event. */
|
|
18
|
+
checked) {
|
|
19
|
+
this.source = source;
|
|
20
|
+
this.checked = checked;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
class CheckboxComponentBase {
|
|
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
|
+
const _CheckboxComponentMixinBase = mixinTabIndex(mixinErrorState(CheckboxComponentBase));
|
|
34
|
+
/**
|
|
35
|
+
* The `CheckboxComponent` (`<impdc-checkbox`) is an input with a simple boolean value as a checkbox or toggle switch.
|
|
36
|
+
* This component can be used within a `FormFieldComponent` (`<impdc-form-field`).
|
|
37
|
+
* To use, import `CheckboxModule` or another module that imports and exports that module from `@impartner/design-components`.
|
|
38
|
+
*/
|
|
39
|
+
export class CheckboxComponent extends _CheckboxComponentMixinBase {
|
|
40
|
+
constructor(_changeDetector, tabIndex, defaultErrorStateMatcher, formRoot, parentForm, parentFormGroup, ngControl) {
|
|
41
|
+
super(defaultErrorStateMatcher, formRoot, parentForm, parentFormGroup, ngControl);
|
|
42
|
+
this._changeDetector = _changeDetector;
|
|
43
|
+
this._uid = `impdc-checkbox-${nanoid()}`;
|
|
44
|
+
this._cvaOnChange = () => { };
|
|
45
|
+
this._cvaOnTouched = () => { };
|
|
46
|
+
this.id = this._uid;
|
|
47
|
+
/**
|
|
48
|
+
* The primary label text for the checkbox control.
|
|
49
|
+
*/
|
|
50
|
+
this.label = '';
|
|
51
|
+
/**
|
|
52
|
+
* Text to provide additional description or context for the checkbox control. Does not display when `inline` is `true`.
|
|
53
|
+
*/
|
|
54
|
+
this.description = '';
|
|
55
|
+
/**
|
|
56
|
+
* Whether or not the input displays as a toggle switch.
|
|
57
|
+
*/
|
|
58
|
+
this.isSwitch = false;
|
|
59
|
+
/**
|
|
60
|
+
* When `isSwitch` is `true`, sets whether or not the toggle switch uses icons.
|
|
61
|
+
*/
|
|
62
|
+
this.switchIcons = false;
|
|
63
|
+
/**
|
|
64
|
+
* Whether or not the checkbox displays inline.
|
|
65
|
+
*/
|
|
66
|
+
this.inline = false;
|
|
67
|
+
this._indeterminate = false;
|
|
68
|
+
this._disabled = false;
|
|
69
|
+
/**
|
|
70
|
+
* Event emitted whenever the checkedness of the input changes.
|
|
71
|
+
*/
|
|
72
|
+
this.change = new EventEmitter();
|
|
73
|
+
/**
|
|
74
|
+
* Event emitted whenever the control enters or leaves an `indeterminate` state.
|
|
75
|
+
*/
|
|
76
|
+
this.indeterminateChange = new EventEmitter();
|
|
77
|
+
this._value = false;
|
|
78
|
+
this._focused = false;
|
|
79
|
+
this.controlType = 'impdc-check';
|
|
80
|
+
this.supportsAffixes = false;
|
|
81
|
+
this.tabIndex = parseInt(tabIndex) || 0;
|
|
82
|
+
if (this.ngControl) {
|
|
83
|
+
this.ngControl.valueAccessor = this;
|
|
84
|
+
this.ngControl.control?.addValidators(() => {
|
|
85
|
+
return this.validate();
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Whether or not the checkbox input is checked.
|
|
91
|
+
*/
|
|
92
|
+
get checked() {
|
|
93
|
+
return this.value;
|
|
94
|
+
}
|
|
95
|
+
set checked(value) {
|
|
96
|
+
this.value = value;
|
|
97
|
+
this._cvaOnChange(this.value);
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Whether or not the checkbox input is in an `indeterminate` state.
|
|
101
|
+
*/
|
|
102
|
+
get indeterminate() {
|
|
103
|
+
return this._indeterminate;
|
|
104
|
+
}
|
|
105
|
+
set indeterminate(value) {
|
|
106
|
+
const coercedValue = coerceBooleanPropertyValue(value);
|
|
107
|
+
const isChange = coercedValue !== this._indeterminate;
|
|
108
|
+
this._indeterminate = coercedValue;
|
|
109
|
+
if (isChange) {
|
|
110
|
+
this.indeterminateChange.emit(this._indeterminate);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
get disabled() {
|
|
114
|
+
return this._disabled;
|
|
115
|
+
}
|
|
116
|
+
set disabled(value) {
|
|
117
|
+
const newDisabledState = coerceBooleanPropertyValue(value);
|
|
118
|
+
if (newDisabledState !== this._disabled) {
|
|
119
|
+
this._disabled = newDisabledState;
|
|
120
|
+
this._changeDetector.markForCheck();
|
|
121
|
+
this.stateChanges.next();
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
get inputId() {
|
|
125
|
+
return `${this.id || this._uid}-input`;
|
|
126
|
+
}
|
|
127
|
+
/** @ignore */
|
|
128
|
+
ngDoCheck() {
|
|
129
|
+
const ngControl = this.ngControl;
|
|
130
|
+
if (!ngControl) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
this.updateErrorState();
|
|
134
|
+
}
|
|
135
|
+
/** @ignore */
|
|
136
|
+
ngOnDestroy() {
|
|
137
|
+
this.stateChanges.complete();
|
|
138
|
+
}
|
|
139
|
+
/* ImpdcFormFieldControl */
|
|
140
|
+
get value() {
|
|
141
|
+
return this._value;
|
|
142
|
+
}
|
|
143
|
+
set value(value) {
|
|
144
|
+
const newValue = coerceBooleanPropertyValue(value);
|
|
145
|
+
if (newValue !== this._value) {
|
|
146
|
+
this._value = newValue;
|
|
147
|
+
this._changeDetector.markForCheck();
|
|
148
|
+
this.stateChanges.next();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
get focused() {
|
|
152
|
+
return this._focused;
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Used to set requiredness of control in a template-based manner; not necessary when using the
|
|
156
|
+
* Angular reactive forms API and 'required' or `requiredTrue` validators.
|
|
157
|
+
*/
|
|
158
|
+
get required() {
|
|
159
|
+
if (this._required !== undefined) {
|
|
160
|
+
return this._required;
|
|
161
|
+
}
|
|
162
|
+
const control = this.ngControl?.control;
|
|
163
|
+
if (control) {
|
|
164
|
+
const hasRequired = control.hasValidator(Validators.required);
|
|
165
|
+
const hasRequiredTrue = control.hasValidator(Validators.requiredTrue);
|
|
166
|
+
return hasRequired || hasRequiredTrue;
|
|
167
|
+
}
|
|
168
|
+
return false;
|
|
169
|
+
}
|
|
170
|
+
set required(value) {
|
|
171
|
+
this._required = coerceBooleanPropertyValue(value);
|
|
172
|
+
this.stateChanges.next();
|
|
173
|
+
}
|
|
174
|
+
/* ControlValueAccessor */
|
|
175
|
+
/** @ignore */
|
|
176
|
+
writeValue(value) {
|
|
177
|
+
this.value = !!value;
|
|
178
|
+
this._changeDetector.markForCheck();
|
|
179
|
+
}
|
|
180
|
+
/** @ignore */
|
|
181
|
+
registerOnChange(fn) {
|
|
182
|
+
this._cvaOnChange = fn;
|
|
183
|
+
}
|
|
184
|
+
/** @ignore */
|
|
185
|
+
registerOnTouched(fn) {
|
|
186
|
+
this._cvaOnTouched = fn;
|
|
187
|
+
}
|
|
188
|
+
/** @ignore */
|
|
189
|
+
setDisabledState(isDisabled) {
|
|
190
|
+
this.disabled = isDisabled;
|
|
191
|
+
this._changeDetector.markForCheck();
|
|
192
|
+
}
|
|
193
|
+
/* Validator */
|
|
194
|
+
/** @ignore */
|
|
195
|
+
validate() {
|
|
196
|
+
return !this.disabled && this.required && !this.value
|
|
197
|
+
? { required: true }
|
|
198
|
+
: null;
|
|
199
|
+
}
|
|
200
|
+
/* Internals */
|
|
201
|
+
_getAriaChecked() {
|
|
202
|
+
if (this.checked) {
|
|
203
|
+
return 'true';
|
|
204
|
+
}
|
|
205
|
+
return this.indeterminate ? 'mixed' : 'false';
|
|
206
|
+
}
|
|
207
|
+
_onBlur() {
|
|
208
|
+
this._focused = false;
|
|
209
|
+
// When a focused element becomes disabled, the browser *immediately* fires a blur event.
|
|
210
|
+
// Angular does not expect events to be raised during change detection, so any state change
|
|
211
|
+
// (such as a form control's 'ng-touched') will cause a changed-after-checked error.
|
|
212
|
+
// See https://github.com/angular/angular/issues/17793. To work around this, we defer
|
|
213
|
+
// telling the form control it has been touched until the next tick.
|
|
214
|
+
Promise.resolve().then(() => {
|
|
215
|
+
this._cvaOnTouched();
|
|
216
|
+
this._changeDetector.markForCheck();
|
|
217
|
+
this.stateChanges.next();
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
_onFocus() {
|
|
221
|
+
if (!this.disabled) {
|
|
222
|
+
this._focused = true;
|
|
223
|
+
this.stateChanges.next();
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
_handleCheckClick() {
|
|
227
|
+
if (!this.disabled) {
|
|
228
|
+
if (this.indeterminate) {
|
|
229
|
+
Promise.resolve().then(() => {
|
|
230
|
+
this.indeterminate = false;
|
|
231
|
+
this.indeterminateChange.emit(this._indeterminate);
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
this.checked = !this.checked;
|
|
235
|
+
this._emitChangeEvents();
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
_onInteractionEvent(event) {
|
|
239
|
+
// We always have to stop propagation on the change event.
|
|
240
|
+
// Otherwise the change event, from the input element, will bubble up and
|
|
241
|
+
// emit its event object to the `change` output.
|
|
242
|
+
event.stopPropagation();
|
|
243
|
+
}
|
|
244
|
+
_emitChangeEvents() {
|
|
245
|
+
this._cvaOnChange(this.checked);
|
|
246
|
+
this.change.emit(new CheckboxChangeEvent(this, this.checked));
|
|
247
|
+
// Assigning the value again here is redundant, but we have to do it in case it was
|
|
248
|
+
// changed inside the `change` listener which will cause the input to be out of sync.
|
|
249
|
+
if (this._inputElement) {
|
|
250
|
+
this._inputElement.nativeElement.checked = this.checked;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Prevent click events that come from the `<label/>` element from bubbling. This prevents the
|
|
255
|
+
* click handler on the host from triggering twice when clicking on the `<label/>` element. After
|
|
256
|
+
* the click event on the `<label/>` propagates, the browsers dispatches click on the associated
|
|
257
|
+
* `<input/>`. By preventing clicks on the label by bubbling, we ensure only one click event
|
|
258
|
+
* bubbles when the label is clicked.
|
|
259
|
+
*/
|
|
260
|
+
_preventBubblingFromLabel(event) {
|
|
261
|
+
if (!!event.target &&
|
|
262
|
+
!!this._inputElement &&
|
|
263
|
+
!event.target.contains(this._inputElement.nativeElement)) {
|
|
264
|
+
event.stopPropagation();
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
CheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: 'tabindex', attribute: true }, { 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 });
|
|
269
|
+
CheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CheckboxComponent, selector: "impdc-checkbox", inputs: { tabIndex: "tabIndex", id: "id", label: "label", description: "description", isSwitch: "isSwitch", switchIcons: "switchIcons", inline: "inline", checked: "checked", indeterminate: "indeterminate", disabled: "disabled", errorStateMatcher: "errorStateMatcher", required: "required" }, outputs: { change: "change", indeterminateChange: "indeterminateChange" }, host: { properties: { "attr.id": "id", "attr.tabindex": "null", "class.impdc-checkbox--required": "required", "class.impdc-checkbox--disabled": "disabled", "class.impdc-checkbox--invalid": "errorState", "class.impdc-checkbox--inline": "inline" }, classAttribute: "impdc-checkbox" }, providers: [
|
|
270
|
+
{
|
|
271
|
+
provide: ImpdcFormFieldControl,
|
|
272
|
+
useExisting: CheckboxComponent
|
|
273
|
+
}
|
|
274
|
+
], viewQueries: [{ propertyName: "_inputElement", first: true, predicate: ["nativeInput"], descendants: true, read: ElementRef }], exportAs: ["impdcCheckControl"], usesInheritance: true, ngImport: i0, template: "<impdc-toggle\n [label]=\"label\"\n [description]=\"description\"\n [isSwitch]=\"isSwitch\"\n [switchIcons]=\"switchIcons\"\n [inline]=\"inline\"\n (click)=\"_preventBubblingFromLabel($event)\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"checkbox\"\n class=\"impdc-checkbox__native-control\"\n [class.is-invalid]=\"errorState\"\n [id]=\"inputId\"\n [attr.aria-checked]=\"_getAriaChecked()\"\n [attr.aria-required]=\"required\"\n [attr.tabindex]=\"tabIndex\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (change)=\"_onInteractionEvent($event)\"\n (click)=\"_handleCheckClick()\"\n (blur)=\"_onBlur()\"\n (focus)=\"_onFocus()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-checkbox--inline{display:inline-block}:host.impdc-checkbox--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-checkbox--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-checkbox--disabled{--impartner-hex-input-opacity: .5}:host.impdc-checkbox--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"], dependencies: [{ kind: "component", type: i3.ToggleComponent, selector: "impdc-toggle", inputs: ["isSwitch", "label", "description", "inline", "switchIcons"] }, { kind: "component", type: i4.ToggleInputComponent, selector: "input[impdc-toggle-input]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
275
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxComponent, decorators: [{
|
|
276
|
+
type: Component,
|
|
277
|
+
args: [{ selector: 'impdc-checkbox', host: {
|
|
278
|
+
class: 'impdc-checkbox',
|
|
279
|
+
'[attr.id]': 'id',
|
|
280
|
+
'[attr.tabindex]': 'null',
|
|
281
|
+
'[class.impdc-checkbox--required]': 'required',
|
|
282
|
+
'[class.impdc-checkbox--disabled]': 'disabled',
|
|
283
|
+
'[class.impdc-checkbox--invalid]': 'errorState',
|
|
284
|
+
'[class.impdc-checkbox--inline]': 'inline'
|
|
285
|
+
}, inputs: ['tabIndex'], exportAs: 'impdcCheckControl', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
286
|
+
{
|
|
287
|
+
provide: ImpdcFormFieldControl,
|
|
288
|
+
useExisting: CheckboxComponent
|
|
289
|
+
}
|
|
290
|
+
], template: "<impdc-toggle\n [label]=\"label\"\n [description]=\"description\"\n [isSwitch]=\"isSwitch\"\n [switchIcons]=\"switchIcons\"\n [inline]=\"inline\"\n (click)=\"_preventBubblingFromLabel($event)\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"checkbox\"\n class=\"impdc-checkbox__native-control\"\n [class.is-invalid]=\"errorState\"\n [id]=\"inputId\"\n [attr.aria-checked]=\"_getAriaChecked()\"\n [attr.aria-required]=\"required\"\n [attr.tabindex]=\"tabIndex\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (change)=\"_onInteractionEvent($event)\"\n (click)=\"_handleCheckClick()\"\n (blur)=\"_onBlur()\"\n (focus)=\"_onFocus()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-checkbox--inline{display:inline-block}:host.impdc-checkbox--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-checkbox--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-checkbox--disabled{--impartner-hex-input-opacity: .5}:host.impdc-checkbox--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"] }]
|
|
291
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
292
|
+
type: Attribute,
|
|
293
|
+
args: ['tabindex']
|
|
294
|
+
}] }, { type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
|
|
295
|
+
type: Optional
|
|
296
|
+
}, {
|
|
297
|
+
type: Inject,
|
|
298
|
+
args: [IMPDC_FORM_ROOT]
|
|
299
|
+
}] }, { type: i2.NgForm, decorators: [{
|
|
300
|
+
type: Optional
|
|
301
|
+
}] }, { type: i2.FormGroupDirective, decorators: [{
|
|
302
|
+
type: Optional
|
|
303
|
+
}] }, { type: i2.NgControl, decorators: [{
|
|
304
|
+
type: Self
|
|
305
|
+
}, {
|
|
306
|
+
type: Optional
|
|
307
|
+
}] }]; }, propDecorators: { _inputElement: [{
|
|
308
|
+
type: ViewChild,
|
|
309
|
+
args: ['nativeInput', { read: ElementRef }]
|
|
310
|
+
}], id: [{
|
|
311
|
+
type: Input
|
|
312
|
+
}], label: [{
|
|
313
|
+
type: Input
|
|
314
|
+
}], description: [{
|
|
315
|
+
type: Input
|
|
316
|
+
}], isSwitch: [{
|
|
317
|
+
type: Input
|
|
318
|
+
}], switchIcons: [{
|
|
319
|
+
type: Input
|
|
320
|
+
}], inline: [{
|
|
321
|
+
type: Input
|
|
322
|
+
}], checked: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], indeterminate: [{
|
|
325
|
+
type: Input
|
|
326
|
+
}], disabled: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], errorStateMatcher: [{
|
|
329
|
+
type: Input
|
|
330
|
+
}], change: [{
|
|
331
|
+
type: Output
|
|
332
|
+
}], indeterminateChange: [{
|
|
333
|
+
type: Output
|
|
334
|
+
}], required: [{
|
|
335
|
+
type: Input
|
|
336
|
+
}] } });
|
|
337
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/form-field/controls/checkbox/checkbox.component.ts","../../../../../../../../projects/design-components/src/lib/form-field/controls/checkbox/checkbox.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAOL,UAAU,EACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAEL,0BAA0B,EAC3B,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAiB,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAElE,OAAO,EAIL,qBAAqB,EACrB,eAAe,EACf,aAAa,EACd,MAAM,cAAc,CAAC;;;;;;AAEtB,MAAM,OAAO,mBAAmB;IAC9B;IACE,0CAA0C;IAC1B,MAAyB;IACzC,sFAAsF;IACtE,OAAgB;QAFhB,WAAM,GAAN,MAAM,CAAmB;QAEzB,YAAO,GAAP,OAAO,CAAS;IAC/B,CAAC;CACL;AAED,MAAe,qBAAqB;IAKlC,YACS,yBAA4C,EAC5C,SAAwB,EACxB,WAAmB,EACnB,gBAAoC,EACpC,SAA2B;QAJ3B,8BAAyB,GAAzB,yBAAyB,CAAmB;QAC5C,cAAS,GAAT,SAAS,CAAe;QACxB,gBAAW,GAAX,WAAW,CAAQ;QACnB,qBAAgB,GAAhB,gBAAgB,CAAoB;QACpC,cAAS,GAAT,SAAS,CAAkB;QATpB,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;IAUhD,CAAC;CACL;AAED,MAAM,2BAA2B,GAAG,aAAa,CAC/C,eAAe,CAAC,qBAAqB,CAAC,CACvC,CAAC;AAEF;;;;GAIG;AA0BH,MAAM,OAAO,iBACX,SAAQ,2BAA2B;IAoHnC,YACmB,eAAkC,EAC5B,QAAgB,EACvC,wBAA2C,EACN,QAAuB,EAChD,UAAkB,EAClB,eAAmC,EAC3B,SAA2B;QAE/C,KAAK,CACH,wBAAwB,EACxB,QAAQ,EACR,UAAU,EACV,eAAe,EACf,SAAS,CACV,CAAC;QAde,oBAAe,GAAf,eAAe,CAAmB;QA1GpC,SAAI,GAAW,kBAAkB,MAAM,EAAE,EAAE,CAAC;QACrD,iBAAY,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;QAC9C,kBAAa,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAM1B,OAAE,GAAW,IAAI,CAAC,IAAI,CAAC;QAE9B;;WAEG;QAEI,UAAK,GAAW,EAAE,CAAC;QAE1B;;WAEG;QAEI,gBAAW,GAAW,EAAE,CAAC;QAEhC;;WAEG;QAEI,aAAQ,GAAY,KAAK,CAAC;QAEjC;;WAEG;QAEI,gBAAW,GAAY,KAAK,CAAC;QAEpC;;WAEG;QAEI,WAAM,GAAY,KAAK,CAAC;QA8BvB,mBAAc,GAAY,KAAK,CAAC;QAe9B,cAAS,GAAY,KAAK,CAAC;QAKrC;;WAEG;QAGa,WAAM,GAAsC,IAAI,YAAY,EAAuB,CAAC;QAEpG;;WAEG;QAEa,wBAAmB,GAA0B,IAAI,YAAY,EAAW,CAAC;QA+DjF,WAAM,GAAY,KAAK,CAAC;QAKxB,aAAQ,GAAY,KAAK,CAAC;QA4BlB,gBAAW,GAAW,aAAa,CAAC;QACpC,oBAAe,GAAY,KAAK,CAAC;QA1E/C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAExC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;YACpC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,aAAa,CAAC,GAAG,EAAE;gBACzC,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IA1FD;;OAEG;IACH,IACW,OAAO;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,IAAW,OAAO,CAAC,KAAmB;QACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,IACW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IACD,IAAW,aAAa,CAAC,KAAmB;QAC1C,MAAM,YAAY,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,QAAQ,GAAG,YAAY,KAAK,IAAI,CAAC,cAAc,CAAC;QACtD,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;QAEnC,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACpD;IACH,CAAC;IAGD,IACW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,MAAM,gBAAgB,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAE3D,IAAI,gBAAgB,KAAK,IAAI,CAAC,SAAS,EAAE;YACvC,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;YAClC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAmBD,IAAW,OAAO;QAChB,OAAO,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,QAAQ,CAAC;IACzC,CAAC;IA6BD,cAAc;IACP,SAAS;QACd,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAEjC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;SACR;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;IACP,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,2BAA2B;IAE3B,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAW,KAAK,CAAC,KAAmB;QAClC,MAAM,QAAQ,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAEnD,IAAI,QAAQ,KAAK,IAAI,CAAC,MAAM,EAAE;YAC5B,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAGD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAGD;;;OAGG;IACH,IACW,QAAQ;QACjB,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,OAAO,IAAI,CAAC,SAAS,CAAC;SACvB;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;QACxC,IAAI,OAAO,EAAE;YACX,MAAM,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC9D,MAAM,eAAe,GAAG,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;YAEtE,OAAO,WAAW,IAAI,eAAe,CAAC;SACvC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,IAAI,CAAC,SAAS,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAMD,0BAA0B;IAE1B,cAAc;IACP,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;QACrB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,cAAc;IACP,gBAAgB,CAAC,EAAwB;QAC9C,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED,cAAc;IACP,iBAAiB,CAAC,EAAY;QACnC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;IACP,gBAAgB,CAAC,UAAmB;QACzC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,eAAe;IAEf,cAAc;IACP,QAAQ;QACb,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK;YACnD,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;YACpB,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;IAED,eAAe;IACL,eAAe;QACvB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,OAAO,MAAM,CAAC;SACf;QAED,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;IAChD,CAAC;IAES,OAAO;QACf,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,yFAAyF;QACzF,2FAA2F;QAC3F,oFAAoF;QACpF,qFAAqF;QACrF,oEAAoE;QACpE,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;IAES,QAAQ;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAES,iBAAiB;QACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,IAAI,CAAC,aAAa,EAAE;gBACtB,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;oBAC1B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;oBAC3B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBACrD,CAAC,CAAC,CAAC;aACJ;YAED,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;YAE7B,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;IACH,CAAC;IAES,mBAAmB,CAAC,KAAY;QACxC,0DAA0D;QAC1D,yEAAyE;QACzE,gDAAgD;QAChD,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE9D,mFAAmF;QACnF,qFAAqF;QACrF,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;SACzD;IACH,CAAC;IAED;;;;;;OAMG;IACO,yBAAyB,CAAC,KAAiB;QACnD,IACE,CAAC,CAAC,KAAK,CAAC,MAAM;YACd,CAAC,CAAC,IAAI,CAAC,aAAa;YACpB,CAAE,KAAK,CAAC,MAAsB,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,EACzE;YACA,KAAK,CAAC,eAAe,EAAE,CAAC;SACzB;IACH,CAAC;;+GAjUU,iBAAiB,mDAuHf,UAAU,+DAED,eAAe;mGAzH1B,iBAAiB,mrBAPjB;QACT;YACE,OAAO,EAAE,qBAAqB;YAC9B,WAAW,EAAE,iBAAiB;SAC/B;KACF,mHAkBiC,UAAU,qFCnH9C,mxBA0BA;4FDyEa,iBAAiB;kBAzB7B,SAAS;+BACE,gBAAgB,QAIpB;wBACJ,KAAK,EAAE,gBAAgB;wBACvB,WAAW,EAAE,IAAI;wBACjB,iBAAiB,EAAE,MAAM;wBACzB,kCAAkC,EAAE,UAAU;wBAC9C,kCAAkC,EAAE,UAAU;wBAC9C,iCAAiC,EAAE,YAAY;wBAC/C,gCAAgC,EAAE,QAAQ;qBAC3C,UAEO,CAAC,UAAU,CAAC,YACV,mBAAmB,mBACZ,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,WAAW,mBAAmB;yBAC/B;qBACF;;0BAyHE,SAAS;2BAAC,UAAU;;0BAEpB,QAAQ;;0BAAI,MAAM;2BAAC,eAAe;;0BAClC,QAAQ;;0BACR,QAAQ;;0BACR,IAAI;;0BAAI,QAAQ;4CA3GT,aAAa;sBADtB,SAAS;uBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAIvC,EAAE;sBADR,KAAK;gBAOC,KAAK;sBADX,KAAK;gBAOC,WAAW;sBADjB,KAAK;gBAOC,QAAQ;sBADd,KAAK;gBAOC,WAAW;sBADjB,KAAK;gBAOC,MAAM;sBADZ,KAAK;gBAOK,OAAO;sBADjB,KAAK;gBAaK,aAAa;sBADvB,KAAK;gBAgBK,QAAQ;sBADlB,KAAK;gBAgBU,iBAAiB;sBADhC,KAAK;gBAQU,MAAM;sBAFrB,MAAM;gBAQS,mBAAmB;sBADlC,MAAM;gBA4EI,QAAQ;sBADlB,KAAK","sourcesContent":["import {\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ValidationErrors,\n  Validator,\n  Validators\n} from '@angular/forms';\nimport { nanoid } from 'nanoid';\nimport { Subject } from 'rxjs';\nimport {\n  BooleanInput,\n  coerceBooleanPropertyValue\n} from '../../../../utilities';\nimport { ImpdcFormRoot, IMPDC_FORM_ROOT } from '../../directives';\nimport { ErrorStateMatcher } from '../../services';\nimport {\n  HasTabIndex,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  mixinErrorState,\n  mixinTabIndex\n} from '../../shared';\n\nexport class CheckboxChangeEvent {\n  constructor(\n    /** The specific checkbox that changed. */\n    public readonly source: CheckboxComponent,\n    /** Whether the changed checkbox was checked or unchecked at the time of the event. */\n    public readonly checked: boolean\n  ) {}\n}\n\nabstract class CheckboxComponentBase {\n  public readonly stateChanges = new Subject<void>();\n\n  abstract disabled: boolean;\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\nconst _CheckboxComponentMixinBase = mixinTabIndex(\n  mixinErrorState(CheckboxComponentBase)\n);\n\n/**\n * The `CheckboxComponent` (`<impdc-checkbox`) is an input with a simple boolean value as a checkbox or toggle switch.\n * This component can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, import `CheckboxModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-checkbox',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'null',\n    '[class.impdc-checkbox--required]': 'required',\n    '[class.impdc-checkbox--disabled]': 'disabled',\n    '[class.impdc-checkbox--invalid]': 'errorState',\n    '[class.impdc-checkbox--inline]': 'inline'\n  },\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['tabIndex'],\n  exportAs: 'impdcCheckControl',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: CheckboxComponent\n    }\n  ]\n})\nexport class CheckboxComponent\n  extends _CheckboxComponentMixinBase\n  implements\n    DoCheck,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    HasTabIndex,\n    ImpdcFormFieldControl<boolean>,\n    ICanUpdateErrorState,\n    IHasErrorState\n{\n  private readonly _uid: string = `impdc-checkbox-${nanoid()}`;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  @ViewChild('nativeInput', { read: ElementRef })\n  protected _inputElement?: ElementRef<HTMLInputElement>;\n\n  @Input()\n  public id: string = this._uid;\n\n  /**\n   * The primary label text for the checkbox control.\n   */\n  @Input()\n  public label: string = '';\n\n  /**\n   * Text to provide additional description or context for the checkbox control. Does not display when `inline` is `true`.\n   */\n  @Input()\n  public description: string = '';\n\n  /**\n   * Whether or not the input displays as a toggle switch.\n   */\n  @Input()\n  public isSwitch: boolean = false;\n\n  /**\n   * When `isSwitch` is `true`, sets whether or not the toggle switch uses icons.\n   */\n  @Input()\n  public switchIcons: boolean = false;\n\n  /**\n   * Whether or not the checkbox displays inline.\n   */\n  @Input()\n  public inline: boolean = false;\n\n  /**\n   * Whether or not the checkbox input is checked.\n   */\n  @Input()\n  public get checked(): boolean {\n    return this.value;\n  }\n  public set checked(value: BooleanInput) {\n    this.value = value;\n    this._cvaOnChange(this.value);\n  }\n\n  /**\n   * Whether or not the checkbox input is in an `indeterminate` state.\n   */\n  @Input()\n  public get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n  public set indeterminate(value: BooleanInput) {\n    const coercedValue = coerceBooleanPropertyValue(value);\n    const isChange = coercedValue !== this._indeterminate;\n    this._indeterminate = coercedValue;\n\n    if (isChange) {\n      this.indeterminateChange.emit(this._indeterminate);\n    }\n  }\n  private _indeterminate: boolean = false;\n\n  @Input()\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n  public set disabled(value: BooleanInput) {\n    const newDisabledState = coerceBooleanPropertyValue(value);\n\n    if (newDisabledState !== this._disabled) {\n      this._disabled = newDisabledState;\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n  protected _disabled: boolean = false;\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /**\n   * Event emitted whenever the checkedness of the input changes.\n   */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public readonly change: EventEmitter<CheckboxChangeEvent> = new EventEmitter<CheckboxChangeEvent>();\n\n  /**\n   * Event emitted whenever the control enters or leaves an `indeterminate` state.\n   */\n  @Output()\n  public readonly indeterminateChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  public get inputId(): string {\n    return `${this.id || this._uid}-input`;\n  }\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    @Attribute('tabindex') tabIndex: string,\n    defaultErrorStateMatcher: ErrorStateMatcher,\n    @Optional() @Inject(IMPDC_FORM_ROOT) formRoot: ImpdcFormRoot,\n    @Optional() parentForm: NgForm,\n    @Optional() parentFormGroup: FormGroupDirective,\n    @Self() @Optional() ngControl: NgControl | null\n  ) {\n    super(\n      defaultErrorStateMatcher,\n      formRoot,\n      parentForm,\n      parentFormGroup,\n      ngControl\n    );\n\n    this.tabIndex = parseInt(tabIndex) || 0;\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n      this.ngControl.control?.addValidators(() => {\n        return this.validate();\n      });\n    }\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /* ImpdcFormFieldControl */\n\n  public get value(): boolean {\n    return this._value;\n  }\n  public set value(value: BooleanInput) {\n    const newValue = coerceBooleanPropertyValue(value);\n\n    if (newValue !== this._value) {\n      this._value = newValue;\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n  private _value: boolean = false;\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n  private _focused: boolean = false;\n\n  /**\n   * Used to set requiredness of control in a template-based manner; not necessary when using the\n   * Angular reactive forms API and 'required' or `requiredTrue` validators.\n   */\n  @Input()\n  public get required(): boolean {\n    if (this._required !== undefined) {\n      return this._required;\n    }\n\n    const control = this.ngControl?.control;\n    if (control) {\n      const hasRequired = control.hasValidator(Validators.required);\n      const hasRequiredTrue = control.hasValidator(Validators.requiredTrue);\n\n      return hasRequired || hasRequiredTrue;\n    }\n\n    return false;\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 readonly controlType: string = 'impdc-check';\n  public readonly supportsAffixes: boolean = false;\n\n  /* ControlValueAccessor */\n\n  /** @ignore */\n  public writeValue(value: any): 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  /* Validator */\n\n  /** @ignore */\n  public validate(): ValidationErrors | null {\n    return !this.disabled && this.required && !this.value\n      ? { required: true }\n      : null;\n  }\n\n  /* Internals */\n  protected _getAriaChecked(): 'true' | 'false' | 'mixed' {\n    if (this.checked) {\n      return 'true';\n    }\n\n    return this.indeterminate ? 'mixed' : 'false';\n  }\n\n  protected _onBlur(): void {\n    this._focused = false;\n    // When a focused element becomes disabled, the browser *immediately* fires a blur event.\n    // Angular does not expect events to be raised during change detection, so any state change\n    // (such as a form control's 'ng-touched') will cause a changed-after-checked error.\n    // See https://github.com/angular/angular/issues/17793. To work around this, we defer\n    // telling the form control it has been touched until the next tick.\n    Promise.resolve().then(() => {\n      this._cvaOnTouched();\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    });\n  }\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  protected _handleCheckClick(): void {\n    if (!this.disabled) {\n      if (this.indeterminate) {\n        Promise.resolve().then(() => {\n          this.indeterminate = false;\n          this.indeterminateChange.emit(this._indeterminate);\n        });\n      }\n\n      this.checked = !this.checked;\n\n      this._emitChangeEvents();\n    }\n  }\n\n  protected _onInteractionEvent(event: Event) {\n    // We always have to stop propagation on the change event.\n    // Otherwise the change event, from the input element, will bubble up and\n    // emit its event object to the `change` output.\n    event.stopPropagation();\n  }\n\n  private _emitChangeEvents(): void {\n    this._cvaOnChange(this.checked);\n    this.change.emit(new CheckboxChangeEvent(this, this.checked));\n\n    // Assigning the value again here is redundant, but we have to do it in case it was\n    // changed inside the `change` listener which will cause the input to be out of sync.\n    if (this._inputElement) {\n      this._inputElement.nativeElement.checked = this.checked;\n    }\n  }\n\n  /**\n   *  Prevent click events that come from the `<label/>` element from bubbling. This prevents the\n   *  click handler on the host from triggering twice when clicking on the `<label/>` element. After\n   *  the click event on the `<label/>` propagates, the browsers dispatches click on the associated\n   *  `<input/>`. By preventing clicks on the label by bubbling, we ensure only one click event\n   *  bubbles when the label is clicked.\n   */\n  protected _preventBubblingFromLabel(event: MouseEvent) {\n    if (\n      !!event.target &&\n      !!this._inputElement &&\n      !(event.target as HTMLElement).contains(this._inputElement.nativeElement)\n    ) {\n      event.stopPropagation();\n    }\n  }\n}\n","<impdc-toggle\n  [label]=\"label\"\n  [description]=\"description\"\n  [isSwitch]=\"isSwitch\"\n  [switchIcons]=\"switchIcons\"\n  [inline]=\"inline\"\n  (click)=\"_preventBubblingFromLabel($event)\">\n  <input\n    #nativeInput\n    impdc-toggle-input\n    type=\"checkbox\"\n    class=\"impdc-checkbox__native-control\"\n    [class.is-invalid]=\"errorState\"\n    [id]=\"inputId\"\n    [attr.aria-checked]=\"_getAriaChecked()\"\n    [attr.aria-required]=\"required\"\n    [attr.tabindex]=\"tabIndex\"\n    [checked]=\"checked\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [indeterminate]=\"indeterminate\"\n    (change)=\"_onInteractionEvent($event)\"\n    (click)=\"_handleCheckClick()\"\n    (blur)=\"_onBlur()\"\n    (focus)=\"_onFocus()\" />\n</impdc-toggle>\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { ToggleModule } from '../shared';
|
|
4
|
+
import { CheckboxComponent } from './checkbox.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class CheckboxModule {
|
|
7
|
+
}
|
|
8
|
+
CheckboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
+
CheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, declarations: [CheckboxComponent], imports: [CommonModule, ToggleModule], exports: [CheckboxComponent] });
|
|
10
|
+
CheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, imports: [CommonModule, ToggleModule] });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, decorators: [{
|
|
12
|
+
type: NgModule,
|
|
13
|
+
args: [{
|
|
14
|
+
declarations: [CheckboxComponent],
|
|
15
|
+
imports: [CommonModule, ToggleModule],
|
|
16
|
+
exports: [CheckboxComponent]
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi9mb3JtLWZpZWxkL2NvbnRyb2xzL2NoZWNrYm94L2NoZWNrYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQU96RCxNQUFNLE9BQU8sY0FBYzs7NEdBQWQsY0FBYzs2R0FBZCxjQUFjLGlCQUpWLGlCQUFpQixhQUN0QixZQUFZLEVBQUUsWUFBWSxhQUMxQixpQkFBaUI7NkdBRWhCLGNBQWMsWUFIZixZQUFZLEVBQUUsWUFBWTs0RkFHekIsY0FBYztrQkFMMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDakMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUb2dnbGVNb2R1bGUgfSBmcm9tICcuLi9zaGFyZWQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0NoZWNrYm94Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVG9nZ2xlTW9kdWxlXSxcbiAgZXhwb3J0czogW0NoZWNrYm94Q29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveE1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { CheckboxChangeEvent, CheckboxComponent } from './checkbox.component';
|
|
2
|
+
export { CheckboxModule } from './checkbox.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvY2hlY2tib3gvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDOUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ2hlY2tib3hDaGFuZ2VFdmVudCwgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94LmNvbXBvbmVudCc7XG5leHBvcnQgeyBDaGVja2JveE1vZHVsZSB9IGZyb20gJy4vY2hlY2tib3gubW9kdWxlJztcbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './checkbox';
|
|
2
|
+
export * from './input';
|
|
3
|
+
export * from './radio';
|
|
4
|
+
export * from './select';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NoZWNrYm94JztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9yYWRpbyc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdCc7XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { InputDirective } from './input.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvaW5wdXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgSW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL2lucHV0LmRpcmVjdGl2ZSc7XG4iXX0=
|