@ngutil/aria 0.0.69 → 0.0.71

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.
@@ -0,0 +1,44 @@
1
+ import { Position } from "@ngutil/style";
2
+ export type GestureDomEvent<T extends GestureEvent> = T extends GestureEvent<infer N> ? CustomEvent<T> & {
3
+ type: N;
4
+ } : never;
5
+ export interface GestureEvent<T extends string = string> {
6
+ readonly type: T;
7
+ readonly origin: GestureOrigin;
8
+ readonly target: HTMLElement;
9
+ readonly pointerType: GesturePointerType;
10
+ readonly phase: GesturePhase;
11
+ readonly pointers: ReadonlyArray<GesturePointer>;
12
+ readonly timeStamp: number;
13
+ readonly elapsed: number;
14
+ readonly scrollDistance?: Position;
15
+ }
16
+ export type PointersPosition = ReadonlyArray<Readonly<Position>>;
17
+ export interface GesturePointer {
18
+ readonly start: Position;
19
+ readonly current: Position;
20
+ readonly end?: Position;
21
+ readonly distance: Position;
22
+ readonly direction: {
23
+ x: -1 | 0 | 1;
24
+ y: -1 | 0 | 1;
25
+ };
26
+ }
27
+ export type GestureOrigin = MouseEvent | TouchEvent;
28
+ export declare const enum GesturePointerType {
29
+ Mouse = "mouse",
30
+ Touch = "touch"
31
+ }
32
+ export declare const enum GesturePhase {
33
+ Start = "start",
34
+ Moving = "moving",
35
+ End = "end"
36
+ }
37
+ export interface GestureListenerConfig {
38
+ options?: AddEventListenerOptions;
39
+ pointerType: GesturePointerType;
40
+ phase: GesturePhase;
41
+ }
42
+ export declare const Listeners: {
43
+ [key: string]: GestureListenerConfig;
44
+ };
@@ -0,0 +1,12 @@
1
+ import { Observable } from "rxjs";
2
+ import { Gesture, GestureCaptureState, GestureOptions } from "./gesture";
3
+ import { GestureEvent } from "./gesture-event";
4
+ export type GestureLongtapEvent = GestureEvent<"gesture-longtap">;
5
+ export type GestureLongtapOptions = GestureOptions<GestureLongTapImpl>;
6
+ export declare class GestureLongTapImpl extends Gesture<GestureLongtapEvent> {
7
+ constructor(options?: GestureLongtapOptions);
8
+ capture(events: Observable<GestureEvent>): Observable<GestureCaptureState>;
9
+ handle(events: Observable<GestureEvent>): Observable<import("utility-types").Mutable<GestureLongtapEvent>>;
10
+ }
11
+ export declare function gestureLongTap(options?: GestureLongtapOptions): GestureLongTapImpl;
12
+ export declare const GestureLongTap: GestureLongTapImpl;
@@ -0,0 +1,12 @@
1
+ import { Observable } from "rxjs";
2
+ import { Gesture, GestureCaptureState, GestureOptions } from "./gesture";
3
+ import { GestureEvent } from "./gesture-event";
4
+ export type GestureTapEvent = GestureEvent<"gesture-tap">;
5
+ export type GestureTapOptions = GestureOptions<GestureTapImpl>;
6
+ export declare class GestureTapImpl extends Gesture<GestureTapEvent> {
7
+ constructor(options?: GestureTapOptions);
8
+ capture(events: Observable<GestureEvent>): Observable<GestureCaptureState>;
9
+ handle(events: Observable<GestureEvent>): Observable<import("utility-types").Mutable<GestureTapEvent>>;
10
+ }
11
+ export declare function gestureTap(options?: GestureTapOptions): GestureTapImpl;
12
+ export declare const GestureTap: GestureTapImpl;
@@ -0,0 +1,35 @@
1
+ import { Observable } from "rxjs";
2
+ import { FunctionKeys, Mutable } from "utility-types";
3
+ import { GestureEvent, GesturePointerType } from "./gesture-event";
4
+ export declare const enum GestureCaptureState {
5
+ Unchecked = 0,
6
+ Pending = 1,
7
+ Skip = 2,
8
+ Maybe = 3,
9
+ Instant = 4
10
+ }
11
+ type _GestureOptions = Partial<Omit<Gesture<any>, "filterListeners" | "name" | FunctionKeys<Gesture<any>>>>;
12
+ export type GestureOptions<T extends object> = Partial<Omit<T, keyof Gesture<any> | FunctionKeys<T>>> & _GestureOptions;
13
+ export declare abstract class Gesture<T extends GestureEvent = GestureEvent> {
14
+ readonly name: string;
15
+ readonly distanceInclusion = 10;
16
+ readonly timeWithin = 300;
17
+ readonly priority = 0;
18
+ readonly includeScrollDistance: boolean;
19
+ readonly filterPointerTypes: Array<GesturePointerType>;
20
+ readonly filterMouseButtons: Array<number>;
21
+ readonly filterListeners: Array<keyof DocumentEventMap>;
22
+ constructor(name: string, listeners: Array<keyof DocumentEventMap>, options?: _GestureOptions);
23
+ /**
24
+ * Test if the gesture should be captured.
25
+ * ! important, dont rely on this object state, because not always create a new object
26
+ */
27
+ abstract capture(events: Observable<GestureEvent>): Observable<GestureCaptureState>;
28
+ /**
29
+ * Transform input event, to gesture event
30
+ * ! important, dont rely on this object state, because not always create a new object
31
+ */
32
+ handle(events: Observable<GestureEvent>): Observable<Mutable<T>>;
33
+ filterByEvent: <T_1 extends GestureEvent>(event: T_1) => event is T_1;
34
+ }
35
+ export {};
@@ -0,0 +1,22 @@
1
+ import { Observable } from "rxjs";
2
+ import { ElementInput } from "@ngutil/common";
3
+ import { Gesture } from "./gesture";
4
+ import { GestureDomEvent } from "./gesture-event";
5
+ import * as i0 from "@angular/core";
6
+ type GesturesToEventsType<T extends Array<Gesture>> = T extends Array<infer G> ? (G extends Gesture<infer E> ? E : never) : never;
7
+ type GestureEventDiscriminator<T> = T extends {
8
+ type: infer N;
9
+ } ? {
10
+ type: N;
11
+ } & T : never;
12
+ export type GestureWatchReturns<T extends Array<Gesture>> = Observable<GestureEventDiscriminator<GesturesToEventsType<T>>>;
13
+ export type GestureListenReturns<T extends Array<Gesture>> = Observable<GestureDomEvent<GesturesToEventsType<T>>>;
14
+ export declare class GestureService {
15
+ #private;
16
+ constructor();
17
+ listen<T extends Array<Gesture>>(el: ElementInput, ...gestures: T): GestureListenReturns<T>;
18
+ watch<T extends Array<Gesture>>(el: ElementInput, ...gestures: T): GestureWatchReturns<T>;
19
+ static ɵfac: i0.ɵɵFactoryDeclaration<GestureService, never>;
20
+ static ɵprov: i0.ɵɵInjectableDeclaration<GestureService>;
21
+ }
22
+ export {};
@@ -1,2 +1,6 @@
1
- export * from "./gestures";
2
- export * from "./gestures.service";
1
+ export * from "./gesture-drag";
2
+ export * from "./gesture-event";
3
+ export * from "./gesture-longtap";
4
+ export * from "./gesture-tap";
5
+ export * from "./gesture.service";
6
+ export * from "./gesture";
package/package.json CHANGED
@@ -1,15 +1,16 @@
1
1
  {
2
2
  "name": "@ngutil/aria",
3
- "version": "0.0.69",
3
+ "version": "0.0.71",
4
4
  "peerDependencies": {
5
5
  "@angular/cdk": "18.2.6",
6
6
  "@angular/common": "18.2.6",
7
7
  "@angular/core": "18.2.6",
8
+ "lodash-es": "^4.17.21",
8
9
  "rxjs": "^7.8.1",
9
10
  "tabbable": "^6.2.0",
10
11
  "utility-types": "^3.11.0",
11
- "@ngutil/common": "0.0.69",
12
- "@ngutil/style": "0.0.69"
12
+ "@ngutil/style": "0.0.71",
13
+ "@ngutil/common": "0.0.71"
13
14
  },
14
15
  "publishConfig": {
15
16
  "access": "public",
@@ -1,55 +0,0 @@
1
- export function stateToEvent(state, type) {
2
- return {
3
- type: type,
4
- origin: state.origin,
5
- target: state.target,
6
- pointerType: state.pointerType,
7
- phase: state.phase,
8
- pointers: state.pointers
9
- };
10
- }
11
- export const Listeners = {
12
- mousedown: {
13
- target: "element" /* ListenerTarget.Element */,
14
- pointerType: "mouse" /* GesturePointerType.Mouse */,
15
- phase: "start" /* GesturePhase.Start */,
16
- options: { capture: true, passive: false }
17
- },
18
- mousemove: {
19
- target: "document" /* ListenerTarget.Document */,
20
- pointerType: "mouse" /* GesturePointerType.Mouse */,
21
- phase: "moving" /* GesturePhase.Moving */,
22
- options: { capture: true, passive: false }
23
- },
24
- mouseup: {
25
- target: "document" /* ListenerTarget.Document */,
26
- pointerType: "mouse" /* GesturePointerType.Mouse */,
27
- phase: "end" /* GesturePhase.End */,
28
- options: { capture: true, passive: true }
29
- },
30
- touchstart: {
31
- target: "element" /* ListenerTarget.Element */,
32
- pointerType: "touch" /* GesturePointerType.Touch */,
33
- phase: "start" /* GesturePhase.Start */,
34
- options: { capture: true, passive: false }
35
- },
36
- touchmove: {
37
- target: "document" /* ListenerTarget.Document */,
38
- pointerType: "touch" /* GesturePointerType.Touch */,
39
- phase: "moving" /* GesturePhase.Moving */,
40
- options: { capture: true, passive: false }
41
- },
42
- touchend: {
43
- target: "document" /* ListenerTarget.Document */,
44
- pointerType: "touch" /* GesturePointerType.Touch */,
45
- phase: "end" /* GesturePhase.End */,
46
- options: { capture: true, passive: false }
47
- },
48
- touchcancel: {
49
- target: "document" /* ListenerTarget.Document */,
50
- pointerType: "touch" /* GesturePointerType.Touch */,
51
- phase: "end" /* GesturePhase.End */,
52
- options: { capture: true, passive: true }
53
- }
54
- };
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiX2Jhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy9nZXN0dXJlcy9nZXN0dXJlcy9fYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRUEsTUFBTSxVQUFVLFlBQVksQ0FBeUIsS0FBd0IsRUFBRSxJQUFZO0lBQ3ZGLE9BQU87UUFDSCxJQUFJLEVBQUUsSUFBSTtRQUNWLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTztRQUNyQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU87UUFDckIsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFZO1FBQy9CLEtBQUssRUFBRSxLQUFLLENBQUMsS0FBTTtRQUNuQixRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVM7S0FDdkIsQ0FBQTtBQUNWLENBQUM7QUFjRCxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQXNDO0lBQ3hELFNBQVMsRUFBRTtRQUNQLE1BQU0sd0NBQXdCO1FBQzlCLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssa0NBQW9CO1FBQ3pCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtLQUM3QztJQUNELFNBQVMsRUFBRTtRQUNQLE1BQU0sMENBQXlCO1FBQy9CLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssb0NBQXFCO1FBQzFCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtLQUM3QztJQUNELE9BQU8sRUFBRTtRQUNMLE1BQU0sMENBQXlCO1FBQy9CLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssOEJBQWtCO1FBQ3ZCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRTtLQUM1QztJQUNELFVBQVUsRUFBRTtRQUNSLE1BQU0sd0NBQXdCO1FBQzlCLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssa0NBQW9CO1FBQ3pCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtLQUM3QztJQUNELFNBQVMsRUFBRTtRQUNQLE1BQU0sMENBQXlCO1FBQy9CLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssb0NBQXFCO1FBQzFCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtLQUM3QztJQUNELFFBQVEsRUFBRTtRQUNOLE1BQU0sMENBQXlCO1FBQy9CLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssOEJBQWtCO1FBQ3ZCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtLQUM3QztJQUNELFdBQVcsRUFBRTtRQUNULE1BQU0sMENBQXlCO1FBQy9CLFdBQVcsd0NBQTBCO1FBQ3JDLEtBQUssOEJBQWtCO1FBQ3ZCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRTtLQUM1QztDQUNLLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgeyBNdXRhYmxlIH0gZnJvbSBcInV0aWxpdHktdHlwZXNcIlxuXG5pbXBvcnQgeyBQb3NpdGlvbiB9IGZyb20gXCJAbmd1dGlsL3N0eWxlXCJcblxuZXhwb3J0IGludGVyZmFjZSBHZXN0dXJlPFQgZXh0ZW5kcyBHZXN0dXJlRXZlbnQ+IHtcbiAgICBuYW1lOiBzdHJpbmdcbiAgICBwcmlvcml0eTogbnVtYmVyXG4gICAgbGlzdGVuZXJzPzogQXJyYXk8a2V5b2YgRG9jdW1lbnRFdmVudE1hcD5cbiAgICBoYW5kbGVyOiBHZXN0dXJlSGFuZGxlcjxUPlxufVxuXG5leHBvcnQgdHlwZSBHZXN0dXJlSGFuZGxlcjxUIGV4dGVuZHMgR2VzdHVyZUV2ZW50PiA9IChldmVudHM6IE9ic2VydmFibGU8R2VzdHVyZU1hdGNoU3RhdGU8VD4+KSA9PiBPYnNlcnZhYmxlPFQ+XG5cbmV4cG9ydCB0eXBlIEdlc3R1cmVMaXN0ZW5lciA9IHtcbiAgICBuYW1lOiBrZXlvZiBEb2N1bWVudEV2ZW50TWFwXG4gICAgdGFyZ2V0OiBMaXN0ZW5lclRhcmdldFxuICAgIC8vIG9wdGlvbnM/OiBBZGRFdmVudExpc3RlbmVyT3B0aW9uc1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdlc3R1cmVFdmVudDxUIGV4dGVuZHMgc3RyaW5nID0gc3RyaW5nPiB7XG4gICAgcmVhZG9ubHkgdHlwZTogVFxuICAgIHJlYWRvbmx5IG9yaWdpbjogR2VzdHVyZU9yaWdpblxuICAgIHJlYWRvbmx5IHRhcmdldDogSFRNTEVsZW1lbnRcbiAgICByZWFkb25seSBwb2ludGVyVHlwZTogR2VzdHVyZVBvaW50ZXJUeXBlXG4gICAgcmVhZG9ubHkgcGhhc2U6IEdlc3R1cmVQaGFzZVxuICAgIHJlYWRvbmx5IHBvaW50ZXJzOiBSZWFkb25seUFycmF5PEdlc3R1cmVQb2ludGVyPlxuXG4gICAgcHJldmVudERlZmF1bHQoKTogdm9pZFxufVxuXG50eXBlIEdlc3R1cmVFdmVudEZpeEZpZWxkcyA9IFwidGFyZ2V0XCIgfCBcIm9yaWdpblwiIHwgXCJwb2ludGVyc1wiIHwgXCJwaGFzZVwiIHwgXCJwb2ludGVyVHlwZVwiIHwgXCJwcmV2ZW50RGVmYXVsdFwiXG5cbmV4cG9ydCB0eXBlIFBvaW50ZXJzUG9zaXRpb24gPSBSZWFkb25seUFycmF5PFJlYWRvbmx5PFBvc2l0aW9uPj5cblxuZXhwb3J0IGludGVyZmFjZSBHZXN0dXJlUG9pbnRlciB7XG4gICAgcmVhZG9ubHkgc3RhcnQ6IFBvc2l0aW9uXG4gICAgcmVhZG9ubHkgY3VycmVudDogUG9zaXRpb25cbiAgICByZWFkb25seSBlbmQ/OiBQb3NpdGlvblxuICAgIHJlYWRvbmx5IGRpc3RhbmNlOiBQb3NpdGlvblxuICAgIHJlYWRvbmx5IGRpcmVjdGlvbjogeyB4OiAtMSB8IDAgfCAxOyB5OiAtMSB8IDAgfCAxIH1cbn1cblxuZXhwb3J0IHR5cGUgR2VzdHVyZU9yaWdpbiA9IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50XG5cbmV4cG9ydCBjb25zdCBlbnVtIEdlc3R1cmVQb2ludGVyVHlwZSB7XG4gICAgTW91c2UgPSBcIm1vdXNlXCIsXG4gICAgVG91Y2ggPSBcInRvdWNoXCJcbn1cblxuZXhwb3J0IGNvbnN0IGVudW0gR2VzdHVyZVBoYXNlIHtcbiAgICBTdGFydCA9IFwic3RhcnRcIixcbiAgICBNb3ZpbmcgPSBcIm1vdmluZ1wiLFxuICAgIEVuZCA9IFwiZW5kXCJcbn1cblxuZXhwb3J0IHR5cGUgR2VzdHVyZU1hdGNoU3RhdGU8VCBleHRlbmRzIEdlc3R1cmVFdmVudCA9IEdlc3R1cmVFdmVudD4gPSBQYXJ0aWFsPFxuICAgIE11dGFibGU8T21pdDxULCBHZXN0dXJlRXZlbnRGaXhGaWVsZHM+PlxuPiAmXG4gICAgUGljazxULCBHZXN0dXJlRXZlbnRGaXhGaWVsZHM+ICYge1xuICAgICAgICByZWFkb25seSBwZW5kaW5nPzogQXJyYXk8c3RyaW5nPlxuICAgIH1cblxuZXhwb3J0IGZ1bmN0aW9uIHN0YXRlVG9FdmVudDxUIGV4dGVuZHMgR2VzdHVyZUV2ZW50PihzdGF0ZTogR2VzdHVyZU1hdGNoU3RhdGUsIHR5cGU6IHN0cmluZyk6IFQge1xuICAgIHJldHVybiB7XG4gICAgICAgIHR5cGU6IHR5cGUsXG4gICAgICAgIG9yaWdpbjogc3RhdGUub3JpZ2luISxcbiAgICAgICAgdGFyZ2V0OiBzdGF0ZS50YXJnZXQhLFxuICAgICAgICBwb2ludGVyVHlwZTogc3RhdGUucG9pbnRlclR5cGUhLFxuICAgICAgICBwaGFzZTogc3RhdGUucGhhc2UhLFxuICAgICAgICBwb2ludGVyczogc3RhdGUucG9pbnRlcnMhXG4gICAgfSBhcyBUXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdGVuZXJDb25maWcge1xuICAgIHRhcmdldDogTGlzdGVuZXJUYXJnZXRcbiAgICBvcHRpb25zPzogQWRkRXZlbnRMaXN0ZW5lck9wdGlvbnNcbiAgICBwb2ludGVyVHlwZTogR2VzdHVyZVBvaW50ZXJUeXBlXG4gICAgcGhhc2U6IEdlc3R1cmVQaGFzZVxufVxuXG5leHBvcnQgY29uc3QgZW51bSBMaXN0ZW5lclRhcmdldCB7XG4gICAgRG9jdW1lbnQgPSBcImRvY3VtZW50XCIsXG4gICAgRWxlbWVudCA9IFwiZWxlbWVudFwiXG59XG5cbmV4cG9ydCBjb25zdCBMaXN0ZW5lcnM6IHsgW2tleTogc3RyaW5nXTogTGlzdGVuZXJDb25maWcgfSA9IHtcbiAgICBtb3VzZWRvd246IHtcbiAgICAgICAgdGFyZ2V0OiBMaXN0ZW5lclRhcmdldC5FbGVtZW50LFxuICAgICAgICBwb2ludGVyVHlwZTogR2VzdHVyZVBvaW50ZXJUeXBlLk1vdXNlLFxuICAgICAgICBwaGFzZTogR2VzdHVyZVBoYXNlLlN0YXJ0LFxuICAgICAgICBvcHRpb25zOiB7IGNhcHR1cmU6IHRydWUsIHBhc3NpdmU6IGZhbHNlIH1cbiAgICB9LFxuICAgIG1vdXNlbW92ZToge1xuICAgICAgICB0YXJnZXQ6IExpc3RlbmVyVGFyZ2V0LkRvY3VtZW50LFxuICAgICAgICBwb2ludGVyVHlwZTogR2VzdHVyZVBvaW50ZXJUeXBlLk1vdXNlLFxuICAgICAgICBwaGFzZTogR2VzdHVyZVBoYXNlLk1vdmluZyxcbiAgICAgICAgb3B0aW9uczogeyBjYXB0dXJlOiB0cnVlLCBwYXNzaXZlOiBmYWxzZSB9XG4gICAgfSxcbiAgICBtb3VzZXVwOiB7XG4gICAgICAgIHRhcmdldDogTGlzdGVuZXJUYXJnZXQuRG9jdW1lbnQsXG4gICAgICAgIHBvaW50ZXJUeXBlOiBHZXN0dXJlUG9pbnRlclR5cGUuTW91c2UsXG4gICAgICAgIHBoYXNlOiBHZXN0dXJlUGhhc2UuRW5kLFxuICAgICAgICBvcHRpb25zOiB7IGNhcHR1cmU6IHRydWUsIHBhc3NpdmU6IHRydWUgfVxuICAgIH0sXG4gICAgdG91Y2hzdGFydDoge1xuICAgICAgICB0YXJnZXQ6IExpc3RlbmVyVGFyZ2V0LkVsZW1lbnQsXG4gICAgICAgIHBvaW50ZXJUeXBlOiBHZXN0dXJlUG9pbnRlclR5cGUuVG91Y2gsXG4gICAgICAgIHBoYXNlOiBHZXN0dXJlUGhhc2UuU3RhcnQsXG4gICAgICAgIG9wdGlvbnM6IHsgY2FwdHVyZTogdHJ1ZSwgcGFzc2l2ZTogZmFsc2UgfVxuICAgIH0sXG4gICAgdG91Y2htb3ZlOiB7XG4gICAgICAgIHRhcmdldDogTGlzdGVuZXJUYXJnZXQuRG9jdW1lbnQsXG4gICAgICAgIHBvaW50ZXJUeXBlOiBHZXN0dXJlUG9pbnRlclR5cGUuVG91Y2gsXG4gICAgICAgIHBoYXNlOiBHZXN0dXJlUGhhc2UuTW92aW5nLFxuICAgICAgICBvcHRpb25zOiB7IGNhcHR1cmU6IHRydWUsIHBhc3NpdmU6IGZhbHNlIH1cbiAgICB9LFxuICAgIHRvdWNoZW5kOiB7XG4gICAgICAgIHRhcmdldDogTGlzdGVuZXJUYXJnZXQuRG9jdW1lbnQsXG4gICAgICAgIHBvaW50ZXJUeXBlOiBHZXN0dXJlUG9pbnRlclR5cGUuVG91Y2gsXG4gICAgICAgIHBoYXNlOiBHZXN0dXJlUGhhc2UuRW5kLFxuICAgICAgICBvcHRpb25zOiB7IGNhcHR1cmU6IHRydWUsIHBhc3NpdmU6IGZhbHNlIH1cbiAgICB9LFxuICAgIHRvdWNoY2FuY2VsOiB7XG4gICAgICAgIHRhcmdldDogTGlzdGVuZXJUYXJnZXQuRG9jdW1lbnQsXG4gICAgICAgIHBvaW50ZXJUeXBlOiBHZXN0dXJlUG9pbnRlclR5cGUuVG91Y2gsXG4gICAgICAgIHBoYXNlOiBHZXN0dXJlUGhhc2UuRW5kLFxuICAgICAgICBvcHRpb25zOiB7IGNhcHR1cmU6IHRydWUsIHBhc3NpdmU6IHRydWUgfVxuICAgIH1cbn0gYXMgY29uc3RcbiJdfQ==
@@ -1,14 +0,0 @@
1
- import { filter, map, tap } from "rxjs";
2
- import { stateToEvent } from "./_base";
3
- const TypeMap = {
4
- ["start" /* GesturePhase.Start */]: "dragging-start",
5
- ["moving" /* GesturePhase.Moving */]: "dragging-move",
6
- ["end" /* GesturePhase.End */]: "dragging-end"
7
- };
8
- export const Dragging = {
9
- name: "dragging",
10
- listeners: ["mousedown", "mousemove", "mouseup", "touchstart", "touchmove", "touchend", "touchcancel"],
11
- priority: 0,
12
- handler: events => events.pipe(filter(state => !state.pending || state.pending.length === 0), tap(state => state.preventDefault()), map(state => stateToEvent(state, TypeMap[state.phase])))
13
- };
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZ2dpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy9nZXN0dXJlcy9nZXN0dXJlcy9kcmFnZ2luZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUE7QUFFdkMsT0FBTyxFQUF1QyxZQUFZLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFNM0UsTUFBTSxPQUFPLEdBQUc7SUFDWixrQ0FBb0IsRUFBRSxnQkFBZ0I7SUFDdEMsb0NBQXFCLEVBQUUsZUFBZTtJQUN0Qyw4QkFBa0IsRUFBRSxjQUFjO0NBQ3JDLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQTJCO0lBQzVDLElBQUksRUFBRSxVQUFVO0lBQ2hCLFNBQVMsRUFBRSxDQUFDLFdBQVcsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLGFBQWEsQ0FBQztJQUN0RyxRQUFRLEVBQUUsQ0FBQztJQUNYLE9BQU8sRUFBRSxNQUFNLENBQUMsRUFBRSxDQUNkLE1BQU0sQ0FBQyxJQUFJLENBQ1AsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxFQUM3RCxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUMsRUFDcEMsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FDMUQ7Q0FDUixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZmlsdGVyLCBtYXAsIHRhcCB9IGZyb20gXCJyeGpzXCJcblxuaW1wb3J0IHsgR2VzdHVyZSwgR2VzdHVyZUV2ZW50LCBHZXN0dXJlUGhhc2UsIHN0YXRlVG9FdmVudCB9IGZyb20gXCIuL19iYXNlXCJcblxuLy8gZXhwb3J0IHR5cGUgRHJhZ2dpbmdFdmVudCA9IEdlc3R1cmVFdmVudDxcImRyYWdnaW5nLXN0YXJ0XCIgfCBcImRyYWdnaW5nLWVuZFwiIHwgXCJkcmFnZ2luZy1tb3ZlXCI+XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJhZ2dpbmdFdmVudCBleHRlbmRzIEdlc3R1cmVFdmVudDxcImRyYWdnaW5nLXN0YXJ0XCIgfCBcImRyYWdnaW5nLWVuZFwiIHwgXCJkcmFnZ2luZy1tb3ZlXCI+IHt9XG5cbmNvbnN0IFR5cGVNYXAgPSB7XG4gICAgW0dlc3R1cmVQaGFzZS5TdGFydF06IFwiZHJhZ2dpbmctc3RhcnRcIixcbiAgICBbR2VzdHVyZVBoYXNlLk1vdmluZ106IFwiZHJhZ2dpbmctbW92ZVwiLFxuICAgIFtHZXN0dXJlUGhhc2UuRW5kXTogXCJkcmFnZ2luZy1lbmRcIlxufVxuXG5leHBvcnQgY29uc3QgRHJhZ2dpbmc6IEdlc3R1cmU8RHJhZ2dpbmdFdmVudD4gPSB7XG4gICAgbmFtZTogXCJkcmFnZ2luZ1wiLFxuICAgIGxpc3RlbmVyczogW1wibW91c2Vkb3duXCIsIFwibW91c2Vtb3ZlXCIsIFwibW91c2V1cFwiLCBcInRvdWNoc3RhcnRcIiwgXCJ0b3VjaG1vdmVcIiwgXCJ0b3VjaGVuZFwiLCBcInRvdWNoY2FuY2VsXCJdLFxuICAgIHByaW9yaXR5OiAwLFxuICAgIGhhbmRsZXI6IGV2ZW50cyA9PlxuICAgICAgICBldmVudHMucGlwZShcbiAgICAgICAgICAgIGZpbHRlcihzdGF0ZSA9PiAhc3RhdGUucGVuZGluZyB8fCBzdGF0ZS5wZW5kaW5nLmxlbmd0aCA9PT0gMCksXG4gICAgICAgICAgICB0YXAoc3RhdGUgPT4gc3RhdGUucHJldmVudERlZmF1bHQoKSksXG4gICAgICAgICAgICBtYXAoc3RhdGUgPT4gc3RhdGVUb0V2ZW50KHN0YXRlLCBUeXBlTWFwW3N0YXRlLnBoYXNlXSkpXG4gICAgICAgIClcbn1cbiJdfQ==
@@ -1,3 +0,0 @@
1
- export * from "./_base";
2
- export * from "./dragging";
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy9nZXN0dXJlcy9nZXN0dXJlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFNBQVMsQ0FBQTtBQUN2QixjQUFjLFlBQVksQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL19iYXNlXCJcbmV4cG9ydCAqIGZyb20gXCIuL2RyYWdnaW5nXCJcbiJdfQ==
@@ -1,146 +0,0 @@
1
- import { DOCUMENT } from "@angular/common";
2
- import { inject, Injectable, NgZone } from "@angular/core";
3
- import { concatMap, filter, finalize, fromEvent, map, merge, of, scan, share, startWith, takeWhile, tap } from "rxjs";
4
- import { flatten } from "lodash";
5
- import { coerceElement } from "@ngutil/common";
6
- import { Listeners } from "./gestures";
7
- import * as i0 from "@angular/core";
8
- export class GesturesService {
9
- #document = inject(DOCUMENT);
10
- #zone = inject(NgZone);
11
- #listeners = new Map();
12
- watch(el, ...gestures) {
13
- return this.#zone.runOutsideAngular(() => {
14
- const listeners = flatten(gestures.map(v => v.listeners || []));
15
- const { trigger, watch } = this.#getListeners(coerceElement(el), listeners);
16
- let pointerType;
17
- return trigger.pipe(filter(state => {
18
- if (pointerType == null) {
19
- pointerType = state.pointerType;
20
- }
21
- return pointerType === state.pointerType;
22
- }), concatMap(v => this.#zone.runOutsideAngular(() => {
23
- const watching = watch[pointerType].pipe(startWith(v), scan((state, curr) => updatePointers({ ...state, ...curr }), {}), takeWhile(state => state.phase !== "end" /* GesturePhase.End */, true), share());
24
- return merge(...gestures.map(v => v.handler(watching)));
25
- })));
26
- });
27
- }
28
- #getListeners(inputEl, listeners) {
29
- const triggers = [];
30
- const watches = {};
31
- for (const name of listeners) {
32
- const conf = Listeners[name];
33
- const container = conf.phase === "start" /* GesturePhase.Start */
34
- ? triggers
35
- : (watches[conf.pointerType] = watches[conf.pointerType] || []);
36
- if (container.indexOf(name) === -1) {
37
- container.push(name);
38
- }
39
- }
40
- if (triggers.length === 0) {
41
- throw Error("Missing start events");
42
- }
43
- const observable = (names) => {
44
- if (names.length === 0) {
45
- return of();
46
- }
47
- else if (names.length === 1) {
48
- return this.#getListener(inputEl, names[0]);
49
- }
50
- else {
51
- return merge(...names.map(v => this.#getListener(inputEl, v)));
52
- }
53
- };
54
- return {
55
- trigger: observable(triggers),
56
- watch: {
57
- ["mouse" /* GesturePointerType.Mouse */]: observable(watches["mouse" /* GesturePointerType.Mouse */]),
58
- ["touch" /* GesturePointerType.Touch */]: observable(watches["touch" /* GesturePointerType.Touch */])
59
- }
60
- };
61
- }
62
- #getListener(inputEl, name) {
63
- return this.#zone.runOutsideAngular(() => {
64
- const target = Listeners[name].target;
65
- const targetObj = target === "document" ? this.#document : inputEl;
66
- let targetListeners = this.#listeners.get(targetObj);
67
- if (targetListeners == null) {
68
- targetListeners = new Map();
69
- this.#listeners.set(targetObj, targetListeners);
70
- }
71
- let listener = targetListeners.get(name);
72
- if (listener == null) {
73
- const { phase, pointerType, options } = Listeners[name];
74
- const passive = options?.passive;
75
- listener = fromEvent(targetObj, name, options).pipe(finalize(() => {
76
- targetListeners.delete(name);
77
- }), map(origin => ({
78
- origin,
79
- phase,
80
- pointerType,
81
- preventDefault: passive === false ? origin.preventDefault.bind(origin) : noop
82
- })));
83
- if (phase === "start" /* GesturePhase.Start */) {
84
- listener = listener.pipe(tap(state => {
85
- ;
86
- state.target = state.origin.target;
87
- }));
88
- }
89
- listener = listener.pipe(share());
90
- targetListeners.set(name, listener);
91
- }
92
- return listener;
93
- });
94
- }
95
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: GesturesService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
96
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: GesturesService, providedIn: "root" }); }
97
- }
98
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: GesturesService, decorators: [{
99
- type: Injectable,
100
- args: [{ providedIn: "root" }]
101
- }] });
102
- function pointersFromEvent(event) {
103
- if (event instanceof MouseEvent) {
104
- return [
105
- {
106
- x: event.clientX,
107
- y: event.clientY
108
- }
109
- ];
110
- }
111
- else {
112
- return Array.from(event.touches).map(t => {
113
- return { x: t.clientX, y: t.clientY };
114
- });
115
- }
116
- }
117
- function updatePointers(state) {
118
- if (state.phase === "start" /* GesturePhase.Start */) {
119
- state.pointers = pointersFromEvent(state.origin).map(v => {
120
- return { start: v, current: v, distance: { x: 0, y: 0 }, direction: { x: 0, y: 0 } };
121
- });
122
- }
123
- else if (state.pointers) {
124
- const pointers = pointersFromEvent(state.origin);
125
- if (pointers.length === 0) {
126
- return state;
127
- }
128
- state.pointers = state.pointers.map((v, i) => {
129
- const p = pointers[i];
130
- return {
131
- start: v.start,
132
- current: p,
133
- distance: { x: p.x - v.start.x, y: p.y - v.start.y },
134
- direction: { x: direction(v.start.x, p.x), y: direction(v.start.y, p.y) }
135
- };
136
- });
137
- }
138
- return state;
139
- }
140
- function direction(prev, curr) {
141
- return curr > prev ? 1 : curr < prev ? -1 : 0;
142
- }
143
- // const svc = new GesturesService()
144
- // const w = svc.watch(document.createElement("div"), DragAndDrop)
145
- function noop() { }
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gestures.service.js","sourceRoot":"","sources":["../../../../../packages/aria/src/gestures/gestures.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from \"@angular/common\"\nimport { inject, Injectable, NgZone } from \"@angular/core\"\n\nimport {\n    concatMap,\n    filter,\n    finalize,\n    fromEvent,\n    map,\n    merge,\n    Observable,\n    of,\n    scan,\n    share,\n    startWith,\n    takeWhile,\n    tap\n} from \"rxjs\"\n\nimport { flatten } from \"lodash\"\nimport { Mutable } from \"utility-types\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\nimport { Position } from \"@ngutil/style\"\n\nimport {\n    Gesture,\n    GestureEvent,\n    GestureMatchState,\n    GestureOrigin,\n    GesturePhase,\n    GesturePointerType,\n    Listeners\n} from \"./gestures\"\n\n@Injectable({ providedIn: \"root\" })\nexport class GesturesService {\n    readonly #document = inject(DOCUMENT)\n    readonly #zone = inject(NgZone)\n    readonly #listeners = new Map<HTMLElement | Document, Map<string, Observable<GestureMatchState>>>()\n\n    watch<T extends GestureEvent>(el: ElementInput, ...gestures: Gesture<T>[]): Observable<T> {\n        return this.#zone.runOutsideAngular(() => {\n            const listeners = flatten(gestures.map(v => v.listeners || []))\n            const { trigger, watch } = this.#getListeners(coerceElement(el), listeners)\n\n            let pointerType: GesturePointerType | undefined\n            return trigger.pipe(\n                filter(state => {\n                    if (pointerType == null) {\n                        pointerType = state.pointerType\n                    }\n                    return pointerType === state.pointerType\n                }),\n                concatMap(v =>\n                    this.#zone.runOutsideAngular(() => {\n                        const watching = watch[pointerType!].pipe(\n                            startWith(v),\n                            scan(\n                                (state, curr) => updatePointers<T>({ ...state, ...curr } as T),\n                                {} as GestureMatchState<T>\n                            ),\n                            takeWhile(state => state.phase !== GesturePhase.End, true),\n                            share()\n                        )\n                        return merge(...gestures.map(v => v.handler(watching)))\n                    })\n                )\n            )\n        })\n    }\n\n    #getListeners<T extends GestureEvent>(inputEl: HTMLElement, listeners: string[]) {\n        const triggers: string[] = []\n        const watches: { [key: string]: string[] } = {}\n\n        for (const name of listeners) {\n            const conf = Listeners[name]\n\n            const container =\n                conf.phase === GesturePhase.Start\n                    ? triggers\n                    : (watches[conf.pointerType] = watches[conf.pointerType] || [])\n\n            if (container.indexOf(name) === -1) {\n                container.push(name)\n            }\n        }\n\n        if (triggers.length === 0) {\n            throw Error(\"Missing start events\")\n        }\n\n        const observable = (names: string[]) => {\n            if (names.length === 0) {\n                return of()\n            } else if (names.length === 1) {\n                return this.#getListener<T>(inputEl, names[0])\n            } else {\n                return merge(...names.map(v => this.#getListener<T>(inputEl, v)))\n            }\n        }\n\n        return {\n            trigger: observable(triggers),\n            watch: {\n                [GesturePointerType.Mouse]: observable(watches[GesturePointerType.Mouse]),\n                [GesturePointerType.Touch]: observable(watches[GesturePointerType.Touch])\n            }\n        }\n    }\n\n    #getListener<T extends GestureEvent>(inputEl: HTMLElement, name: string): Observable<GestureMatchState<T>> {\n        return this.#zone.runOutsideAngular(() => {\n            const target = Listeners[name].target\n            const targetObj = target === \"document\" ? this.#document : inputEl\n            let targetListeners = this.#listeners.get(targetObj)\n\n            if (targetListeners == null) {\n                targetListeners = new Map()\n                this.#listeners.set(targetObj, targetListeners)\n            }\n\n            let listener = targetListeners.get(name)\n            if (listener == null) {\n                const { phase, pointerType, options } = Listeners[name]\n                const passive = options?.passive\n\n                listener = fromEvent<GestureOrigin>(targetObj, name, options as any).pipe(\n                    finalize(() => {\n                        targetListeners.delete(name)\n                    }),\n                    map(\n                        origin =>\n                            ({\n                                origin,\n                                phase,\n                                pointerType,\n                                preventDefault: passive === false ? origin.preventDefault.bind(origin) : noop\n                            }) as unknown as GestureMatchState<T>\n                    )\n                )\n\n                if (phase === GesturePhase.Start) {\n                    listener = listener.pipe(\n                        tap(state => {\n                            ;(state as Mutable<GestureMatchState>).target = state.origin.target as HTMLElement\n                        })\n                    )\n                }\n\n                listener = listener.pipe(share())\n\n                targetListeners.set(name, listener)\n            }\n\n            return listener as Observable<GestureMatchState<T>>\n        })\n    }\n}\n\nfunction pointersFromEvent(event: MouseEvent | TouchEvent): Position[] {\n    if (event instanceof MouseEvent) {\n        return [\n            {\n                x: event.clientX,\n                y: event.clientY\n            }\n        ]\n    } else {\n        return Array.from(event.touches).map(t => {\n            return { x: t.clientX, y: t.clientY }\n        })\n    }\n}\n\nfunction updatePointers<T extends GestureEvent>(state: Mutable<T>): GestureMatchState<T> {\n    if (state.phase === GesturePhase.Start) {\n        state.pointers = pointersFromEvent(state.origin).map(v => {\n            return { start: v, current: v, distance: { x: 0, y: 0 }, direction: { x: 0, y: 0 } }\n        })\n    } else if (state.pointers) {\n        const pointers = pointersFromEvent(state.origin)\n        if (pointers.length === 0) {\n            return state\n        }\n\n        state.pointers = state.pointers.map((v, i) => {\n            const p = pointers[i]\n            return {\n                start: v.start,\n                current: p,\n                distance: { x: p.x - v.start.x, y: p.y - v.start.y },\n                direction: { x: direction(v.start.x, p.x), y: direction(v.start.y, p.y) }\n            }\n        })\n    }\n\n    return state\n}\n\nfunction direction(prev: number, curr: number): -1 | 0 | 1 {\n    return curr > prev ? 1 : curr < prev ? -1 : 0\n}\n\n// const svc = new GesturesService()\n// const w = svc.watch(document.createElement(\"div\"), DragAndDrop)\nfunction noop() {}\n"]}
@@ -1,63 +0,0 @@
1
- import { Observable } from "rxjs";
2
- import { Mutable } from "utility-types";
3
- import { Position } from "@ngutil/style";
4
- export interface Gesture<T extends GestureEvent> {
5
- name: string;
6
- priority: number;
7
- listeners?: Array<keyof DocumentEventMap>;
8
- handler: GestureHandler<T>;
9
- }
10
- export type GestureHandler<T extends GestureEvent> = (events: Observable<GestureMatchState<T>>) => Observable<T>;
11
- export type GestureListener = {
12
- name: keyof DocumentEventMap;
13
- target: ListenerTarget;
14
- };
15
- export interface GestureEvent<T extends string = string> {
16
- readonly type: T;
17
- readonly origin: GestureOrigin;
18
- readonly target: HTMLElement;
19
- readonly pointerType: GesturePointerType;
20
- readonly phase: GesturePhase;
21
- readonly pointers: ReadonlyArray<GesturePointer>;
22
- preventDefault(): void;
23
- }
24
- type GestureEventFixFields = "target" | "origin" | "pointers" | "phase" | "pointerType" | "preventDefault";
25
- export type PointersPosition = ReadonlyArray<Readonly<Position>>;
26
- export interface GesturePointer {
27
- readonly start: Position;
28
- readonly current: Position;
29
- readonly end?: Position;
30
- readonly distance: Position;
31
- readonly direction: {
32
- x: -1 | 0 | 1;
33
- y: -1 | 0 | 1;
34
- };
35
- }
36
- export type GestureOrigin = MouseEvent | TouchEvent;
37
- export declare const enum GesturePointerType {
38
- Mouse = "mouse",
39
- Touch = "touch"
40
- }
41
- export declare const enum GesturePhase {
42
- Start = "start",
43
- Moving = "moving",
44
- End = "end"
45
- }
46
- export type GestureMatchState<T extends GestureEvent = GestureEvent> = Partial<Mutable<Omit<T, GestureEventFixFields>>> & Pick<T, GestureEventFixFields> & {
47
- readonly pending?: Array<string>;
48
- };
49
- export declare function stateToEvent<T extends GestureEvent>(state: GestureMatchState, type: string): T;
50
- export interface ListenerConfig {
51
- target: ListenerTarget;
52
- options?: AddEventListenerOptions;
53
- pointerType: GesturePointerType;
54
- phase: GesturePhase;
55
- }
56
- export declare const enum ListenerTarget {
57
- Document = "document",
58
- Element = "element"
59
- }
60
- export declare const Listeners: {
61
- [key: string]: ListenerConfig;
62
- };
63
- export {};
@@ -1,4 +0,0 @@
1
- import { Gesture, GestureEvent } from "./_base";
2
- export interface DraggingEvent extends GestureEvent<"dragging-start" | "dragging-end" | "dragging-move"> {
3
- }
4
- export declare const Dragging: Gesture<DraggingEvent>;
@@ -1,2 +0,0 @@
1
- export * from "./_base";
2
- export * from "./dragging";
@@ -1,10 +0,0 @@
1
- import { Observable } from "rxjs";
2
- import { ElementInput } from "@ngutil/common";
3
- import { Gesture, GestureEvent } from "./gestures";
4
- import * as i0 from "@angular/core";
5
- export declare class GesturesService {
6
- #private;
7
- watch<T extends GestureEvent>(el: ElementInput, ...gestures: Gesture<T>[]): Observable<T>;
8
- static ɵfac: i0.ɵɵFactoryDeclaration<GesturesService, never>;
9
- static ɵprov: i0.ɵɵInjectableDeclaration<GesturesService>;
10
- }