@ethlete/core 2.4.2 → 2.4.3

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.
@@ -25,6 +25,8 @@ class AnimatedOverlayDirective {
25
25
  this._beforeClosed = null;
26
26
  this._afterClosed = null;
27
27
  this._isMounted$ = new BehaviorSubject(false);
28
+ this._isMounting$ = new BehaviorSubject(false);
29
+ this._isUnmounting$ = new BehaviorSubject(false);
28
30
  /**
29
31
  * The placement of the animated overlay.
30
32
  * @default 'auto'
@@ -48,6 +50,15 @@ class AnimatedOverlayDirective {
48
50
  get isMounted$() {
49
51
  return this._isMounted$.asObservable();
50
52
  }
53
+ get isMounting() {
54
+ return this._isMounting$.value;
55
+ }
56
+ get isMounting$() {
57
+ return this._isMounting$.asObservable();
58
+ }
59
+ get isUnmounting() {
60
+ return this._isUnmounting$.value;
61
+ }
51
62
  get portal() {
52
63
  return this._portal;
53
64
  }
@@ -61,12 +72,13 @@ class AnimatedOverlayDirective {
61
72
  return this._popper;
62
73
  }
63
74
  mount(config) {
64
- if (this.isMounted) {
75
+ if (this.isMounted || this.isMounting) {
65
76
  if (isDevMode()) {
66
- console.warn('AnimatedOverlayDirective: There is already a component mounted. Please call `unmount` before calling `mount` again.');
77
+ console.warn('AnimatedOverlayDirective: The component is already mounted or mounting. Please unmount the component before mounting again.');
67
78
  }
68
79
  return;
69
80
  }
81
+ this._isMounting$.next(true);
70
82
  const { component, providers, data, mirrorWidth } = config;
71
83
  this._beforeOpened?.next();
72
84
  const injector = Injector.create({
@@ -147,14 +159,22 @@ class AnimatedOverlayDirective {
147
159
  }), take(1), takeUntil(this._destroy$))
148
160
  .subscribe();
149
161
  this._isMounted$.next(true);
162
+ this._isMounting$.next(false);
150
163
  });
151
164
  });
152
165
  return this._componentRef.instance;
153
166
  }
154
167
  unmount() {
168
+ if (!this.isMounted || this.isUnmounting) {
169
+ if (isDevMode()) {
170
+ console.warn('AnimatedOverlayDirective: The component is not mounted or is already unmounting. Please call `mount` before calling `unmount` again.');
171
+ }
172
+ return;
173
+ }
155
174
  if (!this._componentRef) {
156
175
  return;
157
176
  }
177
+ this._isUnmounting$.next(true);
158
178
  this._beforeClosed?.next();
159
179
  this._componentRef.instance._animatedLifecycle?.leave();
160
180
  this._componentRef.instance._animatedLifecycle?.state$
@@ -199,6 +219,7 @@ class AnimatedOverlayDirective {
199
219
  this._componentRef = null;
200
220
  }
201
221
  this._isMounted$.next(false);
222
+ this._isUnmounting$.next(false);
202
223
  this._afterClosed?.next();
203
224
  }
204
225
  _reposition() {
@@ -223,4 +244,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImpor
223
244
  }], arrowPadding: [{
224
245
  type: Input
225
246
  }] } });
226
- //# 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 { Instance as PopperInstance, Placement as PopperPlacement, createPopper } from '@popperjs/core';\nimport { Options as ArrowOptions } from '@popperjs/core/lib/modifiers/arrow';\nimport { Options as OffsetOptions } from '@popperjs/core/lib/modifiers/offset';\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  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\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 _popper: PopperInstance | 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\n  /**\n   * The placement of the animated overlay.\n   * @default 'auto'\n   */\n  @Input()\n  placement: PopperPlacement = 'auto';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://popper.js.org/docs/v2/modifiers/flip/#allowedautoplacements\n   */\n  @Input()\n  allowedAutoPlacements?: PopperPlacement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://popper.js.org/docs/v2/modifiers/offset/#offset-1\n   */\n  @Input()\n  offset: OffsetOptions['offset'] | Readonly<OffsetOptions['offset']> | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://popper.js.org/docs/v2/modifiers/arrow/#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: ArrowOptions['padding'] | null = null;\n\n  get isMounted() {\n    return this._isMounted$.value;\n  }\n\n  get isMounted$() {\n    return this._isMounted$.asObservable();\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  get popper() {\n    return this._popper;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n  }) {\n    if (this.isMounted) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: There is already a component mounted. Please call `unmount` before calling `mount` again.',\n        );\n      }\n\n      return;\n    }\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            this._popper?.update();\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      this._popper = createPopper(this._elementRef.nativeElement, this._componentRef.location.nativeElement, {\n        placement: this.placement,\n        modifiers: [\n          ...(this.offset\n            ? [\n                {\n                  name: 'offset',\n                  options: {\n                    offset: this.offset,\n                  },\n                },\n              ]\n            : []),\n          ...(this.arrowPadding\n            ? [\n                {\n                  name: 'arrow',\n                  options: {\n                    padding: this.arrowPadding,\n                  },\n                },\n              ]\n            : []),\n          ...(this.allowedAutoPlacements\n            ? [\n                {\n                  name: 'flip',\n                  options: {\n                    allowedAutoPlacements: this.allowedAutoPlacements,\n                  },\n                },\n              ]\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._popper?.update();\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      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this._componentRef) {\n      return;\n    }\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._popper?.destroy();\n      this._popper = null;\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\n    this._afterClosed?.next();\n  }\n\n  _reposition() {\n    this._popper?.update();\n  }\n}\n"]}
247
+ //# 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 { Instance as PopperInstance, Placement as PopperPlacement, createPopper } from '@popperjs/core';\nimport { Options as ArrowOptions } from '@popperjs/core/lib/modifiers/arrow';\nimport { Options as OffsetOptions } from '@popperjs/core/lib/modifiers/offset';\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  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\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 _popper: PopperInstance | 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 'auto'\n   */\n  @Input()\n  placement: PopperPlacement = 'auto';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://popper.js.org/docs/v2/modifiers/flip/#allowedautoplacements\n   */\n  @Input()\n  allowedAutoPlacements?: PopperPlacement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://popper.js.org/docs/v2/modifiers/offset/#offset-1\n   */\n  @Input()\n  offset: OffsetOptions['offset'] | Readonly<OffsetOptions['offset']> | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://popper.js.org/docs/v2/modifiers/arrow/#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: ArrowOptions['padding'] | null = null;\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  get popper() {\n    return this._popper;\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            this._popper?.update();\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      this._popper = createPopper(this._elementRef.nativeElement, this._componentRef.location.nativeElement, {\n        placement: this.placement,\n        modifiers: [\n          ...(this.offset\n            ? [\n                {\n                  name: 'offset',\n                  options: {\n                    offset: this.offset,\n                  },\n                },\n              ]\n            : []),\n          ...(this.arrowPadding\n            ? [\n                {\n                  name: 'arrow',\n                  options: {\n                    padding: this.arrowPadding,\n                  },\n                },\n              ]\n            : []),\n          ...(this.allowedAutoPlacements\n            ? [\n                {\n                  name: 'flip',\n                  options: {\n                    allowedAutoPlacements: this.allowedAutoPlacements,\n                  },\n                },\n              ]\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._popper?.update();\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._popper?.destroy();\n      this._popper = null;\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  _reposition() {\n    this._popper?.update();\n  }\n}\n"]}
@@ -2028,6 +2028,8 @@ class AnimatedOverlayDirective {
2028
2028
  this._beforeClosed = null;
2029
2029
  this._afterClosed = null;
2030
2030
  this._isMounted$ = new BehaviorSubject(false);
2031
+ this._isMounting$ = new BehaviorSubject(false);
2032
+ this._isUnmounting$ = new BehaviorSubject(false);
2031
2033
  /**
2032
2034
  * The placement of the animated overlay.
2033
2035
  * @default 'auto'
@@ -2051,6 +2053,15 @@ class AnimatedOverlayDirective {
2051
2053
  get isMounted$() {
2052
2054
  return this._isMounted$.asObservable();
2053
2055
  }
2056
+ get isMounting() {
2057
+ return this._isMounting$.value;
2058
+ }
2059
+ get isMounting$() {
2060
+ return this._isMounting$.asObservable();
2061
+ }
2062
+ get isUnmounting() {
2063
+ return this._isUnmounting$.value;
2064
+ }
2054
2065
  get portal() {
2055
2066
  return this._portal;
2056
2067
  }
@@ -2064,12 +2075,13 @@ class AnimatedOverlayDirective {
2064
2075
  return this._popper;
2065
2076
  }
2066
2077
  mount(config) {
2067
- if (this.isMounted) {
2078
+ if (this.isMounted || this.isMounting) {
2068
2079
  if (isDevMode()) {
2069
- console.warn('AnimatedOverlayDirective: There is already a component mounted. Please call `unmount` before calling `mount` again.');
2080
+ console.warn('AnimatedOverlayDirective: The component is already mounted or mounting. Please unmount the component before mounting again.');
2070
2081
  }
2071
2082
  return;
2072
2083
  }
2084
+ this._isMounting$.next(true);
2073
2085
  const { component, providers, data, mirrorWidth } = config;
2074
2086
  this._beforeOpened?.next();
2075
2087
  const injector = Injector.create({
@@ -2150,14 +2162,22 @@ class AnimatedOverlayDirective {
2150
2162
  }), take(1), takeUntil(this._destroy$))
2151
2163
  .subscribe();
2152
2164
  this._isMounted$.next(true);
2165
+ this._isMounting$.next(false);
2153
2166
  });
2154
2167
  });
2155
2168
  return this._componentRef.instance;
2156
2169
  }
2157
2170
  unmount() {
2171
+ if (!this.isMounted || this.isUnmounting) {
2172
+ if (isDevMode()) {
2173
+ console.warn('AnimatedOverlayDirective: The component is not mounted or is already unmounting. Please call `mount` before calling `unmount` again.');
2174
+ }
2175
+ return;
2176
+ }
2158
2177
  if (!this._componentRef) {
2159
2178
  return;
2160
2179
  }
2180
+ this._isUnmounting$.next(true);
2161
2181
  this._beforeClosed?.next();
2162
2182
  this._componentRef.instance._animatedLifecycle?.leave();
2163
2183
  this._componentRef.instance._animatedLifecycle?.state$
@@ -2202,6 +2222,7 @@ class AnimatedOverlayDirective {
2202
2222
  this._componentRef = null;
2203
2223
  }
2204
2224
  this._isMounted$.next(false);
2225
+ this._isUnmounting$.next(false);
2205
2226
  this._afterClosed?.next();
2206
2227
  }
2207
2228
  _reposition() {