@ethlete/core 3.11.0 → 3.11.2
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/directives/animated-overlay/animated-overlay.directive.mjs +5 -2
- package/esm2022/lib/utils/active-selection-model.utils.mjs +5 -1
- package/fesm2022/ethlete-core.mjs +8 -1
- package/fesm2022/ethlete-core.mjs.map +1 -1
- package/lib/directives/animated-overlay/animated-overlay.directive.d.ts +3 -0
- package/lib/utils/active-selection-model.utils.d.ts +1 -0
- package/package.json +3 -2
|
@@ -92,7 +92,7 @@ export class AnimatedOverlayDirective {
|
|
|
92
92
|
return;
|
|
93
93
|
}
|
|
94
94
|
this._isMounting$.next(true);
|
|
95
|
-
const { component, providers, data, mirrorWidth } = config;
|
|
95
|
+
const { component, providers, data, mirrorWidth, themeProvider } = config;
|
|
96
96
|
this._beforeOpened?.next();
|
|
97
97
|
const injector = Injector.create({
|
|
98
98
|
parent: this._injector,
|
|
@@ -105,6 +105,9 @@ export class AnimatedOverlayDirective {
|
|
|
105
105
|
Object.assign(this._componentRef.instance, data);
|
|
106
106
|
}
|
|
107
107
|
this._componentRef.instance._markForCheck?.();
|
|
108
|
+
if (themeProvider) {
|
|
109
|
+
this._componentRef.instance._setThemeFromProvider?.(themeProvider);
|
|
110
|
+
}
|
|
108
111
|
if (mirrorWidth) {
|
|
109
112
|
this._overlayRef.updateSize({
|
|
110
113
|
width: this._elementRef.nativeElement.offsetWidth,
|
|
@@ -270,4 +273,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
270
273
|
}], autoHide: [{
|
|
271
274
|
type: Input
|
|
272
275
|
}] } });
|
|
273
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport {\n  OffsetOptions,\n  Padding,\n  Placement,\n  arrow,\n  autoUpdate,\n  computePosition,\n  flip,\n  hide,\n  limitShift,\n  offset,\n  shift,\n  size,\n} from '@floating-ui/dom';\nimport { BehaviorSubject, Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\nimport { ObserveResizeDirective } from '../observe-resize';\n\nexport interface AnimatedOverlayComponentBase {\n  _elementRef?: ElementRef<HTMLElement>;\n  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\n  host: {\n    class: 'et-animated-overlay',\n  },\n})\nexport class AnimatedOverlayDirective<T extends AnimatedOverlayComponentBase> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _observeResize = inject(ObserveResizeDirective);\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _floatingElCleanupFn: (() => void) | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  private readonly _isMounted$ = new BehaviorSubject<boolean>(false);\n  private readonly _isMounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isUnmounting$ = new BehaviorSubject<boolean>(false);\n\n  /**\n   * The placement of the animated overlay.\n   * @default undefined\n   */\n  @Input()\n  placement?: Placement = 'bottom';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://floating-ui.com/docs/flip#fallbackplacements\n   */\n  @Input()\n  fallbackPlacements?: Placement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://floating-ui.com/docs/offset\n   */\n  @Input()\n  offset: OffsetOptions | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://floating-ui.com/docs/arrow#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: Padding | null = 4;\n\n  /**\n   * The viewport padding.\n   * @default 8\n   */\n  @Input()\n  viewportPadding: Padding | null = 8;\n\n  /**\n   * Whether the animated overlay should auto resize to fit the available space.\n   * Useful for things like selects where the list of options might be longer than the available space.\n   * @default false\n   */\n  @Input()\n  autoResize = false;\n\n  /**\n   * Whether the animated overlay should auto hide when the reference element is hidden.\n   * @default false\n   */\n  @Input()\n  autoHide = false;\n\n  get isMounted() {\n    return this._isMounted$.value;\n  }\n\n  get isMounted$() {\n    return this._isMounted$.asObservable();\n  }\n\n  get isMounting() {\n    return this._isMounting$.value;\n  }\n\n  get isMounting$() {\n    return this._isMounting$.asObservable();\n  }\n\n  get isUnmounting() {\n    return this._isUnmounting$.value;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n  }) {\n    if (this.isMounted || this.isMounting) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: The component is already mounted or mounting. Please unmount the component before mounting again.',\n        );\n      }\n\n      return;\n    }\n\n    this._isMounting$.next(true);\n\n    const { component, providers, data, mirrorWidth } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    if (mirrorWidth) {\n      this._overlayRef.updateSize({\n        width: this._elementRef.nativeElement.offsetWidth,\n      });\n\n      this._observeResize.valueChange\n        .pipe(\n          tap(() => {\n            this._overlayRef?.updateSize({\n              width: this._elementRef.nativeElement.offsetWidth,\n            });\n          }),\n          takeUntil(this._destroy$),\n          takeUntil(this.afterClosed()),\n        )\n        .subscribe();\n    }\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n\n      const floatingEl = this._componentRef.location.nativeElement as HTMLElement;\n      const floatingElArrow = this._componentRef.instance._elementRef?.nativeElement.querySelector(\n        '[et-floating-arrow]',\n      ) as HTMLElement | null;\n\n      floatingEl.classList.add('et-floating-element');\n\n      const refEl = this._elementRef.nativeElement;\n\n      this._floatingElCleanupFn = autoUpdate(refEl, floatingEl, () => {\n        if (!this._componentRef) return;\n\n        computePosition(refEl, floatingEl, {\n          placement: this.placement,\n          middleware: [\n            ...(this.offset ? [offset(this.offset)] : []),\n            flip({\n              fallbackPlacements: this.fallbackPlacements ?? undefined,\n              fallbackAxisSideDirection: 'start',\n              crossAxis: false,\n            }),\n            ...(this.autoResize\n              ? [\n                  size({\n                    padding: this.viewportPadding ?? undefined,\n                    apply({ availableHeight, availableWidth }) {\n                      floatingEl.style.setProperty('--et-floating-max-width', `${availableWidth}px`);\n                      floatingEl.style.setProperty('--et-floating-max-height', `${availableHeight}px`);\n                    },\n                  }),\n                ]\n              : []),\n            shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined }),\n            ...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),\n            ...(this.autoHide ? [hide({ strategy: 'referenceHidden' })] : []),\n          ],\n        }).then(({ x, y, placement, middlewareData }) => {\n          floatingEl.style.setProperty('--et-floating-translate', `translate3d(${x}px, ${y}px, 0)`);\n          floatingEl.setAttribute('et-floating-placement', placement);\n\n          if (middlewareData.arrow && floatingElArrow) {\n            const { x: arrowX, y: arrowY } = middlewareData.arrow;\n\n            floatingEl.style.setProperty(\n              '--et-floating-arrow-translate',\n              `translate3d(${arrowX ?? 0}px, ${arrowY ?? 0}px, 0)`,\n            );\n          }\n\n          if (middlewareData.hide?.referenceHidden) {\n            floatingEl.classList.add('et-floating-element--hidden');\n          } else {\n            floatingEl.classList.remove('et-floating-element--hidden');\n          }\n        });\n      });\n\n      // We need to wait for the  content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n\n        this._isMounted$.next(true);\n        this._isMounting$.next(false);\n      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this.isMounted || this.isUnmounting) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: The component is not mounted or is already unmounting. Please call `mount` before calling `unmount` again.',\n        );\n      }\n\n      return;\n    }\n\n    if (!this._componentRef) {\n      return;\n    }\n\n    this._isUnmounting$.next(true);\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._floatingElCleanupFn?.();\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._isMounted$.next(false);\n    this._isUnmounting$.next(false);\n\n    this._afterClosed?.next();\n  }\n}\n"]}
|
|
276
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport { ProvideThemeDirective } from '@ethlete/theming';\nimport {\n  OffsetOptions,\n  Padding,\n  Placement,\n  arrow,\n  autoUpdate,\n  computePosition,\n  flip,\n  hide,\n  limitShift,\n  offset,\n  shift,\n  size,\n} from '@floating-ui/dom';\nimport { BehaviorSubject, Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\nimport { ObserveResizeDirective } from '../observe-resize';\n\nexport interface AnimatedOverlayComponentBase {\n  _elementRef?: ElementRef<HTMLElement>;\n  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n  _setThemeFromProvider?: (provider: ProvideThemeDirective) => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\n  host: {\n    class: 'et-animated-overlay',\n  },\n})\nexport class AnimatedOverlayDirective<T extends AnimatedOverlayComponentBase> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _observeResize = inject(ObserveResizeDirective);\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _floatingElCleanupFn: (() => void) | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  private readonly _isMounted$ = new BehaviorSubject<boolean>(false);\n  private readonly _isMounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isUnmounting$ = new BehaviorSubject<boolean>(false);\n\n  /**\n   * The placement of the animated overlay.\n   * @default undefined\n   */\n  @Input()\n  placement?: Placement = 'bottom';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://floating-ui.com/docs/flip#fallbackplacements\n   */\n  @Input()\n  fallbackPlacements?: Placement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://floating-ui.com/docs/offset\n   */\n  @Input()\n  offset: OffsetOptions | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://floating-ui.com/docs/arrow#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: Padding | null = 4;\n\n  /**\n   * The viewport padding.\n   * @default 8\n   */\n  @Input()\n  viewportPadding: Padding | null = 8;\n\n  /**\n   * Whether the animated overlay should auto resize to fit the available space.\n   * Useful for things like selects where the list of options might be longer than the available space.\n   * @default false\n   */\n  @Input()\n  autoResize = false;\n\n  /**\n   * Whether the animated overlay should auto hide when the reference element is hidden.\n   * @default false\n   */\n  @Input()\n  autoHide = false;\n\n  get isMounted() {\n    return this._isMounted$.value;\n  }\n\n  get isMounted$() {\n    return this._isMounted$.asObservable();\n  }\n\n  get isMounting() {\n    return this._isMounting$.value;\n  }\n\n  get isMounting$() {\n    return this._isMounting$.asObservable();\n  }\n\n  get isUnmounting() {\n    return this._isUnmounting$.value;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n    themeProvider?: ProvideThemeDirective | null;\n  }) {\n    if (this.isMounted || this.isMounting) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: The component is already mounted or mounting. Please unmount the component before mounting again.',\n        );\n      }\n\n      return;\n    }\n\n    this._isMounting$.next(true);\n\n    const { component, providers, data, mirrorWidth, themeProvider } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    if (themeProvider) {\n      this._componentRef.instance._setThemeFromProvider?.(themeProvider);\n    }\n\n    if (mirrorWidth) {\n      this._overlayRef.updateSize({\n        width: this._elementRef.nativeElement.offsetWidth,\n      });\n\n      this._observeResize.valueChange\n        .pipe(\n          tap(() => {\n            this._overlayRef?.updateSize({\n              width: this._elementRef.nativeElement.offsetWidth,\n            });\n          }),\n          takeUntil(this._destroy$),\n          takeUntil(this.afterClosed()),\n        )\n        .subscribe();\n    }\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n\n      const floatingEl = this._componentRef.location.nativeElement as HTMLElement;\n      const floatingElArrow = this._componentRef.instance._elementRef?.nativeElement.querySelector(\n        '[et-floating-arrow]',\n      ) as HTMLElement | null;\n\n      floatingEl.classList.add('et-floating-element');\n\n      const refEl = this._elementRef.nativeElement;\n\n      this._floatingElCleanupFn = autoUpdate(refEl, floatingEl, () => {\n        if (!this._componentRef) return;\n\n        computePosition(refEl, floatingEl, {\n          placement: this.placement,\n          middleware: [\n            ...(this.offset ? [offset(this.offset)] : []),\n            flip({\n              fallbackPlacements: this.fallbackPlacements ?? undefined,\n              fallbackAxisSideDirection: 'start',\n              crossAxis: false,\n            }),\n            ...(this.autoResize\n              ? [\n                  size({\n                    padding: this.viewportPadding ?? undefined,\n                    apply({ availableHeight, availableWidth }) {\n                      floatingEl.style.setProperty('--et-floating-max-width', `${availableWidth}px`);\n                      floatingEl.style.setProperty('--et-floating-max-height', `${availableHeight}px`);\n                    },\n                  }),\n                ]\n              : []),\n            shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined }),\n            ...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),\n            ...(this.autoHide ? [hide({ strategy: 'referenceHidden' })] : []),\n          ],\n        }).then(({ x, y, placement, middlewareData }) => {\n          floatingEl.style.setProperty('--et-floating-translate', `translate3d(${x}px, ${y}px, 0)`);\n          floatingEl.setAttribute('et-floating-placement', placement);\n\n          if (middlewareData.arrow && floatingElArrow) {\n            const { x: arrowX, y: arrowY } = middlewareData.arrow;\n\n            floatingEl.style.setProperty(\n              '--et-floating-arrow-translate',\n              `translate3d(${arrowX ?? 0}px, ${arrowY ?? 0}px, 0)`,\n            );\n          }\n\n          if (middlewareData.hide?.referenceHidden) {\n            floatingEl.classList.add('et-floating-element--hidden');\n          } else {\n            floatingEl.classList.remove('et-floating-element--hidden');\n          }\n        });\n      });\n\n      // We need to wait for the  content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n\n        this._isMounted$.next(true);\n        this._isMounting$.next(false);\n      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this.isMounted || this.isUnmounting) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: The component is not mounted or is already unmounting. Please call `mount` before calling `unmount` again.',\n        );\n      }\n\n      return;\n    }\n\n    if (!this._componentRef) {\n      return;\n    }\n\n    this._isUnmounting$.next(true);\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._floatingElCleanupFn?.();\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._isMounted$.next(false);\n    this._isUnmounting$.next(false);\n\n    this._afterClosed?.next();\n  }\n}\n"]}
|
|
@@ -26,6 +26,10 @@ export class ActiveSelectionModel {
|
|
|
26
26
|
this._selectionModel$.next(selectionModel);
|
|
27
27
|
return this;
|
|
28
28
|
}
|
|
29
|
+
setActiveOption(option) {
|
|
30
|
+
this._activeOption$.next(option);
|
|
31
|
+
return this;
|
|
32
|
+
}
|
|
29
33
|
evaluateKeyboardEvent(event) {
|
|
30
34
|
const keyCode = event.keyCode;
|
|
31
35
|
const activeOption = this.activeOption;
|
|
@@ -79,4 +83,4 @@ export class ActiveSelectionModel {
|
|
|
79
83
|
this._activeOption$.next(firstOption ?? null);
|
|
80
84
|
}
|
|
81
85
|
}
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZlLXNlbGVjdGlvbi1tb2RlbC51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL2FjdGl2ZS1zZWxlY3Rpb24tbW9kZWwudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDNUYsT0FBTyxFQUFFLGVBQWUsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBR2hELE1BQU0sT0FBTyxvQkFBb0I7SUFHL0IsSUFBSSxlQUFlO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzlDLENBQUM7SUFDRCxJQUFJLGNBQWM7UUFDaEIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDO0lBQ3JDLENBQUM7SUFHRCxJQUFJLGFBQWE7UUFDZixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDNUMsQ0FBQztJQUNELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUM7SUFDbkMsQ0FBQztJQUdEO1FBbEJpQixjQUFTLEdBQUcsYUFBYSxFQUFFLENBQUM7UUFRNUIscUJBQWdCLEdBQUcsSUFBSSxlQUFlLENBQTJCLElBQUksQ0FBQyxDQUFDO1FBUXZFLG1CQUFjLEdBQUcsSUFBSSxlQUFlLENBQVcsSUFBSSxDQUFDLENBQUM7UUFHcEUsSUFBSSxDQUFDLGdCQUFnQjthQUNsQixJQUFJLENBQ0gsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFDekIsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQ3ZELEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQyxDQUN0QzthQUNBLFNBQVMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxjQUF3QztRQUN4RCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRTNDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELGVBQWUsQ0FBQyxNQUFnQjtRQUM5QixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUVqQyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxxQkFBcUIsQ0FBQyxLQUFvQjtRQUN4QyxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzlCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUM7UUFFdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLElBQUksQ0FBQyxZQUFZO1lBQUUsT0FBTztRQUVsRCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsY0FBYyxFQUFFLGNBQWMsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUV2RSxJQUFJLFlBQVksS0FBSyxJQUFJO1lBQUUsT0FBTztRQUVsQyxJQUFJLGVBQWUsR0FBeUIsU0FBUyxDQUFDO1FBRXRELFFBQVEsT0FBTyxFQUFFO1lBQ2YsS0FBSyxVQUFVO2dCQUNiO29CQUNFLGVBQWUsR0FBRyxJQUFJLENBQUMsY0FBYyxFQUFFLGlCQUFpQixDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQztpQkFDM0U7Z0JBQ0QsTUFBTTtZQUNSLEtBQUssUUFBUTtnQkFDWDtvQkFDRSxlQUFlLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQztpQkFDNUU7Z0JBQ0QsTUFBTTtZQUNSLEtBQUssT0FBTztnQkFDVjtvQkFDRSxlQUFlLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDLEVBQUUsRUFBRSxZQUFZLENBQUMsQ0FBQztpQkFDN0U7Z0JBQ0QsTUFBTTtZQUNSLEtBQUssU0FBUztnQkFDWjtvQkFDRSxlQUFlLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQyxFQUFFLEVBQUUsWUFBWSxDQUFDLENBQUM7aUJBQzVFO2dCQUNELE1BQU07WUFDUixLQUFLLElBQUk7Z0JBQ1A7b0JBQ0UsZUFBZSxHQUFHLElBQUksQ0FBQyxjQUFjLEVBQUUsY0FBYyxFQUFFLENBQUM7aUJBQ3pEO2dCQUNELE1BQU07WUFDUixLQUFLLEdBQUc7Z0JBQ047b0JBQ0UsZUFBZSxHQUFHLElBQUksQ0FBQyxjQUFjLEVBQUUsYUFBYSxFQUFFLENBQUM7aUJBQ3hEO2dCQUNELE1BQU07U0FDVDtRQUVELElBQUksZUFBZSxLQUFLLFNBQVMsRUFBRTtZQUNqQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7U0FDeEI7UUFFRCxJQUFJLGVBQWUsS0FBSyxZQUFZLElBQUksZUFBZSxLQUFLLFNBQVMsRUFBRTtZQUNyRSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztTQUMzQztJQUNILENBQUM7SUFFTyxtQkFBbUI7UUFDekIsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxjQUFjLEVBQUUsQ0FBQztRQUUxRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLENBQUM7SUFDaEQsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRE9XTl9BUlJPVywgRU5ELCBIT01FLCBQQUdFX0RPV04sIFBBR0VfVVAsIFVQX0FSUk9XIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2tleWNvZGVzJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgb2YsIHN3aXRjaE1hcCwgdGFrZVVudGlsLCB0YXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGNyZWF0ZURlc3Ryb3kgfSBmcm9tICcuL2Rlc3Ryb3kudXRpbHMnO1xuaW1wb3J0IHsgU2VsZWN0aW9uTW9kZWwgfSBmcm9tICcuL3NlbGVjdGlvbi1tb2RlbC51dGlscyc7XG5cbmV4cG9ydCBjbGFzcyBBY3RpdmVTZWxlY3Rpb25Nb2RlbDxUID0gdW5rbm93bj4ge1xuICBwcml2YXRlIHJlYWRvbmx5IF9kZXN0cm95JCA9IGNyZWF0ZURlc3Ryb3koKTtcblxuICBnZXQgc2VsZWN0aW9uTW9kZWwkKCkge1xuICAgIHJldHVybiB0aGlzLl9zZWxlY3Rpb25Nb2RlbCQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cbiAgZ2V0IHNlbGVjdGlvbk1vZGVsKCkge1xuICAgIHJldHVybiB0aGlzLl9zZWxlY3Rpb25Nb2RlbCQudmFsdWU7XG4gIH1cbiAgcHJpdmF0ZSByZWFkb25seSBfc2VsZWN0aW9uTW9kZWwkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxTZWxlY3Rpb25Nb2RlbDxUPiB8IG51bGw+KG51bGwpO1xuXG4gIGdldCBhY3RpdmVPcHRpb24kKCkge1xuICAgIHJldHVybiB0aGlzLl9hY3RpdmVPcHRpb24kLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG4gIGdldCBhY3RpdmVPcHRpb24oKSB7XG4gICAgcmV0dXJuIHRoaXMuX2FjdGl2ZU9wdGlvbiQudmFsdWU7XG4gIH1cbiAgcHJpdmF0ZSByZWFkb25seSBfYWN0aXZlT3B0aW9uJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8VCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuX3NlbGVjdGlvbk1vZGVsJFxuICAgICAgLnBpcGUoXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JCksXG4gICAgICAgIHN3aXRjaE1hcCgobW9kZWwpID0+IG1vZGVsPy5maWx0ZXJlZE9wdGlvbnMkID8/IG9mKFtdKSksXG4gICAgICAgIHRhcCgoKSA9PiB0aGlzLl9yZXNldEFjdGl2ZU9wdGlvbnMoKSksXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCk7XG4gIH1cblxuICBzZXRTZWxlY3Rpb25Nb2RlbChzZWxlY3Rpb25Nb2RlbDogU2VsZWN0aW9uTW9kZWw8VD4gfCBudWxsKSB7XG4gICAgdGhpcy5fc2VsZWN0aW9uTW9kZWwkLm5leHQoc2VsZWN0aW9uTW9kZWwpO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBzZXRBY3RpdmVPcHRpb24ob3B0aW9uOiBUIHwgbnVsbCkge1xuICAgIHRoaXMuX2FjdGl2ZU9wdGlvbiQubmV4dChvcHRpb24pO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBldmFsdWF0ZUtleWJvYXJkRXZlbnQoZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcbiAgICBjb25zdCBrZXlDb2RlID0gZXZlbnQua2V5Q29kZTtcbiAgICBjb25zdCBhY3RpdmVPcHRpb24gPSB0aGlzLmFjdGl2ZU9wdGlvbjtcblxuICAgIGlmICghdGhpcy5zZWxlY3Rpb25Nb2RlbCB8fCAhYWN0aXZlT3B0aW9uKSByZXR1cm47XG5cbiAgICBjb25zdCBjdXJyZW50SW5kZXggPSB0aGlzLnNlbGVjdGlvbk1vZGVsPy5nZXRPcHRpb25JbmRleChhY3RpdmVPcHRpb24pO1xuXG4gICAgaWYgKGN1cnJlbnRJbmRleCA9PT0gbnVsbCkgcmV0dXJuO1xuXG4gICAgbGV0IG5ld0FjdGl2ZU9wdGlvbjogVCB8IG51bGwgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XG5cbiAgICBzd2l0Y2ggKGtleUNvZGUpIHtcbiAgICAgIGNhc2UgRE9XTl9BUlJPVzpcbiAgICAgICAge1xuICAgICAgICAgIG5ld0FjdGl2ZU9wdGlvbiA9IHRoaXMuc2VsZWN0aW9uTW9kZWw/LmdldE9wdGlvbkJ5T2Zmc2V0KDEsIGN1cnJlbnRJbmRleCk7XG4gICAgICAgIH1cbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlIFVQX0FSUk9XOlxuICAgICAgICB7XG4gICAgICAgICAgbmV3QWN0aXZlT3B0aW9uID0gdGhpcy5zZWxlY3Rpb25Nb2RlbD8uZ2V0T3B0aW9uQnlPZmZzZXQoLTEsIGN1cnJlbnRJbmRleCk7XG4gICAgICAgIH1cbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlIFBBR0VfVVA6XG4gICAgICAgIHtcbiAgICAgICAgICBuZXdBY3RpdmVPcHRpb24gPSB0aGlzLnNlbGVjdGlvbk1vZGVsPy5nZXRPcHRpb25CeU9mZnNldCgtMTAsIGN1cnJlbnRJbmRleCk7XG4gICAgICAgIH1cbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlIFBBR0VfRE9XTjpcbiAgICAgICAge1xuICAgICAgICAgIG5ld0FjdGl2ZU9wdGlvbiA9IHRoaXMuc2VsZWN0aW9uTW9kZWw/LmdldE9wdGlvbkJ5T2Zmc2V0KDEwLCBjdXJyZW50SW5kZXgpO1xuICAgICAgICB9XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSBIT01FOlxuICAgICAgICB7XG4gICAgICAgICAgbmV3QWN0aXZlT3B0aW9uID0gdGhpcy5zZWxlY3Rpb25Nb2RlbD8uZ2V0Rmlyc3RPcHRpb24oKTtcbiAgICAgICAgfVxuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgRU5EOlxuICAgICAgICB7XG4gICAgICAgICAgbmV3QWN0aXZlT3B0aW9uID0gdGhpcy5zZWxlY3Rpb25Nb2RlbD8uZ2V0TGFzdE9wdGlvbigpO1xuICAgICAgICB9XG4gICAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIGlmIChuZXdBY3RpdmVPcHRpb24gIT09IHVuZGVmaW5lZCkge1xuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICB9XG5cbiAgICBpZiAobmV3QWN0aXZlT3B0aW9uICE9PSBhY3RpdmVPcHRpb24gJiYgbmV3QWN0aXZlT3B0aW9uICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMuX2FjdGl2ZU9wdGlvbiQubmV4dChuZXdBY3RpdmVPcHRpb24pO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgX3Jlc2V0QWN0aXZlT3B0aW9ucygpIHtcbiAgICBjb25zdCBmaXJzdE9wdGlvbiA9IHRoaXMuc2VsZWN0aW9uTW9kZWw/LmdldEZpcnN0T3B0aW9uKCk7XG5cbiAgICB0aGlzLl9hY3RpdmVPcHRpb24kLm5leHQoZmlyc3RPcHRpb24gPz8gbnVsbCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -128,6 +128,10 @@ class ActiveSelectionModel {
|
|
|
128
128
|
this._selectionModel$.next(selectionModel);
|
|
129
129
|
return this;
|
|
130
130
|
}
|
|
131
|
+
setActiveOption(option) {
|
|
132
|
+
this._activeOption$.next(option);
|
|
133
|
+
return this;
|
|
134
|
+
}
|
|
131
135
|
evaluateKeyboardEvent(event) {
|
|
132
136
|
const keyCode = event.keyCode;
|
|
133
137
|
const activeOption = this.activeOption;
|
|
@@ -2683,7 +2687,7 @@ class AnimatedOverlayDirective {
|
|
|
2683
2687
|
return;
|
|
2684
2688
|
}
|
|
2685
2689
|
this._isMounting$.next(true);
|
|
2686
|
-
const { component, providers, data, mirrorWidth } = config;
|
|
2690
|
+
const { component, providers, data, mirrorWidth, themeProvider } = config;
|
|
2687
2691
|
this._beforeOpened?.next();
|
|
2688
2692
|
const injector = Injector.create({
|
|
2689
2693
|
parent: this._injector,
|
|
@@ -2696,6 +2700,9 @@ class AnimatedOverlayDirective {
|
|
|
2696
2700
|
Object.assign(this._componentRef.instance, data);
|
|
2697
2701
|
}
|
|
2698
2702
|
this._componentRef.instance._markForCheck?.();
|
|
2703
|
+
if (themeProvider) {
|
|
2704
|
+
this._componentRef.instance._setThemeFromProvider?.(themeProvider);
|
|
2705
|
+
}
|
|
2699
2706
|
if (mirrorWidth) {
|
|
2700
2707
|
this._overlayRef.updateSize({
|
|
2701
2708
|
width: this._elementRef.nativeElement.offsetWidth,
|