@ethlete/cdk 4.7.1 → 4.7.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/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # @ethlete/cdk
2
2
 
3
+ ## 4.7.2
4
+
5
+ ### Patch Changes
6
+
7
+ - [`d1c6fa6`](https://github.com/ethlete-io/ethdk/commit/d1c6fa6be7e131559623b52f2fe85840dc241c57) Thanks [@TomTomB](https://github.com/TomTomB)! - Do not override user defined inputs with default values in menu trigger directive
8
+
3
9
  ## 4.7.1
4
10
 
5
11
  ### Patch Changes
@@ -38,9 +38,20 @@ export class MenuTriggerDirective {
38
38
  });
39
39
  this._animatedOverlay.autoHide = true;
40
40
  this._animatedOverlay.shift = false;
41
- this._animatedOverlay.placement = 'bottom';
42
41
  this._animatedOverlay.autoResize = true;
43
- this._animatedOverlay.fallbackPlacements = ['bottom', 'bottom-start', 'bottom-end', 'top', 'top-start', 'top-end'];
42
+ if (!this._animatedOverlay.placement) {
43
+ this._animatedOverlay.placement = 'bottom';
44
+ }
45
+ if (!this._animatedOverlay.fallbackPlacements) {
46
+ this._animatedOverlay.fallbackPlacements = [
47
+ 'bottom',
48
+ 'bottom-start',
49
+ 'bottom-end',
50
+ 'top',
51
+ 'top-start',
52
+ 'top-end',
53
+ ];
54
+ }
44
55
  fromEvent(this._elementRef.nativeElement, 'click')
45
56
  .pipe(tap(() => this.mount()), takeUntilDestroyed())
46
57
  .subscribe();
@@ -145,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImpor
145
156
  type: Input,
146
157
  args: [{ alias: 'etMenuTrigger', required: true }]
