@leanix/components 0.4.263 → 0.4.265
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/components/badge/badge.component.mjs +2 -2
- package/esm2022/lib/core-ui/components/ellipsis/ellipsis.component.mjs +2 -2
- package/esm2022/lib/core-ui/components/empty-state/empty-state.component.mjs +2 -2
- package/esm2022/lib/core-ui/components/stepper/stepper.component.mjs +3 -3
- package/esm2022/lib/core-ui/core-ui.module.mjs +6 -6
- 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/cdk-options-dropdown/cdk-options-dropdown.component.mjs +2 -2
- package/esm2022/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.mjs +2 -2
- package/esm2022/lib/forms-ui/components/currency/currency-input.component.mjs +3 -3
- package/esm2022/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.mjs +1 -1
- package/esm2022/lib/forms-ui/components/keyboard-select.directive.mjs +2 -2
- package/esm2022/lib/forms-ui/components/multi-select/multi-select-selection/multi-select-selection.component.mjs +2 -2
- package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +2 -2
- package/esm2022/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.mjs +2 -2
- package/esm2022/lib/forms-ui/components/picker/picker-trigger.directive.mjs +2 -2
- package/esm2022/lib/forms-ui/components/pill-list/pill-list.component.mjs +1 -1
- package/esm2022/lib/forms-ui/directives/form-error.directive.mjs +1 -1
- package/esm2022/lib/forms-ui/directives/form-submit.directive.mjs +1 -1
- package/esm2022/lib/forms-ui/directives/max-length-counter.directive.mjs +2 -3
- package/esm2022/lib/forms-ui/validators/string-not-in-array.validator.mjs +1 -1
- package/esm2022/lib/tab-ui/components/tab-group/tab-group.component.mjs +2 -2
- package/fesm2022/leanix-components.mjs +147 -147
- package/fesm2022/leanix-components.mjs.map +1 -1
- package/lib/core-ui/components/stepper/stepper.component.d.ts +2 -2
- package/lib/forms-ui/directives/max-length-counter.directive.d.ts +1 -1
- package/package.json +1 -1
@@ -1,6 +1,6 @@
|
|
1
1
|
import { CdkConnectedOverlay } from '@angular/cdk/overlay';
|
2
2
|
import { Component, ContentChildren, Input, ViewChild } from '@angular/core';
|
3
|
-
import { combineLatest, fromEvent, merge
|
3
|
+
import { Subject, combineLatest, fromEvent, merge } from 'rxjs';
|
4
4
|
import { debounceTime, delay, distinctUntilChanged, map, startWith, switchMap, takeUntil } from 'rxjs/operators';
|
5
5
|
import { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';
|
6
6
|
import { executeOnNextTick } from '../../../shared/misc-helpers';
|
@@ -132,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
132
132
|
type: ViewChild,
|
133
133
|
args: ['dropdown']
|
134
134
|
}] } });
|
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":"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","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 />\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,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,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,0ZAaA,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 { Subject, combineLatest, fromEvent, merge } 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 />\n  </ul>\n</ng-template>\n"]}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
import { __decorate } from "tslib";
|
2
2
|
import { AsyncPipe, DecimalPipe, NgIf } from '@angular/common';
|
3
|
-
import { ChangeDetectionStrategy, Component, EventEmitter,
|
3
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, forwardRef } from '@angular/core';
|
4
4
|
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
|
5
|
-
import {
|
5
|
+
import { ReplaySubject, Subject, fromEvent } from 'rxjs';
|
6
6
|
import { filter, takeUntil } from 'rxjs/operators';
|
7
7
|
import { Observe } from '../../../shared/observe';
|
8
8
|
import { MarkInvalidDirective } from '../../directives/mark-invalid.directive';
|
@@ -144,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
144
144
|
type: ViewChild,
|
145
145
|
args: ['currencyInput']
|
146
146
|
}] } });
|
147
|
-
//# 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 { 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  @Input() public inputId?: string;\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\" />\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    [attr.id]=\"inputId\"\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\" />\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\" />\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\" />\n</span>\n"]}
|
147
|
+
//# 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 { AsyncPipe, DecimalPipe, NgIf } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, ReplaySubject, Subject, fromEvent } 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  @Input() public inputId?: string;\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\" />\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    [attr.id]=\"inputId\"\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\" />\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\" />\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\" />\n</span>\n"]}
|
@@ -35,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
35
35
|
}], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { keyboardSortableItems$: [], keyboardSortableItems: [{
|
36
36
|
type: Input
|
37
37
|
}] } });
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Ym9hcmQtc29ydGFibGUtbGlzdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2RyYWctYW5kLWRyb3AtbGlzdC9rZXlib2FyZC1zb3J0YWJsZS1saXN0L2tleWJvYXJkLXNvcnRhYmxlLWxpc3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFaEUsT0FBTyxFQUFjLEtBQUssRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN6QyxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDckQsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sY0FBYyxDQUFDOzs7QUFPbkUsTUFBTSxPQUFPLDZCQUE2QjtJQUl4QyxZQUFvQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUFHLENBQUM7SUFFMUQsZUFBZTtRQUNiLElBQUksQ0FBQywrQ0FBK0MsRUFBRSxDQUFDO0lBQ3pELENBQUM7SUFFTywrQ0FBK0M7UUFDckQsTUFBTSxnQ0FBZ0MsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUN2RSxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssSUFBSSxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxFQUM1QyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsRUFDN0csSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUNSLENBQUM7UUFFRixnQ0FBZ0MsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUNsRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsR0FBRyxtQ0FBbUMsY0FBYyxDQUFDLENBQUM7WUFDcEgsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs4R0FyQlUsNkJBQTZCO2tHQUE3Qiw2QkFBNkI7O0FBQ0U7SUFBekMsT0FBTyxDQUFDLHVCQUF1QixDQUFDOzZFQUE4RTsyRkFEcEcsNkJBQTZCO2tCQUp6QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSwwQkFBMEI7b0JBQ3BDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjtxRkFFMkMsc0JBQXNCLE1BQ3ZELHFCQUFxQjtzQkFBN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIG1lcmdlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBmaWx0ZXIsIHN3aXRjaE1hcCwgdGFrZSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IE9ic2VydmUgfSBmcm9tICcuLi8uLi8uLi8uLi9zaGFyZWQvb2JzZXJ2ZSc7XG5pbXBvcnQgeyBEUkFHX0FORF9EUk9QX0xJU1RfVFJBTlNMQVRJT05fTkFNRSB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBLZXlib2FyZFNvcnRhYmxlSXRlbURpcmVjdGl2ZSB9IGZyb20gJy4uL2tleWJvYXJkLXNvcnRhYmxlLWl0ZW0va2V5Ym9hcmQtc29ydGFibGUtaXRlbS5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbbHhLZXlib2FyZFNvcnRhYmxlTGlzdF0nLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIEtleWJvYXJkU29ydGFibGVMaXN0RGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBPYnNlcnZlKCdrZXlib2FyZFNvcnRhYmxlSXRlbXMnKSBwcml2YXRlIGtleWJvYXJkU29ydGFibGVJdGVtcyQhOiBPYnNlcnZhYmxlPEtleWJvYXJkU29ydGFibGVJdGVtRGlyZWN0aXZlW10+O1xuICBASW5wdXQoKSBrZXlib2FyZFNvcnRhYmxlSXRlbXMhOiBLZXlib2FyZFNvcnRhYmxlSXRlbURpcmVjdGl2ZVtdIHwgbnVsbDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyYW5zbGF0ZVNlcnZpY2U6IFRyYW5zbGF0ZVNlcnZpY2UpIHt9XG5cbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMuc2V0dXBDb250cm9sc1Rvb2x0aXBUb0JlU2hvd25PbkZpcnN0Rm9jdXNlZEl0ZW0oKTtcbiAgfVxuXG4gIHByaXZhdGUgc2V0dXBDb250cm9sc1Rvb2x0aXBUb0JlU2hvd25PbkZpcnN0Rm9jdXNlZEl0ZW0oKSB7XG4gICAgY29uc3QgZmlyc3RGb2N1c0V2ZW50T25BRHJhZ2dhYmxlSXRlbSQgPSB0aGlzLmtleWJvYXJkU29ydGFibGVJdGVtcyQucGlwZShcbiAgICAgIGZpbHRlcigoaXRlbXMpID0+IGl0ZW1zICYmIGl0ZW1zLmxlbmd0aCA+IDApLFxuICAgICAgc3dpdGNoTWFwKChpdGVtcykgPT4gbWVyZ2UoLi4uaXRlbXMuZmlsdGVyKChpdGVtKSA9PiBpdGVtLmlzU29ydGFibGUpLm1hcCgoaXRlbSkgPT4gaXRlbS5mb2N1c1dpdGhLZXlib2FyZCkpKSxcbiAgICAgIHRha2UoMSlcbiAgICApO1xuXG4gICAgZmlyc3RGb2N1c0V2ZW50T25BRHJhZ2dhYmxlSXRlbSQuc3Vic2NyaWJlKChpdGVtKSA9PiB7XG4gICAgICBpdGVtLnRvb2x0aXBEaXJlY3RpdmUuY29udGVudCA9IHRoaXMudHJhbnNsYXRlU2VydmljZS5pbnN0YW50KGAke0RSQUdfQU5EX0RST1BfTElTVF9UUkFOU0xBVElPTl9OQU1FfS5oZWxwVG9vbHRpcGApO1xuICAgICAgaXRlbS50b29sdGlwRGlyZWN0aXZlLnNob3coKTtcbiAgICB9KTtcbiAgfVxufVxuIl19
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { Directive, EventEmitter, Input, Output, ViewChild, ViewChildren } from '@angular/core';
|
2
|
-
import { BehaviorSubject,
|
2
|
+
import { BehaviorSubject, Observable, ReplaySubject, Subject, combineLatest } from 'rxjs';
|
3
3
|
import { delay, distinctUntilChanged, filter, map, startWith, takeUntil, withLatestFrom } from 'rxjs/operators';
|
4
4
|
import { SelectableItemDirective } from '../directives/selectable-item.directive';
|
5
5
|
import * as i0 from "@angular/core";
|
@@ -116,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
116
116
|
type: ViewChild,
|
117
117
|
args: ['keyboardSelectContainer', { static: true }]
|
118
118
|
}] } });
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyboard-select.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/components/keyboard-select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { delay, distinctUntilChanged, filter, map, startWith, takeUntil, withLatestFrom } from 'rxjs/operators';\nimport { SelectableItemDirective } from '../directives/selectable-item.directive';\nimport { DropdownItem } from '../models/dropdown-item.interface';\n\nexport enum KeyboardSelectAction {\n  PREV = 'PREV',\n  NEXT = 'NEXT',\n  FIRST = 'FIRST',\n  LAST = 'LAST',\n  LEFT = 'LEFT',\n  RIGHT = 'RIGHT',\n  EXECUTE = 'EXECUTE',\n  UNSELECT = 'UNSELECT',\n  CLOSE = 'CLOSE'\n}\n\n@Directive()\nexport class KeyboardSelectDirective implements OnDestroy, AfterViewInit {\n  cdkOverlayOpenState = new ReplaySubject<boolean>(1);\n  cdkOverlayOpen$ = this.cdkOverlayOpenState.asObservable().pipe(startWith(false), distinctUntilChanged());\n  overlayPositioning: boolean = false;\n  @Input() keyboardSelectAction = new Observable<KeyboardSelectAction | null>();\n  @Output() selectedItemIndexChange = new EventEmitter<number>(true); // TODO: this is just index change from navigating (highlighting)\n\n  @ViewChildren(SelectableItemDirective) _items!: QueryList<DropdownItem>;\n\n  @ViewChild('keyboardSelectContainer', { static: true }) keyboardSelectContainer!: ElementRef<HTMLElement>;\n\n  readonly destroyed$ = new Subject<void>();\n\n  get selectedItem$(): Observable<any> {\n    return this.selectedItemSubject$.asObservable();\n  }\n\n  // Beware: If the list of items is empty, there might not come a -1 because Angular only updates the ViewChildren lazily.\n  private readonly selectedItemIndex$ = new BehaviorSubject<number>(-1);\n  private readonly selectedItemSubject$ = new BehaviorSubject<DropdownItem | null>(null);\n\n  public select(index: number) {\n    this.selectedItemIndex$.next(index);\n  }\n\n  ngAfterViewInit(): void {\n    const itemsChanges$ = this._items.changes.pipe(startWith(this._items));\n\n    this.keyboardSelectAction\n      .pipe(\n        filter((action): action is KeyboardSelectAction => !!action),\n        withLatestFrom(this.selectedItemIndex$, itemsChanges$),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(([action, index, items]) => this.adaptSelectedIndexBasedOnKeyboardSelectAction(action, index, items));\n\n    this.keyboardSelectAction\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.EXECUTE),\n        withLatestFrom(this.selectedItem$, (_, item) => item),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((item) => item?.select?.emit());\n\n    this.selectedItemIndex$.pipe(takeUntil(this.destroyed$)).subscribe((index) => {\n      this.selectedItemIndexChange.emit(index);\n    });\n\n    combineLatest([itemsChanges$, this.selectedItemIndex$])\n      .pipe(\n        delay(0),\n        map(([items, index]: [QueryList<DropdownItem>, number]) => {\n          if (index > -1) {\n            return items.toArray()[index] ?? null;\n          } else {\n            return null;\n          }\n        }),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(this.selectedItemSubject$);\n\n    this.selectedItem$\n      .pipe(\n        filter((item) => !!item),\n        distinctUntilChanged(),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((item) => item?.scrollToItem());\n  }\n\n  public isItemSelected(item: HTMLElement, selectedItem: ElementRef<HTMLElement>) {\n    return selectedItem && item === selectedItem.nativeElement;\n  }\n\n  private adaptSelectedIndexBasedOnKeyboardSelectAction(\n    keyboardSelectAction: KeyboardSelectAction,\n    currentIndex: number,\n    items: QueryList<DropdownItem>\n  ) {\n    if (keyboardSelectAction === KeyboardSelectAction.PREV) {\n      this.selectedItemIndex$.next(this.prev(currentIndex));\n    } else if (keyboardSelectAction === KeyboardSelectAction.NEXT) {\n      this.selectedItemIndex$.next(this.next(currentIndex, items));\n    } else if (keyboardSelectAction === KeyboardSelectAction.LAST) {\n      this.selectedItemIndex$.next(this.last(items));\n    } else if (keyboardSelectAction === KeyboardSelectAction.FIRST) {\n      this.selectedItemIndex$.next(0);\n    } else if (keyboardSelectAction === KeyboardSelectAction.UNSELECT) {\n      this.selectedItemIndex$.next(-1);\n    }\n  }\n\n  private prev(index: number): number {\n    if (index > -1) {\n      return index - 1;\n    } else {\n      return index;\n    }\n  }\n\n  private next(index: number, items: QueryList<DropdownItem>): number {\n    if (items.length - 1 > index) {\n      return index + 1;\n    } else {\n      return index;\n    }\n  }\n\n  private last(items: QueryList<DropdownItem>): number {\n    return items.length - 1;\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n}\n"]}
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyboard-select.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/components/keyboard-select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport { BehaviorSubject, Observable, ReplaySubject, Subject, combineLatest } from 'rxjs';\nimport { delay, distinctUntilChanged, filter, map, startWith, takeUntil, withLatestFrom } from 'rxjs/operators';\nimport { SelectableItemDirective } from '../directives/selectable-item.directive';\nimport { DropdownItem } from '../models/dropdown-item.interface';\n\nexport enum KeyboardSelectAction {\n  PREV = 'PREV',\n  NEXT = 'NEXT',\n  FIRST = 'FIRST',\n  LAST = 'LAST',\n  LEFT = 'LEFT',\n  RIGHT = 'RIGHT',\n  EXECUTE = 'EXECUTE',\n  UNSELECT = 'UNSELECT',\n  CLOSE = 'CLOSE'\n}\n\n@Directive()\nexport class KeyboardSelectDirective implements OnDestroy, AfterViewInit {\n  cdkOverlayOpenState = new ReplaySubject<boolean>(1);\n  cdkOverlayOpen$ = this.cdkOverlayOpenState.asObservable().pipe(startWith(false), distinctUntilChanged());\n  overlayPositioning: boolean = false;\n  @Input() keyboardSelectAction = new Observable<KeyboardSelectAction | null>();\n  @Output() selectedItemIndexChange = new EventEmitter<number>(true); // TODO: this is just index change from navigating (highlighting)\n\n  @ViewChildren(SelectableItemDirective) _items!: QueryList<DropdownItem>;\n\n  @ViewChild('keyboardSelectContainer', { static: true }) keyboardSelectContainer!: ElementRef<HTMLElement>;\n\n  readonly destroyed$ = new Subject<void>();\n\n  get selectedItem$(): Observable<any> {\n    return this.selectedItemSubject$.asObservable();\n  }\n\n  // Beware: If the list of items is empty, there might not come a -1 because Angular only updates the ViewChildren lazily.\n  private readonly selectedItemIndex$ = new BehaviorSubject<number>(-1);\n  private readonly selectedItemSubject$ = new BehaviorSubject<DropdownItem | null>(null);\n\n  public select(index: number) {\n    this.selectedItemIndex$.next(index);\n  }\n\n  ngAfterViewInit(): void {\n    const itemsChanges$ = this._items.changes.pipe(startWith(this._items));\n\n    this.keyboardSelectAction\n      .pipe(\n        filter((action): action is KeyboardSelectAction => !!action),\n        withLatestFrom(this.selectedItemIndex$, itemsChanges$),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(([action, index, items]) => this.adaptSelectedIndexBasedOnKeyboardSelectAction(action, index, items));\n\n    this.keyboardSelectAction\n      .pipe(\n        filter((keyboardSelectAction) => keyboardSelectAction === KeyboardSelectAction.EXECUTE),\n        withLatestFrom(this.selectedItem$, (_, item) => item),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((item) => item?.select?.emit());\n\n    this.selectedItemIndex$.pipe(takeUntil(this.destroyed$)).subscribe((index) => {\n      this.selectedItemIndexChange.emit(index);\n    });\n\n    combineLatest([itemsChanges$, this.selectedItemIndex$])\n      .pipe(\n        delay(0),\n        map(([items, index]: [QueryList<DropdownItem>, number]) => {\n          if (index > -1) {\n            return items.toArray()[index] ?? null;\n          } else {\n            return null;\n          }\n        }),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(this.selectedItemSubject$);\n\n    this.selectedItem$\n      .pipe(\n        filter((item) => !!item),\n        distinctUntilChanged(),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((item) => item?.scrollToItem());\n  }\n\n  public isItemSelected(item: HTMLElement, selectedItem: ElementRef<HTMLElement>) {\n    return selectedItem && item === selectedItem.nativeElement;\n  }\n\n  private adaptSelectedIndexBasedOnKeyboardSelectAction(\n    keyboardSelectAction: KeyboardSelectAction,\n    currentIndex: number,\n    items: QueryList<DropdownItem>\n  ) {\n    if (keyboardSelectAction === KeyboardSelectAction.PREV) {\n      this.selectedItemIndex$.next(this.prev(currentIndex));\n    } else if (keyboardSelectAction === KeyboardSelectAction.NEXT) {\n      this.selectedItemIndex$.next(this.next(currentIndex, items));\n    } else if (keyboardSelectAction === KeyboardSelectAction.LAST) {\n      this.selectedItemIndex$.next(this.last(items));\n    } else if (keyboardSelectAction === KeyboardSelectAction.FIRST) {\n      this.selectedItemIndex$.next(0);\n    } else if (keyboardSelectAction === KeyboardSelectAction.UNSELECT) {\n      this.selectedItemIndex$.next(-1);\n    }\n  }\n\n  private prev(index: number): number {\n    if (index > -1) {\n      return index - 1;\n    } else {\n      return index;\n    }\n  }\n\n  private next(index: number, items: QueryList<DropdownItem>): number {\n    if (items.length - 1 > index) {\n      return index + 1;\n    } else {\n      return index;\n    }\n  }\n\n  private last(items: QueryList<DropdownItem>): number {\n    return items.length - 1;\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n}\n"]}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { AsyncPipe, NgTemplateOutlet } from '@angular/common';
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter,
|
2
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Output, TemplateRef, input } from '@angular/core';
|
3
3
|
import { TokenComponent } from '../../../../core-ui/components/tokenizer/token/token.component';
|
4
4
|
import { TokenizerComponent } from '../../../../core-ui/components/tokenizer/tokenizer.component';
|
5
5
|
import { SelectableItemDirective } from '../../../directives/selectable-item.directive';
|
@@ -25,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
25
25
|
type: ContentChild,
|
26
26
|
args: ['innerSelectionTemplate', { read: TemplateRef, static: true }]
|
27
27
|
}] } });
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGktc2VsZWN0LXNlbGVjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL211bHRpLXNlbGVjdC9tdWx0aS1zZWxlY3Qtc2VsZWN0aW9uL211bHRpLXNlbGVjdC1zZWxlY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvY29tcG9uZW50cy9tdWx0aS1zZWxlY3QvbXVsdGktc2VsZWN0LXNlbGVjdGlvbi9tdWx0aS1zZWxlY3Qtc2VsZWN0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0gsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGdFQUFnRSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhEQUE4RCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQVUxRSxNQUFNLE9BQU8sNkJBQThCLFNBQVEsdUJBQXVCO0lBUjFFOztRQVNFLGNBQVMsR0FBRyxLQUFLLEVBQWdCLENBQUM7UUFDbEMsYUFBUSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUViLGVBQVUsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBRTBCLHNCQUFpQixHQUE0QixJQUFJLENBQUM7S0FDaEk7OEdBUFksNkJBQTZCO2tHQUE3Qiw2QkFBNkIsaWZBTVEsV0FBVyxrRUNyQjdELDJmQWdCQSwwTUROWSxTQUFTLDhDQUFFLGdCQUFnQixvSkFBRSx1QkFBdUIsdUlBQUUsa0JBQWtCLG9IQUFFLGNBQWM7OzJGQUt2Riw2QkFBNkI7a0JBUnpDLFNBQVM7K0JBQ0UsMkJBQTJCLGNBQ3pCLElBQUksV0FDUCxDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSx1QkFBdUIsRUFBRSxrQkFBa0IsRUFBRSxjQUFjLENBQUMsbUJBR2xGLHVCQUF1QixDQUFDLE1BQU07OEJBTXJDLFVBQVU7c0JBQW5CLE1BQU07Z0JBRXNFLGlCQUFpQjtzQkFBN0YsWUFBWTt1QkFBQyx3QkFBd0IsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzeW5jUGlwZSwgTmdUZW1wbGF0ZU91dGxldCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIEV2ZW50RW1pdHRlciwgT3V0cHV0LCBUZW1wbGF0ZVJlZiwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRva2VuQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vY29yZS11aS9jb21wb25lbnRzL3Rva2VuaXplci90b2tlbi90b2tlbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG9rZW5pemVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vY29yZS11aS9jb21wb25lbnRzL3Rva2VuaXplci90b2tlbml6ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNlbGVjdGFibGVJdGVtRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vZGlyZWN0aXZlcy9zZWxlY3RhYmxlLWl0ZW0uZGlyZWN0aXZlJztcbmltcG9ydCB7IEtleWJvYXJkU2VsZWN0RGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4va2V5Ym9hcmQtc2VsZWN0LmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2x4LW11bHRpLXNlbGVjdC1zZWxlY3Rpb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQXN5bmNQaXBlLCBOZ1RlbXBsYXRlT3V0bGV0LCBTZWxlY3RhYmxlSXRlbURpcmVjdGl2ZSwgVG9rZW5pemVyQ29tcG9uZW50LCBUb2tlbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlVXJsOiAnLi9tdWx0aS1zZWxlY3Qtc2VsZWN0aW9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbXVsdGktc2VsZWN0LXNlbGVjdGlvbi5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBNdWx0aVNlbGVjdFNlbGVjdGlvbkNvbXBvbmVudCBleHRlbmRzIEtleWJvYXJkU2VsZWN0RGlyZWN0aXZlIHtcbiAgc2VsZWN0aW9uID0gaW5wdXQ8YW55W10gfCBudWxsPigpO1xuICB0b2tlbml6ZSA9IGlucHV0KHRydWUpO1xuXG4gIEBPdXRwdXQoKSByZW1vdmVJdGVtID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xuXG4gIEBDb250ZW50Q2hpbGQoJ2lubmVyU2VsZWN0aW9uVGVtcGxhdGUnLCB7IHJlYWQ6IFRlbXBsYXRlUmVmLCBzdGF0aWM6IHRydWUgfSkgc2VsZWN0aW9uVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4gfCBudWxsID0gbnVsbDtcbn1cbiIsIjx1bD5cbiAgPGx4LXRva2VuaXplciBbYWN0aXZlXT1cInRva2VuaXplKClcIj5cbiAgICBAZm9yIChzZWxlY3RlZEl0ZW0gb2Ygc2VsZWN0aW9uKCk7IHRyYWNrICRpbmRleCkge1xuICAgICAgPGx4LXRva2VuPlxuICAgICAgICA8bGlcbiAgICAgICAgICBseFNlbGVjdGFibGVJdGVtXG4gICAgICAgICAgI2l0ZW1cbiAgICAgICAgICBbY2xhc3Muc2VsZWN0ZWRdPVwiaXNJdGVtU2VsZWN0ZWQoaXRlbSwgKHNlbGVjdGVkSXRlbSQgfCBhc3luYyk/LmVsZW1lbnQpXCJcbiAgICAgICAgICAoc2VsZWN0KT1cInJlbW92ZUl0ZW0uZW1pdChzZWxlY3RlZEl0ZW0pXCJcbiAgICAgICAgPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJzZWxlY3Rpb25UZW1wbGF0ZTsgY29udGV4dDogeyAkaW1wbGljaXQ6IHNlbGVjdGVkSXRlbSB9XCIgLz5cbiAgICAgICAgPC9saT5cbiAgICAgIDwvbHgtdG9rZW4+XG4gICAgfVxuICA8L2x4LXRva2VuaXplcj5cbjwvdWw+XG4iXX0=
|
package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';
|
2
2
|
import { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';
|
3
|
-
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter,
|
3
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, ViewChild, forwardRef } from '@angular/core';
|
4
4
|
import { TranslateModule } from '@ngx-translate/core';
|
5
5
|
import { InfiniteScrollModule } from 'ngx-infinite-scroll';
|
6
6
|
import { CounterComponent } from '../../../core-ui/components/counter/counter.component';
|
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
125
125
|
type: ViewChild,
|
126
126
|
args: ['selectOrigin', { static: false }]
|
127
127
|
}] } });
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { BasicDropdownItemComponent } from '../basic-dropdown-item/basic-dropdown-item.component';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n *\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => OptionGroupDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    NgTemplateOutlet,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    BasicDropdownItemComponent,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  readonly NAME = 'OptionGroupDropdownComponent';\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n  @Input() override overlayPositioning: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  isTopDropdown = false;\n\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n}\n","<ng-container *ngIf=\"overlayPositioning; else dropdown\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\" />\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <div\n    #keyboardSelectContainer\n    class=\"scrollingPanel lxThinScrollbar\"\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    (scrolled)=\"containerScrolled.emit()\"\n  >\n    <ul class=\"options\">\n      <li\n        *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n        lxSelectableItem\n        [scrollInContainer]=\"keyboardSelectContainer\"\n        #item\n        (click)=\"onCreateNewOption()\"\n        (select)=\"onCreateNewOption()\"\n        [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n        class=\"option\"\n      >\n        <span class=\"newEntryContent\">\n          {{ newOptionLabel }}\n        </span>\n        <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\" />\n      </li>\n      <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n        <li>\n          <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n            <span>{{ optionGroup.label | uppercase }}</span>\n          </div>\n          <ul>\n            <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n              <li class=\"noResult\">\n                <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                  <ng-container *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\" />\n                </ng-container>\n                <ng-template #defaultText>\n                  <span>{{ NAME + '.noResults' | translate }}</span>\n                </ng-template>\n              </li>\n            </ng-container>\n            <ng-template #options>\n              <li\n                *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n                lxSelectableItem\n                [scrollInContainer]=\"keyboardSelectContainer\"\n                #item\n                class=\"option\"\n                (click)=\"selectOption(option)\"\n                (select)=\"selectOption(option)\"\n                [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n              >\n                <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                  <ng-container\n                    *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                  />\n                </ng-container>\n                <ng-template #basicDropdownOption>\n                  <lx-basic-dropdown-item [label]=\"option.label\" labelFontWeight=\"normal\" [highlightTerm]=\"highlightTerm\" />\n                </ng-template>\n              </li>\n            </ng-template>\n          </ul>\n        </li>\n      </ng-container>\n      <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\" />\n    </ul>\n  </div>\n</ng-template>\n"]}
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { BasicDropdownItemComponent } from '../basic-dropdown-item/basic-dropdown-item.component';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n *\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => OptionGroupDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    NgTemplateOutlet,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    BasicDropdownItemComponent,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  readonly NAME = 'OptionGroupDropdownComponent';\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n  @Input() override overlayPositioning: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  isTopDropdown = false;\n\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n}\n","<ng-container *ngIf=\"overlayPositioning; else dropdown\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\" />\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <div\n    #keyboardSelectContainer\n    class=\"scrollingPanel lxThinScrollbar\"\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    (scrolled)=\"containerScrolled.emit()\"\n  >\n    <ul class=\"options\">\n      <li\n        *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n        lxSelectableItem\n        [scrollInContainer]=\"keyboardSelectContainer\"\n        #item\n        (click)=\"onCreateNewOption()\"\n        (select)=\"onCreateNewOption()\"\n        [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n        class=\"option\"\n      >\n        <span class=\"newEntryContent\">\n          {{ newOptionLabel }}\n        </span>\n        <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\" />\n      </li>\n      <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n        <li>\n          <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n            <span>{{ optionGroup.label | uppercase }}</span>\n          </div>\n          <ul>\n            <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n              <li class=\"noResult\">\n                <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                  <ng-container *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\" />\n                </ng-container>\n                <ng-template #defaultText>\n                  <span>{{ NAME + '.noResults' | translate }}</span>\n                </ng-template>\n              </li>\n            </ng-container>\n            <ng-template #options>\n              <li\n                *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n                lxSelectableItem\n                [scrollInContainer]=\"keyboardSelectContainer\"\n                #item\n                class=\"option\"\n                (click)=\"selectOption(option)\"\n                (select)=\"selectOption(option)\"\n                [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n              >\n                <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                  <ng-container\n                    *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                  />\n                </ng-container>\n                <ng-template #basicDropdownOption>\n                  <lx-basic-dropdown-item [label]=\"option.label\" labelFontWeight=\"normal\" [highlightTerm]=\"highlightTerm\" />\n                </ng-template>\n              </li>\n            </ng-template>\n          </ul>\n        </li>\n      </ng-container>\n      <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\" />\n    </ul>\n  </div>\n</ng-template>\n"]}
|
package/esm2022/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.mjs
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { AsyncPipe } from '@angular/common';
|
2
2
|
import { Component, ContentChildren, HostBinding, HostListener, Input } from '@angular/core';
|
3
|
-
import { BehaviorSubject, combineLatest, fromEvent, merge
|
3
|
+
import { BehaviorSubject, Subject, combineLatest, fromEvent, merge } from 'rxjs';
|
4
4
|
import { delay, map, startWith, switchMap, takeUntil } from 'rxjs/operators';
|
5
5
|
import { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';
|
6
6
|
import { executeOnNextTick } from '../../../shared/misc-helpers';
|
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
89
89
|
type: HostListener,
|
90
90
|
args: ['mouseleave']
|
91
91
|
}] } });
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options-sub-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  QueryList\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, fromEvent, merge, Subject } from 'rxjs';\nimport { delay, 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\n@Component({\n  selector: 'lx-options-sub-dropdown',\n  templateUrl: 'options-sub-dropdown.component.html',\n  styleUrls: ['options-sub-dropdown.component.scss'],\n  standalone: true,\n  imports: [AutocloseDirective, AsyncPipe]\n})\nexport class OptionsSubDropdownComponent implements AfterViewInit, OnDestroy {\n  @Input() trigger!: OptionComponent;\n  @Input() align: 'right' | 'left' = 'right';\n  @ContentChildren(OptionComponent, { descendants: true }) options!: QueryList<OptionComponent>;\n\n  @HostBinding('class.hidden')\n  hidden = true;\n\n  private mouseInside$ = new BehaviorSubject<boolean>(false);\n\n  readonly destroyed$ = new Subject<void>();\n  readonly maxHeight$ = new BehaviorSubject<string>('none');\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  @HostListener('mouseenter')\n  mouseenter() {\n    this.mouseInside$.next(true);\n  }\n\n  @HostListener('mouseleave')\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    });\n\n    merge(this.showByKeyboard(), this.showByMouse())\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((show) => {\n        this.hidden = !show;\n        this.changeDetection.markForCheck();\n        if (show) {\n          this.updateMaxHeight(this.trigger.elementRef);\n        }\n      });\n  }\n\n  private updateMaxHeight(elementRef: ElementRef) {\n    const marginBottom = 8;\n    const optionTopPosition = elementRef.nativeElement.getBoundingClientRect().top;\n    const screenHeight = window.innerHeight;\n    const maxHeight = `${screenHeight - optionTopPosition - marginBottom}px`;\n    if (this.maxHeight$.getValue() !== maxHeight) {\n      this.maxHeight$.next(maxHeight);\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 showOnEnterSubmenu$ = mouseEnterTrigger$.pipe(\n      switchMap(() => mouseLeaveTrigger$),\n      switchMap(() => this.mouseInside$)\n    );\n\n    return merge(showOnEnterMouse$, showOnEnterSubmenu$);\n  }\n\n  closeDropdown() {\n    this.hidden = true;\n  }\n}\n","<div #spacingContainer class=\"spacingContainer\" [class.left]=\"align === 'left'\">\n  <ul\n    #subDropdown\n    class=\"sub-dropdown\"\n    lxAutoclose\n    [class.showScrollbar]=\"(maxHeight$ | async) !== 'none'\"\n    [style.max-height]=\"(maxHeight$ | async) ?? 'none'\"\n    (autoclose)=\"closeDropdown()\"\n  >\n    <ng-content />\n  </ul>\n</div>\n"]}
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options-sub-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  QueryList\n} from '@angular/core';\nimport { BehaviorSubject, Subject, combineLatest, fromEvent, merge } from 'rxjs';\nimport { delay, 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\n@Component({\n  selector: 'lx-options-sub-dropdown',\n  templateUrl: 'options-sub-dropdown.component.html',\n  styleUrls: ['options-sub-dropdown.component.scss'],\n  standalone: true,\n  imports: [AutocloseDirective, AsyncPipe]\n})\nexport class OptionsSubDropdownComponent implements AfterViewInit, OnDestroy {\n  @Input() trigger!: OptionComponent;\n  @Input() align: 'right' | 'left' = 'right';\n  @ContentChildren(OptionComponent, { descendants: true }) options!: QueryList<OptionComponent>;\n\n  @HostBinding('class.hidden')\n  hidden = true;\n\n  private mouseInside$ = new BehaviorSubject<boolean>(false);\n\n  readonly destroyed$ = new Subject<void>();\n  readonly maxHeight$ = new BehaviorSubject<string>('none');\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  @HostListener('mouseenter')\n  mouseenter() {\n    this.mouseInside$.next(true);\n  }\n\n  @HostListener('mouseleave')\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    });\n\n    merge(this.showByKeyboard(), this.showByMouse())\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((show) => {\n        this.hidden = !show;\n        this.changeDetection.markForCheck();\n        if (show) {\n          this.updateMaxHeight(this.trigger.elementRef);\n        }\n      });\n  }\n\n  private updateMaxHeight(elementRef: ElementRef) {\n    const marginBottom = 8;\n    const optionTopPosition = elementRef.nativeElement.getBoundingClientRect().top;\n    const screenHeight = window.innerHeight;\n    const maxHeight = `${screenHeight - optionTopPosition - marginBottom}px`;\n    if (this.maxHeight$.getValue() !== maxHeight) {\n      this.maxHeight$.next(maxHeight);\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 showOnEnterSubmenu$ = mouseEnterTrigger$.pipe(\n      switchMap(() => mouseLeaveTrigger$),\n      switchMap(() => this.mouseInside$)\n    );\n\n    return merge(showOnEnterMouse$, showOnEnterSubmenu$);\n  }\n\n  closeDropdown() {\n    this.hidden = true;\n  }\n}\n","<div #spacingContainer class=\"spacingContainer\" [class.left]=\"align === 'left'\">\n  <ul\n    #subDropdown\n    class=\"sub-dropdown\"\n    lxAutoclose\n    [class.showScrollbar]=\"(maxHeight$ | async) !== 'none'\"\n    [style.max-height]=\"(maxHeight$ | async) ?? 'none'\"\n    (autoclose)=\"closeDropdown()\"\n  >\n    <ng-content />\n  </ul>\n</div>\n"]}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { Directive } from '@angular/core';
|
2
|
-
import {
|
2
|
+
import { Subject, fromEvent } from 'rxjs';
|
3
3
|
import { filter, takeUntil, tap } from 'rxjs/operators';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
export class PickerTriggerDirective {
|
@@ -44,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
44
44
|
standalone: true
|
45
45
|
}]
|
46
46
|
}], ctorParameters: () => [{ type: i0.ElementRef }] });
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLXRyaWdnZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvY29tcG9uZW50cy9waWNrZXIvcGlja2VyLXRyaWdnZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXlCLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQU14RCxNQUFNLE9BQU8sc0JBQXNCO0lBb0JqQyxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQztJQUNoRCxDQUFDO0lBSUQsWUFBb0IsT0FBZ0M7UUFBaEMsWUFBTyxHQUFQLE9BQU8sQ0FBeUI7UUF6Qm5DLGNBQVMsR0FBRyxnQ0FBZ0MsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3ZFLDJCQUFzQixHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvRSxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ2hCLG9CQUFlLEdBQUcsU0FBUyxDQUFhLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FDdkYsR0FBRyxDQUFDLEdBQUcsRUFBRTtZQUNQLCtGQUErRjtZQUMvRiw0RkFBNEY7WUFDNUYsdUZBQXVGO1lBQ3ZGLGtHQUFrRztZQUNsRyxJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLHNCQUFzQixFQUFFO2dCQUNqRCxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUNwQztRQUNILENBQUMsQ0FBQyxDQUNILENBQUM7UUFDTSxnQkFBVyxHQUFHLFNBQVMsQ0FBYSxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN6RSxlQUFVLEdBQUcsU0FBUyxDQUFhLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRXhFLGdCQUFXLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQztRQU0zRSxlQUFVLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUd4QyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUMvRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzlELElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3pCLENBQUM7OEdBckNVLHNCQUFzQjtrR0FBdEIsc0JBQXNCOzsyRkFBdEIsc0JBQXNCO2tCQUpsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0LCBmcm9tRXZlbnQgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGZpbHRlciwgdGFrZVVudGlsLCB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tseFBpY2tlclRyaWdnZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBQaWNrZXJUcmlnZ2VyRGlyZWN0aXZlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBJU19TQUZBUkkgPSAvXigoPyFjaHJvbWV8YW5kcm9pZCkuKSpzYWZhcmkvaS50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuICBwcml2YXRlIHJlYWRvbmx5IEhPU1RfRUxFTUVOVF9JU19CVVRUT04gPSB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudC5tYXRjaGVzKCdidXR0b24nKTtcbiAgcHJpdmF0ZSBmb2N1c2VkID0gZmFsc2U7XG4gIHByaXZhdGUgYWxsQ2xpY2tFdmVudHMkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LCAnY2xpY2snKS5waXBlKFxuICAgIHRhcCgoKSA9PiB7XG4gICAgICAvLyBUaGVyZSBpcyBhbiBpbmNvbnNpc3RlbnQgYmVoYXZpb3IgYW1vbmcgYnJvd3NlcnMgd2hlbiBpdCBjb21lcyB0byBmb2N1c2luZyBidXR0b25zIG9uIGNsaWNrLlxuICAgICAgLy8gU2FmYXJpIGRvZXMgbm90IGZvY3VzIGJ1dHRvbnMgb24gY2xpY2ssIGJ1dCBtb3N0IG90aGVyIGJyb3dzZXJzIGRvLiBUaGVyZWZvcmUsIHdlIGhhdmUgdG9cbiAgICAgIC8vIGludHJvZHVjZSB0aGlzIGhhY2sgdG8gbWFrZSBzdXJlIHRoYXQgdGhlIGJ1dHRvbiBpcyBmb2N1c2VkIHdoZW4gdGhlIHVzZXIgY2xpY2tzIGl0LlxuICAgICAgLy8gTW9yZSBkZXRhaWxzIGluIHRoaXMgaW50ZXJlc3RpbmcgYXJ0aWNsZTogaHR0cHM6Ly96ZWxsd2suY29tL2Jsb2cvaW5jb25zaXN0ZW50LWJ1dHRvbi1iZWhhdmlvci9cbiAgICAgIGlmICh0aGlzLklTX1NBRkFSSSAmJiB0aGlzLkhPU1RfRUxFTUVOVF9JU19CVVRUT04pIHtcbiAgICAgICAgdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcbiAgICAgIH1cbiAgICB9KVxuICApO1xuICBwcml2YXRlIGZvY3VzRXZlbnQkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LCAnZm9jdXMnKTtcbiAgcHJpdmF0ZSBibHVyRXZlbnQkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LCAnYmx1cicpO1xuXG4gIHB1YmxpYyBjbGlja0V2ZW50JCA9IHRoaXMuYWxsQ2xpY2tFdmVudHMkLnBpcGUoZmlsdGVyKCgpID0+IHRoaXMuZm9jdXNlZCA9PT0gdHJ1ZSkpO1xuXG4gIGdldCB3aWR0aCgpIHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQub2Zmc2V0V2lkdGg7XG4gIH1cblxuICByZWFkb25seSBkZXN0cm95ZWQkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnQ6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+KSB7XG4gICAgdGhpcy5mb2N1c0V2ZW50JC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3llZCQpKS5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5mb2N1c2VkID0gdHJ1ZTtcbiAgICB9KTtcbiAgICB0aGlzLmJsdXJFdmVudCQucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95ZWQkKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMuZm9jdXNlZCA9IGZhbHNlO1xuICAgIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5kZXN0cm95ZWQkLm5leHQoKTtcbiAgfVxufVxuIl19
|
@@ -55,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
55
55
|
type: ContentChildren,
|
56
56
|
args: [PillItemComponent, { emitDistinctChangesOnly: true }]
|
57
57
|
}] } });
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
58
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pill-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/pill-list/pill-list.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/pill-list/pill-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EAEN,WAAW,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAc,KAAK,EAAE,MAAM,MAAM,CAAC;AACzC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAEvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;;AAUrE,MAAM,OAAO,iBAAkB,SAAQ,uBAAuB;IAR9D;;QASW,UAAK,GAAU,EAAE,CAAC;QAOa,aAAQ,GAAY,KAAK,CAAC;QAExD,WAAM,GAAG,IAAI,YAAY,EAA8B,CAAC;KAqCnE;IAxBU,eAAe;QACtB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,MAAM,gBAAgB,GAA2C,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAC7F,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAC5B,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EACvE,KAAK,CAAC,CAAC,CAAC,EACR,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B,CAAC;YACF,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SACxD;IACH,CAAC;IAED,UAAU,CAAC,KAAiC;QAC1C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,qBAAqB,CAAC,IAAS;QAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACnD,CAAC;IAEM,WAAW,CAAC,IAAa;QAC9B,OAAO,CAAC,KAAa,EAAE,IAAS,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACnE,CAAC;8GA9CU,iBAAiB;kGAAjB,iBAAiB,qVAoBU,WAAW,6DAChC,iBAAiB,oDClDpC,4wBAkBA,4LDSY,KAAK,mHAAE,uBAAuB,uIAAE,IAAI,6FAAE,gBAAgB,oJAAE,iBAAiB,gHAAE,SAAS;;2FAEnF,iBAAiB;kBAR7B,SAAS;+BACE,cAAc,mBAEP,uBAAuB,CAAC,MAAM,cAEnC,IAAI,WACP,CAAC,KAAK,EAAE,uBAAuB,EAAE,IAAI,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,SAAS,CAAC;8BAGtF,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBACkC,QAAQ;sBAA/C,WAAW;uBAAC,gBAAgB;;sBAAG,KAAK;gBAE3B,MAAM;sBAAf,MAAM;gBAU4D,YAAY;sBAA9E,YAAY;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE;gBACM,YAAY;sBAAlF,eAAe;uBAAC,iBAAiB,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE","sourcesContent":["import { AsyncPipe, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef\n} from '@angular/core';\nimport { Observable, merge } from 'rxjs';\nimport { delay, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\nimport { MultiSelectRemoveItemEvent } from '../multi-select/multi-select.component';\nimport { PillItemComponent } from '../pill-item/pill-item.component';\n\n@Component({\n  selector: 'lx-pill-list',\n  templateUrl: 'pill-list.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: ['pill-list.component.scss'],\n  standalone: true,\n  imports: [NgFor, SelectableItemDirective, NgIf, NgTemplateOutlet, PillItemComponent, AsyncPipe]\n})\nexport class PillListComponent extends KeyboardSelectDirective implements AfterViewInit {\n  @Input() pills: any[] = [];\n  @Input() labelKey?: string;\n  /**\n   * Provide an itemKey which contains the property name in each object to uniquely identify it.\n   * This will be used in the trackBy function.\n   */\n  @Input() itemKey?: string;\n  @HostBinding('class.disabled') @Input() disabled: boolean = false;\n\n  @Output() remove = new EventEmitter<MultiSelectRemoveItemEvent>();\n\n  /**\n   * If you provide an <ng-template #pillTemplate>, it will be used to render the individual pills inside of the lx-multi-select.\n   * This is useful if you want to apply special attributes or CSS styling to individual pills.\n   * Example:\n   * <ng-template #pillTemplate let-pill>\n   *    <lx-pill-item [class.readOnly]=\"item.readOnly\" [label]=\"item.label\" [item]=\"item\"></lx-pill-item>\n   * </ng-template>\n   */\n  @ContentChild('pillTemplate', { read: TemplateRef, static: true }) pillTemplate?: TemplateRef<any>;\n  @ContentChildren(PillItemComponent, { emitDistinctChangesOnly: true }) contentItems!: QueryList<PillItemComponent>;\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n    if (this.pillTemplate) {\n      const removePillEvents: Observable<MultiSelectRemoveItemEvent> = this.contentItems.changes.pipe(\n        startWith(this.contentItems),\n        switchMap(() => merge(...this.contentItems.map((item) => item.remove))),\n        delay(0),\n        takeUntil(this.destroyed$)\n      );\n      removePillEvents.subscribe(this.removePill.bind(this));\n    }\n  }\n\n  removePill(event: MultiSelectRemoveItemEvent) {\n    this.remove.emit(event);\n  }\n\n  removePillViaKeyboard(pill: any) {\n    this.remove.emit({ item: pill, isMouse: false });\n  }\n\n  public trackByProp(prop?: string) {\n    return (index: number, pill: any) => (prop ? pill[prop] : index);\n  }\n}\n","<ul class=\"pills\" #keyboardSelectContainer>\n  <li\n    *ngFor=\"let pill of pills; let index = index; trackBy: trackByProp(itemKey)\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (select)=\"removePillViaKeyboard(pill)\"\n    class=\"pill\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n  >\n    <ng-container *ngIf=\"pillTemplate; else defaultTemplate\">\n      <ng-container *ngTemplateOutlet=\"pillTemplate; context: { $implicit: pill, index: index }\" />\n    </ng-container>\n    <ng-template #defaultTemplate>\n      <lx-pill-item [item]=\"pill\" [label]=\"labelKey ? pill[labelKey] : pill\" [disabled]=\"disabled\" (remove)=\"removePill($event)\" />\n    </ng-template>\n  </li>\n</ul>\n"]}
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
107
107
|
}] } });
|
108
108
|
const isAbstractControl = (ctrl) => !!ctrl;
|
109
109
|
const resolveStrategy = curry((strategy, control, submitted) => strategy ? strategy({ control, submitted }) : true);
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/directives/form-error.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  Host,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Self,\n  ViewContainerRef\n} from '@angular/core';\nimport { AbstractControl, NgControl } from '@angular/forms';\nimport { curry } from 'lodash-es';\nimport { combineLatest, Observable, of, Subscription } from 'rxjs';\nimport { map, startWith } from 'rxjs/operators';\nimport { ErrorMessageComponent } from '../components/error-message/error-message.component';\nimport { FormSubmitDirective } from './form-submit.directive';\n\nexport type FormControlErrorDisplayStrategy = (obj: { control: AbstractControl; submitted?: boolean }) => boolean;\n\nexport const FORM_CONTROL_ERROR_NAMESPACE = new InjectionToken<string>('FORM_CONTROL_ERROR_NAMESPACE');\nexport const FORM_CONTROL_ERROR_DISPLAY_STRATEGY = new InjectionToken<FormControlErrorDisplayStrategy>(\n  'FORM_CONTROL_ERROR_DISPLAY_STRATEGY'\n);\n\nexport const provideFormControlErrorNamespace = (namespace: string) => ({\n  provide: FORM_CONTROL_ERROR_NAMESPACE,\n  useValue: namespace\n});\n\nexport const provideFormControlErrorDisplayStrategy = (fn: FormControlErrorDisplayStrategy) => ({\n  provide: FORM_CONTROL_ERROR_DISPLAY_STRATEGY,\n  useValue: fn\n});\n\n@Directive({\n  selector: '[lxFormError]',\n  standalone: true\n})\nexport class FormErrorDirective implements OnInit, OnDestroy {\n  @Input('lxFormError') ctrl?: AbstractControl | '';\n  @Input() controlName?: string;\n  private subscription?: Subscription;\n  private ref?: ComponentRef<ErrorMessageComponent>;\n\n  private get control(): AbstractControl | null | undefined {\n    return this.ngControl?.control || this.ctrl || null;\n  }\n\n  private get name(): string | number | null | undefined {\n    return this.ngControl?.name || this.controlName;\n  }\n\n  private get formSubmitted(): Observable<boolean | undefined> {\n    return this.formSubmitDirective ? this.formSubmitDirective.submitted$ : of(undefined);\n  }\n\n  constructor(\n    private viewContainer: ViewContainerRef,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    @Optional() @Self() private ngControl?: NgControl,\n    @Optional() @Host() private formSubmitDirective?: FormSubmitDirective,\n    @Optional() @Inject(FORM_CONTROL_ERROR_NAMESPACE) private namespace?: string,\n    @Optional() @Inject(FORM_CONTROL_ERROR_DISPLAY_STRATEGY) private strategy?: FormControlErrorDisplayStrategy\n  ) {}\n\n  ngOnInit() {\n    const control = this.control;\n    if (isAbstractControl(control)) {\n      this.subscription = combineLatest([control.valueChanges.pipe(startWith(control.value)), this.formSubmitted])\n        .pipe(\n          map(([, submitted]) => submitted),\n          map(resolveStrategy(this.strategy, control))\n        )\n        .subscribe((display) => {\n          const { errors } = control;\n          if (errors && display) {\n            const firstErrorKey = Object.keys(errors)[0];\n            const translationKey = this.buildTranslationKey(firstErrorKey!);\n            this.setError(translationKey);\n          } else if (this.ref) {\n            this.setError();\n          }\n        });\n    }\n  }\n\n  private buildTranslationKey(errorKey: string) {\n    if (this.control) {\n      return `${this.namespace || 'form'}.errors.${this.name ? `${this.name}.` : ''}${errorKey}`;\n    } else {\n      return '';\n    }\n  }\n\n  private setError(key?: string) {\n    if (!this.ref) {\n      const factory = this.componentFactoryResolver.resolveComponentFactory(ErrorMessageComponent);\n      this.ref = this.viewContainer.createComponent(factory);\n    }\n    this.ref.instance.key = key;\n  }\n\n  ngOnDestroy() {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n}\n\nconst isAbstractControl = (ctrl: AbstractControl | null | undefined): ctrl is AbstractControl => !!ctrl;\nconst resolveStrategy = curry(\n  (strategy: FormControlErrorDisplayStrategy | undefined, control: AbstractControl, submitted: boolean | undefined) =>\n    strategy ? strategy({ control, submitted }) : true\n);\n"]}
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/directives/form-error.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  Host,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Self,\n  ViewContainerRef\n} from '@angular/core';\nimport { AbstractControl, NgControl } from '@angular/forms';\nimport { curry } from 'lodash-es';\nimport { Observable, Subscription, combineLatest, of } from 'rxjs';\nimport { map, startWith } from 'rxjs/operators';\nimport { ErrorMessageComponent } from '../components/error-message/error-message.component';\nimport { FormSubmitDirective } from './form-submit.directive';\n\nexport type FormControlErrorDisplayStrategy = (obj: { control: AbstractControl; submitted?: boolean }) => boolean;\n\nexport const FORM_CONTROL_ERROR_NAMESPACE = new InjectionToken<string>('FORM_CONTROL_ERROR_NAMESPACE');\nexport const FORM_CONTROL_ERROR_DISPLAY_STRATEGY = new InjectionToken<FormControlErrorDisplayStrategy>(\n  'FORM_CONTROL_ERROR_DISPLAY_STRATEGY'\n);\n\nexport const provideFormControlErrorNamespace = (namespace: string) => ({\n  provide: FORM_CONTROL_ERROR_NAMESPACE,\n  useValue: namespace\n});\n\nexport const provideFormControlErrorDisplayStrategy = (fn: FormControlErrorDisplayStrategy) => ({\n  provide: FORM_CONTROL_ERROR_DISPLAY_STRATEGY,\n  useValue: fn\n});\n\n@Directive({\n  selector: '[lxFormError]',\n  standalone: true\n})\nexport class FormErrorDirective implements OnInit, OnDestroy {\n  @Input('lxFormError') ctrl?: AbstractControl | '';\n  @Input() controlName?: string;\n  private subscription?: Subscription;\n  private ref?: ComponentRef<ErrorMessageComponent>;\n\n  private get control(): AbstractControl | null | undefined {\n    return this.ngControl?.control || this.ctrl || null;\n  }\n\n  private get name(): string | number | null | undefined {\n    return this.ngControl?.name || this.controlName;\n  }\n\n  private get formSubmitted(): Observable<boolean | undefined> {\n    return this.formSubmitDirective ? this.formSubmitDirective.submitted$ : of(undefined);\n  }\n\n  constructor(\n    private viewContainer: ViewContainerRef,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    @Optional() @Self() private ngControl?: NgControl,\n    @Optional() @Host() private formSubmitDirective?: FormSubmitDirective,\n    @Optional() @Inject(FORM_CONTROL_ERROR_NAMESPACE) private namespace?: string,\n    @Optional() @Inject(FORM_CONTROL_ERROR_DISPLAY_STRATEGY) private strategy?: FormControlErrorDisplayStrategy\n  ) {}\n\n  ngOnInit() {\n    const control = this.control;\n    if (isAbstractControl(control)) {\n      this.subscription = combineLatest([control.valueChanges.pipe(startWith(control.value)), this.formSubmitted])\n        .pipe(\n          map(([, submitted]) => submitted),\n          map(resolveStrategy(this.strategy, control))\n        )\n        .subscribe((display) => {\n          const { errors } = control;\n          if (errors && display) {\n            const firstErrorKey = Object.keys(errors)[0];\n            const translationKey = this.buildTranslationKey(firstErrorKey!);\n            this.setError(translationKey);\n          } else if (this.ref) {\n            this.setError();\n          }\n        });\n    }\n  }\n\n  private buildTranslationKey(errorKey: string) {\n    if (this.control) {\n      return `${this.namespace || 'form'}.errors.${this.name ? `${this.name}.` : ''}${errorKey}`;\n    } else {\n      return '';\n    }\n  }\n\n  private setError(key?: string) {\n    if (!this.ref) {\n      const factory = this.componentFactoryResolver.resolveComponentFactory(ErrorMessageComponent);\n      this.ref = this.viewContainer.createComponent(factory);\n    }\n    this.ref.instance.key = key;\n  }\n\n  ngOnDestroy() {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n}\n\nconst isAbstractControl = (ctrl: AbstractControl | null | undefined): ctrl is AbstractControl => !!ctrl;\nconst resolveStrategy = curry(\n  (strategy: FormControlErrorDisplayStrategy | undefined, control: AbstractControl, submitted: boolean | undefined) =>\n    strategy ? strategy({ control, submitted }) : true\n);\n"]}
|