ng-primitives 0.0.7 → 0.2.0
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/README.md +14 -4
- package/accordion/accordion-trigger/accordion-trigger.directive.d.ts +2 -1
- package/autofill/README.md +3 -0
- package/autofill/autofill/autofill.directive.d.ts +19 -0
- package/{select/select-button/select-button.token.d.ts → autofill/autofill/autofill.token.d.ts} +4 -4
- package/autofill/index.d.ts +9 -0
- package/avatar/avatar/avatar.directive.d.ts +2 -1
- package/button/README.md +3 -0
- package/button/button/button.directive.d.ts +27 -0
- package/{select/select-option/select-option.token.d.ts → button/button/button.token.d.ts} +4 -4
- package/button/index.d.ts +9 -0
- package/checkbox/checkbox/checkbox.directive.d.ts +11 -61
- package/checkbox/index.d.ts +0 -4
- package/esm2022/a11y/visually-hidden/visually-hidden.directive.mjs +3 -3
- package/esm2022/accordion/accordion/accordion.directive.mjs +5 -4
- package/esm2022/accordion/accordion-content/accordion-content.directive.mjs +5 -6
- package/esm2022/accordion/accordion-item/accordion-item.directive.mjs +5 -5
- package/esm2022/accordion/accordion-trigger/accordion-trigger.directive.mjs +8 -5
- package/esm2022/autofill/autofill/autofill.directive.mjs +71 -0
- package/esm2022/autofill/autofill/autofill.token.mjs +16 -0
- package/esm2022/autofill/index.mjs +10 -0
- package/esm2022/autofill/ng-primitives-autofill.mjs +5 -0
- package/esm2022/avatar/avatar/avatar.directive.mjs +7 -4
- package/esm2022/avatar/avatar-fallback/avatar-fallback.directive.mjs +3 -3
- package/esm2022/avatar/avatar-image/avatar-image.directive.mjs +3 -3
- package/esm2022/button/button/button.directive.mjs +47 -0
- package/esm2022/button/button/button.token.mjs +16 -0
- package/esm2022/button/index.mjs +10 -0
- package/esm2022/button/ng-primitives-button.mjs +5 -0
- package/esm2022/checkbox/checkbox/checkbox.directive.mjs +29 -79
- package/esm2022/checkbox/index.mjs +1 -5
- package/esm2022/file-upload/file-upload/file-upload.directive.mjs +7 -4
- package/esm2022/focus-trap/focus-trap/focus-trap.directive.mjs +262 -0
- package/esm2022/focus-trap/focus-trap/focus-trap.token.mjs +16 -0
- package/esm2022/focus-trap/index.mjs +10 -0
- package/esm2022/focus-trap/ng-primitives-focus-trap.mjs +5 -0
- package/esm2022/form-field/description/description.directive.mjs +14 -14
- package/esm2022/form-field/error/error.directive.mjs +27 -29
- package/esm2022/form-field/form-control/form-control.directive.mjs +22 -16
- package/esm2022/form-field/form-field/form-field.directive.mjs +3 -3
- package/esm2022/form-field/form-field/form-field.token.mjs +3 -7
- package/esm2022/form-field/label/label.directive.mjs +56 -17
- package/esm2022/input/index.mjs +10 -0
- package/esm2022/input/input/input.directive.mjs +55 -0
- package/esm2022/input/input/input.token.mjs +16 -0
- package/esm2022/input/ng-primitives-input.mjs +5 -0
- package/esm2022/interactions/focus/focus.directive.mjs +15 -10
- package/esm2022/interactions/focus-visible/focus-visible.directive.mjs +12 -7
- package/esm2022/interactions/hover/hover.directive.mjs +16 -11
- package/esm2022/interactions/index.mjs +5 -1
- package/esm2022/interactions/move/move.directive.mjs +216 -0
- package/esm2022/interactions/move/move.token.mjs +16 -0
- package/esm2022/interactions/press/press.directive.mjs +118 -0
- package/esm2022/interactions/press/press.token.mjs +16 -0
- package/esm2022/internal/disabled/disabled.mjs +19 -0
- package/esm2022/internal/index.mjs +11 -0
- package/esm2022/internal/ng-primitives-internal.mjs +5 -0
- package/esm2022/internal/orientation/orientation.mjs +19 -0
- package/esm2022/internal/style-injector/style-injector.mjs +81 -0
- package/esm2022/progress/progress/progress.directive.mjs +3 -3
- package/esm2022/progress/progress-indicator/progress-indicator.directive.mjs +3 -3
- package/esm2022/radio/radio-group/radio-group.directive.mjs +14 -54
- package/esm2022/radio/radio-indicator/radio-indicator.directive.mjs +8 -5
- package/esm2022/radio/radio-item/radio-item.directive.mjs +8 -6
- package/esm2022/resize/resize/resize.directive.mjs +3 -3
- package/esm2022/roving-focus/roving-focus-group/roving-focus-group.directive.mjs +14 -9
- package/esm2022/roving-focus/roving-focus-item/roving-focus-item.directive.mjs +3 -3
- package/esm2022/search/index.mjs +10 -0
- package/esm2022/search/ng-primitives-search.mjs +5 -0
- package/esm2022/search/search-field/search-field.directive.mjs +47 -0
- package/esm2022/search/search-field/search-field.token.mjs +16 -0
- package/esm2022/select/index.mjs +1 -7
- package/esm2022/select/select/select.directive.mjs +23 -36
- package/esm2022/select/select/select.token.mjs +1 -1
- package/esm2022/slider/slider/slider.directive.mjs +18 -5
- package/esm2022/slider/slider-range/slider-range.directive.mjs +6 -5
- package/esm2022/slider/slider-thumb/slider-thumb.directive.mjs +7 -4
- package/esm2022/slider/slider-track/slider-track.directive.mjs +8 -4
- package/esm2022/switch/switch/switch.directive.mjs +18 -58
- package/esm2022/switch/switch-thumb/switch-thumb.directive.mjs +9 -6
- package/esm2022/tabs/tab-button/tab-button.directive.mjs +8 -6
- package/esm2022/tabs/tab-list/tab-list.directive.mjs +3 -3
- package/esm2022/tabs/tab-panel/tab-panel.directive.mjs +5 -6
- package/esm2022/tabs/tabset/tabset.directive.mjs +14 -18
- package/esm2022/textarea/index.mjs +10 -0
- package/esm2022/textarea/ng-primitives-textarea.mjs +5 -0
- package/esm2022/textarea/textarea/textarea.directive.mjs +37 -0
- package/esm2022/textarea/textarea/textarea.token.mjs +16 -0
- package/esm2022/toggle/toggle/toggle.directive.mjs +33 -13
- package/esm2022/tooltip/tooltip/tooltip.directive.mjs +3 -3
- package/esm2022/tooltip/tooltip-trigger/tooltip-trigger.directive.mjs +7 -7
- package/esm2022/utils/helpers/focus-manager.mjs +3 -3
- package/esm2022/utils/index.mjs +2 -2
- package/esm2022/utils/signals/async.mjs +11 -17
- package/fesm2022/ng-primitives-a11y.mjs +3 -3
- package/fesm2022/ng-primitives-accordion.mjs +19 -16
- package/fesm2022/ng-primitives-accordion.mjs.map +1 -1
- package/fesm2022/ng-primitives-autofill.mjs +100 -0
- package/fesm2022/ng-primitives-autofill.mjs.map +1 -0
- package/fesm2022/ng-primitives-avatar.mjs +13 -10
- package/fesm2022/ng-primitives-avatar.mjs.map +1 -1
- package/fesm2022/ng-primitives-button.mjs +76 -0
- package/fesm2022/ng-primitives-button.mjs.map +1 -0
- package/fesm2022/ng-primitives-checkbox.mjs +25 -203
- package/fesm2022/ng-primitives-checkbox.mjs.map +1 -1
- package/fesm2022/ng-primitives-file-upload.mjs +6 -3
- package/fesm2022/ng-primitives-file-upload.mjs.map +1 -1
- package/fesm2022/ng-primitives-focus-trap.mjs +291 -0
- package/fesm2022/ng-primitives-focus-trap.mjs.map +1 -0
- package/fesm2022/ng-primitives-form-field.mjs +119 -80
- package/fesm2022/ng-primitives-form-field.mjs.map +1 -1
- package/fesm2022/ng-primitives-input.mjs +84 -0
- package/fesm2022/ng-primitives-input.mjs.map +1 -0
- package/fesm2022/ng-primitives-interactions.mjs +394 -26
- package/fesm2022/ng-primitives-interactions.mjs.map +1 -1
- package/fesm2022/ng-primitives-internal.mjs +132 -0
- package/fesm2022/ng-primitives-internal.mjs.map +1 -0
- package/fesm2022/ng-primitives-progress.mjs +6 -6
- package/fesm2022/ng-primitives-radio.mjs +25 -62
- package/fesm2022/ng-primitives-radio.mjs.map +1 -1
- package/fesm2022/ng-primitives-resize.mjs +3 -3
- package/fesm2022/ng-primitives-roving-focus.mjs +15 -10
- package/fesm2022/ng-primitives-roving-focus.mjs.map +1 -1
- package/fesm2022/ng-primitives-search.mjs +76 -0
- package/fesm2022/ng-primitives-search.mjs.map +1 -0
- package/fesm2022/ng-primitives-select.mjs +23 -395
- package/fesm2022/ng-primitives-select.mjs.map +1 -1
- package/fesm2022/ng-primitives-slider.mjs +35 -14
- package/fesm2022/ng-primitives-slider.mjs.map +1 -1
- package/fesm2022/ng-primitives-switch.mjs +23 -62
- package/fesm2022/ng-primitives-switch.mjs.map +1 -1
- package/fesm2022/ng-primitives-tabs.mjs +27 -30
- package/fesm2022/ng-primitives-tabs.mjs.map +1 -1
- package/fesm2022/ng-primitives-textarea.mjs +66 -0
- package/fesm2022/ng-primitives-textarea.mjs.map +1 -0
- package/fesm2022/ng-primitives-toggle.mjs +32 -12
- package/fesm2022/ng-primitives-toggle.mjs.map +1 -1
- package/fesm2022/ng-primitives-tooltip.mjs +9 -9
- package/fesm2022/ng-primitives-tooltip.mjs.map +1 -1
- package/fesm2022/ng-primitives-utils.mjs +14 -20
- package/fesm2022/ng-primitives-utils.mjs.map +1 -1
- package/file-upload/file-upload/file-upload.directive.d.ts +2 -1
- package/focus-trap/README.md +3 -0
- package/focus-trap/focus-trap/focus-trap.directive.d.ts +64 -0
- package/{select/select-options/select-options.token.d.ts → focus-trap/focus-trap/focus-trap.token.d.ts} +4 -4
- package/focus-trap/index.d.ts +9 -0
- package/form-field/description/description.directive.d.ts +1 -1
- package/form-field/error/error.directive.d.ts +9 -5
- package/form-field/form-control/form-control.directive.d.ts +7 -3
- package/form-field/form-field/form-field.token.d.ts +1 -1
- package/form-field/label/label.directive.d.ts +3 -2
- package/input/README.md +3 -0
- package/input/index.d.ts +9 -0
- package/input/input/input.directive.d.ts +33 -0
- package/input/input/input.token.d.ts +14 -0
- package/interactions/focus/focus.directive.d.ts +6 -2
- package/interactions/focus-visible/focus-visible.directive.d.ts +5 -1
- package/interactions/hover/hover.directive.d.ts +5 -1
- package/interactions/index.d.ts +4 -0
- package/interactions/move/move.directive.d.ts +126 -0
- package/interactions/move/move.token.d.ts +14 -0
- package/interactions/press/press.directive.d.ts +59 -0
- package/interactions/press/press.token.d.ts +14 -0
- package/internal/README.md +3 -0
- package/internal/disabled/disabled.d.ts +21 -0
- package/internal/index.d.ts +10 -0
- package/internal/orientation/orientation.d.ts +22 -0
- package/internal/style-injector/style-injector.d.ts +36 -0
- package/package.json +49 -7
- package/radio/radio-group/radio-group.directive.d.ts +4 -41
- package/radio/radio-indicator/radio-indicator.directive.d.ts +2 -1
- package/radio/radio-item/radio-item.directive.d.ts +2 -1
- package/roving-focus/roving-focus-group/roving-focus-group.directive.d.ts +7 -2
- package/search/README.md +3 -0
- package/search/index.d.ts +9 -0
- package/search/search-field/search-field.directive.d.ts +15 -0
- package/search/search-field/search-field.token.d.ts +14 -0
- package/select/index.d.ts +0 -6
- package/select/select/select.directive.d.ts +7 -22
- package/select/select/select.token.d.ts +2 -2
- package/slider/slider/slider.directive.d.ts +4 -2
- package/slider/slider-thumb/slider-thumb.directive.d.ts +2 -1
- package/slider/slider-track/slider-track.directive.d.ts +1 -1
- package/switch/switch/switch.directive.d.ts +5 -45
- package/switch/switch-thumb/switch-thumb.directive.d.ts +2 -1
- package/tabs/tab-button/tab-button.directive.d.ts +2 -1
- package/tabs/tabset/tabset.directive.d.ts +3 -9
- package/textarea/README.md +3 -0
- package/textarea/index.d.ts +9 -0
- package/textarea/textarea/textarea.directive.d.ts +20 -0
- package/textarea/textarea/textarea.token.d.ts +14 -0
- package/toggle/toggle/toggle.directive.d.ts +16 -4
- package/utils/index.d.ts +1 -1
- package/utils/signals/async.d.ts +10 -12
- package/checkbox/checkbox-indicator/checkbox-indicator.directive.d.ts +0 -19
- package/checkbox/checkbox-indicator/checkbox-indicator.token.d.ts +0 -15
- package/checkbox/checkbox-input/checkbox-input.directive.d.ts +0 -10
- package/checkbox/checkbox-label/checkbox-label.directive.d.ts +0 -9
- package/esm2022/checkbox/checkbox-indicator/checkbox-indicator.directive.mjs +0 -51
- package/esm2022/checkbox/checkbox-indicator/checkbox-indicator.token.mjs +0 -17
- package/esm2022/checkbox/checkbox-input/checkbox-input.directive.mjs +0 -40
- package/esm2022/checkbox/checkbox-label/checkbox-label.directive.mjs +0 -32
- package/esm2022/select/select-button/select-button.directive.mjs +0 -84
- package/esm2022/select/select-button/select-button.token.mjs +0 -16
- package/esm2022/select/select-option/select-option.directive.mjs +0 -90
- package/esm2022/select/select-option/select-option.token.mjs +0 -16
- package/esm2022/select/select-options/select-options.directive.mjs +0 -157
- package/esm2022/select/select-options/select-options.token.mjs +0 -16
- package/select/select-button/select-button.directive.d.ts +0 -51
- package/select/select-option/select-option.directive.d.ts +0 -57
- package/select/select-options/select-options.directive.d.ts +0 -65
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
|
|
2
2
|
import { Directive, HostListener, Injectable, PLATFORM_ID, booleanAttribute, inject, input, output, signal, } from '@angular/core';
|
|
3
|
+
import { injectDisabled } from 'ng-primitives/internal';
|
|
3
4
|
import { NgpHoverToken } from './hover.token';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
/**
|
|
@@ -42,10 +43,10 @@ class GlobalPointerEvents {
|
|
|
42
43
|
this.setGlobalIgnoreEmulatedMouseEvents();
|
|
43
44
|
}
|
|
44
45
|
}
|
|
45
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.
|
|
46
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.
|
|
46
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: GlobalPointerEvents, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
47
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: GlobalPointerEvents, providedIn: 'root' }); }
|
|
47
48
|
}
|
|
48
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: GlobalPointerEvents, decorators: [{
|
|
49
50
|
type: Injectable,
|
|
50
51
|
args: [{
|
|
51
52
|
providedIn: 'root',
|
|
@@ -70,6 +71,10 @@ export class NgpHover {
|
|
|
70
71
|
alias: 'ngpHoverDisabled',
|
|
71
72
|
transform: booleanAttribute,
|
|
72
73
|
});
|
|
74
|
+
/**
|
|
75
|
+
* Access the disabled state from any parent.
|
|
76
|
+
*/
|
|
77
|
+
this.isDisabled = injectDisabled(this.disabled);
|
|
73
78
|
/**
|
|
74
79
|
* Store the current hover state.
|
|
75
80
|
*/
|
|
@@ -89,7 +94,7 @@ export class NgpHover {
|
|
|
89
94
|
/**
|
|
90
95
|
* Emit an event when the hover state changes.
|
|
91
96
|
*/
|
|
92
|
-
this.hoverChange = output({ alias: '
|
|
97
|
+
this.hoverChange = output({ alias: 'ngpHover' });
|
|
93
98
|
}
|
|
94
99
|
ngOnChanges(changes) {
|
|
95
100
|
if ('disabled' in changes) {
|
|
@@ -106,7 +111,7 @@ export class NgpHover {
|
|
|
106
111
|
* @param pointerType
|
|
107
112
|
*/
|
|
108
113
|
onHoverStart(event, pointerType) {
|
|
109
|
-
if (this.
|
|
114
|
+
if (this.isDisabled() ||
|
|
110
115
|
pointerType === 'touch' ||
|
|
111
116
|
this.hovered() ||
|
|
112
117
|
!event.currentTarget?.contains(event.target)) {
|
|
@@ -135,7 +140,7 @@ export class NgpHover {
|
|
|
135
140
|
this.onHoverStart(event, event.pointerType);
|
|
136
141
|
}
|
|
137
142
|
onPointerLeave(event) {
|
|
138
|
-
if (!this.
|
|
143
|
+
if (!this.isDisabled() && event.currentTarget?.contains(event.target)) {
|
|
139
144
|
this.onHoverEnd(event.pointerType);
|
|
140
145
|
}
|
|
141
146
|
}
|
|
@@ -149,14 +154,14 @@ export class NgpHover {
|
|
|
149
154
|
this.ignoreEmulatedMouseEvents = false;
|
|
150
155
|
}
|
|
151
156
|
onMouseLeave(event) {
|
|
152
|
-
if (!this.
|
|
157
|
+
if (!this.isDisabled() && event.currentTarget?.contains(event.target)) {
|
|
153
158
|
this.onHoverEnd('mouse');
|
|
154
159
|
}
|
|
155
160
|
}
|
|
156
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.
|
|
157
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.
|
|
161
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpHover, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
162
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpHover, isStandalone: true, selector: "[ngpHover]", inputs: { disabled: { classPropertyName: "disabled", publicName: "ngpHoverDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { hoverStart: "ngpHoverStart", hoverEnd: "ngpHoverEnd", hoverChange: "ngpHover" }, host: { listeners: { "pointerenter": "onPointerEnter($event)", "pointerleave": "onPointerLeave($event)", "touchstart": "onTouchStart()", "mouseenter": "onMouseEnter($event)", "mouseleave": "onMouseLeave($event)" }, properties: { "attr.data-hover": "hovered()" } }, providers: [{ provide: NgpHoverToken, useExisting: NgpHover }], exportAs: ["ngpHover"], usesOnChanges: true, ngImport: i0 }); }
|
|
158
163
|
}
|
|
159
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.
|
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpHover, decorators: [{
|
|
160
165
|
type: Directive,
|
|
161
166
|
args: [{
|
|
162
167
|
standalone: true,
|
|
@@ -183,4 +188,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
|
183
188
|
type: HostListener,
|
|
184
189
|
args: ['mouseleave', ['$event']]
|
|
185
190
|
}] } });
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover.directive.js","sourceRoot":"","sources":["../../../../../../packages/ng-primitives/interactions/src/hover/hover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright © 2024 Angular Primitives.\n * https://github.com/ng-primitives/ng-primitives\n *\n * This source code is licensed under the CC BY-ND 4.0 license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport type { BooleanInput } from '@angular/cdk/coercion';\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n  Directive,\n  HostListener,\n  Injectable,\n  OnChanges,\n  PLATFORM_ID,\n  SimpleChanges,\n  booleanAttribute,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { NgpHoverToken } from './hover.token';\n\n/**\n * We use a service here as this value is a singleton\n * and allows us to register the dom events once.\n */\n@Injectable({\n  providedIn: 'root',\n})\nclass GlobalPointerEvents {\n  /**\n   * Whether global mouse events should be ignored.\n   */\n  ignoreEmulatedMouseEvents: boolean = false;\n\n  /**\n   * Access the document.\n   */\n  private readonly document = inject(DOCUMENT);\n\n  /**\n   * Determine the platform id.\n   */\n  private readonly platformId = inject(PLATFORM_ID);\n\n  constructor() {\n    // we only want to setup events on the client\n    if (isPlatformBrowser(this.platformId)) {\n      this.setupGlobalTouchEvents();\n    }\n  }\n\n  private setupGlobalTouchEvents(): void {\n    this.document.addEventListener('pointerup', this.handleGlobalPointerEvent.bind(this));\n    this.document.addEventListener('touchend', this.setGlobalIgnoreEmulatedMouseEvents.bind(this));\n  }\n\n  private setGlobalIgnoreEmulatedMouseEvents(): void {\n    this.ignoreEmulatedMouseEvents = true;\n    // Clear globalIgnoreEmulatedMouseEvents after a short timeout. iOS fires onPointerEnter\n    // with pointerType=\"mouse\" immediately after onPointerUp and before onFocus. On other\n    // devices that don't have this quirk, we don't want to ignore a mouse hover sometime in\n    // the distant future because a user previously touched the element.\n    setTimeout(() => (this.ignoreEmulatedMouseEvents = false), 50);\n  }\n\n  private handleGlobalPointerEvent(event: PointerEvent): void {\n    if (event.pointerType === 'touch') {\n      this.setGlobalIgnoreEmulatedMouseEvents();\n    }\n  }\n}\n\n/**\n * A directive for normalizing hover events across the different browsers and devices.\n *\n * This is an Angular port of the useHover hook from\n * react-aria: https://github.com/adobe/react-spectrum/blob/main/packages/%40react-aria/interactions/src/useHover.ts\n */\n@Directive({\n  standalone: true,\n  selector: '[ngpHover]',\n  exportAs: 'ngpHover',\n  providers: [{ provide: NgpHoverToken, useExisting: NgpHover }],\n  host: {\n    '[attr.data-hover]': 'hovered()',\n  },\n})\nexport class NgpHover implements OnChanges {\n  /**\n   * Access the global pointer events handler.\n   */\n  private readonly globalPointerEvents = inject(GlobalPointerEvents);\n\n  /**\n   * Whether hoving should be disabled.\n   */\n  readonly disabled = input<boolean, BooleanInput>(false, {\n    alias: 'ngpHoverDisabled',\n    transform: booleanAttribute,\n  });\n\n  /**\n   * Store the current hover state.\n   */\n  protected hovered = signal<boolean>(false);\n\n  /**\n   * Whether this element should ignore emulated mouse events.\n   */\n  private ignoreEmulatedMouseEvents: boolean = false;\n\n  /**\n   * Emit an event when hovering starts.\n   */\n  readonly hoverStart = output<void>({ alias: 'ngpHoverStart' });\n\n  /**\n   * Emit an event when hovering ends.\n   */\n  readonly hoverEnd = output<void>({ alias: 'ngpHoverEnd' });\n\n  /**\n   * Emit an event when the hover state changes.\n   */\n  readonly hoverChange = output<boolean>({ alias: 'ngpHoverChange' });\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if ('disabled' in changes) {\n      // if the component is suddenly disabled and is currently hovered\n      // switch to the unhovered state.\n      if (changes['disabled'].currentValue === true) {\n        this.onHoverEnd('mouse');\n      }\n    }\n  }\n\n  /**\n   * Trigger the hover start events.\n   * @param event\n   * @param pointerType\n   */\n  private onHoverStart(event: Event, pointerType: string): void {\n    if (\n      this.disabled() ||\n      pointerType === 'touch' ||\n      this.hovered() ||\n      !(event.currentTarget as Element)?.contains(event.target as Element)\n    ) {\n      return;\n    }\n\n    this.hovered.set(true);\n    this.hoverStart.emit();\n    this.hoverChange.emit(true);\n  }\n\n  /**\n   * Trigger the hover end events.\n   * @param pointerType\n   */\n  private onHoverEnd(pointerType: string): void {\n    if (pointerType === 'touch' || !this.hovered()) {\n      return;\n    }\n\n    this.hovered.set(false);\n    this.hoverEnd.emit();\n    this.hoverChange.emit(false);\n  }\n\n  @HostListener('pointerenter', ['$event'])\n  protected onPointerEnter(event: PointerEvent): void {\n    if (this.globalPointerEvents.ignoreEmulatedMouseEvents && event.pointerType === 'mouse') {\n      return;\n    }\n\n    this.onHoverStart(event, event.pointerType);\n  }\n\n  @HostListener('pointerleave', ['$event'])\n  protected onPointerLeave(event: PointerEvent): void {\n    if (!this.disabled() && (event.currentTarget as Element)?.contains(event.target as Element)) {\n      this.onHoverEnd(event.pointerType);\n    }\n  }\n\n  @HostListener('touchstart')\n  protected onTouchStart(): void {\n    this.ignoreEmulatedMouseEvents = true;\n  }\n\n  @HostListener('mouseenter', ['$event'])\n  protected onMouseEnter(event: MouseEvent): void {\n    if (!this.ignoreEmulatedMouseEvents && !this.globalPointerEvents.ignoreEmulatedMouseEvents) {\n      this.onHoverStart(event, 'mouse');\n    }\n\n    this.ignoreEmulatedMouseEvents = false;\n  }\n\n  @HostListener('mouseleave', ['$event'])\n  protected onMouseLeave(event: MouseEvent): void {\n    if (!this.disabled() && (event.currentTarget as Element)?.contains(event.target as Element)) {\n      this.onHoverEnd('mouse');\n    }\n  }\n}\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover.directive.js","sourceRoot":"","sources":["../../../../../../packages/ng-primitives/interactions/src/hover/hover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright © 2024 Angular Primitives.\n * https://github.com/ng-primitives/ng-primitives\n *\n * This source code is licensed under the CC BY-ND 4.0 license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport type { BooleanInput } from '@angular/cdk/coercion';\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n  Directive,\n  HostListener,\n  Injectable,\n  OnChanges,\n  PLATFORM_ID,\n  SimpleChanges,\n  booleanAttribute,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { injectDisabled } from 'ng-primitives/internal';\nimport { NgpHoverToken } from './hover.token';\n\n/**\n * We use a service here as this value is a singleton\n * and allows us to register the dom events once.\n */\n@Injectable({\n  providedIn: 'root',\n})\nclass GlobalPointerEvents {\n  /**\n   * Whether global mouse events should be ignored.\n   */\n  ignoreEmulatedMouseEvents: boolean = false;\n\n  /**\n   * Access the document.\n   */\n  private readonly document = inject(DOCUMENT);\n\n  /**\n   * Determine the platform id.\n   */\n  private readonly platformId = inject(PLATFORM_ID);\n\n  constructor() {\n    // we only want to setup events on the client\n    if (isPlatformBrowser(this.platformId)) {\n      this.setupGlobalTouchEvents();\n    }\n  }\n\n  private setupGlobalTouchEvents(): void {\n    this.document.addEventListener('pointerup', this.handleGlobalPointerEvent.bind(this));\n    this.document.addEventListener('touchend', this.setGlobalIgnoreEmulatedMouseEvents.bind(this));\n  }\n\n  private setGlobalIgnoreEmulatedMouseEvents(): void {\n    this.ignoreEmulatedMouseEvents = true;\n    // Clear globalIgnoreEmulatedMouseEvents after a short timeout. iOS fires onPointerEnter\n    // with pointerType=\"mouse\" immediately after onPointerUp and before onFocus. On other\n    // devices that don't have this quirk, we don't want to ignore a mouse hover sometime in\n    // the distant future because a user previously touched the element.\n    setTimeout(() => (this.ignoreEmulatedMouseEvents = false), 50);\n  }\n\n  private handleGlobalPointerEvent(event: PointerEvent): void {\n    if (event.pointerType === 'touch') {\n      this.setGlobalIgnoreEmulatedMouseEvents();\n    }\n  }\n}\n\n/**\n * A directive for normalizing hover events across the different browsers and devices.\n *\n * This is an Angular port of the useHover hook from\n * react-aria: https://github.com/adobe/react-spectrum/blob/main/packages/%40react-aria/interactions/src/useHover.ts\n */\n@Directive({\n  standalone: true,\n  selector: '[ngpHover]',\n  exportAs: 'ngpHover',\n  providers: [{ provide: NgpHoverToken, useExisting: NgpHover }],\n  host: {\n    '[attr.data-hover]': 'hovered()',\n  },\n})\nexport class NgpHover implements OnChanges {\n  /**\n   * Access the global pointer events handler.\n   */\n  private readonly globalPointerEvents = inject(GlobalPointerEvents);\n\n  /**\n   * Whether hoving should be disabled.\n   */\n  readonly disabled = input<boolean, BooleanInput>(false, {\n    alias: 'ngpHoverDisabled',\n    transform: booleanAttribute,\n  });\n\n  /**\n   * Access the disabled state from any parent.\n   */\n  private readonly isDisabled = injectDisabled(this.disabled);\n\n  /**\n   * Store the current hover state.\n   */\n  protected hovered = signal<boolean>(false);\n\n  /**\n   * Whether this element should ignore emulated mouse events.\n   */\n  private ignoreEmulatedMouseEvents: boolean = false;\n\n  /**\n   * Emit an event when hovering starts.\n   */\n  readonly hoverStart = output<void>({ alias: 'ngpHoverStart' });\n\n  /**\n   * Emit an event when hovering ends.\n   */\n  readonly hoverEnd = output<void>({ alias: 'ngpHoverEnd' });\n\n  /**\n   * Emit an event when the hover state changes.\n   */\n  readonly hoverChange = output<boolean>({ alias: 'ngpHover' });\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if ('disabled' in changes) {\n      // if the component is suddenly disabled and is currently hovered\n      // switch to the unhovered state.\n      if (changes['disabled'].currentValue === true) {\n        this.onHoverEnd('mouse');\n      }\n    }\n  }\n\n  /**\n   * Trigger the hover start events.\n   * @param event\n   * @param pointerType\n   */\n  private onHoverStart(event: Event, pointerType: string): void {\n    if (\n      this.isDisabled() ||\n      pointerType === 'touch' ||\n      this.hovered() ||\n      !(event.currentTarget as Element)?.contains(event.target as Element)\n    ) {\n      return;\n    }\n\n    this.hovered.set(true);\n    this.hoverStart.emit();\n    this.hoverChange.emit(true);\n  }\n\n  /**\n   * Trigger the hover end events.\n   * @param pointerType\n   */\n  private onHoverEnd(pointerType: string): void {\n    if (pointerType === 'touch' || !this.hovered()) {\n      return;\n    }\n\n    this.hovered.set(false);\n    this.hoverEnd.emit();\n    this.hoverChange.emit(false);\n  }\n\n  @HostListener('pointerenter', ['$event'])\n  protected onPointerEnter(event: PointerEvent): void {\n    if (this.globalPointerEvents.ignoreEmulatedMouseEvents && event.pointerType === 'mouse') {\n      return;\n    }\n\n    this.onHoverStart(event, event.pointerType);\n  }\n\n  @HostListener('pointerleave', ['$event'])\n  protected onPointerLeave(event: PointerEvent): void {\n    if (!this.isDisabled() && (event.currentTarget as Element)?.contains(event.target as Element)) {\n      this.onHoverEnd(event.pointerType);\n    }\n  }\n\n  @HostListener('touchstart')\n  protected onTouchStart(): void {\n    this.ignoreEmulatedMouseEvents = true;\n  }\n\n  @HostListener('mouseenter', ['$event'])\n  protected onMouseEnter(event: MouseEvent): void {\n    if (!this.ignoreEmulatedMouseEvents && !this.globalPointerEvents.ignoreEmulatedMouseEvents) {\n      this.onHoverStart(event, 'mouse');\n    }\n\n    this.ignoreEmulatedMouseEvents = false;\n  }\n\n  @HostListener('mouseleave', ['$event'])\n  protected onMouseLeave(event: MouseEvent): void {\n    if (!this.isDisabled() && (event.currentTarget as Element)?.contains(event.target as Element)) {\n      this.onHoverEnd('mouse');\n    }\n  }\n}\n"]}
|
|
@@ -11,4 +11,8 @@ export { NgpFocus } from './focus/focus.directive';
|
|
|
11
11
|
export { NgpFocusToken } from './focus/focus.token';
|
|
12
12
|
export { NgpFocusVisible } from './focus-visible/focus-visible.directive';
|
|
13
13
|
export { NgpFocusVisibleToken } from './focus-visible/focus-visible.token';
|
|
14
|
-
|
|
14
|
+
export { NgpPress } from './press/press.directive';
|
|
15
|
+
export { NgpPressToken } from './press/press.token';
|
|
16
|
+
export { NgpMove } from './move/move.directive';
|
|
17
|
+
export { NgpMoveToken } from './move/move.token';
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy1wcmltaXRpdmVzL2ludGVyYWN0aW9ucy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDM0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDaEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgwqkgMjAyNCBBbmd1bGFyIFByaW1pdGl2ZXMuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vbmctcHJpbWl0aXZlcy9uZy1wcmltaXRpdmVzXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgQ0MgQlktTkQgNC4wIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cblxuZXhwb3J0IHsgTmdwSG92ZXIgfSBmcm9tICcuL2hvdmVyL2hvdmVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBOZ3BIb3ZlclRva2VuLCBpbmplY3RIb3ZlciB9IGZyb20gJy4vaG92ZXIvaG92ZXIudG9rZW4nO1xuZXhwb3J0IHsgTmdwRm9jdXMgfSBmcm9tICcuL2ZvY3VzL2ZvY3VzLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBOZ3BGb2N1c1Rva2VuIH0gZnJvbSAnLi9mb2N1cy9mb2N1cy50b2tlbic7XG5leHBvcnQgeyBOZ3BGb2N1c1Zpc2libGUgfSBmcm9tICcuL2ZvY3VzLXZpc2libGUvZm9jdXMtdmlzaWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgTmdwRm9jdXNWaXNpYmxlVG9rZW4gfSBmcm9tICcuL2ZvY3VzLXZpc2libGUvZm9jdXMtdmlzaWJsZS50b2tlbic7XG5leHBvcnQgeyBOZ3BQcmVzcyB9IGZyb20gJy4vcHJlc3MvcHJlc3MuZGlyZWN0aXZlJztcbmV4cG9ydCB7IE5ncFByZXNzVG9rZW4gfSBmcm9tICcuL3ByZXNzL3ByZXNzLnRva2VuJztcbmV4cG9ydCB7IE5ncE1vdmUgfSBmcm9tICcuL21vdmUvbW92ZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgTmdwTW92ZVRva2VuIH0gZnJvbSAnLi9tb3ZlL21vdmUudG9rZW4nO1xuIl19
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
import { booleanAttribute, Directive, HostListener, input, output, signal } from '@angular/core';
|
|
2
|
+
import { injectDisabled } from 'ng-primitives/internal';
|
|
3
|
+
import { injectDisposables } from 'ng-primitives/utils';
|
|
4
|
+
import { NgpMoveToken } from './move.token';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* Inspired by react-aria useMove hook:
|
|
8
|
+
* https://github.com/adobe/react-spectrum/blob/main/packages/%40react-aria/interactions/src/useMove.ts
|
|
9
|
+
*/
|
|
10
|
+
export class NgpMove {
|
|
11
|
+
constructor() {
|
|
12
|
+
/**
|
|
13
|
+
* Access the disposable helper.
|
|
14
|
+
*/
|
|
15
|
+
this.disposables = injectDisposables();
|
|
16
|
+
/**
|
|
17
|
+
* Whether movement is disabled.
|
|
18
|
+
*/
|
|
19
|
+
this.disabled = input(false, {
|
|
20
|
+
alias: 'ngpMoveDisabled',
|
|
21
|
+
transform: booleanAttribute,
|
|
22
|
+
});
|
|
23
|
+
/**
|
|
24
|
+
* Access the disabled state from any parent.
|
|
25
|
+
*/
|
|
26
|
+
this.isDisabled = injectDisabled(this.disabled);
|
|
27
|
+
/**
|
|
28
|
+
* Emit when the move event begins.
|
|
29
|
+
*/
|
|
30
|
+
this.start = output({
|
|
31
|
+
alias: 'ngpMoveStart',
|
|
32
|
+
});
|
|
33
|
+
/**
|
|
34
|
+
* Emit when the element is moved.
|
|
35
|
+
*/
|
|
36
|
+
this.move = output({
|
|
37
|
+
alias: 'ngpMove',
|
|
38
|
+
});
|
|
39
|
+
/**
|
|
40
|
+
* Emit when the move event ends.
|
|
41
|
+
*/
|
|
42
|
+
this.end = output({
|
|
43
|
+
alias: 'ngpMoveEnd',
|
|
44
|
+
});
|
|
45
|
+
/**
|
|
46
|
+
* Whether the element is currently being moved.
|
|
47
|
+
*/
|
|
48
|
+
this.isMoving = signal(false);
|
|
49
|
+
/**
|
|
50
|
+
* Store the last x position of the element.
|
|
51
|
+
*/
|
|
52
|
+
this.x = null;
|
|
53
|
+
/**
|
|
54
|
+
* Store the last y position of the element.
|
|
55
|
+
*/
|
|
56
|
+
this.y = null;
|
|
57
|
+
/**
|
|
58
|
+
* Store the id of the last pointer.
|
|
59
|
+
*/
|
|
60
|
+
this.pointerId = null;
|
|
61
|
+
/**
|
|
62
|
+
* Store the disposable event listeners.
|
|
63
|
+
*/
|
|
64
|
+
this.disposableListeners = [];
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Handle a move start.
|
|
68
|
+
*/
|
|
69
|
+
onMoveStart(event, pointerType) {
|
|
70
|
+
this.start.emit({
|
|
71
|
+
pointerType,
|
|
72
|
+
shiftKey: event.shiftKey,
|
|
73
|
+
ctrlKey: event.ctrlKey,
|
|
74
|
+
metaKey: event.metaKey,
|
|
75
|
+
altKey: event.altKey,
|
|
76
|
+
});
|
|
77
|
+
this.isMoving.set(true);
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Handle a move event.
|
|
81
|
+
*/
|
|
82
|
+
onMove(event, pointerType, deltaX, deltaY) {
|
|
83
|
+
if (deltaX === 0 && deltaY === 0) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
this.move.emit({
|
|
87
|
+
deltaX,
|
|
88
|
+
deltaY,
|
|
89
|
+
pointerType,
|
|
90
|
+
shiftKey: event.shiftKey,
|
|
91
|
+
ctrlKey: event.ctrlKey,
|
|
92
|
+
metaKey: event.metaKey,
|
|
93
|
+
altKey: event.altKey,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Handle a move end.
|
|
98
|
+
*/
|
|
99
|
+
onMoveEnd(event, pointerType) {
|
|
100
|
+
this.end.emit({
|
|
101
|
+
pointerType,
|
|
102
|
+
shiftKey: event.shiftKey,
|
|
103
|
+
ctrlKey: event.ctrlKey,
|
|
104
|
+
metaKey: event.metaKey,
|
|
105
|
+
altKey: event.altKey,
|
|
106
|
+
});
|
|
107
|
+
this.isMoving.set(false);
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Handle the pointer down event.
|
|
111
|
+
*/
|
|
112
|
+
onPointerDown(event) {
|
|
113
|
+
// ignore right-click or additional pointers
|
|
114
|
+
if (event.button !== 0 || this.pointerId !== null || this.isDisabled()) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
// prevent the default behavior
|
|
118
|
+
event.preventDefault();
|
|
119
|
+
event.stopPropagation();
|
|
120
|
+
this.onMoveStart(event, event.pointerType);
|
|
121
|
+
// store the pointer id and initial position
|
|
122
|
+
this.pointerId = event.pointerId;
|
|
123
|
+
this.x = event.pageX;
|
|
124
|
+
this.y = event.pageY;
|
|
125
|
+
// add global event listeners
|
|
126
|
+
const pointerMove = this.disposables.addEventListener(window, 'pointermove', this.onPointerMove.bind(this), false);
|
|
127
|
+
const pointerUp = this.disposables.addEventListener(window, 'pointerup', this.onPointerUp.bind(this), false);
|
|
128
|
+
const pointerCancel = this.disposables.addEventListener(window, 'pointercancel', this.onPointerUp.bind(this), false);
|
|
129
|
+
// store the disposable event listeners
|
|
130
|
+
this.disposableListeners = [pointerMove, pointerUp, pointerCancel];
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Handle the pointer up event.
|
|
134
|
+
*/
|
|
135
|
+
onPointerUp(event) {
|
|
136
|
+
if (this.pointerId !== event.pointerId) {
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
const pointerType = (event.pointerType ?? 'mouse');
|
|
140
|
+
this.onMoveEnd(event, pointerType);
|
|
141
|
+
this.pointerId = null;
|
|
142
|
+
this.disposableListeners.forEach(dispose => dispose());
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Handle the pointer move event.
|
|
146
|
+
*/
|
|
147
|
+
onPointerMove(event) {
|
|
148
|
+
if (this.pointerId !== event.pointerId) {
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
// Problems with PointerEvent#movementX/movementY:
|
|
152
|
+
// 1. it is always 0 on macOS Safari.
|
|
153
|
+
// 2. On Chrome Android, it's scaled by devicePixelRatio, but not on Chrome macOS
|
|
154
|
+
this.onMove(event, event.pointerType, event.pageX - (this.x ?? 0), event.pageY - (this.y ?? 0));
|
|
155
|
+
this.x = event.pageX;
|
|
156
|
+
this.y = event.pageY;
|
|
157
|
+
}
|
|
158
|
+
triggerKeyboardMove(event, deltaX, deltaY) {
|
|
159
|
+
if (this.isDisabled()) {
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
this.onMoveStart(event, 'keyboard');
|
|
163
|
+
this.onMove(event, 'keyboard', deltaX, deltaY);
|
|
164
|
+
this.onMoveEnd(event, 'keyboard');
|
|
165
|
+
}
|
|
166
|
+
onArrowUp(event) {
|
|
167
|
+
event.preventDefault();
|
|
168
|
+
event.stopPropagation();
|
|
169
|
+
this.triggerKeyboardMove(event, 0, -1);
|
|
170
|
+
}
|
|
171
|
+
onArrowDown(event) {
|
|
172
|
+
event.preventDefault();
|
|
173
|
+
event.stopPropagation();
|
|
174
|
+
this.triggerKeyboardMove(event, 0, 1);
|
|
175
|
+
}
|
|
176
|
+
onArrowLeft(event) {
|
|
177
|
+
event.preventDefault();
|
|
178
|
+
event.stopPropagation();
|
|
179
|
+
this.triggerKeyboardMove(event, -1, 0);
|
|
180
|
+
}
|
|
181
|
+
onArrowRight(event) {
|
|
182
|
+
event.preventDefault();
|
|
183
|
+
event.stopPropagation();
|
|
184
|
+
this.triggerKeyboardMove(event, 1, 0);
|
|
185
|
+
}
|
|
186
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpMove, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
187
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpMove, isStandalone: true, selector: "[ngpMove]", inputs: { disabled: { classPropertyName: "disabled", publicName: "ngpMoveDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { start: "ngpMoveStart", move: "ngpMove", end: "ngpMoveEnd" }, host: { listeners: { "pointerdown": "onPointerDown($event)", "keydown.ArrowUp": "onArrowUp($event)", "keydown.ArrowDown": "onArrowDown($event)", "keydown.ArrowLeft": "onArrowLeft($event)", "keydown.ArrowRight": "onArrowRight($event)" }, properties: { "attr.data-move": "isMoving()" } }, providers: [{ provide: NgpMoveToken, useExisting: NgpMove }], exportAs: ["ngpMove"], ngImport: i0 }); }
|
|
188
|
+
}
|
|
189
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpMove, decorators: [{
|
|
190
|
+
type: Directive,
|
|
191
|
+
args: [{
|
|
192
|
+
standalone: true,
|
|
193
|
+
selector: '[ngpMove]',
|
|
194
|
+
exportAs: 'ngpMove',
|
|
195
|
+
providers: [{ provide: NgpMoveToken, useExisting: NgpMove }],
|
|
196
|
+
host: {
|
|
197
|
+
'[attr.data-move]': 'isMoving()',
|
|
198
|
+
},
|
|
199
|
+
}]
|
|
200
|
+
}], propDecorators: { onPointerDown: [{
|
|
201
|
+
type: HostListener,
|
|
202
|
+
args: ['pointerdown', ['$event']]
|
|
203
|
+
}], onArrowUp: [{
|
|
204
|
+
type: HostListener,
|
|
205
|
+
args: ['keydown.ArrowUp', ['$event']]
|
|
206
|
+
}], onArrowDown: [{
|
|
207
|
+
type: HostListener,
|
|
208
|
+
args: ['keydown.ArrowDown', ['$event']]
|
|
209
|
+
}], onArrowLeft: [{
|
|
210
|
+
type: HostListener,
|
|
211
|
+
args: ['keydown.ArrowLeft', ['$event']]
|
|
212
|
+
}], onArrowRight: [{
|
|
213
|
+
type: HostListener,
|
|
214
|
+
args: ['keydown.ArrowRight', ['$event']]
|
|
215
|
+
}] } });
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"move.directive.js","sourceRoot":"","sources":["../../../../../../packages/ng-primitives/interactions/src/move/move.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright © 2024 Angular Primitives.\n * https://github.com/ng-primitives/ng-primitives\n *\n * This source code is licensed under the CC BY-ND 4.0 license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport { booleanAttribute, Directive, HostListener, input, output, signal } from '@angular/core';\nimport { injectDisabled } from 'ng-primitives/internal';\nimport { injectDisposables } from 'ng-primitives/utils';\nimport { NgpMoveToken } from './move.token';\n\n/**\n * Inspired by react-aria useMove hook:\n * https://github.com/adobe/react-spectrum/blob/main/packages/%40react-aria/interactions/src/useMove.ts\n */\n\n@Directive({\n  standalone: true,\n  selector: '[ngpMove]',\n  exportAs: 'ngpMove',\n  providers: [{ provide: NgpMoveToken, useExisting: NgpMove }],\n  host: {\n    '[attr.data-move]': 'isMoving()',\n  },\n})\nexport class NgpMove {\n  /**\n   * Access the disposable helper.\n   */\n  private readonly disposables = injectDisposables();\n\n  /**\n   * Whether movement is disabled.\n   */\n  readonly disabled = input<boolean, BooleanInput>(false, {\n    alias: 'ngpMoveDisabled',\n    transform: booleanAttribute,\n  });\n\n  /**\n   * Access the disabled state from any parent.\n   */\n  private readonly isDisabled = injectDisabled(this.disabled);\n\n  /**\n   * Emit when the move event begins.\n   */\n  readonly start = output<NgpMoveStartEvent>({\n    alias: 'ngpMoveStart',\n  });\n\n  /**\n   * Emit when the element is moved.\n   */\n  readonly move = output<NgpMoveEvent>({\n    alias: 'ngpMove',\n  });\n\n  /**\n   * Emit when the move event ends.\n   */\n  readonly end = output<NgpMoveEndEvent>({\n    alias: 'ngpMoveEnd',\n  });\n\n  /**\n   * Whether the element is currently being moved.\n   */\n  private isMoving = signal<boolean>(false);\n\n  /**\n   * Store the last x position of the element.\n   */\n  private x: number | null = null;\n\n  /**\n   * Store the last y position of the element.\n   */\n  private y: number | null = null;\n\n  /**\n   * Store the id of the last pointer.\n   */\n  private pointerId: number | null = null;\n\n  /**\n   * Store the disposable event listeners.\n   */\n  private disposableListeners: (() => void)[] = [];\n\n  /**\n   * Handle a move start.\n   */\n  private onMoveStart(event: PointerEvent | KeyboardEvent, pointerType: PointerType): void {\n    this.start.emit({\n      pointerType,\n      shiftKey: event.shiftKey,\n      ctrlKey: event.ctrlKey,\n      metaKey: event.metaKey,\n      altKey: event.altKey,\n    });\n    this.isMoving.set(true);\n  }\n\n  /**\n   * Handle a move event.\n   */\n  private onMove(\n    event: PointerEvent | KeyboardEvent,\n    pointerType: PointerType,\n    deltaX: number,\n    deltaY: number,\n  ): void {\n    if (deltaX === 0 && deltaY === 0) {\n      return;\n    }\n\n    this.move.emit({\n      deltaX,\n      deltaY,\n      pointerType,\n      shiftKey: event.shiftKey,\n      ctrlKey: event.ctrlKey,\n      metaKey: event.metaKey,\n      altKey: event.altKey,\n    });\n  }\n\n  /**\n   * Handle a move end.\n   */\n  private onMoveEnd(event: PointerEvent | KeyboardEvent, pointerType: PointerType): void {\n    this.end.emit({\n      pointerType,\n      shiftKey: event.shiftKey,\n      ctrlKey: event.ctrlKey,\n      metaKey: event.metaKey,\n      altKey: event.altKey,\n    });\n    this.isMoving.set(false);\n  }\n\n  /**\n   * Handle the pointer down event.\n   */\n  @HostListener('pointerdown', ['$event'])\n  protected onPointerDown(event: PointerEvent): void {\n    // ignore right-click or additional pointers\n    if (event.button !== 0 || this.pointerId !== null || this.isDisabled()) {\n      return;\n    }\n\n    // prevent the default behavior\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.onMoveStart(event, event.pointerType as PointerType);\n\n    // store the pointer id and initial position\n    this.pointerId = event.pointerId;\n    this.x = event.pageX;\n    this.y = event.pageY;\n\n    // add global event listeners\n    const pointerMove = this.disposables.addEventListener(\n      window,\n      'pointermove',\n      this.onPointerMove.bind(this) as EventListener,\n      false,\n    );\n\n    const pointerUp = this.disposables.addEventListener(\n      window,\n      'pointerup',\n      this.onPointerUp.bind(this) as EventListener,\n      false,\n    );\n\n    const pointerCancel = this.disposables.addEventListener(\n      window,\n      'pointercancel',\n      this.onPointerUp.bind(this) as EventListener,\n      false,\n    );\n\n    // store the disposable event listeners\n    this.disposableListeners = [pointerMove, pointerUp, pointerCancel];\n  }\n\n  /**\n   * Handle the pointer up event.\n   */\n  protected onPointerUp(event: PointerEvent): void {\n    if (this.pointerId !== event.pointerId) {\n      return;\n    }\n\n    const pointerType = (event.pointerType ?? 'mouse') as PointerType;\n    this.onMoveEnd(event, pointerType);\n    this.pointerId = null;\n    this.disposableListeners.forEach(dispose => dispose());\n  }\n\n  /**\n   * Handle the pointer move event.\n   */\n  protected onPointerMove(event: PointerEvent): void {\n    if (this.pointerId !== event.pointerId) {\n      return;\n    }\n\n    // Problems with PointerEvent#movementX/movementY:\n    // 1. it is always 0 on macOS Safari.\n    // 2. On Chrome Android, it's scaled by devicePixelRatio, but not on Chrome macOS\n    this.onMove(\n      event,\n      event.pointerType as PointerType,\n      event.pageX - (this.x ?? 0),\n      event.pageY - (this.y ?? 0),\n    );\n    this.x = event.pageX;\n    this.y = event.pageY;\n  }\n\n  private triggerKeyboardMove(event: KeyboardEvent, deltaX: number, deltaY: number): void {\n    if (this.isDisabled()) {\n      return;\n    }\n\n    this.onMoveStart(event, 'keyboard');\n    this.onMove(event, 'keyboard', deltaX, deltaY);\n    this.onMoveEnd(event, 'keyboard');\n  }\n\n  @HostListener('keydown.ArrowUp', ['$event'])\n  protected onArrowUp(event: KeyboardEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.triggerKeyboardMove(event, 0, -1);\n  }\n\n  @HostListener('keydown.ArrowDown', ['$event'])\n  protected onArrowDown(event: KeyboardEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.triggerKeyboardMove(event, 0, 1);\n  }\n\n  @HostListener('keydown.ArrowLeft', ['$event'])\n  protected onArrowLeft(event: KeyboardEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.triggerKeyboardMove(event, -1, 0);\n  }\n\n  @HostListener('keydown.ArrowRight', ['$event'])\n  protected onArrowRight(event: KeyboardEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.triggerKeyboardMove(event, 1, 0);\n  }\n}\n\ninterface NgpMoveBaseEvent {\n  /**\n   * Whether the event was triggered by a mouse or keyboard event.\n   */\n  pointerType: PointerType;\n  /**\n   * Whether the shift key was pressed during the event.\n   */\n  shiftKey: boolean;\n  /**\n   * Whether the control key was pressed during the event.\n   */\n  ctrlKey: boolean;\n  /**\n   * Whether the meta key was pressed during the event.\n   */\n  metaKey: boolean;\n  /**\n   * Whether the alt key was pressed during the event.\n   */\n  altKey: boolean;\n}\n\nexport type NgpMoveStartEvent = NgpMoveBaseEvent;\nexport type NgpMoveEndEvent = NgpMoveBaseEvent;\n\nexport interface NgpMoveEvent extends NgpMoveBaseEvent {\n  /**\n   * The amount of pixels moved in the x-axis.\n   */\n  deltaX: number;\n  /**\n   * The amount of pixels moved in the y-axis.\n   */\n  deltaY: number;\n}\n\nexport type PointerType = 'mouse' | 'pen' | 'touch' | 'keyboard' | 'virtual';\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the CC BY-ND 4.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { InjectionToken, inject } from '@angular/core';
|
|
9
|
+
export const NgpMoveToken = new InjectionToken('NgpMoveToken');
|
|
10
|
+
/**
|
|
11
|
+
* Inject the Move directive instance
|
|
12
|
+
*/
|
|
13
|
+
export function injectMove() {
|
|
14
|
+
return inject(NgpMoveToken);
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92ZS50b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25nLXByaW1pdGl2ZXMvaW50ZXJhY3Rpb25zL3NyYy9tb3ZlL21vdmUudG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBQ0gsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkQsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLElBQUksY0FBYyxDQUFVLGNBQWMsQ0FBQyxDQUFDO0FBRXhFOztHQUVHO0FBQ0gsTUFBTSxVQUFVLFVBQVU7SUFDeEIsT0FBTyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7QUFDOUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IMKpIDIwMjQgQW5ndWxhciBQcmltaXRpdmVzLlxuICogaHR0cHM6Ly9naXRodWIuY29tL25nLXByaW1pdGl2ZXMvbmctcHJpbWl0aXZlc1xuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIENDIEJZLU5EIDQuMCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5pbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7IE5ncE1vdmUgfSBmcm9tICcuL21vdmUuZGlyZWN0aXZlJztcblxuZXhwb3J0IGNvbnN0IE5ncE1vdmVUb2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxOZ3BNb3ZlPignTmdwTW92ZVRva2VuJyk7XG5cbi8qKlxuICogSW5qZWN0IHRoZSBNb3ZlIGRpcmVjdGl2ZSBpbnN0YW5jZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0TW92ZSgpOiBOZ3BNb3ZlIHtcbiAgcmV0dXJuIGluamVjdChOZ3BNb3ZlVG9rZW4pO1xufVxuIl19
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostListener, booleanAttribute, inject, input, output, signal, } from '@angular/core';
|
|
2
|
+
import { injectDisabled } from 'ng-primitives/internal';
|
|
3
|
+
import { injectDisposables } from 'ng-primitives/utils';
|
|
4
|
+
import { NgpPressToken } from './press.token';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* This was inpsired by Headless UI's active-press hook:
|
|
8
|
+
* https://github.com/tailwindlabs/headlessui/blob/main/packages/%40headlessui-react/src/hooks/use-active-press.tsx
|
|
9
|
+
*/
|
|
10
|
+
export class NgpPress {
|
|
11
|
+
constructor() {
|
|
12
|
+
/**
|
|
13
|
+
* Access the HTML Element.
|
|
14
|
+
*/
|
|
15
|
+
this.element = inject(ElementRef);
|
|
16
|
+
/**
|
|
17
|
+
* Access the disposables.
|
|
18
|
+
*/
|
|
19
|
+
this.disposables = injectDisposables();
|
|
20
|
+
/**
|
|
21
|
+
* Whether listening for press events is disabled.
|
|
22
|
+
*/
|
|
23
|
+
this.disabled = input(false, {
|
|
24
|
+
alias: 'ngpPressDisabled',
|
|
25
|
+
transform: booleanAttribute,
|
|
26
|
+
});
|
|
27
|
+
/**
|
|
28
|
+
* Access the disabled state from any parent.
|
|
29
|
+
*/
|
|
30
|
+
this.isDisabled = injectDisabled(this.disabled);
|
|
31
|
+
/**
|
|
32
|
+
* Emit when the press begins.
|
|
33
|
+
*/
|
|
34
|
+
this.pressStart = output({
|
|
35
|
+
alias: 'ngpPressStart',
|
|
36
|
+
});
|
|
37
|
+
/**
|
|
38
|
+
* Emit when the press ends.
|
|
39
|
+
*/
|
|
40
|
+
this.pressEnd = output({
|
|
41
|
+
alias: 'ngpPressEnd',
|
|
42
|
+
});
|
|
43
|
+
/**
|
|
44
|
+
* Emit when the press changes.
|
|
45
|
+
*/
|
|
46
|
+
this.pressChange = output({
|
|
47
|
+
alias: 'ngpPress',
|
|
48
|
+
});
|
|
49
|
+
/**
|
|
50
|
+
* The press state.
|
|
51
|
+
*/
|
|
52
|
+
this.pressed = signal(false);
|
|
53
|
+
/**
|
|
54
|
+
* Store the list of disposables.
|
|
55
|
+
*/
|
|
56
|
+
this.disposableListeners = [];
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Reset the press state.
|
|
60
|
+
*/
|
|
61
|
+
reset() {
|
|
62
|
+
// if we are not pressing, then do nothing
|
|
63
|
+
if (!this.pressed()) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
// clear any existing disposables
|
|
67
|
+
this.disposableListeners.forEach(dispose => dispose());
|
|
68
|
+
this.pressed.set(false);
|
|
69
|
+
this.pressEnd.emit();
|
|
70
|
+
this.pressChange.emit(false);
|
|
71
|
+
}
|
|
72
|
+
onPointerDown() {
|
|
73
|
+
if (this.isDisabled()) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
// clear any existing disposables
|
|
77
|
+
this.disposableListeners.forEach(dispose => dispose());
|
|
78
|
+
// update the press state
|
|
79
|
+
this.pressed.set(true);
|
|
80
|
+
this.pressStart.emit();
|
|
81
|
+
this.pressChange.emit(true);
|
|
82
|
+
// setup global event listeners to catch events on elements outside the directive
|
|
83
|
+
const ownerDocument = this.element.nativeElement.ownerDocument ?? document;
|
|
84
|
+
// if the pointer up event happens on any elements, then we are no longer pressing on this element
|
|
85
|
+
const pointerUp = this.disposables.addEventListener(ownerDocument, 'pointerup', this.reset.bind(this), false);
|
|
86
|
+
// Instead of relying on the `pointerleave` event, which is not consistently called on iOS Safari,
|
|
87
|
+
// we use the `pointermove` event to determine if we are still "pressing".
|
|
88
|
+
// By checking if the target is still within the element, we can determine if the press is ongoing.
|
|
89
|
+
const pointerMove = this.disposables.addEventListener(ownerDocument, 'pointermove', this.onPointerMove.bind(this), false);
|
|
90
|
+
// if the pointer is cancelled, then we are no longer pressing on this element
|
|
91
|
+
const pointerCancel = this.disposables.addEventListener(ownerDocument, 'pointercancel', this.reset.bind(this), false);
|
|
92
|
+
this.disposableListeners = [pointerUp, pointerMove, pointerCancel];
|
|
93
|
+
}
|
|
94
|
+
onPointerMove(event) {
|
|
95
|
+
if (this.element.nativeElement !== event.target &&
|
|
96
|
+
!this.element.nativeElement.contains(event.target)) {
|
|
97
|
+
this.reset();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpPress, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
101
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpPress, isStandalone: true, selector: "[ngpPress]", inputs: { disabled: { classPropertyName: "disabled", publicName: "ngpPressDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { pressStart: "ngpPressStart", pressEnd: "ngpPressEnd", pressChange: "ngpPress" }, host: { listeners: { "pointerdown": "onPointerDown()" }, properties: { "attr.data-press": "pressed()" } }, providers: [{ provide: NgpPressToken, useExisting: NgpPress }], exportAs: ["ngpPress"], ngImport: i0 }); }
|
|
102
|
+
}
|
|
103
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpPress, decorators: [{
|
|
104
|
+
type: Directive,
|
|
105
|
+
args: [{
|
|
106
|
+
standalone: true,
|
|
107
|
+
selector: '[ngpPress]',
|
|
108
|
+
exportAs: 'ngpPress',
|
|
109
|
+
providers: [{ provide: NgpPressToken, useExisting: NgpPress }],
|
|
110
|
+
host: {
|
|
111
|
+
'[attr.data-press]': 'pressed()',
|
|
112
|
+
},
|
|
113
|
+
}]
|
|
114
|
+
}], propDecorators: { onPointerDown: [{
|
|
115
|
+
type: HostListener,
|
|
116
|
+
args: ['pointerdown']
|
|
117
|
+
}] } });
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"press.directive.js","sourceRoot":"","sources":["../../../../../../packages/ng-primitives/interactions/src/press/press.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright © 2024 Angular Primitives.\n * https://github.com/ng-primitives/ng-primitives\n *\n * This source code is licensed under the CC BY-ND 4.0 license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport {\n  Directive,\n  ElementRef,\n  HostListener,\n  booleanAttribute,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { injectDisabled } from 'ng-primitives/internal';\nimport { injectDisposables } from 'ng-primitives/utils';\nimport { NgpPressToken } from './press.token';\n\n/**\n * This was inpsired by Headless UI's active-press hook:\n * https://github.com/tailwindlabs/headlessui/blob/main/packages/%40headlessui-react/src/hooks/use-active-press.tsx\n */\n\n@Directive({\n  standalone: true,\n  selector: '[ngpPress]',\n  exportAs: 'ngpPress',\n  providers: [{ provide: NgpPressToken, useExisting: NgpPress }],\n  host: {\n    '[attr.data-press]': 'pressed()',\n  },\n})\nexport class NgpPress {\n  /**\n   * Access the HTML Element.\n   */\n  private readonly element = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  /**\n   * Access the disposables.\n   */\n  private readonly disposables = injectDisposables();\n\n  /**\n   * Whether listening for press events is disabled.\n   */\n  readonly disabled = input<boolean, BooleanInput>(false, {\n    alias: 'ngpPressDisabled',\n    transform: booleanAttribute,\n  });\n\n  /**\n   * Access the disabled state from any parent.\n   */\n  private readonly isDisabled = injectDisabled(this.disabled);\n\n  /**\n   * Emit when the press begins.\n   */\n  readonly pressStart = output<void>({\n    alias: 'ngpPressStart',\n  });\n\n  /**\n   * Emit when the press ends.\n   */\n  readonly pressEnd = output<void>({\n    alias: 'ngpPressEnd',\n  });\n\n  /**\n   * Emit when the press changes.\n   */\n  readonly pressChange = output<boolean>({\n    alias: 'ngpPress',\n  });\n\n  /**\n   * The press state.\n   */\n  protected readonly pressed = signal(false);\n\n  /**\n   * Reset the press state.\n   */\n  private reset(): void {\n    // if we are not pressing, then do nothing\n    if (!this.pressed()) {\n      return;\n    }\n\n    // clear any existing disposables\n    this.disposableListeners.forEach(dispose => dispose());\n    this.pressed.set(false);\n    this.pressEnd.emit();\n    this.pressChange.emit(false);\n  }\n\n  /**\n   * Store the list of disposables.\n   */\n  private disposableListeners: (() => void)[] = [];\n\n  @HostListener('pointerdown')\n  protected onPointerDown(): void {\n    if (this.isDisabled()) {\n      return;\n    }\n\n    // clear any existing disposables\n    this.disposableListeners.forEach(dispose => dispose());\n\n    // update the press state\n    this.pressed.set(true);\n    this.pressStart.emit();\n    this.pressChange.emit(true);\n\n    // setup global event listeners to catch events on elements outside the directive\n    const ownerDocument = this.element.nativeElement.ownerDocument ?? document;\n\n    // if the pointer up event happens on any elements, then we are no longer pressing on this element\n    const pointerUp = this.disposables.addEventListener(\n      ownerDocument,\n      'pointerup',\n      this.reset.bind(this),\n      false,\n    );\n\n    // Instead of relying on the `pointerleave` event, which is not consistently called on iOS Safari,\n    // we use the `pointermove` event to determine if we are still \"pressing\".\n    // By checking if the target is still within the element, we can determine if the press is ongoing.\n    const pointerMove = this.disposables.addEventListener(\n      ownerDocument,\n      'pointermove',\n      this.onPointerMove.bind(this) as EventListener,\n      false,\n    );\n\n    // if the pointer is cancelled, then we are no longer pressing on this element\n    const pointerCancel = this.disposables.addEventListener(\n      ownerDocument,\n      'pointercancel',\n      this.reset.bind(this),\n      false,\n    );\n\n    this.disposableListeners = [pointerUp, pointerMove, pointerCancel];\n  }\n\n  private onPointerMove(event: PointerEvent): void {\n    if (\n      this.element.nativeElement !== event.target &&\n      !this.element.nativeElement.contains(event.target as Node)\n    ) {\n      this.reset();\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the CC BY-ND 4.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { InjectionToken, inject } from '@angular/core';
|
|
9
|
+
export const NgpPressToken = new InjectionToken('NgpPressToken');
|
|
10
|
+
/**
|
|
11
|
+
* Inject the Press directive instance
|
|
12
|
+
*/
|
|
13
|
+
export function injectPress() {
|
|
14
|
+
return inject(NgpPressToken);
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlc3MudG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy1wcmltaXRpdmVzL2ludGVyYWN0aW9ucy9zcmMvcHJlc3MvcHJlc3MudG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBQ0gsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLElBQUksY0FBYyxDQUFXLGVBQWUsQ0FBQyxDQUFDO0FBRTNFOztHQUVHO0FBQ0gsTUFBTSxVQUFVLFdBQVc7SUFDekIsT0FBTyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDL0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IMKpIDIwMjQgQW5ndWxhciBQcmltaXRpdmVzLlxuICogaHR0cHM6Ly9naXRodWIuY29tL25nLXByaW1pdGl2ZXMvbmctcHJpbWl0aXZlc1xuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIENDIEJZLU5EIDQuMCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5pbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7IE5ncFByZXNzIH0gZnJvbSAnLi9wcmVzcy5kaXJlY3RpdmUnO1xuXG5leHBvcnQgY29uc3QgTmdwUHJlc3NUb2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxOZ3BQcmVzcz4oJ05ncFByZXNzVG9rZW4nKTtcblxuLyoqXG4gKiBJbmplY3QgdGhlIFByZXNzIGRpcmVjdGl2ZSBpbnN0YW5jZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0UHJlc3MoKTogTmdwUHJlc3Mge1xuICByZXR1cm4gaW5qZWN0KE5ncFByZXNzVG9rZW4pO1xufVxuIl19
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the CC BY-ND 4.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { inject, InjectionToken, signal } from '@angular/core';
|
|
9
|
+
export const NgpDisabledToken = new InjectionToken('NgpDisabledToken');
|
|
10
|
+
/**
|
|
11
|
+
* Determine if we are in a disabled context.
|
|
12
|
+
* @param disabled The disabled signal for the local context.
|
|
13
|
+
* @returns The disabled signal.
|
|
14
|
+
*/
|
|
15
|
+
export function injectDisabled(disabled = signal(false)) {
|
|
16
|
+
const provider = inject(NgpDisabledToken, { optional: true });
|
|
17
|
+
return provider ? provider.disabled : disabled;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzYWJsZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy1wcmltaXRpdmVzL2ludGVybmFsL3NyYy9kaXNhYmxlZC9kaXNhYmxlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxPQUFPLEVBQUUsTUFBTSxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFFdkUsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxjQUFjLENBQWdCLGtCQUFrQixDQUFDLENBQUM7QUFTdEY7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQzVCLFdBQTRCLE1BQU0sQ0FBVSxLQUFLLENBQUM7SUFFbEQsTUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFFOUQsT0FBTyxRQUFRLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQztBQUNqRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgwqkgMjAyNCBBbmd1bGFyIFByaW1pdGl2ZXMuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vbmctcHJpbWl0aXZlcy9uZy1wcmltaXRpdmVzXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgQ0MgQlktTkQgNC4wIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cbmltcG9ydCB7IGluamVjdCwgSW5qZWN0aW9uVG9rZW4sIHNpZ25hbCwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBOZ3BEaXNhYmxlZFRva2VuID0gbmV3IEluamVjdGlvblRva2VuPE5ncENhbkRpc2FibGU+KCdOZ3BEaXNhYmxlZFRva2VuJyk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTmdwQ2FuRGlzYWJsZSB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBlbGVtZW50IGlzIGRpc2FibGVkLlxuICAgKi9cbiAgcmVhZG9ubHkgZGlzYWJsZWQ6IFNpZ25hbDxib29sZWFuPjtcbn1cblxuLyoqXG4gKiBEZXRlcm1pbmUgaWYgd2UgYXJlIGluIGEgZGlzYWJsZWQgY29udGV4dC5cbiAqIEBwYXJhbSBkaXNhYmxlZCBUaGUgZGlzYWJsZWQgc2lnbmFsIGZvciB0aGUgbG9jYWwgY29udGV4dC5cbiAqIEByZXR1cm5zIFRoZSBkaXNhYmxlZCBzaWduYWwuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3REaXNhYmxlZChcbiAgZGlzYWJsZWQ6IFNpZ25hbDxib29sZWFuPiA9IHNpZ25hbDxib29sZWFuPihmYWxzZSksXG4pOiBTaWduYWw8Ym9vbGVhbj4ge1xuICBjb25zdCBwcm92aWRlciA9IGluamVjdChOZ3BEaXNhYmxlZFRva2VuLCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xuXG4gIHJldHVybiBwcm92aWRlciA/IHByb3ZpZGVyLmRpc2FibGVkIDogZGlzYWJsZWQ7XG59XG4iXX0=
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the CC BY-ND 4.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
export * from './disabled/disabled';
|
|
9
|
+
export * from './orientation/orientation';
|
|
10
|
+
export * from './style-injector/style-injector';
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy1wcmltaXRpdmVzL2ludGVybmFsL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IMKpIDIwMjQgQW5ndWxhciBQcmltaXRpdmVzLlxuICogaHR0cHM6Ly9naXRodWIuY29tL25nLXByaW1pdGl2ZXMvbmctcHJpbWl0aXZlc1xuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIENDIEJZLU5EIDQuMCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vZGlzYWJsZWQvZGlzYWJsZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9vcmllbnRhdGlvbi9vcmllbnRhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3N0eWxlLWluamVjdG9yL3N0eWxlLWluamVjdG9yJztcbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctcHJpbWl0aXZlcy1pbnRlcm5hbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25nLXByaW1pdGl2ZXMvaW50ZXJuYWwvc3JjL25nLXByaW1pdGl2ZXMtaW50ZXJuYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|