147
158
  }] } });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-trigger.directive.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/menu/directives/menu-trigger/menu-trigger.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AnimatedOverlayDirective, ClickObserverService, signalHostAttributes, signalHostClasses } from '@ethlete/core';\nimport { THEME_PROVIDER } from '@ethlete/theming';\nimport { Subscription, filter, fromEvent, take, tap } from 'rxjs';\nimport { OverlayCloseBlockerDirective } from '../../../../directives/overlay-close-auto-blocker';\nimport { MENU_TEMPLATE, MenuComponent, MenuContainerComponent } from '../../components';\n\nexport const MENU_TRIGGER_TOKEN = new InjectionToken<MenuTriggerDirective>('ET_MENU_TRIGGER_TOKEN');\n\nlet uniqueId = 0;\n\n@Directive({\n  selector: '[etMenuTrigger]',\n  standalone: true,\n  providers: [\n    {\n      provide: MENU_TRIGGER_TOKEN,\n      useExisting: MenuTriggerDirective,\n    },\n  ],\n  hostDirectives: [\n    { directive: AnimatedOverlayDirective, inputs: ['placement', 'offset', 'viewportPadding', 'fallbackPlacements'] },\n    OverlayCloseBlockerDirective,\n  ],\n  host: {\n    'aria-haspopup': 'menu',\n    class: 'et-menu-trigger',\n    '[id]': 'id',\n  },\n})\nexport class MenuTriggerDirective implements OnDestroy {\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  readonly _animatedOverlay = inject<AnimatedOverlayDirective<MenuContainerComponent>>(AnimatedOverlayDirective);\n  private readonly _themeProvider = inject(THEME_PROVIDER, { optional: true });\n  private readonly _clickObserverService = inject(ClickObserverService);\n\n  readonly id = `et-menu-trigger-${uniqueId++}`;\n\n  protected readonly isOpen = signal<boolean>(false);\n\n  private readonly _listenerSubscriptions: Subscription[] = [];\n\n  private readonly _currentMenu = signal<MenuComponent | null>(null);\n\n  private readonly _currentMenuId = computed(() => {\n    const menu = this._currentMenu();\n    return menu ? menu.id() : null;\n  });\n\n  readonly currentMenu = this._currentMenu.asReadonly();\n\n  @Input({ alias: 'etMenuTrigger', required: true })\n  set __menuTemplate(value: TemplateRef<unknown>) {\n    this.menuTemplate.set(value);\n  }\n  protected readonly menuTemplate = signal<TemplateRef<unknown> | null>(null);\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-menu-trigger--open': this.isOpen,\n  });\n\n  readonly hostAttributeBindings = signalHostAttributes({\n    'aria-controls': this._currentMenuId,\n    'aria-expanded': this.isOpen,\n  });\n\n  constructor() {\n    this._animatedOverlay.autoHide = true;\n    this._animatedOverlay.shift = false;\n    this._animatedOverlay.placement = 'bottom';\n    this._animatedOverlay.autoResize = true;\n    this._animatedOverlay.fallbackPlacements = ['bottom', 'bottom-start', 'bottom-end', 'top', 'top-start', 'top-end'];\n\n    fromEvent<MouseEvent>(this._elementRef.nativeElement, 'click')\n      .pipe(\n        tap(() => this.mount()),\n        takeUntilDestroyed(),\n      )\n      .subscribe();\n\n    this._animatedOverlay\n      .afterClosed()\n      .pipe(\n        tap(() => this._removeListeners()),\n        takeUntilDestroyed(),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this._animatedOverlay._destroy();\n    this._removeListeners();\n  }\n\n  mount() {\n    const menuTemplate = this.menuTemplate();\n\n    if (!menuTemplate) {\n      throw new Error('No menu template provided');\n    }\n\n    if (!this._animatedOverlay.canMount) return;\n\n    const menuRef = this._animatedOverlay.mount({\n      component: MenuContainerComponent,\n      themeProvider: this._themeProvider,\n      providers: [\n        {\n          provide: MENU_TEMPLATE,\n          useValue: menuTemplate,\n        },\n      ],\n    });\n\n    if (menuRef) {\n      this.isOpen.set(true);\n      this._addListeners();\n    }\n  }\n\n  unmount(restoreFocus = true) {\n    if (!this._animatedOverlay.canUnmount) return;\n\n    this._animatedOverlay.unmount();\n    this.isOpen.set(false);\n\n    if (restoreFocus) {\n      this._animatedOverlay\n        .afterClosed()\n        .pipe(\n          tap(() => this._elementRef.nativeElement.focus()),\n          take(1),\n        )\n        .subscribe();\n    }\n  }\n\n  _connectWithMenu(menu: MenuComponent) {\n    this._currentMenu.set(menu);\n  }\n\n  _clearMenuConnection() {\n    this._currentMenu.set(null);\n  }\n\n  private _addListeners() {\n    const keyupEscSub = fromEvent<KeyboardEvent>(document, 'keyup')\n      .pipe(\n        filter((e) => e.key === 'Escape'),\n        tap(() => this.unmount()),\n      )\n      .subscribe();\n\n    const clickOutsideSub = this._clickObserverService\n      .observe(this._animatedOverlay.componentRef?.location.nativeElement)\n      .subscribe((e) => {\n        const targetElement = e.target as HTMLElement;\n        const isInside = this._animatedOverlay.componentRef?.location.nativeElement.contains(targetElement);\n\n        if (!isInside) {\n          this.unmount();\n        }\n      });\n\n    this._listenerSubscriptions.push(keyupEscSub, clickOutsideSub);\n  }\n\n  private _removeListeners() {\n    this._listenerSubscriptions.forEach((s) => s.unsubscribe());\n    this._listenerSubscriptions.length = 0;\n  }\n}\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-trigger.directive.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/menu/directives/menu-trigger/menu-trigger.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AnimatedOverlayDirective, ClickObserverService, signalHostAttributes, signalHostClasses } from '@ethlete/core';\nimport { THEME_PROVIDER } from '@ethlete/theming';\nimport { Subscription, filter, fromEvent, take, tap } from 'rxjs';\nimport { OverlayCloseBlockerDirective } from '../../../../directives/overlay-close-auto-blocker';\nimport { MENU_TEMPLATE, MenuComponent, MenuContainerComponent } from '../../components';\n\nexport const MENU_TRIGGER_TOKEN = new InjectionToken<MenuTriggerDirective>('ET_MENU_TRIGGER_TOKEN');\n\nlet uniqueId = 0;\n\n@Directive({\n  selector: '[etMenuTrigger]',\n  standalone: true,\n  providers: [\n    {\n      provide: MENU_TRIGGER_TOKEN,\n      useExisting: MenuTriggerDirective,\n    },\n  ],\n  hostDirectives: [\n    { directive: AnimatedOverlayDirective, inputs: ['placement', 'offset', 'viewportPadding', 'fallbackPlacements'] },\n    OverlayCloseBlockerDirective,\n  ],\n  host: {\n    'aria-haspopup': 'menu',\n    class: 'et-menu-trigger',\n    '[id]': 'id',\n  },\n})\nexport class MenuTriggerDirective implements OnDestroy {\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  readonly _animatedOverlay = inject<AnimatedOverlayDirective<MenuContainerComponent>>(AnimatedOverlayDirective);\n  private readonly _themeProvider = inject(THEME_PROVIDER, { optional: true });\n  private readonly _clickObserverService = inject(ClickObserverService);\n\n  readonly id = `et-menu-trigger-${uniqueId++}`;\n\n  protected readonly isOpen = signal<boolean>(false);\n\n  private readonly _listenerSubscriptions: Subscription[] = [];\n\n  private readonly _currentMenu = signal<MenuComponent | null>(null);\n\n  private readonly _currentMenuId = computed(() => {\n    const menu = this._currentMenu();\n    return menu ? menu.id() : null;\n  });\n\n  readonly currentMenu = this._currentMenu.asReadonly();\n\n  @Input({ alias: 'etMenuTrigger', required: true })\n  set __menuTemplate(value: TemplateRef<unknown>) {\n    this.menuTemplate.set(value);\n  }\n  protected readonly menuTemplate = signal<TemplateRef<unknown> | null>(null);\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-menu-trigger--open': this.isOpen,\n  });\n\n  readonly hostAttributeBindings = signalHostAttributes({\n    'aria-controls': this._currentMenuId,\n    'aria-expanded': this.isOpen,\n  });\n\n  constructor() {\n    this._animatedOverlay.autoHide = true;\n    this._animatedOverlay.shift = false;\n    this._animatedOverlay.autoResize = true;\n\n    if (!this._animatedOverlay.placement) {\n      this._animatedOverlay.placement = 'bottom';\n    }\n\n    if (!this._animatedOverlay.fallbackPlacements) {\n      this._animatedOverlay.fallbackPlacements = [\n        'bottom',\n        'bottom-start',\n        'bottom-end',\n        'top',\n        'top-start',\n        'top-end',\n      ];\n    }\n\n    fromEvent<MouseEvent>(this._elementRef.nativeElement, 'click')\n      .pipe(\n        tap(() => this.mount()),\n        takeUntilDestroyed(),\n      )\n      .subscribe();\n\n    this._animatedOverlay\n      .afterClosed()\n      .pipe(\n        tap(() => this._removeListeners()),\n        takeUntilDestroyed(),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this._animatedOverlay._destroy();\n    this._removeListeners();\n  }\n\n  mount() {\n    const menuTemplate = this.menuTemplate();\n\n    if (!menuTemplate) {\n      throw new Error('No menu template provided');\n    }\n\n    if (!this._animatedOverlay.canMount) return;\n\n    const menuRef = this._animatedOverlay.mount({\n      component: MenuContainerComponent,\n      themeProvider: this._themeProvider,\n      providers: [\n        {\n          provide: MENU_TEMPLATE,\n          useValue: menuTemplate,\n        },\n      ],\n    });\n\n    if (menuRef) {\n      this.isOpen.set(true);\n      this._addListeners();\n    }\n  }\n\n  unmount(restoreFocus = true) {\n    if (!this._animatedOverlay.canUnmount) return;\n\n    this._animatedOverlay.unmount();\n    this.isOpen.set(false);\n\n    if (restoreFocus) {\n      this._animatedOverlay\n        .afterClosed()\n        .pipe(\n          tap(() => this._elementRef.nativeElement.focus()),\n          take(1),\n        )\n        .subscribe();\n    }\n  }\n\n  _connectWithMenu(menu: MenuComponent) {\n    this._currentMenu.set(menu);\n  }\n\n  _clearMenuConnection() {\n    this._currentMenu.set(null);\n  }\n\n  private _addListeners() {\n    const keyupEscSub = fromEvent<KeyboardEvent>(document, 'keyup')\n      .pipe(\n        filter((e) => e.key === 'Escape'),\n        tap(() => this.unmount()),\n      )\n      .subscribe();\n\n    const clickOutsideSub = this._clickObserverService\n      .observe(this._animatedOverlay.componentRef?.location.nativeElement)\n      .subscribe((e) => {\n        const targetElement = e.target as HTMLElement;\n        const isInside = this._animatedOverlay.componentRef?.location.nativeElement.contains(targetElement);\n\n        if (!isInside) {\n          this.unmount();\n        }\n      });\n\n    this._listenerSubscriptions.push(keyupEscSub, clickOutsideSub);\n  }\n\n  private _removeListeners() {\n    this._listenerSubscriptions.forEach((s) => s.unsubscribe());\n    this._listenerSubscriptions.length = 0;\n  }\n}\n"]}
@@ -4504,9 +4504,20 @@ class MenuTriggerDirective {
4504
4504
  });
4505
4505
  this._animatedOverlay.autoHide = true;
4506
4506
  this._animatedOverlay.shift = false;
4507
- this._animatedOverlay.placement = 'bottom';
4508
4507
  this._animatedOverlay.autoResize = true;
4509
- this._animatedOverlay.fallbackPlacements = ['bottom', 'bottom-start', 'bottom-end', 'top', 'top-start', 'top-end'];
4508
+ if (!this._animatedOverlay.placement) {
4509
+ this._animatedOverlay.placement = 'bottom';
4510
+ }
4511
+ if (!this._animatedOverlay.fallbackPlacements) {
4512
+ this._animatedOverlay.fallbackPlacements = [
4513
+ 'bottom',
4514
+ 'bottom-start',
4515
+ 'bottom-end',
4516
+ 'top',
4517
+ 'top-start',
4518
+ 'top-end',
4519
+ ];
4520
+ }
4510
4521
  fromEvent(this._elementRef.nativeElement, 'click')
4511
4522
  .pipe(tap(() => this.mount()), takeUntilDestroyed())
4512
4523
  .subscribe();