@leanix/components 0.4.68 → 0.4.69
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/core-ui/directives/autoclose.directive.mjs +2 -2
- package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +1 -1
- package/esm2022/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.mjs +26 -10
- package/esm2022/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +7 -7
- package/esm2022/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.mjs +4 -5
- package/esm2022/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.mjs +4 -5
- package/esm2022/lib/forms-ui/components/copy-button/copy-button.component.mjs +4 -3
- package/esm2022/lib/forms-ui/components/currency/currency-input.component.mjs +9 -9
- package/esm2022/lib/forms-ui/components/currency/currency-symbol.component.mjs +4 -4
- package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +10 -11
- package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.mjs +7 -5
- package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.mjs +5 -12
- package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker.component.mjs +9 -8
- package/esm2022/lib/forms-ui/components/date-picker-ui/daypicker.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/date-picker-ui/monthpicker.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/date-picker-ui/yearpicker.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component.mjs +19 -10
- package/esm2022/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module.mjs +22 -5
- package/esm2022/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/components/error-message/error-message.component.mjs +6 -5
- package/esm2022/lib/forms-ui/components/expanded-dropdown/expanded-dropdown.component.mjs +7 -6
- package/esm2022/lib/forms-ui/components/form-error/form-error.component.mjs +6 -5
- package/esm2022/lib/forms-ui/components/icon/icon.component.mjs +3 -3
- package/esm2022/lib/forms-ui/components/input/input.component.mjs +3 -3
- package/esm2022/lib/forms-ui/components/multi-select/multi-select.component.mjs +8 -9
- package/esm2022/lib/forms-ui/components/option/option.component.mjs +6 -6
- package/esm2022/lib/forms-ui/components/option-group/option-group.component.mjs +4 -4
- package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +28 -11
- package/esm2022/lib/forms-ui/components/options-dropdown/options-dropdown.component.mjs +7 -6
- package/esm2022/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/picker/picker-trigger.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/components/picker/picker.component.mjs +6 -6
- package/esm2022/lib/forms-ui/components/picker-option/picker-option.component.mjs +5 -5
- package/esm2022/lib/forms-ui/components/pill-item/pill-item.component.mjs +4 -4
- package/esm2022/lib/forms-ui/components/pill-list/pill-list.component.mjs +5 -6
- package/esm2022/lib/forms-ui/components/responsive-input/responsive-input.component.mjs +6 -6
- package/esm2022/lib/forms-ui/components/select-list/select-list.component.mjs +6 -5
- package/esm2022/lib/forms-ui/components/single-select/single-select.component.mjs +8 -8
- package/esm2022/lib/forms-ui/components/slider-toggle/slider-toggle.component.mjs +4 -4
- package/esm2022/lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component.mjs +20 -10
- package/esm2022/lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component.mjs +4 -4
- package/esm2022/lib/forms-ui/directives/contenteditable.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/form-error.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/form-submit.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/keyboard-action-source.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/mark-invalid.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/select-dropdown.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/selectable-item.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/directives/selected-option.directive.mjs +4 -3
- package/esm2022/lib/forms-ui/forms-ui.module.mjs +35 -23
- package/esm2022/lib/forms-ui/pipes/filter-selection.pipe.mjs +6 -3
- package/esm2022/lib/forms-ui/pipes/filter-term.pipe.mjs +6 -3
- package/esm2022/lib/forms-ui/pipes/format-number.pipe.mjs +4 -3
- package/fesm2022/leanix-components.mjs +332 -237
- package/fesm2022/leanix-components.mjs.map +1 -1
- package/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.d.ts +1 -1
- package/lib/forms-ui/components/breadcrumb/breadcrumb.component.d.ts +1 -1
- package/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/copy-button/copy-button.component.d.ts +1 -1
- package/lib/forms-ui/components/currency/currency-input.component.d.ts +1 -1
- package/lib/forms-ui/components/currency/currency-symbol.component.d.ts +1 -1
- package/lib/forms-ui/components/date-input/date-input.component.d.ts +1 -1
- package/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.d.ts +1 -1
- package/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.d.ts +1 -7
- package/lib/forms-ui/components/date-picker-ui/datepicker.component.d.ts +1 -1
- package/lib/forms-ui/components/date-picker-ui/daypicker.component.d.ts +1 -1
- package/lib/forms-ui/components/date-picker-ui/monthpicker.component.d.ts +1 -1
- package/lib/forms-ui/components/date-picker-ui/yearpicker.component.d.ts +1 -1
- package/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component.d.ts +1 -1
- package/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component.d.ts +1 -1
- package/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module.d.ts +9 -9
- package/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive.d.ts +1 -1
- package/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.d.ts +1 -1
- package/lib/forms-ui/components/error-message/error-message.component.d.ts +1 -1
- package/lib/forms-ui/components/expanded-dropdown/expanded-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/form-error/form-error.component.d.ts +1 -1
- package/lib/forms-ui/components/icon/icon.component.d.ts +1 -1
- package/lib/forms-ui/components/input/input.component.d.ts +1 -1
- package/lib/forms-ui/components/multi-select/multi-select.component.d.ts +1 -1
- package/lib/forms-ui/components/option/option.component.d.ts +1 -1
- package/lib/forms-ui/components/option-group/option-group.component.d.ts +1 -1
- package/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/options-dropdown/options-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/picker/picker-trigger.directive.d.ts +1 -1
- package/lib/forms-ui/components/picker/picker.component.d.ts +1 -1
- package/lib/forms-ui/components/picker-option/picker-option.component.d.ts +1 -1
- package/lib/forms-ui/components/pill-item/pill-item.component.d.ts +1 -1
- package/lib/forms-ui/components/pill-list/pill-list.component.d.ts +1 -1
- package/lib/forms-ui/components/responsive-input/responsive-input.component.d.ts +1 -1
- package/lib/forms-ui/components/select-list/select-list.component.d.ts +1 -1
- package/lib/forms-ui/components/single-select/single-select.component.d.ts +1 -1
- package/lib/forms-ui/components/slider-toggle/slider-toggle.component.d.ts +1 -1
- package/lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component.d.ts +1 -1
- package/lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component.d.ts +1 -1
- package/lib/forms-ui/directives/contenteditable.directive.d.ts +1 -1
- package/lib/forms-ui/directives/form-error.directive.d.ts +1 -1
- package/lib/forms-ui/directives/form-submit.directive.d.ts +1 -1
- package/lib/forms-ui/directives/keyboard-action-source.directive.d.ts +1 -1
- package/lib/forms-ui/directives/mark-invalid.directive.d.ts +1 -1
- package/lib/forms-ui/directives/select-dropdown.directive.d.ts +1 -1
- package/lib/forms-ui/directives/selectable-item.directive.d.ts +1 -1
- package/lib/forms-ui/directives/selected-option.directive.d.ts +1 -1
- package/lib/forms-ui/forms-ui.module.d.ts +52 -52
- package/lib/forms-ui/pipes/filter-selection.pipe.d.ts +1 -1
- package/lib/forms-ui/pipes/filter-term.pipe.d.ts +1 -1
- package/lib/forms-ui/pipes/format-number.pipe.d.ts +1 -1
- package/package.json +1 -1
package/esm2022/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.mjs
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
import { CdkConnectedOverlay } from '@angular/cdk/overlay';
|
1
|
+
import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';
|
2
2
|
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, Input, ViewChild } from '@angular/core';
|
3
3
|
import { BehaviorSubject, combineLatest, fromEvent, merge, Subject } from 'rxjs';
|
4
4
|
import { debounceTime, delay, distinctUntilChanged, filter, map, startWith, switchMap, takeUntil, withLatestFrom } from 'rxjs/operators';
|
@@ -7,7 +7,6 @@ import { KeyboardActionSourceDirective } from '../../directives/keyboard-action-
|
|
7
7
|
import { KeyboardSelectAction } from '../keyboard-select.directive';
|
8
8
|
import { OptionComponent } from '../option/option.component';
|
9
9
|
import * as i0 from "@angular/core";
|
10
|
-
import * as i1 from "@angular/cdk/overlay";
|
11
10
|
const BOTTOM_LEFT_POSITION = {
|
12
11
|
originX: 'end',
|
13
12
|
overlayX: 'end',
|
@@ -184,11 +183,11 @@ export class CdkOptionsDropdownComponent {
|
|
184
183
|
}
|
185
184
|
}
|
186
185
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CdkOptionsDropdownComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
187
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CdkOptionsDropdownComponent, selector: "lx-cdk-options-dropdown", inputs: { align: "align", closeOnScroll: "closeOnScroll", disabled: "disabled", maxHeight: "maxHeight" }, queries: [{ propertyName: "trigger", first: true, predicate: KeyboardActionSourceDirective, descendants: true }, { propertyName: "_options", predicate: OptionComponent, descendants: true }, { propertyName: "tooltips", predicate: TooltipDirective, descendants: true }], viewQueries: [{ propertyName: "dropdownContainer", first: true, predicate: ["dropdown"], descendants: true }, { propertyName: "overlay", first: true, predicate: CdkConnectedOverlay, descendants: true }], ngImport: i0, template: "<div (click)=\"open = !open\" class=\"triggerContainer\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n <ng-content select=\"[lxKeyboardActionSource]\"></ng-content>\n</div>\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"open\"\n (overlayOutsideClick)=\"closeDropdown()\"\n>\n <ul\n #dropdown\n [class.showScrollbar]=\"maxHeight !== 'none'\"\n [style.max-height]=\"maxHeight\"\n [style.visibility]=\"isPositionComputed ? null : 'hidden'\"\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [":host{display:inline-block;position:relative}ul{position:absolute;background-color:#fff;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;border:solid 1px #e1e5eb;text-align:left;list-style:none;margin:0;padding-left:0;z-index:20;white-space:nowrap}ul::-webkit-scrollbar{width:.5em;height:.5em;background-color:transparent}ul::-webkit-scrollbar-thumb{background-color:#c2c9d6;border-radius:6px}ul::-webkit-scrollbar-track-piece{background-color:transparent}ul.left{right:0;padding-right:0}ul.showScrollbar{overflow-y:auto}.triggerContainer{display:inline-block}\n"], dependencies: [{ kind: "directive", type:
|
186
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CdkOptionsDropdownComponent, isStandalone: true, selector: "lx-cdk-options-dropdown", inputs: { align: "align", closeOnScroll: "closeOnScroll", disabled: "disabled", maxHeight: "maxHeight" }, queries: [{ propertyName: "trigger", first: true, predicate: KeyboardActionSourceDirective, descendants: true }, { propertyName: "_options", predicate: OptionComponent, descendants: true }, { propertyName: "tooltips", predicate: TooltipDirective, descendants: true }], viewQueries: [{ propertyName: "dropdownContainer", first: true, predicate: ["dropdown"], descendants: true }, { propertyName: "overlay", first: true, predicate: CdkConnectedOverlay, descendants: true }], ngImport: i0, template: "<div (click)=\"open = !open\" class=\"triggerContainer\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n <ng-content select=\"[lxKeyboardActionSource]\"></ng-content>\n</div>\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"open\"\n (overlayOutsideClick)=\"closeDropdown()\"\n>\n <ul\n #dropdown\n [class.showScrollbar]=\"maxHeight !== 'none'\"\n [style.max-height]=\"maxHeight\"\n [style.visibility]=\"isPositionComputed ? null : 'hidden'\"\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [":host{display:inline-block;position:relative}ul{position:absolute;background-color:#fff;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;border:solid 1px #e1e5eb;text-align:left;list-style:none;margin:0;padding-left:0;z-index:20;white-space:nowrap}ul::-webkit-scrollbar{width:.5em;height:.5em;background-color:transparent}ul::-webkit-scrollbar-thumb{background-color:#c2c9d6;border-radius:6px}ul::-webkit-scrollbar-track-piece{background-color:transparent}ul.left{right:0;padding-right:0}ul.showScrollbar{overflow-y:auto}.triggerContainer{display:inline-block}\n"], dependencies: [{ kind: "directive", type: CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "directive", type: CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
188
187
|
}
|
189
188
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CdkOptionsDropdownComponent, decorators: [{
|
190
189
|
type: Component,
|
191
|
-
args: [{ selector: 'lx-cdk-options-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div (click)=\"open = !open\" class=\"triggerContainer\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n <ng-content select=\"[lxKeyboardActionSource]\"></ng-content>\n</div>\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"open\"\n (overlayOutsideClick)=\"closeDropdown()\"\n>\n <ul\n #dropdown\n [class.showScrollbar]=\"maxHeight !== 'none'\"\n [style.max-height]=\"maxHeight\"\n [style.visibility]=\"isPositionComputed ? null : 'hidden'\"\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [":host{display:inline-block;position:relative}ul{position:absolute;background-color:#fff;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;border:solid 1px #e1e5eb;text-align:left;list-style:none;margin:0;padding-left:0;z-index:20;white-space:nowrap}ul::-webkit-scrollbar{width:.5em;height:.5em;background-color:transparent}ul::-webkit-scrollbar-thumb{background-color:#c2c9d6;border-radius:6px}ul::-webkit-scrollbar-track-piece{background-color:transparent}ul.left{right:0;padding-right:0}ul.showScrollbar{overflow-y:auto}.triggerContainer{display:inline-block}\n"] }]
|
190
|
+
args: [{ selector: 'lx-cdk-options-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CdkOverlayOrigin, CdkConnectedOverlay], template: "<div (click)=\"open = !open\" class=\"triggerContainer\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n <ng-content select=\"[lxKeyboardActionSource]\"></ng-content>\n</div>\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"open\"\n (overlayOutsideClick)=\"closeDropdown()\"\n>\n <ul\n #dropdown\n [class.showScrollbar]=\"maxHeight !== 'none'\"\n [style.max-height]=\"maxHeight\"\n [style.visibility]=\"isPositionComputed ? null : 'hidden'\"\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [":host{display:inline-block;position:relative}ul{position:absolute;background-color:#fff;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;border:solid 1px #e1e5eb;text-align:left;list-style:none;margin:0;padding-left:0;z-index:20;white-space:nowrap}ul::-webkit-scrollbar{width:.5em;height:.5em;background-color:transparent}ul::-webkit-scrollbar-thumb{background-color:#c2c9d6;border-radius:6px}ul::-webkit-scrollbar-track-piece{background-color:transparent}ul.left{right:0;padding-right:0}ul.showScrollbar{overflow-y:auto}.triggerContainer{display:inline-block}\n"] }]
|
192
191
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { dropdownContainer: [{
|
193
192
|
type: ViewChild,
|
194
193
|
args: ['dropdown']
|
@@ -213,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
|
|
213
212
|
type: ContentChildren,
|
214
213
|
args: [TooltipDirective, { descendants: true }]
|
215
214
|
}] } });
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-options-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, ConnectedPosition } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChild\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, fromEvent, merge, Subject } from 'rxjs';\nimport { debounceTime, delay, distinctUntilChanged, filter, map, startWith, switchMap, takeUntil, withLatestFrom } from 'rxjs/operators';\nimport { TooltipDirective } from '../../../core-ui/tooltip/tooltip.directive';\nimport { KeyboardActionSourceDirective } from '../../directives/keyboard-action-source.directive';\nimport { KeyboardSelectAction } from '../keyboard-select.directive';\nimport { OptionComponent } from '../option/option.component';\n\nconst BOTTOM_LEFT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'end',\n  originY: 'bottom',\n  overlayY: 'top'\n};\n\nconst BOTTOM_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'start',\n  originY: 'bottom',\n  overlayY: 'top'\n};\n\nconst TOP_LEFT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'end',\n  originY: 'top',\n  overlayY: 'bottom'\n};\n\nconst TOP_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'start',\n  originY: 'top',\n  overlayY: 'bottom'\n};\n\nconst LEFT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION, BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION];\nconst RIGHT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION, BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION];\n\n@Component({\n  selector: 'lx-cdk-options-dropdown',\n  templateUrl: 'cdk-options-dropdown.component.html',\n  styleUrls: ['cdk-options-dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CdkOptionsDropdownComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('dropdown') dropdownContainer!: ElementRef;\n\n  @Input() align: 'right' | 'left' = 'right';\n  @Input() closeOnScroll: boolean = false;\n  @Input() disabled: boolean = false;\n  @Input() maxHeight: string = 'none';\n\n  set open(value) {\n    if (this.disabled) {\n      return;\n    }\n\n    this._open = value;\n    if (this.trigger) {\n      // Don't emit keyboard actions while the dropdown is not open yet.\n      this.trigger.dontEmit = !this.open;\n    }\n    if (this.open) {\n      this.isSubdropdownExpanded = false;\n      this.setInitialHighlightingIndex();\n    }\n    this.reloadOverlayPosition(this.open);\n  }\n  get open() {\n    return this._open;\n  }\n\n  @ContentChild(KeyboardActionSourceDirective) trigger!: KeyboardActionSourceDirective;\n  @ViewChild(CdkConnectedOverlay) overlay!: CdkConnectedOverlay;\n\n  @ContentChildren(OptionComponent, { descendants: true })\n  _options!: QueryList<OptionComponent>;\n\n  @ContentChildren(TooltipDirective, { descendants: true })\n  tooltips!: QueryList<TooltipDirective>;\n\n  get options() {\n    return this._options.toArray();\n  }\n\n  private readonly highlightedOptionIndex$ = new BehaviorSubject<number>(0);\n  private _open = false;\n  private isSubdropdownExpanded = false;\n\n  private readonly destroyed$ = new Subject<void>();\n\n  isPositionComputed = true;\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  ngAfterViewInit() {\n    this.trigger.dontEmit = !this.open;\n\n    this.overlay.positions = this.align === 'left' ? LEFT_ALIGN_POSITIONS : RIGHT_ALIGN_POSITIONS;\n\n    const optionsChanges$ = this._options.changes.pipe(\n      startWith(this._options),\n      map((options: QueryList<OptionComponent>) => options.toArray())\n    );\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.NEXT),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) => this.next(index, options))\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.PREV),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) => this.prev(index, options))\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.LEFT),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) =>\n          this.isSubdropdownExpanded ? this.collapse(index, options) : this.expand(index, options)\n        )\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.RIGHT),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) =>\n          this.isSubdropdownExpanded ? this.collapse(index, options) : this.expand(index, options)\n        )\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.CLOSE))\n      .subscribe(() => this.closeDropdown());\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.EXECUTE),\n        withLatestFrom(this.highlightedOptionIndex$, (_, index) => index)\n      )\n      .subscribe((index) => {\n        this.options[index]?.selectOption();\n      });\n\n    /** Combined stream of all of the child options' select outputs. */\n    this._options.changes\n      .pipe(\n        startWith(this._options),\n        switchMap(() => merge(...this._options.map((option) => option.select), ...this._options.map((option) => option.selectedClick))),\n        delay(0),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((_value) => {\n        this.closeDropdown();\n      });\n\n    combineLatest([optionsChanges$, this.highlightedOptionIndex$])\n      .pipe(\n        delay(0),\n        map(([options, index]: [OptionComponent[], number]) => options[index]),\n        distinctUntilChanged(),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((optionToBeHighlighted) => {\n        this.options.forEach((option) => option.setHighlighted(optionToBeHighlighted === option));\n        this.changeDetection.markForCheck();\n      });\n\n    if (this.closeOnScroll) {\n      fromEvent(window, 'scroll')\n        .pipe(debounceTime(100), takeUntil(this.destroyed$))\n        .subscribe(() => {\n          this.open = false;\n          this.trigger.blur();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  closeDropdown() {\n    this.tooltips.toArray().forEach((tooltip) => tooltip.hide());\n    this.open = false;\n  }\n\n  private setInitialHighlightingIndex() {\n    const firstAvailableIndex = this.options.map((option) => !this.optionIsHighlightable(option)).indexOf(false, 0);\n    this.highlightedOptionIndex$.next(firstAvailableIndex);\n  }\n\n  private prev(currentIndex: number, items: OptionComponent[]): number {\n    if (currentIndex > 0) {\n      const prevEnabledIndex = items.map((option) => !this.optionIsHighlightable(option)).lastIndexOf(false, currentIndex - 1);\n      return prevEnabledIndex !== -1 ? prevEnabledIndex : currentIndex;\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private next(currentIndex: number, items: OptionComponent[]): number {\n    if (currentIndex < items.length) {\n      const nextEnabledIndex = items.map((option) => !this.optionIsHighlightable(option)).indexOf(false, currentIndex + 1);\n      return nextEnabledIndex !== -1 ? nextEnabledIndex : currentIndex;\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private expand(currentIndex: number, items: OptionComponent[]) {\n    if (items[currentIndex]?.hasSubdropdown) {\n      this.isSubdropdownExpanded = true;\n      return this.next(currentIndex, items);\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private collapse(currentIndex: number, items: OptionComponent[]) {\n    if (this.isSubdropdownExpanded) {\n      this.isSubdropdownExpanded = false;\n      return this.prev(currentIndex, items);\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private optionIsHighlightable(option: OptionComponent): boolean {\n    const isToplevelOptionAndAllowed = !option.isSuboption && !this.isSubdropdownExpanded;\n    const isSecondlevelOptionAndAllowed = option.isSuboption && this.isSubdropdownExpanded;\n    return !option.disabled && (isToplevelOptionAndAllowed || isSecondlevelOptionAndAllowed);\n  }\n\n  private reloadOverlayPosition(open: boolean) {\n    if (open) {\n      this.isPositionComputed = false;\n      setTimeout(() => {\n        const dropdownElement = this.dropdownContainer.nativeElement;\n\n        this.overlay.overlayRef.updateSize({\n          height: dropdownElement.offsetHeight,\n          width: dropdownElement.offsetWidth\n        });\n        this.overlay.overlayRef.updatePosition();\n\n        this.isPositionComputed = true;\n        this.changeDetection.markForCheck();\n      }, 0);\n    } else {\n      this.changeDetection.markForCheck();\n    }\n  }\n}\n","<div (click)=\"open = !open\" class=\"triggerContainer\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n  <ng-content select=\"[lxKeyboardActionSource]\"></ng-content>\n</div>\n<ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"trigger\"\n  [cdkConnectedOverlayOpen]=\"open\"\n  (overlayOutsideClick)=\"closeDropdown()\"\n>\n  <ul\n    #dropdown\n    [class.showScrollbar]=\"maxHeight !== 'none'\"\n    [style.max-height]=\"maxHeight\"\n    [style.visibility]=\"isPositionComputed ? null : 'hidden'\"\n  >\n    <ng-content></ng-content>\n  </ul>\n</ng-template>\n"]}
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-options-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedPosition } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChild\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, fromEvent, merge, Subject } from 'rxjs';\nimport { debounceTime, delay, distinctUntilChanged, filter, map, startWith, switchMap, takeUntil, withLatestFrom } from 'rxjs/operators';\nimport { TooltipDirective } from '../../../core-ui/tooltip/tooltip.directive';\nimport { KeyboardActionSourceDirective } from '../../directives/keyboard-action-source.directive';\nimport { KeyboardSelectAction } from '../keyboard-select.directive';\nimport { OptionComponent } from '../option/option.component';\n\nconst BOTTOM_LEFT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'end',\n  originY: 'bottom',\n  overlayY: 'top'\n};\n\nconst BOTTOM_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'start',\n  originY: 'bottom',\n  overlayY: 'top'\n};\n\nconst TOP_LEFT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'end',\n  originY: 'top',\n  overlayY: 'bottom'\n};\n\nconst TOP_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'start',\n  originY: 'top',\n  overlayY: 'bottom'\n};\n\nconst LEFT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION, BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION];\nconst RIGHT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION, BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION];\n\n@Component({\n  selector: 'lx-cdk-options-dropdown',\n  templateUrl: 'cdk-options-dropdown.component.html',\n  styleUrls: ['cdk-options-dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CdkOverlayOrigin, CdkConnectedOverlay]\n})\nexport class CdkOptionsDropdownComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('dropdown') dropdownContainer!: ElementRef;\n\n  @Input() align: 'right' | 'left' = 'right';\n  @Input() closeOnScroll: boolean = false;\n  @Input() disabled: boolean = false;\n  @Input() maxHeight: string = 'none';\n\n  set open(value) {\n    if (this.disabled) {\n      return;\n    }\n\n    this._open = value;\n    if (this.trigger) {\n      // Don't emit keyboard actions while the dropdown is not open yet.\n      this.trigger.dontEmit = !this.open;\n    }\n    if (this.open) {\n      this.isSubdropdownExpanded = false;\n      this.setInitialHighlightingIndex();\n    }\n    this.reloadOverlayPosition(this.open);\n  }\n  get open() {\n    return this._open;\n  }\n\n  @ContentChild(KeyboardActionSourceDirective) trigger!: KeyboardActionSourceDirective;\n  @ViewChild(CdkConnectedOverlay) overlay!: CdkConnectedOverlay;\n\n  @ContentChildren(OptionComponent, { descendants: true })\n  _options!: QueryList<OptionComponent>;\n\n  @ContentChildren(TooltipDirective, { descendants: true })\n  tooltips!: QueryList<TooltipDirective>;\n\n  get options() {\n    return this._options.toArray();\n  }\n\n  private readonly highlightedOptionIndex$ = new BehaviorSubject<number>(0);\n  private _open = false;\n  private isSubdropdownExpanded = false;\n\n  private readonly destroyed$ = new Subject<void>();\n\n  isPositionComputed = true;\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  ngAfterViewInit() {\n    this.trigger.dontEmit = !this.open;\n\n    this.overlay.positions = this.align === 'left' ? LEFT_ALIGN_POSITIONS : RIGHT_ALIGN_POSITIONS;\n\n    const optionsChanges$ = this._options.changes.pipe(\n      startWith(this._options),\n      map((options: QueryList<OptionComponent>) => options.toArray())\n    );\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.NEXT),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) => this.next(index, options))\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.PREV),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) => this.prev(index, options))\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.LEFT),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) =>\n          this.isSubdropdownExpanded ? this.collapse(index, options) : this.expand(index, options)\n        )\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.RIGHT),\n        withLatestFrom(this.highlightedOptionIndex$, optionsChanges$, (_, index, options) =>\n          this.isSubdropdownExpanded ? this.collapse(index, options) : this.expand(index, options)\n        )\n      )\n      .subscribe(this.highlightedOptionIndex$);\n\n    this.trigger.keyboardActions$\n      .pipe(filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.CLOSE))\n      .subscribe(() => this.closeDropdown());\n\n    this.trigger.keyboardActions$\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.EXECUTE),\n        withLatestFrom(this.highlightedOptionIndex$, (_, index) => index)\n      )\n      .subscribe((index) => {\n        this.options[index]?.selectOption();\n      });\n\n    /** Combined stream of all of the child options' select outputs. */\n    this._options.changes\n      .pipe(\n        startWith(this._options),\n        switchMap(() => merge(...this._options.map((option) => option.select), ...this._options.map((option) => option.selectedClick))),\n        delay(0),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((_value) => {\n        this.closeDropdown();\n      });\n\n    combineLatest([optionsChanges$, this.highlightedOptionIndex$])\n      .pipe(\n        delay(0),\n        map(([options, index]: [OptionComponent[], number]) => options[index]),\n        distinctUntilChanged(),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((optionToBeHighlighted) => {\n        this.options.forEach((option) => option.setHighlighted(optionToBeHighlighted === option));\n        this.changeDetection.markForCheck();\n      });\n\n    if (this.closeOnScroll) {\n      fromEvent(window, 'scroll')\n        .pipe(debounceTime(100), takeUntil(this.destroyed$))\n        .subscribe(() => {\n          this.open = false;\n          this.trigger.blur();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  closeDropdown() {\n    this.tooltips.toArray().forEach((tooltip) => tooltip.hide());\n    this.open = false;\n  }\n\n  private setInitialHighlightingIndex() {\n    const firstAvailableIndex = this.options.map((option) => !this.optionIsHighlightable(option)).indexOf(false, 0);\n    this.highlightedOptionIndex$.next(firstAvailableIndex);\n  }\n\n  private prev(currentIndex: number, items: OptionComponent[]): number {\n    if (currentIndex > 0) {\n      const prevEnabledIndex = items.map((option) => !this.optionIsHighlightable(option)).lastIndexOf(false, currentIndex - 1);\n      return prevEnabledIndex !== -1 ? prevEnabledIndex : currentIndex;\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private next(currentIndex: number, items: OptionComponent[]): number {\n    if (currentIndex < items.length) {\n      const nextEnabledIndex = items.map((option) => !this.optionIsHighlightable(option)).indexOf(false, currentIndex + 1);\n      return nextEnabledIndex !== -1 ? nextEnabledIndex : currentIndex;\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private expand(currentIndex: number, items: OptionComponent[]) {\n    if (items[currentIndex]?.hasSubdropdown) {\n      this.isSubdropdownExpanded = true;\n      return this.next(currentIndex, items);\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private collapse(currentIndex: number, items: OptionComponent[]) {\n    if (this.isSubdropdownExpanded) {\n      this.isSubdropdownExpanded = false;\n      return this.prev(currentIndex, items);\n    } else {\n      return currentIndex;\n    }\n  }\n\n  private optionIsHighlightable(option: OptionComponent): boolean {\n    const isToplevelOptionAndAllowed = !option.isSuboption && !this.isSubdropdownExpanded;\n    const isSecondlevelOptionAndAllowed = option.isSuboption && this.isSubdropdownExpanded;\n    return !option.disabled && (isToplevelOptionAndAllowed || isSecondlevelOptionAndAllowed);\n  }\n\n  private reloadOverlayPosition(open: boolean) {\n    if (open) {\n      this.isPositionComputed = false;\n      setTimeout(() => {\n        const dropdownElement = this.dropdownContainer.nativeElement;\n\n        this.overlay.overlayRef.updateSize({\n          height: dropdownElement.offsetHeight,\n          width: dropdownElement.offsetWidth\n        });\n        this.overlay.overlayRef.updatePosition();\n\n        this.isPositionComputed = true;\n        this.changeDetection.markForCheck();\n      }, 0);\n    } else {\n      this.changeDetection.markForCheck();\n    }\n  }\n}\n","<div (click)=\"open = !open\" class=\"triggerContainer\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n  <ng-content select=\"[lxKeyboardActionSource]\"></ng-content>\n</div>\n<ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"trigger\"\n  [cdkConnectedOverlayOpen]=\"open\"\n  (overlayOutsideClick)=\"closeDropdown()\"\n>\n  <ul\n    #dropdown\n    [class.showScrollbar]=\"maxHeight !== 'none'\"\n    [style.max-height]=\"maxHeight\"\n    [style.visibility]=\"isPositionComputed ? null : 'hidden'\"\n  >\n    <ng-content></ng-content>\n  </ul>\n</ng-template>\n"]}
|
@@ -2,11 +2,10 @@ import { CdkConnectedOverlay } from '@angular/cdk/overlay';
|
|
2
2
|
import { Component, ContentChildren, Input, ViewChild } from '@angular/core';
|
3
3
|
import { combineLatest, fromEvent, merge, Subject } from 'rxjs';
|
4
4
|
import { debounceTime, delay, distinctUntilChanged, map, startWith, switchMap, takeUntil } from 'rxjs/operators';
|
5
|
+
import { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';
|
5
6
|
import { executeOnNextTick } from '../../../shared/misc-helpers';
|
6
7
|
import { OptionComponent } from '../option/option.component';
|
7
8
|
import * as i0 from "@angular/core";
|
8
|
-
import * as i1 from "@angular/cdk/overlay";
|
9
|
-
import * as i2 from "../../../core-ui/directives/autoclose.directive";
|
10
9
|
const BOTTOM_LEFT_POSITION = {
|
11
10
|
originX: 'start',
|
12
11
|
overlayX: 'end',
|
@@ -114,11 +113,11 @@ export class CdkOptionsSubDropdownComponent {
|
|
114
113
|
this.mouseInside$.next(false);
|
115
114
|
}
|
116
115
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CdkOptionsSubDropdownComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
117
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CdkOptionsSubDropdownComponent, selector: "lx-cdk-options-sub-dropdown", inputs: { trigger: "trigger", align: "align" }, queries: [{ propertyName: "options", predicate: OptionComponent, descendants: true }], viewQueries: [{ propertyName: "overlay", first: true, predicate: CdkConnectedOverlay, descendants: true }, { propertyName: "dropdownContainer", first: true, predicate: ["dropdown"], descendants: true }], ngImport: i0, template: "<ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger.elementRef\" [cdkConnectedOverlayOpen]=\"open\">\n <ul\n (mouseenter)=\"mouseenter()\"\n (mouseleave)=\"mouseleave()\"\n class=\"sub-dropdown\"\n [style.visibility]=\"isPositionComputed ? '' : 'hidden'\"\n lxAutoclose\n (autoclose)=\"closeDropdown()\"\n #dropdown\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [".sub-dropdown{height:100%;padding:0;margin:0;background-color:#fff;border:solid 1px #e1e5eb;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;text-align:left;list-style:none;max-height:50vh;overflow-y:auto}\n"], dependencies: [{ kind: "directive", type:
|
116
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CdkOptionsSubDropdownComponent, isStandalone: true, selector: "lx-cdk-options-sub-dropdown", inputs: { trigger: "trigger", align: "align" }, queries: [{ propertyName: "options", predicate: OptionComponent, descendants: true }], viewQueries: [{ propertyName: "overlay", first: true, predicate: CdkConnectedOverlay, descendants: true }, { propertyName: "dropdownContainer", first: true, predicate: ["dropdown"], descendants: true }], ngImport: i0, template: "<ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger.elementRef\" [cdkConnectedOverlayOpen]=\"open\">\n <ul\n (mouseenter)=\"mouseenter()\"\n (mouseleave)=\"mouseleave()\"\n class=\"sub-dropdown\"\n [style.visibility]=\"isPositionComputed ? '' : 'hidden'\"\n lxAutoclose\n (autoclose)=\"closeDropdown()\"\n #dropdown\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [".sub-dropdown{height:100%;padding:0;margin:0;background-color:#fff;border:solid 1px #e1e5eb;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;text-align:left;list-style:none;max-height:50vh;overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: AutocloseDirective, selector: "[lxAutoclose]", inputs: ["autocloseGroup"], outputs: ["autoclose"] }] }); }
|
118
117
|
}
|
119
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CdkOptionsSubDropdownComponent, decorators: [{
|
120
119
|
type: Component,
|
121
|
-
args: [{ selector: 'lx-cdk-options-sub-dropdown', template: "<ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger.elementRef\" [cdkConnectedOverlayOpen]=\"open\">\n <ul\n (mouseenter)=\"mouseenter()\"\n (mouseleave)=\"mouseleave()\"\n class=\"sub-dropdown\"\n [style.visibility]=\"isPositionComputed ? '' : 'hidden'\"\n lxAutoclose\n (autoclose)=\"closeDropdown()\"\n #dropdown\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [".sub-dropdown{height:100%;padding:0;margin:0;background-color:#fff;border:solid 1px #e1e5eb;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;text-align:left;list-style:none;max-height:50vh;overflow-y:auto}\n"] }]
|
120
|
+
args: [{ selector: 'lx-cdk-options-sub-dropdown', standalone: true, imports: [CdkConnectedOverlay, AutocloseDirective], template: "<ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger.elementRef\" [cdkConnectedOverlayOpen]=\"open\">\n <ul\n (mouseenter)=\"mouseenter()\"\n (mouseleave)=\"mouseleave()\"\n class=\"sub-dropdown\"\n [style.visibility]=\"isPositionComputed ? '' : 'hidden'\"\n lxAutoclose\n (autoclose)=\"closeDropdown()\"\n #dropdown\n >\n <ng-content></ng-content>\n </ul>\n</ng-template>\n", styles: [".sub-dropdown{height:100%;padding:0;margin:0;background-color:#fff;border:solid 1px #e1e5eb;border-radius:3px;box-shadow:0 8px 12px 2px #00000026;text-align:left;list-style:none;max-height:50vh;overflow-y:auto}\n"] }]
|
122
121
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { trigger: [{
|
123
122
|
type: Input
|
124
123
|
}], align: [{
|
@@ -133,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
|
|
133
132
|
type: ViewChild,
|
134
133
|
args: ['dropdown']
|
135
134
|
}] } });
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-options-sub-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAGL,SAAS,EACT,eAAe,EAEf,KAAK,EAGL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,oBAAoB,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACjH,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;;;;AAE7D,MAAM,oBAAoB,GAAsB;IAC9C,OAAO,EAAE,OAAO;IAChB,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,CAAC,CAAC;CACZ,CAAC;AAEF,MAAM,qBAAqB,GAAsB;IAC/C,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,OAAO;IACjB,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,CAAC;CACX,CAAC;AAEF,MAAM,iBAAiB,GAAsB;IAC3C,OAAO,EAAE,OAAO;IAChB,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,QAAQ;IAClB,OAAO,EAAE,CAAC,CAAC;CACZ,CAAC;AAEF,MAAM,kBAAkB,GAAsB;IAC5C,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,OAAO;IACjB,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,QAAQ;IAClB,OAAO,EAAE,CAAC;CACX,CAAC;AAEF,MAAM,oBAAoB,GAAwB,CAAC,oBAAoB,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,kBAAkB,CAAC,CAAC;AACvI,MAAM,qBAAqB,GAAwB,CAAC,qBAAqB,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,iBAAiB,CAAC,CAAC;AAOxI,MAAM,OAAO,8BAA8B;IAezC,YAAoB,eAAkC;QAAlC,oBAAe,GAAf,eAAe,CAAmB;QAb7C,UAAK,GAAqB,OAAO,CAAC;QAM3C,SAAI,GAAG,KAAK,CAAC;QACb,uBAAkB,GAAG,IAAI,CAAC;QAElB,iBAAY,GAAG,IAAI,OAAO,EAAW,CAAC;QAErC,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAEe,CAAC;IAE1D,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,eAAe;QACb,yDAAyD;QACzD,iBAAiB,CAAC,GAAG,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;YACnC,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,qBAAqB,CAAC;QAChG,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC;aAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,oBAAoB,EAAE,CAAC;aACxD,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,OAAO,CAAC,OAAO;aACjB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,EAC7H,KAAK,CAAC,CAAC,CAAC,EACR,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,cAAc;QACpB,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAC7C,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,GAAG,CAAC,CAAC,OAAmC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,EAC/D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACrB,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC;YAC1B,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CACF,CAAC;QAEF,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,IAAI,CAC/E,KAAK,CAAC,CAAC,CAAC,EAAE,oEAAoE;QAC9E,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CACnG,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACtG,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QAEtG,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QACnE,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QAEpE,qGAAqG;QACrG,uGAAuG;QACvG,eAAe;QACf,MAAM,gBAAgB,GAAG,KAAK,CAAC,iBAAiB,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7F,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAE3F,OAAO,KAAK,CAAC,iBAAiB,EAAE,uBAAuB,CAAC,CAAC;IAC3D,CAAC;IAEO,qBAAqB,CAAC,IAAa;QACzC,8EAA8E;QAC9E,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QACpC,IAAI,IAAI,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAClC,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;gBAC7D,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC;oBACjC,MAAM,EAAE,eAAe,CAAC,YAAY;oBACpC,KAAK,EAAE,eAAe,CAAC,WAAW;iBACnC,CAAC,CAAC;gBAEH,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;gBACzC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YACjC,CAAC,EAAE,CAAC,CAAC,CAAC;SACP;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAClB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;8GA/GU,8BAA8B;kGAA9B,8BAA8B,2IAIxB,eAAe,yFACrB,mBAAmB,gJC9DhC,qaAaA;;2FD4Ca,8BAA8B;kBAL1C,SAAS;+BACE,6BAA6B;sFAK9B,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEmD,OAAO;sBAA/D,eAAe;uBAAC,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBACvB,OAAO;sBAAtC,SAAS;uBAAC,mBAAmB;gBACP,iBAAiB;sBAAvC,SAAS;uBAAC,UAAU","sourcesContent":["import { CdkConnectedOverlay, ConnectedPosition } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChild\n} from '@angular/core';\nimport { combineLatest, fromEvent, merge, Subject } from 'rxjs';\nimport { debounceTime, delay, distinctUntilChanged, map, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { executeOnNextTick } from '../../../shared/misc-helpers';\nimport { OptionComponent } from '../option/option.component';\n\nconst BOTTOM_LEFT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'end',\n  originY: 'top',\n  overlayY: 'top',\n  offsetX: -4\n};\n\nconst BOTTOM_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'start',\n  originY: 'top',\n  overlayY: 'top',\n  offsetX: 4\n};\n\nconst TOP_LEFT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'end',\n  originY: 'bottom',\n  overlayY: 'bottom',\n  offsetX: -4\n};\n\nconst TOP_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'start',\n  originY: 'bottom',\n  overlayY: 'bottom',\n  offsetX: 4\n};\n\nconst LEFT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION, BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION];\nconst RIGHT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION, BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION];\n\n@Component({\n  selector: 'lx-cdk-options-sub-dropdown',\n  templateUrl: 'cdk-options-sub-dropdown.component.html',\n  styleUrls: ['cdk-options-sub-dropdown.component.scss']\n})\nexport class CdkOptionsSubDropdownComponent implements AfterViewInit, OnDestroy {\n  @Input() trigger!: OptionComponent;\n  @Input() align: 'right' | 'left' = 'right';\n\n  @ContentChildren(OptionComponent, { descendants: true }) options!: QueryList<OptionComponent>;\n  @ViewChild(CdkConnectedOverlay) overlay!: CdkConnectedOverlay;\n  @ViewChild('dropdown') dropdownContainer!: ElementRef;\n\n  open = false;\n  isPositionComputed = true;\n\n  private mouseInside$ = new Subject<boolean>();\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  mouseenter() {\n    this.mouseInside$.next(true);\n  }\n\n  mouseleave() {\n    this.mouseInside$.next(false);\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  ngAfterViewInit() {\n    // To avoid `Expression has changed after it was checked`\n    executeOnNextTick(() => {\n      this.trigger.hasSubdropdown = true;\n      this.overlay.positions = this.align === 'left' ? LEFT_ALIGN_POSITIONS : RIGHT_ALIGN_POSITIONS;\n    });\n\n    merge(this.showByMouse(), this.showByKeyboard())\n      .pipe(takeUntil(this.destroyed$), distinctUntilChanged())\n      .subscribe((show) => {\n        this.open = show;\n        this.reloadOverlayPosition(this.open);\n      });\n\n    this.options.changes\n      .pipe(\n        startWith(this.options),\n        switchMap(() => merge(...this.options.map((option) => option.select), ...this.options.map((option) => option.selectedClick))),\n        delay(0),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(() => {\n        this.closeDropdown();\n      });\n  }\n\n  private showByKeyboard() {\n    const optionChange$ = this.options.changes.pipe(\n      startWith(this.options),\n      map((options: QueryList<OptionComponent>) => options.toArray()),\n      map((options) =>\n        options.map((option) => {\n          option.isSuboption = true;\n          return option;\n        })\n      )\n    );\n\n    return combineLatest([this.trigger.highlight.asObservable(), optionChange$]).pipe(\n      delay(0), // Need tick delay to get option highlighted and filter it out after\n      map(([isHighlighted, options]) => isHighlighted || options.some((option) => option.isHighlighted))\n    );\n  }\n\n  private showByMouse() {\n    const mouseEnterTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseenter');\n    const mouseLeaveTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseleave');\n\n    const showOnEnterMouse$ = mouseEnterTrigger$.pipe(map(() => true));\n    const hideOnLeaveMouse$ = mouseLeaveTrigger$.pipe(map(() => false));\n\n    // react to trigger mouse leave events, and mouse enter events in the sub-dropdown. We'll use a 300ms\n    // debounce, so that while navigating from the trigger to the sub-dropdown, all the intermediate events\n    // are ignored.\n    const showSubdropdown$ = merge(hideOnLeaveMouse$, this.mouseInside$).pipe(debounceTime(300));\n\n    const showOnEnterSubdropdown$ = mouseEnterTrigger$.pipe(switchMap(() => showSubdropdown$));\n\n    return merge(showOnEnterMouse$, showOnEnterSubdropdown$);\n  }\n\n  private reloadOverlayPosition(open: boolean) {\n    // force a rendering so that the dropdown container's dimensions are computed.\n    this.changeDetection.markForCheck();\n    if (open && this.dropdownContainer) {\n      this.isPositionComputed = false;\n      setTimeout(() => {\n        const dropdownElement = this.dropdownContainer.nativeElement;\n        this.overlay.overlayRef.updateSize({\n          height: dropdownElement.offsetHeight,\n          width: dropdownElement.offsetWidth\n        });\n\n        this.overlay.overlayRef.updatePosition();\n        this.isPositionComputed = true;\n      }, 0);\n    }\n  }\n\n  closeDropdown() {\n    this.open = false;\n    this.mouseInside$.next(false);\n  }\n}\n","<ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger.elementRef\" [cdkConnectedOverlayOpen]=\"open\">\n  <ul\n    (mouseenter)=\"mouseenter()\"\n    (mouseleave)=\"mouseleave()\"\n    class=\"sub-dropdown\"\n    [style.visibility]=\"isPositionComputed ? '' : 'hidden'\"\n    lxAutoclose\n    (autoclose)=\"closeDropdown()\"\n    #dropdown\n  >\n    <ng-content></ng-content>\n  </ul>\n</ng-template>\n"]}
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-options-sub-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAGL,SAAS,EACT,eAAe,EAEf,KAAK,EAGL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,oBAAoB,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACjH,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AACrF,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;;AAE7D,MAAM,oBAAoB,GAAsB;IAC9C,OAAO,EAAE,OAAO;IAChB,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,CAAC,CAAC;CACZ,CAAC;AAEF,MAAM,qBAAqB,GAAsB;IAC/C,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,OAAO;IACjB,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,CAAC;CACX,CAAC;AAEF,MAAM,iBAAiB,GAAsB;IAC3C,OAAO,EAAE,OAAO;IAChB,QAAQ,EAAE,KAAK;IACf,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,QAAQ;IAClB,OAAO,EAAE,CAAC,CAAC;CACZ,CAAC;AAEF,MAAM,kBAAkB,GAAsB;IAC5C,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,OAAO;IACjB,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,QAAQ;IAClB,OAAO,EAAE,CAAC;CACX,CAAC;AAEF,MAAM,oBAAoB,GAAwB,CAAC,oBAAoB,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,kBAAkB,CAAC,CAAC;AACvI,MAAM,qBAAqB,GAAwB,CAAC,qBAAqB,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,iBAAiB,CAAC,CAAC;AASxI,MAAM,OAAO,8BAA8B;IAezC,YAAoB,eAAkC;QAAlC,oBAAe,GAAf,eAAe,CAAmB;QAb7C,UAAK,GAAqB,OAAO,CAAC;QAM3C,SAAI,GAAG,KAAK,CAAC;QACb,uBAAkB,GAAG,IAAI,CAAC;QAElB,iBAAY,GAAG,IAAI,OAAO,EAAW,CAAC;QAErC,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAEe,CAAC;IAE1D,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,eAAe;QACb,yDAAyD;QACzD,iBAAiB,CAAC,GAAG,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;YACnC,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,qBAAqB,CAAC;QAChG,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC;aAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,oBAAoB,EAAE,CAAC;aACxD,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,OAAO,CAAC,OAAO;aACjB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,EAC7H,KAAK,CAAC,CAAC,CAAC,EACR,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,cAAc;QACpB,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAC7C,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,GAAG,CAAC,CAAC,OAAmC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,EAC/D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACrB,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC;YAC1B,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CACF,CAAC;QAEF,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,IAAI,CAC/E,KAAK,CAAC,CAAC,CAAC,EAAE,oEAAoE;QAC9E,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CACnG,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACtG,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QAEtG,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QACnE,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QAEpE,qGAAqG;QACrG,uGAAuG;QACvG,eAAe;QACf,MAAM,gBAAgB,GAAG,KAAK,CAAC,iBAAiB,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7F,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAE3F,OAAO,KAAK,CAAC,iBAAiB,EAAE,uBAAuB,CAAC,CAAC;IAC3D,CAAC;IAEO,qBAAqB,CAAC,IAAa;QACzC,8EAA8E;QAC9E,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QACpC,IAAI,IAAI,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAClC,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;gBAC7D,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC;oBACjC,MAAM,EAAE,eAAe,CAAC,YAAY;oBACpC,KAAK,EAAE,eAAe,CAAC,WAAW;iBACnC,CAAC,CAAC;gBAEH,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;gBACzC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YACjC,CAAC,EAAE,CAAC,CAAC,CAAC;SACP;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAClB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;8GA/GU,8BAA8B;kGAA9B,8BAA8B,+JAIxB,eAAe,yFACrB,mBAAmB,gJCjEhC,qaAaA,8QD6CY,mBAAmB,4+BAAE,kBAAkB;;2FAEtC,8BAA8B;kBAP1C,SAAS;+BACE,6BAA6B,cAG3B,IAAI,WACP,CAAC,mBAAmB,EAAE,kBAAkB,CAAC;sFAGzC,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEmD,OAAO;sBAA/D,eAAe;uBAAC,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBACvB,OAAO;sBAAtC,SAAS;uBAAC,mBAAmB;gBACP,iBAAiB;sBAAvC,SAAS;uBAAC,UAAU","sourcesContent":["import { CdkConnectedOverlay, ConnectedPosition } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChild\n} from '@angular/core';\nimport { combineLatest, fromEvent, merge, Subject } from 'rxjs';\nimport { debounceTime, delay, distinctUntilChanged, map, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';\nimport { executeOnNextTick } from '../../../shared/misc-helpers';\nimport { OptionComponent } from '../option/option.component';\n\nconst BOTTOM_LEFT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'end',\n  originY: 'top',\n  overlayY: 'top',\n  offsetX: -4\n};\n\nconst BOTTOM_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'start',\n  originY: 'top',\n  overlayY: 'top',\n  offsetX: 4\n};\n\nconst TOP_LEFT_POSITION: ConnectedPosition = {\n  originX: 'start',\n  overlayX: 'end',\n  originY: 'bottom',\n  overlayY: 'bottom',\n  offsetX: -4\n};\n\nconst TOP_RIGHT_POSITION: ConnectedPosition = {\n  originX: 'end',\n  overlayX: 'start',\n  originY: 'bottom',\n  overlayY: 'bottom',\n  offsetX: 4\n};\n\nconst LEFT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION, BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION];\nconst RIGHT_ALIGN_POSITIONS: ConnectedPosition[] = [BOTTOM_RIGHT_POSITION, TOP_RIGHT_POSITION, BOTTOM_LEFT_POSITION, TOP_LEFT_POSITION];\n\n@Component({\n  selector: 'lx-cdk-options-sub-dropdown',\n  templateUrl: 'cdk-options-sub-dropdown.component.html',\n  styleUrls: ['cdk-options-sub-dropdown.component.scss'],\n  standalone: true,\n  imports: [CdkConnectedOverlay, AutocloseDirective]\n})\nexport class CdkOptionsSubDropdownComponent implements AfterViewInit, OnDestroy {\n  @Input() trigger!: OptionComponent;\n  @Input() align: 'right' | 'left' = 'right';\n\n  @ContentChildren(OptionComponent, { descendants: true }) options!: QueryList<OptionComponent>;\n  @ViewChild(CdkConnectedOverlay) overlay!: CdkConnectedOverlay;\n  @ViewChild('dropdown') dropdownContainer!: ElementRef;\n\n  open = false;\n  isPositionComputed = true;\n\n  private mouseInside$ = new Subject<boolean>();\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  mouseenter() {\n    this.mouseInside$.next(true);\n  }\n\n  mouseleave() {\n    this.mouseInside$.next(false);\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  ngAfterViewInit() {\n    // To avoid `Expression has changed after it was checked`\n    executeOnNextTick(() => {\n      this.trigger.hasSubdropdown = true;\n      this.overlay.positions = this.align === 'left' ? LEFT_ALIGN_POSITIONS : RIGHT_ALIGN_POSITIONS;\n    });\n\n    merge(this.showByMouse(), this.showByKeyboard())\n      .pipe(takeUntil(this.destroyed$), distinctUntilChanged())\n      .subscribe((show) => {\n        this.open = show;\n        this.reloadOverlayPosition(this.open);\n      });\n\n    this.options.changes\n      .pipe(\n        startWith(this.options),\n        switchMap(() => merge(...this.options.map((option) => option.select), ...this.options.map((option) => option.selectedClick))),\n        delay(0),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(() => {\n        this.closeDropdown();\n      });\n  }\n\n  private showByKeyboard() {\n    const optionChange$ = this.options.changes.pipe(\n      startWith(this.options),\n      map((options: QueryList<OptionComponent>) => options.toArray()),\n      map((options) =>\n        options.map((option) => {\n          option.isSuboption = true;\n          return option;\n        })\n      )\n    );\n\n    return combineLatest([this.trigger.highlight.asObservable(), optionChange$]).pipe(\n      delay(0), // Need tick delay to get option highlighted and filter it out after\n      map(([isHighlighted, options]) => isHighlighted || options.some((option) => option.isHighlighted))\n    );\n  }\n\n  private showByMouse() {\n    const mouseEnterTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseenter');\n    const mouseLeaveTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseleave');\n\n    const showOnEnterMouse$ = mouseEnterTrigger$.pipe(map(() => true));\n    const hideOnLeaveMouse$ = mouseLeaveTrigger$.pipe(map(() => false));\n\n    // react to trigger mouse leave events, and mouse enter events in the sub-dropdown. We'll use a 300ms\n    // debounce, so that while navigating from the trigger to the sub-dropdown, all the intermediate events\n    // are ignored.\n    const showSubdropdown$ = merge(hideOnLeaveMouse$, this.mouseInside$).pipe(debounceTime(300));\n\n    const showOnEnterSubdropdown$ = mouseEnterTrigger$.pipe(switchMap(() => showSubdropdown$));\n\n    return merge(showOnEnterMouse$, showOnEnterSubdropdown$);\n  }\n\n  private reloadOverlayPosition(open: boolean) {\n    // force a rendering so that the dropdown container's dimensions are computed.\n    this.changeDetection.markForCheck();\n    if (open && this.dropdownContainer) {\n      this.isPositionComputed = false;\n      setTimeout(() => {\n        const dropdownElement = this.dropdownContainer.nativeElement;\n        this.overlay.overlayRef.updateSize({\n          height: dropdownElement.offsetHeight,\n          width: dropdownElement.offsetWidth\n        });\n\n        this.overlay.overlayRef.updatePosition();\n        this.isPositionComputed = true;\n      }, 0);\n    }\n  }\n\n  closeDropdown() {\n    this.open = false;\n    this.mouseInside$.next(false);\n  }\n}\n","<ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger.elementRef\" [cdkConnectedOverlayOpen]=\"open\">\n  <ul\n    (mouseenter)=\"mouseenter()\"\n    (mouseleave)=\"mouseleave()\"\n    class=\"sub-dropdown\"\n    [style.visibility]=\"isPositionComputed ? '' : 'hidden'\"\n    lxAutoclose\n    (autoclose)=\"closeDropdown()\"\n    #dropdown\n  >\n    <ng-content></ng-content>\n  </ul>\n</ng-template>\n"]}
|
@@ -1,4 +1,5 @@
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
2
|
+
import { TranslateModule } from '@ngx-translate/core';
|
2
3
|
import { isString } from 'lodash-es';
|
3
4
|
import * as i0 from "@angular/core";
|
4
5
|
import * as i1 from "@angular/cdk/clipboard";
|
@@ -34,11 +35,11 @@ export class CopyButtonComponent {
|
|
34
35
|
return isString(this.data) ? this.data : JSON.stringify(this.data, null, '\t');
|
35
36
|
}
|
36
37
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CopyButtonComponent, deps: [{ token: i1.Clipboard }], target: i0.ɵɵFactoryTarget.Component }); }
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CopyButtonComponent, selector: "lx-copy-button", inputs: { data: "data", dataDescription: "dataDescription", btn: "btn" }, outputs: { success: "success", error: "error" }, ngImport: i0, template: "<button (click)=\"copy()\" class=\"btn btn-{{ btn }} btnCopyJson\">\n <i class=\"far fa-copy\"></i>\n <span>\n {{ 'buttons.copy' | translate }}\n </span>\n</button>\n", dependencies: [{ kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
38
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CopyButtonComponent, isStandalone: true, selector: "lx-copy-button", inputs: { data: "data", dataDescription: "dataDescription", btn: "btn" }, outputs: { success: "success", error: "error" }, ngImport: i0, template: "<button (click)=\"copy()\" class=\"btn btn-{{ btn }} btnCopyJson\">\n <i class=\"far fa-copy\"></i>\n <span>\n {{ 'buttons.copy' | translate }}\n </span>\n</button>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
38
39
|
}
|
39
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CopyButtonComponent, decorators: [{
|
40
41
|
type: Component,
|
41
|
-
args: [{ selector: 'lx-copy-button', template: "<button (click)=\"copy()\" class=\"btn btn-{{ btn }} btnCopyJson\">\n <i class=\"far fa-copy\"></i>\n <span>\n {{ 'buttons.copy' | translate }}\n </span>\n</button>\n" }]
|
42
|
+
args: [{ selector: 'lx-copy-button', standalone: true, imports: [TranslateModule], template: "<button (click)=\"copy()\" class=\"btn btn-{{ btn }} btnCopyJson\">\n <i class=\"far fa-copy\"></i>\n <span>\n {{ 'buttons.copy' | translate }}\n </span>\n</button>\n" }]
|
42
43
|
}], ctorParameters: () => [{ type: i1.Clipboard }], propDecorators: { data: [{
|
43
44
|
type: Input
|
44
45
|
}], dataDescription: [{
|
@@ -50,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
|
|
50
51
|
}], error: [{
|
51
52
|
type: Output
|
52
53
|
}] } });
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29weS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvY29tcG9uZW50cy9jb3B5LWJ1dHRvbi9jb3B5LWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2NvcHktYnV0dG9uL2NvcHktYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7Ozs7QUFRckMsTUFBTSxPQUFPLG1CQUFtQjtJQWE5QixZQUFvQixTQUFvQjtRQUFwQixjQUFTLEdBQVQsU0FBUyxDQUFXO1FBWnhDLHVEQUF1RDtRQUM5QyxTQUFJLEdBQXFDLEVBQUUsQ0FBQztRQUdyRCwwRUFBMEU7UUFDakUsUUFBRyxHQUE0QyxTQUFTLENBQUM7UUFFeEQsWUFBTyxHQUFHLElBQUksWUFBWSxFQUErRSxDQUFDO1FBQzFHLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBK0UsQ0FBQztRQUV6RyxTQUFJLEdBQUcscUJBQXFCLENBQUM7SUFFSyxDQUFDO0lBRTVDLEtBQUssQ0FBQyxJQUFJO1FBQ1IsSUFBSTtZQUNGLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNsQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMxQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztnQkFDaEIsVUFBVSxFQUFFLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksa0JBQWtCLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksY0FBYztnQkFDOUYsZUFBZSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxlQUFlLEVBQUU7YUFDaEQsQ0FBQyxDQUFDO1NBQ0o7UUFBQyxPQUFPLEdBQUcsRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO2dCQUNkLFVBQVUsRUFBRSxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLGNBQWM7Z0JBQzlGLGVBQWUsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsZUFBZSxFQUFFO2FBQ2hELENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQztJQUVPLGFBQWE7UUFDbkIsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2pGLENBQUM7OEdBakNVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLHFNQ1hoQyw4S0FNQSwyQ0RHWSxlQUFlOzsyRkFFZCxtQkFBbUI7a0JBTi9CLFNBQVM7K0JBQ0UsZ0JBQWdCLGNBRWQsSUFBSSxXQUNQLENBQUMsZUFBZSxDQUFDOzhFQUlqQixJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsZUFBZTtzQkFBdkIsS0FBSztnQkFFRyxHQUFHO3NCQUFYLEtBQUs7Z0JBRUksT0FBTztzQkFBaEIsTUFBTTtnQkFDRyxLQUFLO3NCQUFkLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGlwYm9hcmQgfSBmcm9tICdAYW5ndWxhci9jZGsvY2xpcGJvYXJkJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IGlzU3RyaW5nIH0gZnJvbSAnbG9kYXNoLWVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtY29weS1idXR0b24nLFxuICB0ZW1wbGF0ZVVybDogJ2NvcHktYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1RyYW5zbGF0ZU1vZHVsZV1cbn0pXG5leHBvcnQgY2xhc3MgQ29weUJ1dHRvbkNvbXBvbmVudCB7XG4gIC8qKiBKU09OIHN0cmluZyBvciBvYmplY3QgdG8gYmUgc2F2ZWQvY29waWVkIGFzIEpTT04gKi9cbiAgQElucHV0KCkgZGF0YTogc3RyaW5nIHwgUmVjb3JkPHN0cmluZywgdW5rbm93bj4gPSAnJztcbiAgLyoqIExhYmVsIHRvIGJlIHVzZWQgZm9yIGRhdGEgaW4gdG9hc3RyIG1lc3NhZ2VzICovXG4gIEBJbnB1dCgpIGRhdGFEZXNjcmlwdGlvbj86IHN0cmluZztcbiAgLyoqIERldGVybWluZSBjb3B5IGJ1dHRvbiBCb290c3RyYXAgY2xhc3MgJiBjb2xvciBvciBoaWRlIGl0IGFsdG9nZXRoZXIgKi9cbiAgQElucHV0KCkgYnRuOiAnZGVmYXVsdCcgfCAncHJpbWFyeScgfCAnaW5mbycgfCAnaGlkZScgPSAnZGVmYXVsdCc7XG5cbiAgQE91dHB1dCgpIHN1Y2Nlc3MgPSBuZXcgRXZlbnRFbWl0dGVyPHsgbWVzc2FnZUtleTogc3RyaW5nOyB0cmFuc2xhdGVQYXJhbXM6IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IHVuZGVmaW5lZD4gfT4oKTtcbiAgQE91dHB1dCgpIGVycm9yID0gbmV3IEV2ZW50RW1pdHRlcjx7IG1lc3NhZ2VLZXk6IHN0cmluZzsgdHJhbnNsYXRlUGFyYW1zOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+IH0+KCk7XG5cbiAgcmVhZG9ubHkgTkFNRSA9ICdDb3B5QnV0dG9uQ29tcG9uZW50JztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNsaXBib2FyZDogQ2xpcGJvYXJkKSB7fVxuXG4gIGFzeW5jIGNvcHkoKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGpzb24gPSB0aGlzLmdldFN0cmluZ0RhdGEoKTtcbiAgICAgIHRoaXMuY2xpcGJvYXJkLmNvcHkoanNvbik7XG4gICAgICB0aGlzLnN1Y2Nlc3MuZW1pdCh7XG4gICAgICAgIG1lc3NhZ2VLZXk6IHRoaXMuZGF0YURlc2NyaXB0aW9uID8gYCR7dGhpcy5OQU1FfS5kYXRhQ29weVN1Y2Nlc3NgIDogYCR7dGhpcy5OQU1FfS5jb3B5U3VjY2Vzc2AsXG4gICAgICAgIHRyYW5zbGF0ZVBhcmFtczogeyBkYXRhOiB0aGlzLmRhdGFEZXNjcmlwdGlvbiB9XG4gICAgICB9KTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIHRoaXMuZXJyb3IuZW1pdCh7XG4gICAgICAgIG1lc3NhZ2VLZXk6IHRoaXMuZGF0YURlc2NyaXB0aW9uID8gYCR7dGhpcy5OQU1FfS5kYXRhQ29weUZhaWx1cmVgIDogYCR7dGhpcy5OQU1FfS5jb3B5RmFpbHVyZWAsXG4gICAgICAgIHRyYW5zbGF0ZVBhcmFtczogeyBkYXRhOiB0aGlzLmRhdGFEZXNjcmlwdGlvbiB9XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldFN0cmluZ0RhdGEoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gaXNTdHJpbmcodGhpcy5kYXRhKSA/IHRoaXMuZGF0YSA6IEpTT04uc3RyaW5naWZ5KHRoaXMuZGF0YSwgbnVsbCwgJ1xcdCcpO1xuICB9XG59XG4iLCI8YnV0dG9uIChjbGljayk9XCJjb3B5KClcIiBjbGFzcz1cImJ0biBidG4te3sgYnRuIH19IGJ0bkNvcHlKc29uXCI+XG4gIDxpIGNsYXNzPVwiZmFyIGZhLWNvcHlcIj48L2k+XG4gIDxzcGFuPlxuICAgIHt7ICdidXR0b25zLmNvcHknIHwgdHJhbnNsYXRlIH19XG4gIDwvc3Bhbj5cbjwvYnV0dG9uPlxuIl19
|
@@ -1,14 +1,14 @@
|
|
1
1
|
import { __decorate } from "tslib";
|
2
|
+
import { AsyncPipe, DecimalPipe, NgIf } from '@angular/common';
|
2
3
|
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
|
3
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
|
+
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
5
|
import { fromEvent, ReplaySubject, Subject } from 'rxjs';
|
5
6
|
import { filter, takeUntil } from 'rxjs/operators';
|
6
7
|
import { Observe } from '../../../shared/observe';
|
8
|
+
import { MarkInvalidDirective } from '../../directives/mark-invalid.directive';
|
9
|
+
import { CurrencySymbolComponent } from './currency-symbol.component';
|
7
10
|
import * as i0 from "@angular/core";
|
8
|
-
import * as i1 from "@angular/
|
9
|
-
import * as i2 from "@angular/forms";
|
10
|
-
import * as i3 from "./currency-symbol.component";
|
11
|
-
import * as i4 from "../../directives/mark-invalid.directive";
|
11
|
+
import * as i1 from "@angular/forms";
|
12
12
|
export class CurrencyInputComponent {
|
13
13
|
get allowedCharacters() {
|
14
14
|
return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\e\\${this.decimalSeparator}\]`) : /[0-9\e\\]/;
|
@@ -94,13 +94,13 @@ export class CurrencyInputComponent {
|
|
94
94
|
return value.indexOf(',') > -1 || value.indexOf('.') > -1;
|
95
95
|
}
|
96
96
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CurrencyInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
97
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CurrencyInputComponent, selector: "lx-currency-input", inputs: { code: "code", decimalSeparator: "decimalSeparator", placeholder: "placeholder", data: "data", disabled: "disabled", mode: "mode", fieldDefinitionType: "fieldDefinitionType", iconPosition: "iconPosition", format: "format", markInvalid: "markInvalid" }, outputs: { onFocusLost: "onFocusLost", onChange: "onChange" }, providers: [
|
97
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CurrencyInputComponent, isStandalone: true, selector: "lx-currency-input", inputs: { code: "code", decimalSeparator: "decimalSeparator", placeholder: "placeholder", data: "data", disabled: "disabled", mode: "mode", fieldDefinitionType: "fieldDefinitionType", iconPosition: "iconPosition", format: "format", markInvalid: "markInvalid" }, outputs: { onFocusLost: "onFocusLost", onChange: "onChange" }, providers: [
|
98
98
|
{
|
99
99
|
provide: NG_VALUE_ACCESSOR,
|
100
100
|
useExisting: forwardRef(() => CurrencyInputComponent),
|
101
101
|
multi: true
|
102
102
|
}
|
103
|
-
], viewQueries: [{ propertyName: "currencyInput", first: true, predicate: ["currencyInput"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number: format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number: format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"], dependencies: [{ kind: "directive", type:
|
103
|
+
], viewQueries: [{ propertyName: "currencyInput", first: true, predicate: ["currencyInput"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number: format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number: format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CurrencySymbolComponent, selector: "lx-currency-symbol", inputs: ["code"] }, { kind: "directive", type: MarkInvalidDirective, selector: "[lxMarkInvalid]", inputs: ["lxMarkInvalid"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: DecimalPipe, name: "number" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
104
104
|
}
|
105
105
|
__decorate([
|
106
106
|
Observe('data')
|
@@ -113,7 +113,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
|
|
113
113
|
useExisting: forwardRef(() => CurrencyInputComponent),
|
114
114
|
multi: true
|
115
115
|
}
|
116
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number: format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number: format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"] }]
|
116
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, CurrencySymbolComponent, MarkInvalidDirective, FormsModule, AsyncPipe, DecimalPipe], template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number: format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number: format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"] }]
|
117
117
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { code: [{
|
118
118
|
type: Input
|
119
119
|
}], decimalSeparator: [{
|
@@ -142,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
|
|
142
142
|
type: ViewChild,
|
143
143
|
args: ['currencyInput']
|
144
144
|
}] } });
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\n\nexport type CurrencyInputMode = 'view' | 'edit';\nexport type CurrencyIconPosition = 'first' | 'end' | 'none';\n\nexport type DecimalSeparator = ',' | '.';\n\n@Component({\n  selector: 'lx-currency-input',\n  templateUrl: 'currency-input.component.html',\n  styleUrls: ['currency-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CurrencyInputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CurrencyInputComponent implements AfterViewInit, OnDestroy, ControlValueAccessor, OnInit {\n  @Input() public code!: string | null;\n  @Input() public decimalSeparator: DecimalSeparator = '.';\n  @Input() public placeholder!: string;\n  @Input() public data: number = 0;\n  @Observe<number>('data') data$!: Observable<number>;\n\n  @Input() public disabled: boolean = false;\n  @Input() public mode: CurrencyInputMode = 'edit';\n  @Input() public fieldDefinitionType!: 'DOUBLE' | 'INTEGER';\n  @Input() public iconPosition: CurrencyIconPosition = 'first';\n  @Input() public format: string = '1.2-2';\n  @Input() markInvalid = false;\n\n  @Output() public onFocusLost = new EventEmitter<boolean>();\n  @Output() public onChange = new EventEmitter<number>();\n\n  @ViewChild('currencyInput') private currencyInput!: ElementRef<HTMLInputElement>;\n  showCurrencyInput: boolean = false;\n  dataValue$ = new ReplaySubject<number>();\n\n  private get allowedCharacters() {\n    return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\\e\\\\${this.decimalSeparator}\\]`) : /[0-9\\e\\\\]/;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetector: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.data$.pipe(takeUntil(this.destroyed$)).subscribe(this.dataValue$);\n  }\n\n  ngAfterViewInit() {\n    if (this.currencyInput) {\n      fromEvent<KeyboardEvent>(this.currencyInput.nativeElement, 'keypress')\n        .pipe(\n          filter((keyboardEvent) => this.shouldRejectKey(keyboardEvent)),\n          takeUntil(this.destroyed$)\n        )\n        .subscribe((keyboardEvent) => {\n          keyboardEvent.preventDefault();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  valueChanged(value: string | number) {\n    if (typeof value === 'string') {\n      const invalidSeparator = this.decimalSeparator === '.' ? ',' : '.';\n      value = this.parseInput(value, invalidSeparator) as number;\n    }\n    // fix copy & paste string values being interpreted wrongly\n    this.dataValue$.next(value);\n    this.onChange.emit(value);\n    this.propagateChange(value);\n  }\n\n  onBlur() {\n    this.showCurrencyInput = false;\n    this.onFocusLost.emit(true);\n  }\n\n  focusCurrencyInput() {\n    this.showCurrencyInput = true;\n    this.changeDetector.detectChanges();\n    this.currencyInput.nativeElement.focus();\n    this.currencyInput.nativeElement.setSelectionRange(0, 0);\n  }\n\n  shouldRejectKey(event: KeyboardEvent) {\n    if (this.fieldDefinitionType === 'DOUBLE' && event.key === this.decimalSeparator) {\n      return this.containsSeparators(this.currencyInput.nativeElement.value);\n    }\n    return !this.allowedCharacters.test(event.key);\n  }\n\n  propagateChange(_newValue: number) {}\n\n  writeValue(newValue: number) {\n    this.dataValue$.next(newValue);\n  }\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(_fn: any) {}\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  private parseInput(value: string, char: string) {\n    const countOccurences = value.split(char).length - 1;\n    if (countOccurences > 1) {\n      for (let i = 0; i < countOccurences; i++) {\n        value = value.replace(char, '');\n      }\n    }\n    const parsedValue = parseFloat(value.replace(',', '.').replace(/ /g, ''));\n    return isNaN(parsedValue) ? null : parsedValue;\n  }\n\n  private containsSeparators(value: string) {\n    return value.indexOf(',') > -1 || value.indexOf('.') > -1;\n  }\n}\n","<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n  <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    *ngIf=\"!showCurrencyInput\"\n    type=\"text\"\n    class=\"form-control currencyDisplayValue\"\n    placeholder=\"{{ placeholder }}\"\n    [lxMarkInvalid]=\"markInvalid\"\n    [value]=\"dataValue$ | async | number: format\"\n    (focus)=\"focusCurrencyInput()\"\n  />\n  <input\n    autocomplete=\"off\"\n    [attr.disabled]=\"disabled ? true : null\"\n    [class.hideInput]=\"!showCurrencyInput\"\n    type=\"text\"\n    inputmode=\"numeric\"\n    class=\"form-control currencyInput\"\n    name=\"inputAmount\"\n    #currencyInput\n    placeholder=\"{{ placeholder }}\"\n    [ngModel]=\"dataValue$ | async\"\n    (blur)=\"onBlur()\"\n    (ngModelChange)=\"valueChanged($event)\"\n  />\n  <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n  <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n  <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n"]}
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,YAAY,EACZ,UAAU,EACV,KAAK,EAGL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EAAE,SAAS,EAAc,aAAa,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAAE,oBAAoB,EAAE,MAAM,yCAAyC,CAAC;AAC/E,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;;;AAsBtE,MAAM,OAAO,sBAAsB;IAqBjC,IAAY,iBAAiB;QAC3B,OAAO,IAAI,CAAC,mBAAmB,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,WAAW,IAAI,CAAC,gBAAgB,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IAChH,CAAC;IAID,YAAoB,cAAiC;QAAjC,mBAAc,GAAd,cAAc,CAAmB;QAzBrC,qBAAgB,GAAqB,GAAG,CAAC;QAEzC,SAAI,GAAW,CAAC,CAAC;QAGjB,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAsB,MAAM,CAAC;QAEjC,iBAAY,GAAyB,OAAO,CAAC;QAC7C,WAAM,GAAW,OAAO,CAAC;QAChC,gBAAW,GAAG,KAAK,CAAC;QAEZ,gBAAW,GAAG,IAAI,YAAY,EAAW,CAAC;QAC1C,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QAGvD,sBAAiB,GAAY,KAAK,CAAC;QACnC,eAAU,GAAG,IAAI,aAAa,EAAU,CAAC;QAMhC,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAEc,CAAC;IAEzD,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACzE,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,SAAS,CAAgB,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,UAAU,CAAC;iBACnE,IAAI,CACH,MAAM,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,EAC9D,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;iBACA,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE;gBAC3B,aAAa,CAAC,cAAc,EAAE,CAAC;YACjC,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,YAAY,CAAC,KAAsB;QACjC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YACnE,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,gBAAgB,CAAW,CAAC;SAC5D;QACD,2DAA2D;QAC3D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACpC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACzC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED,eAAe,CAAC,KAAoB;QAClC,IAAI,IAAI,CAAC,mBAAmB,KAAK,QAAQ,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,gBAAgB,EAAE;YAChF,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;SACxE;QACD,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACjD,CAAC;IAED,eAAe,CAAC,SAAiB,IAAG,CAAC;IAErC,UAAU,CAAC,QAAgB;QACzB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IACD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,GAAQ,IAAG,CAAC;IAE9B,gBAAgB,CAAC,QAAiB;QAChC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAEO,UAAU,CAAC,KAAa,EAAE,IAAY;QAC5C,MAAM,eAAe,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QACrD,IAAI,eAAe,GAAG,CAAC,EAAE;YACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,EAAE,CAAC,EAAE,EAAE;gBACxC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;aACjC;SACF;QACD,MAAM,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;QAC1E,OAAO,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC;IACjD,CAAC;IAEO,kBAAkB,CAAC,KAAa;QACtC,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC;8GA5GU,sBAAsB;kGAAtB,sBAAsB,qYAXtB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACZ;SACF,0ICrCH,8mDAsCA,4NDEY,IAAI,6FAAE,uBAAuB,iFAAE,oBAAoB,sFAAE,WAAW,0mBAAE,SAAS,yCAAE,WAAW;;AAOzE;IAAxB,OAAO,CAAS,MAAM,CAAC;qDAA4B;2FALzC,sBAAsB;kBAflC,SAAS;+BACE,mBAAmB,aAGlB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ;qBACF,mBACgB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,IAAI,EAAE,uBAAuB,EAAE,oBAAoB,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,CAAC;sFAGnF,IAAI;sBAAnB,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACmB,KAAK,MAEd,QAAQ;sBAAvB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEW,WAAW;sBAA3B,MAAM;gBACU,QAAQ;sBAAxB,MAAM;gBAE6B,aAAa;sBAAhD,SAAS;uBAAC,eAAe","sourcesContent":["import { AsyncPipe, DecimalPipe, NgIf } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\nimport { MarkInvalidDirective } from '../../directives/mark-invalid.directive';\nimport { CurrencySymbolComponent } from './currency-symbol.component';\n\nexport type CurrencyInputMode = 'view' | 'edit';\nexport type CurrencyIconPosition = 'first' | 'end' | 'none';\n\nexport type DecimalSeparator = ',' | '.';\n\n@Component({\n  selector: 'lx-currency-input',\n  templateUrl: 'currency-input.component.html',\n  styleUrls: ['currency-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CurrencyInputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgIf, CurrencySymbolComponent, MarkInvalidDirective, FormsModule, AsyncPipe, DecimalPipe]\n})\nexport class CurrencyInputComponent implements AfterViewInit, OnDestroy, ControlValueAccessor, OnInit {\n  @Input() public code!: string | null;\n  @Input() public decimalSeparator: DecimalSeparator = '.';\n  @Input() public placeholder!: string;\n  @Input() public data: number = 0;\n  @Observe<number>('data') data$!: Observable<number>;\n\n  @Input() public disabled: boolean = false;\n  @Input() public mode: CurrencyInputMode = 'edit';\n  @Input() public fieldDefinitionType!: 'DOUBLE' | 'INTEGER';\n  @Input() public iconPosition: CurrencyIconPosition = 'first';\n  @Input() public format: string = '1.2-2';\n  @Input() markInvalid = false;\n\n  @Output() public onFocusLost = new EventEmitter<boolean>();\n  @Output() public onChange = new EventEmitter<number>();\n\n  @ViewChild('currencyInput') private currencyInput!: ElementRef<HTMLInputElement>;\n  showCurrencyInput: boolean = false;\n  dataValue$ = new ReplaySubject<number>();\n\n  private get allowedCharacters() {\n    return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\\e\\\\${this.decimalSeparator}\\]`) : /[0-9\\e\\\\]/;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetector: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.data$.pipe(takeUntil(this.destroyed$)).subscribe(this.dataValue$);\n  }\n\n  ngAfterViewInit() {\n    if (this.currencyInput) {\n      fromEvent<KeyboardEvent>(this.currencyInput.nativeElement, 'keypress')\n        .pipe(\n          filter((keyboardEvent) => this.shouldRejectKey(keyboardEvent)),\n          takeUntil(this.destroyed$)\n        )\n        .subscribe((keyboardEvent) => {\n          keyboardEvent.preventDefault();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  valueChanged(value: string | number) {\n    if (typeof value === 'string') {\n      const invalidSeparator = this.decimalSeparator === '.' ? ',' : '.';\n      value = this.parseInput(value, invalidSeparator) as number;\n    }\n    // fix copy & paste string values being interpreted wrongly\n    this.dataValue$.next(value);\n    this.onChange.emit(value);\n    this.propagateChange(value);\n  }\n\n  onBlur() {\n    this.showCurrencyInput = false;\n    this.onFocusLost.emit(true);\n  }\n\n  focusCurrencyInput() {\n    this.showCurrencyInput = true;\n    this.changeDetector.detectChanges();\n    this.currencyInput.nativeElement.focus();\n    this.currencyInput.nativeElement.setSelectionRange(0, 0);\n  }\n\n  shouldRejectKey(event: KeyboardEvent) {\n    if (this.fieldDefinitionType === 'DOUBLE' && event.key === this.decimalSeparator) {\n      return this.containsSeparators(this.currencyInput.nativeElement.value);\n    }\n    return !this.allowedCharacters.test(event.key);\n  }\n\n  propagateChange(_newValue: number) {}\n\n  writeValue(newValue: number) {\n    this.dataValue$.next(newValue);\n  }\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(_fn: any) {}\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  private parseInput(value: string, char: string) {\n    const countOccurences = value.split(char).length - 1;\n    if (countOccurences > 1) {\n      for (let i = 0; i < countOccurences; i++) {\n        value = value.replace(char, '');\n      }\n    }\n    const parsedValue = parseFloat(value.replace(',', '.').replace(/ /g, ''));\n    return isNaN(parsedValue) ? null : parsedValue;\n  }\n\n  private containsSeparators(value: string) {\n    return value.indexOf(',') > -1 || value.indexOf('.') > -1;\n  }\n}\n","<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n  <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    *ngIf=\"!showCurrencyInput\"\n    type=\"text\"\n    class=\"form-control currencyDisplayValue\"\n    placeholder=\"{{ placeholder }}\"\n    [lxMarkInvalid]=\"markInvalid\"\n    [value]=\"dataValue$ | async | number: format\"\n    (focus)=\"focusCurrencyInput()\"\n  />\n  <input\n    autocomplete=\"off\"\n    [attr.disabled]=\"disabled ? true : null\"\n    [class.hideInput]=\"!showCurrencyInput\"\n    type=\"text\"\n    inputmode=\"numeric\"\n    class=\"form-control currencyInput\"\n    name=\"inputAmount\"\n    #currencyInput\n    placeholder=\"{{ placeholder }}\"\n    [ngModel]=\"dataValue$ | async\"\n    (blur)=\"onBlur()\"\n    (ngModelChange)=\"valueChanged($event)\"\n  />\n  <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n  <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n  <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n"]}
|
@@ -1,24 +1,24 @@
|
|
1
1
|
import { __decorate } from "tslib";
|
2
|
+
import { AsyncPipe } from '@angular/common';
|
2
3
|
import { Component, Input } from '@angular/core';
|
3
4
|
import { map } from 'rxjs/operators';
|
4
5
|
import { Observe } from '../../../shared/observe';
|
5
6
|
import { CURRENCY_SYMBOL_MAP } from './currency-symbol-map.constant';
|
6
7
|
import * as i0 from "@angular/core";
|
7
|
-
import * as i1 from "@angular/common";
|
8
8
|
export class CurrencySymbolComponent {
|
9
9
|
ngOnInit() {
|
10
10
|
this.currency$ = this.code$.pipe(map((code) => CURRENCY_SYMBOL_MAP[code] || code));
|
11
11
|
}
|
12
12
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CurrencySymbolComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
13
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CurrencySymbolComponent, selector: "lx-currency-symbol", inputs: { code: "code" }, ngImport: i0, template: "<span [innerHtml]=\"currency$ | async\"></span>\n", dependencies: [{ kind: "pipe", type:
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: CurrencySymbolComponent, isStandalone: true, selector: "lx-currency-symbol", inputs: { code: "code" }, ngImport: i0, template: "<span [innerHtml]=\"currency$ | async\"></span>\n", dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }] }); }
|
14
14
|
}
|
15
15
|
__decorate([
|
16
16
|
Observe('code')
|
17
17
|
], CurrencySymbolComponent.prototype, "code$", void 0);
|
18
18
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: CurrencySymbolComponent, decorators: [{
|
19
19
|
type: Component,
|
20
|
-
args: [{ selector: 'lx-currency-symbol', template: "<span [innerHtml]=\"currency$ | async\"></span>\n" }]
|
20
|
+
args: [{ selector: 'lx-currency-symbol', standalone: true, imports: [AsyncPipe], template: "<span [innerHtml]=\"currency$ | async\"></span>\n" }]
|
21
21
|
}], propDecorators: { code: [{
|
22
22
|
type: Input
|
23
23
|
}], code$: [] } });
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvY3VycmVuY3kvY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvY3VycmVuY3kvY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDNUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFFekQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFRckUsTUFBTSxPQUFPLHVCQUF1QjtJQUtsQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDckYsQ0FBQzs4R0FQVSx1QkFBdUI7a0dBQXZCLHVCQUF1Qix3R0NicEMsbURBQ0EsdUNEVVksU0FBUzs7QUFJRjtJQUFoQixPQUFPLENBQUMsTUFBTSxDQUFDO3NEQUE0QjsyRkFGakMsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLG9CQUFvQixjQUVsQixJQUFJLFdBQ1AsQ0FBQyxTQUFTLENBQUM7OEJBR1gsSUFBSTtzQkFBWixLQUFLO2dCQUNXLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3luY1BpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBPYnNlcnZlIH0gZnJvbSAnLi4vLi4vLi4vc2hhcmVkL29ic2VydmUnO1xuaW1wb3J0IHsgQ1VSUkVOQ1lfU1lNQk9MX01BUCB9IGZyb20gJy4vY3VycmVuY3ktc3ltYm9sLW1hcC5jb25zdGFudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2x4LWN1cnJlbmN5LXN5bWJvbCcsXG4gIHRlbXBsYXRlVXJsOiAnY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC5odG1sJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0FzeW5jUGlwZV1cbn0pXG5leHBvcnQgY2xhc3MgQ3VycmVuY3lTeW1ib2xDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBjb2RlITogc3RyaW5nIHwgbnVsbDtcbiAgQE9ic2VydmUoJ2NvZGUnKSBjb2RlJCE6IE9ic2VydmFibGU8c3RyaW5nPjtcbiAgY3VycmVuY3kkITogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuY3VycmVuY3kkID0gdGhpcy5jb2RlJC5waXBlKG1hcCgoY29kZSkgPT4gQ1VSUkVOQ1lfU1lNQk9MX01BUFtjb2RlXSB8fCBjb2RlKSk7XG4gIH1cbn1cbiIsIjxzcGFuIFtpbm5lckh0bWxdPVwiY3VycmVuY3kkIHwgYXN5bmNcIj48L3NwYW4+XG4iXX0=
|