@ethlete/cdk 3.3.0 → 3.3.1

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
+ ## 3.3.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [`625b4173`](https://github.com/ethlete-io/ethdk/commit/625b4173e20b66f74d4a02aee1795a4b765af2f9) Thanks [@TomTomB](https://github.com/TomTomB)! - Supress default events on bottom sheet drag handle
8
+
3
9
  ## 3.3.0
4
10
 
5
11
  ### Minor Changes
@@ -30,7 +30,7 @@ export class BottomSheetDragHandleComponent {
30
30
  .pipe(tap((event) => this._onTouchMove(event)), takeUntil(this._destroy$))
31
31
  .subscribe();
32
32
  fromEvent(this._elementRef.nativeElement, 'touchend', { passive: true })
33
- .pipe(tap(() => this._onTouchEnd()), takeUntil(this._destroy$))
33
+ .pipe(tap((event) => this._onTouchEnd(event)), takeUntil(this._destroy$))
34
34
  .subscribe();
35
35
  }
36
36
  ngOnChanges(changes) {
@@ -49,21 +49,30 @@ export class BottomSheetDragHandleComponent {
49
49
  if (!this._bottomSheetRef) {
50
50
  return;
51
51
  }
52
+ if (event.cancelable) {
53
+ event.preventDefault();
54
+ }
55
+ event.stopPropagation();
52
56
  this._swipeHandlerId = this._bottomSheetSwipeHandlerService.startSwipe(event, this._bottomSheetRef._containerInstance.elementRef.nativeElement);
53
57
  }
54
58
  _onTouchMove(event) {
55
- if (!this._swipeHandlerId) {
59
+ if (this._swipeHandlerId === null) {
56
60
  return;
57
61
  }
62
+ if (event.cancelable) {
63
+ event.preventDefault();
64
+ }
65
+ event.stopPropagation();
58
66
  const didSwipe = this._bottomSheetSwipeHandlerService.updateSwipe(this._swipeHandlerId, event);
59
67
  if (!didSwipe) {
60
68
  this._swipeHandlerId = null;
61
69
  }
62
70
  }
63
- _onTouchEnd() {
64
- if (!this._swipeHandlerId) {
71
+ _onTouchEnd(event) {
72
+ if (this._swipeHandlerId === null) {
65
73
  return;
66
74
  }
75
+ event.stopPropagation();
67
76
  const shouldClose = this._bottomSheetSwipeHandlerService.endSwipe(this._swipeHandlerId);
68
77
  this._swipeHandlerId = null;
69
78
  if (shouldClose) {
@@ -100,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
100
109
  type: HostListener,
101
110
  args: ['click', ['$event']]
102
111
  }] } });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bottom-sheet-drag-handle.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-drag-handle/bottom-sheet-drag-handle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  inject,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { createDestroy } from '@ethlete/core';\nimport { fromEvent, takeUntil, tap } from 'rxjs';\nimport { BottomSheetService, BottomSheetSwipeHandlerService } from '../../services';\nimport { BottomSheetRef, getClosestBottomSheet } from '../../utils';\n\n@Component({\n  selector: '[et-bottom-sheet-drag-handle], [etBottomSheetDragHandle]',\n  template: '',\n  styleUrls: ['./bottom-sheet-drag-handle.component.scss'],\n  exportAs: 'etBottomSheetDragHandle',\n  host: {\n    class: 'et-bottom-sheet-drag-handle',\n    '[attr.aria-label]': 'ariaLabel || null',\n  },\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [BottomSheetSwipeHandlerService],\n})\nexport class BottomSheetDragHandleComponent implements OnInit, OnChanges {\n  private _bottomSheetRef = inject(BottomSheetRef, { optional: true });\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _bottomSheetService = inject(BottomSheetService);\n  private readonly _bottomSheetSwipeHandlerService = inject(BottomSheetSwipeHandlerService);\n  private readonly _destroy$ = createDestroy();\n\n  @Input('aria-label')\n  ariaLabel?: string = 'Close sheet';\n\n  @Input()\n  @HostBinding('attr.type')\n  type: 'submit' | 'button' | 'reset' = 'button';\n\n  @Input('et-bottom-sheet-drag-handle')\n  bottomSheetResult: unknown;\n\n  @Input('etBottomSheetDragHandle')\n  _etBottomSheetDragHandle: unknown;\n\n  private _swipeHandlerId: number | null = null;\n\n  ngOnInit() {\n    if (!this._bottomSheetRef) {\n      const closestRef = getClosestBottomSheet(this._elementRef, this._bottomSheetService.openBottomSheets);\n\n      if (!closestRef) {\n        throw Error('No closest ref found');\n      }\n\n      this._bottomSheetRef = closestRef;\n    }\n\n    fromEvent<TouchEvent>(this._elementRef.nativeElement, 'touchstart', { passive: true })\n      .pipe(\n        tap((event) => this._onTouchStart(event)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    fromEvent<TouchEvent>(this._elementRef.nativeElement, 'touchmove', { passive: true })\n      .pipe(\n        tap((event) => this._onTouchMove(event)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    fromEvent<TouchEvent>(this._elementRef.nativeElement, 'touchend', { passive: true })\n      .pipe(\n        tap(() => this._onTouchEnd()),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const change = changes['_etBottomSheetDragHandle'];\n\n    if (change) {\n      this.bottomSheetResult = change.currentValue;\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  _onButtonClick(event: MouseEvent) {\n    if (!this._bottomSheetRef) {\n      return;\n    }\n\n    this._bottomSheetRef._closeBottomSheetVia(\n      this._bottomSheetRef,\n      event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse',\n      this.bottomSheetResult,\n    );\n  }\n\n  _onTouchStart(event: TouchEvent) {\n    if (!this._bottomSheetRef) {\n      return;\n    }\n\n    this._swipeHandlerId = this._bottomSheetSwipeHandlerService.startSwipe(\n      event,\n      this._bottomSheetRef._containerInstance.elementRef.nativeElement,\n    );\n  }\n\n  _onTouchMove(event: TouchEvent) {\n    if (!this._swipeHandlerId) {\n      return;\n    }\n\n    const didSwipe = this._bottomSheetSwipeHandlerService.updateSwipe(this._swipeHandlerId, event);\n\n    if (!didSwipe) {\n      this._swipeHandlerId = null;\n    }\n  }\n\n  _onTouchEnd() {\n    if (!this._swipeHandlerId) {\n      return;\n    }\n\n    const shouldClose = this._bottomSheetSwipeHandlerService.endSwipe(this._swipeHandlerId);\n    this._swipeHandlerId = null;\n\n    if (shouldClose) {\n      if (!this._bottomSheetRef) {\n        return;\n      }\n\n      this._bottomSheetRef._closeBottomSheetVia(this._bottomSheetRef, 'touch', this.bottomSheetResult);\n    }\n  }\n}\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bottom-sheet-drag-handle.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-drag-handle/bottom-sheet-drag-handle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  inject,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { createDestroy } from '@ethlete/core';\nimport { fromEvent, takeUntil, tap } from 'rxjs';\nimport { BottomSheetService, BottomSheetSwipeHandlerService } from '../../services';\nimport { BottomSheetRef, getClosestBottomSheet } from '../../utils';\n\n@Component({\n  selector: '[et-bottom-sheet-drag-handle], [etBottomSheetDragHandle]',\n  template: '',\n  styleUrls: ['./bottom-sheet-drag-handle.component.scss'],\n  exportAs: 'etBottomSheetDragHandle',\n  host: {\n    class: 'et-bottom-sheet-drag-handle',\n    '[attr.aria-label]': 'ariaLabel || null',\n  },\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [BottomSheetSwipeHandlerService],\n})\nexport class BottomSheetDragHandleComponent implements OnInit, OnChanges {\n  private _bottomSheetRef = inject(BottomSheetRef, { optional: true });\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _bottomSheetService = inject(BottomSheetService);\n  private readonly _bottomSheetSwipeHandlerService = inject(BottomSheetSwipeHandlerService);\n  private readonly _destroy$ = createDestroy();\n\n  @Input('aria-label')\n  ariaLabel?: string = 'Close sheet';\n\n  @Input()\n  @HostBinding('attr.type')\n  type: 'submit' | 'button' | 'reset' = 'button';\n\n  @Input('et-bottom-sheet-drag-handle')\n  bottomSheetResult: unknown;\n\n  @Input('etBottomSheetDragHandle')\n  _etBottomSheetDragHandle: unknown;\n\n  private _swipeHandlerId: number | null = null;\n\n  ngOnInit() {\n    if (!this._bottomSheetRef) {\n      const closestRef = getClosestBottomSheet(this._elementRef, this._bottomSheetService.openBottomSheets);\n\n      if (!closestRef) {\n        throw Error('No closest ref found');\n      }\n\n      this._bottomSheetRef = closestRef;\n    }\n\n    fromEvent<TouchEvent>(this._elementRef.nativeElement, 'touchstart', { passive: true })\n      .pipe(\n        tap((event) => this._onTouchStart(event)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    fromEvent<TouchEvent>(this._elementRef.nativeElement, 'touchmove', { passive: true })\n      .pipe(\n        tap((event) => this._onTouchMove(event)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    fromEvent<TouchEvent>(this._elementRef.nativeElement, 'touchend', { passive: true })\n      .pipe(\n        tap((event) => this._onTouchEnd(event)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const change = changes['_etBottomSheetDragHandle'];\n\n    if (change) {\n      this.bottomSheetResult = change.currentValue;\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  _onButtonClick(event: MouseEvent) {\n    if (!this._bottomSheetRef) {\n      return;\n    }\n\n    this._bottomSheetRef._closeBottomSheetVia(\n      this._bottomSheetRef,\n      event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse',\n      this.bottomSheetResult,\n    );\n  }\n\n  _onTouchStart(event: TouchEvent) {\n    if (!this._bottomSheetRef) {\n      return;\n    }\n\n    if (event.cancelable) {\n      event.preventDefault();\n    }\n    event.stopPropagation();\n\n    this._swipeHandlerId = this._bottomSheetSwipeHandlerService.startSwipe(\n      event,\n      this._bottomSheetRef._containerInstance.elementRef.nativeElement,\n    );\n  }\n\n  _onTouchMove(event: TouchEvent) {\n    if (this._swipeHandlerId === null) {\n      return;\n    }\n\n    if (event.cancelable) {\n      event.preventDefault();\n    }\n    event.stopPropagation();\n\n    const didSwipe = this._bottomSheetSwipeHandlerService.updateSwipe(this._swipeHandlerId, event);\n\n    if (!didSwipe) {\n      this._swipeHandlerId = null;\n    }\n  }\n\n  _onTouchEnd(event: TouchEvent) {\n    if (this._swipeHandlerId === null) {\n      return;\n    }\n\n    event.stopPropagation();\n\n    const shouldClose = this._bottomSheetSwipeHandlerService.endSwipe(this._swipeHandlerId);\n\n    this._swipeHandlerId = null;\n\n    if (shouldClose) {\n      if (!this._bottomSheetRef) {\n        return;\n      }\n\n      this._bottomSheetRef._closeBottomSheetVia(this._bottomSheetRef, 'touch', this.bottomSheetResult);\n    }\n  }\n}\n"]}
@@ -6531,7 +6531,7 @@ class BottomSheetDragHandleComponent {
6531
6531
  .pipe(tap((event) => this._onTouchMove(event)), takeUntil(this._destroy$))
6532
6532
  .subscribe();
6533
6533
  fromEvent(this._elementRef.nativeElement, 'touchend', { passive: true })
6534
- .pipe(tap(() => this._onTouchEnd()), takeUntil(this._destroy$))
6534
+ .pipe(tap((event) => this._onTouchEnd(event)), takeUntil(this._destroy$))
6535
6535
  .subscribe();
6536
6536
  }
6537
6537
  ngOnChanges(changes) {
@@ -6550,21 +6550,30 @@ class BottomSheetDragHandleComponent {
6550
6550
  if (!this._bottomSheetRef) {
6551
6551
  return;
6552
6552
  }
6553
+ if (event.cancelable) {
6554
+ event.preventDefault();
6555
+ }
6556
+ event.stopPropagation();
6553
6557
  this._swipeHandlerId = this._bottomSheetSwipeHandlerService.startSwipe(event, this._bottomSheetRef._containerInstance.elementRef.nativeElement);
6554
6558
  }
6555
6559
  _onTouchMove(event) {
6556
- if (!this._swipeHandlerId) {
6560
+ if (this._swipeHandlerId === null) {
6557
6561
  return;
6558
6562
  }
6563
+ if (event.cancelable) {
6564
+ event.preventDefault();
6565
+ }
6566
+ event.stopPropagation();
6559
6567
  const didSwipe = this._bottomSheetSwipeHandlerService.updateSwipe(this._swipeHandlerId, event);
6560
6568
  if (!didSwipe) {
6561
6569
  this._swipeHandlerId = null;
6562
6570
  }
6563
6571
  }
6564
- _onTouchEnd() {
6565
- if (!this._swipeHandlerId) {
6572
+ _onTouchEnd(event) {
6573
+ if (this._swipeHandlerId === null) {
6566
6574
  return;
6567
6575
  }
6576
+ event.stopPropagation();
6568
6577
  const shouldClose = this._bottomSheetSwipeHandlerService.endSwipe(this._swipeHandlerId);
6569
6578
  this._swipeHandlerId = null;
6570
6579
  if (shouldClose) {