From 5e305e4f5020df44e66c3cf3b8f86b359b4b0585 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Mon, 26 Feb 2024 10:48:05 +0100 Subject: [PATCH 01/20] add GestureHandlerInterface --- src/RNGestureHandlerModule.web.ts | 5 ++- src/web/handlers/GestureHandler.ts | 31 ++++++++----- src/web/handlers/GestureHandlerInterface.ts | 44 +++++++++++++++++++ src/web/tools/GestureHandlerDelegate.ts | 4 +- src/web/tools/GestureHandlerOrchestrator.ts | 48 +++++++++++---------- src/web/tools/GestureHandlerWebDelegate.ts | 6 +-- src/web/tools/InteractionManager.ts | 23 +++++----- 7 files changed, 110 insertions(+), 51 deletions(-) create mode 100644 src/web/handlers/GestureHandlerInterface.ts diff --git a/src/RNGestureHandlerModule.web.ts b/src/RNGestureHandlerModule.web.ts index 0456f2fa05..8d6347d016 100644 --- a/src/RNGestureHandlerModule.web.ts +++ b/src/RNGestureHandlerModule.web.ts @@ -27,6 +27,7 @@ import HammerRotationGestureHandler from './web_hammer/RotationGestureHandler'; import HammerFlingGestureHandler from './web_hammer/FlingGestureHandler'; import { Config } from './web/interfaces'; import { GestureHandlerWebDelegate } from './web/tools/GestureHandlerWebDelegate'; +import GestureHandlerInterface from './web/handlers/GestureHandlerInterface'; export const Gestures = { NativeViewGestureHandler, @@ -75,7 +76,7 @@ export default { new GestureClass(new GestureHandlerWebDelegate()) ); InteractionManager.getInstance().configureInteractions( - NodeManager.getHandler(handlerTag), + NodeManager.getHandler(handlerTag) as GestureHandlerInterface, config as unknown as Config ); } else { @@ -120,7 +121,7 @@ export default { NodeManager.getHandler(handlerTag).updateGestureConfig(newConfig); InteractionManager.getInstance().configureInteractions( - NodeManager.getHandler(handlerTag), + NodeManager.getHandler(handlerTag) as GestureHandlerInterface, newConfig ); } else { diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index 9b971f88e7..c3c8d0ddea 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -17,8 +17,11 @@ import GestureHandlerOrchestrator from '../tools/GestureHandlerOrchestrator'; import InteractionManager from '../tools/InteractionManager'; import PointerTracker, { TrackerElement } from '../tools/PointerTracker'; import { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; +import GestureHandlerInterface from './GestureHandlerInterface'; -export default abstract class GestureHandler { +export default abstract class GestureHandler + implements GestureHandlerInterface +{ private lastSentState: State | null = null; protected currentState: State = State.UNDETERMINED; @@ -56,7 +59,7 @@ export default abstract class GestureHandler { this.currentState = State.UNDETERMINED; - this.delegate.init(viewRef, this); + this.delegate.init(viewRef, this as GestureHandlerInterface); } public attachEventManager(manager: EventManager): void { @@ -229,46 +232,52 @@ export default abstract class GestureHandler { this.activationIndex = value; } - public shouldWaitForHandlerFailure(handler: GestureHandler): boolean { + public shouldWaitForHandlerFailure( + handler: GestureHandlerInterface + ): boolean { if (handler === this) { return false; } return InteractionManager.getInstance().shouldWaitForHandlerFailure( - this, + this as GestureHandlerInterface, handler ); } - public shouldRequireToWaitForFailure(handler: GestureHandler): boolean { + public shouldRequireToWaitForFailure( + handler: GestureHandlerInterface + ): boolean { if (handler === this) { return false; } return InteractionManager.getInstance().shouldRequireHandlerToWaitForFailure( - this, + this as GestureHandlerInterface, handler ); } - public shouldRecognizeSimultaneously(handler: GestureHandler): boolean { + public shouldRecognizeSimultaneously( + handler: GestureHandlerInterface + ): boolean { if (handler === this) { return true; } return InteractionManager.getInstance().shouldRecognizeSimultaneously( - this, + this as GestureHandlerInterface, handler ); } - public shouldBeCancelledByOther(handler: GestureHandler): boolean { + public shouldBeCancelledByOther(handler: GestureHandlerInterface): boolean { if (handler === this) { return false; } return InteractionManager.getInstance().shouldHandlerBeCancelledBy( - this, + this as GestureHandlerInterface, handler ); } @@ -610,7 +619,7 @@ export default abstract class GestureHandler { break; case State.UNDETERMINED: GestureHandlerOrchestrator.getInstance().removeHandlerFromOrchestrator( - this + this as GestureHandlerInterface ); break; default: diff --git a/src/web/handlers/GestureHandlerInterface.ts b/src/web/handlers/GestureHandlerInterface.ts new file mode 100644 index 0000000000..86825ff0d2 --- /dev/null +++ b/src/web/handlers/GestureHandlerInterface.ts @@ -0,0 +1,44 @@ +/* eslint-disable @typescript-eslint/no-empty-function */ +import { State } from '../../State'; +import { Config, MouseButton, PointerType } from '../interfaces'; +import EventManager from '../tools/EventManager'; +import { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; +import PointerTracker from '../tools/PointerTracker'; + +export default interface GestureHandlerInterface { + getTag: () => number; + getState: () => State; + getConfig: () => Config; + getDelegate: () => GestureHandlerDelegate; + + attachEventManager: (manager: EventManager) => void; + + isButtonInConfig: ( + mouseButton: MouseButton | undefined + ) => boolean | number | undefined; + getPointerType: () => PointerType; + + getTracker: () => PointerTracker; + getTrackedPointersID: () => number[]; + + begin: () => void; + activate: () => void; + fail: () => void; + cancel: () => void; + + reset: () => void; + isEnabled: () => boolean; + isActive: () => boolean; + setActive: (value: boolean) => void; + isAwaiting: () => boolean; + setAwaiting: (value: boolean) => void; + setActivationIndex: (value: number) => void; + setShouldResetProgress: (value: boolean) => void; + + shouldWaitForHandlerFailure: (handler: GestureHandlerInterface) => boolean; + shouldRequireToWaitForFailure: (handler: GestureHandlerInterface) => boolean; + shouldRecognizeSimultaneously: (handler: GestureHandlerInterface) => boolean; + shouldBeCancelledByOther: (handler: GestureHandlerInterface) => boolean; + + sendEvent: (newState: State, oldState: State) => void; +} diff --git a/src/web/tools/GestureHandlerDelegate.ts b/src/web/tools/GestureHandlerDelegate.ts index 259b1c52c9..3b1e8a72ec 100644 --- a/src/web/tools/GestureHandlerDelegate.ts +++ b/src/web/tools/GestureHandlerDelegate.ts @@ -1,4 +1,4 @@ -import type GestureHandler from '../handlers/GestureHandler'; +import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; import { Config } from '../interfaces'; export interface MeasureResult { @@ -11,7 +11,7 @@ export interface MeasureResult { export interface GestureHandlerDelegate { getView(): T; - init(viewRef: number, handler: GestureHandler): void; + init(viewRef: number, handler: GestureHandlerInterface): void; isPointerInBounds({ x, y }: { x: number; y: number }): boolean; measureView(): MeasureResult; reset(): void; diff --git a/src/web/tools/GestureHandlerOrchestrator.ts b/src/web/tools/GestureHandlerOrchestrator.ts index a2c175efd8..f337c2a3fc 100644 --- a/src/web/tools/GestureHandlerOrchestrator.ts +++ b/src/web/tools/GestureHandlerOrchestrator.ts @@ -1,14 +1,14 @@ import { State } from '../../State'; import { PointerType } from '../interfaces'; -import GestureHandler from '../handlers/GestureHandler'; +import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; import PointerTracker from './PointerTracker'; export default class GestureHandlerOrchestrator { private static instance: GestureHandlerOrchestrator; - private gestureHandlers: GestureHandler[] = []; - private awaitingHandlers: GestureHandler[] = []; + private gestureHandlers: GestureHandlerInterface[] = []; + private awaitingHandlers: GestureHandlerInterface[] = []; private handlingChangeSemaphore = 0; private activationIndex = 0; @@ -23,14 +23,14 @@ export default class GestureHandlerOrchestrator { } } - private cleanHandler(handler: GestureHandler): void { + private cleanHandler(handler: GestureHandlerInterface): void { handler.reset(); handler.setActive(false); handler.setAwaiting(false); handler.setActivationIndex(Number.MAX_VALUE); } - public removeHandlerFromOrchestrator(handler: GestureHandler): void { + public removeHandlerFromOrchestrator(handler: GestureHandlerInterface): void { this.gestureHandlers.splice(this.gestureHandlers.indexOf(handler), 1); this.awaitingHandlers.splice(this.awaitingHandlers.indexOf(handler), 1); } @@ -50,7 +50,7 @@ export default class GestureHandlerOrchestrator { } } - private hasOtherHandlerToWaitFor(handler: GestureHandler): boolean { + private hasOtherHandlerToWaitFor(handler: GestureHandlerInterface): boolean { let hasToWait = false; this.gestureHandlers.forEach((otherHandler) => { if ( @@ -66,7 +66,7 @@ export default class GestureHandlerOrchestrator { return hasToWait; } - private tryActivate(handler: GestureHandler): void { + private tryActivate(handler: GestureHandlerInterface): void { if (this.hasOtherHandlerToWaitFor(handler)) { this.addAwaitingHandler(handler); } else if ( @@ -87,7 +87,7 @@ export default class GestureHandlerOrchestrator { } } - private shouldActivate(handler: GestureHandler): boolean { + private shouldActivate(handler: GestureHandlerInterface): boolean { for (const otherHandler of this.gestureHandlers) { if (this.shouldHandlerBeCancelledBy(handler, otherHandler)) { return false; @@ -97,7 +97,7 @@ export default class GestureHandlerOrchestrator { return true; } - private cleanupAwaitingHandlers(handler: GestureHandler): void { + private cleanupAwaitingHandlers(handler: GestureHandlerInterface): void { for (let i = 0; i < this.awaitingHandlers.length; ++i) { if ( !this.awaitingHandlers[i].isAwaiting() && @@ -110,7 +110,7 @@ export default class GestureHandlerOrchestrator { } public onHandlerStateChange( - handler: GestureHandler, + handler: GestureHandlerInterface, newState: State, oldState: State, sendIfDisabled?: boolean @@ -168,7 +168,7 @@ export default class GestureHandlerOrchestrator { } } - private makeActive(handler: GestureHandler): void { + private makeActive(handler: GestureHandlerInterface): void { const currentState = handler.getState(); handler.setActive(true); @@ -207,7 +207,7 @@ export default class GestureHandlerOrchestrator { } } - private addAwaitingHandler(handler: GestureHandler): void { + private addAwaitingHandler(handler: GestureHandlerInterface): void { let alreadyExists = false; this.awaitingHandlers.forEach((otherHandler) => { @@ -227,7 +227,7 @@ export default class GestureHandlerOrchestrator { handler.setActivationIndex(this.activationIndex++); } - public recordHandlerIfNotPresent(handler: GestureHandler): void { + public recordHandlerIfNotPresent(handler: GestureHandlerInterface): void { let alreadyExists = false; this.gestureHandlers.forEach((otherHandler) => { @@ -249,8 +249,8 @@ export default class GestureHandlerOrchestrator { } private shouldHandlerWaitForOther( - handler: GestureHandler, - otherHandler: GestureHandler + handler: GestureHandlerInterface, + otherHandler: GestureHandlerInterface ): boolean { return ( handler !== otherHandler && @@ -260,8 +260,8 @@ export default class GestureHandlerOrchestrator { } private canRunSimultaneously( - gh1: GestureHandler, - gh2: GestureHandler + gh1: GestureHandlerInterface, + gh2: GestureHandlerInterface ): boolean { return ( gh1 === gh2 || @@ -271,8 +271,8 @@ export default class GestureHandlerOrchestrator { } private shouldHandlerBeCancelledBy( - handler: GestureHandler, - otherHandler: GestureHandler + handler: GestureHandlerInterface, + otherHandler: GestureHandlerInterface ): boolean { if (this.canRunSimultaneously(handler, otherHandler)) { return false; @@ -300,8 +300,8 @@ export default class GestureHandlerOrchestrator { } private checkOverlap( - handler: GestureHandler, - otherHandler: GestureHandler + handler: GestureHandlerInterface, + otherHandler: GestureHandlerInterface ): boolean { // If handlers don't have common pointers, default return value is false. // However, if at least on pointer overlaps with both handlers, we return true @@ -355,8 +355,10 @@ export default class GestureHandlerOrchestrator { // This became a problem because handler was left at active state without any signal to end or fail // To handle this, when new touch event is received, we loop through active handlers and check which type of // pointer they're using. If there are any handler with mouse/pen as a pointer, we cancel them - public cancelMouseAndPenGestures(currentHandler: GestureHandler): void { - this.gestureHandlers.forEach((handler: GestureHandler) => { + public cancelMouseAndPenGestures( + currentHandler: GestureHandlerInterface + ): void { + this.gestureHandlers.forEach((handler: GestureHandlerInterface) => { if ( handler.getPointerType() !== PointerType.MOUSE && handler.getPointerType() !== PointerType.PEN diff --git a/src/web/tools/GestureHandlerWebDelegate.ts b/src/web/tools/GestureHandlerWebDelegate.ts index fad27df38c..67775da0d6 100644 --- a/src/web/tools/GestureHandlerWebDelegate.ts +++ b/src/web/tools/GestureHandlerWebDelegate.ts @@ -1,5 +1,5 @@ import { findNodeHandle } from 'react-native'; -import type GestureHandler from '../handlers/GestureHandler'; +import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; import { GestureHandlerDelegate, MeasureResult, @@ -15,14 +15,14 @@ export class GestureHandlerWebDelegate implements GestureHandlerDelegate { private view!: HTMLElement; - private gestureHandler!: GestureHandler; + private gestureHandler!: GestureHandlerInterface; private eventManagers: EventManager[] = []; getView(): HTMLElement { return this.view; } - init(viewRef: number, handler: GestureHandler): void { + init(viewRef: number, handler: GestureHandlerInterface): void { if (!viewRef) { throw new Error( `Cannot find HTML Element for handler ${handler.getTag()}` diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index 55df13b033..eaa0c8741e 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -1,4 +1,4 @@ -import GestureHandler from '../handlers/GestureHandler'; +import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; import { Config, Handler } from '../interfaces'; export default class InteractionManager { @@ -11,7 +11,10 @@ export default class InteractionManager { // eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function private constructor() {} - public configureInteractions(handler: GestureHandler, config: Config) { + public configureInteractions( + handler: GestureHandlerInterface, + config: Config + ) { this.dropRelationsForHandlerWithTag(handler.getTag()); if (config.waitFor) { @@ -57,8 +60,8 @@ export default class InteractionManager { } public shouldWaitForHandlerFailure( - handler: GestureHandler, - otherHandler: GestureHandler + handler: GestureHandlerInterface, + otherHandler: GestureHandlerInterface ): boolean { const waitFor: number[] | undefined = this.waitForRelations.get( handler.getTag() @@ -72,8 +75,8 @@ export default class InteractionManager { } public shouldRecognizeSimultaneously( - handler: GestureHandler, - otherHandler: GestureHandler + handler: GestureHandlerInterface, + otherHandler: GestureHandlerInterface ): boolean { const simultaneousHandlers: number[] | undefined = this.simultaneousRelations.get(handler.getTag()); @@ -86,8 +89,8 @@ export default class InteractionManager { } public shouldRequireHandlerToWaitForFailure( - handler: GestureHandler, - otherHandler: GestureHandler + handler: GestureHandlerInterface, + otherHandler: GestureHandlerInterface ): boolean { const waitFor: number[] | undefined = this.blocksHandlersRelations.get( handler.getTag() @@ -101,8 +104,8 @@ export default class InteractionManager { } public shouldHandlerBeCancelledBy( - _handler: GestureHandler, - _otherHandler: GestureHandler + _handler: GestureHandlerInterface, + _otherHandler: GestureHandlerInterface ): boolean { //TODO: Implement logic return false; From ed060a0032713f108ef9541a059491f408c97b34 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Fri, 1 Mar 2024 10:44:12 +0100 Subject: [PATCH 02/20] Remove most of web circular dependencies --- src/RNGestureHandlerModule.web.ts | 47 ++------------------- src/components/DrawerLayout.tsx | 2 +- src/handlers/gestureHandlerCommon.ts | 11 ++++- src/handlers/gestures/gesture.ts | 2 +- src/index.ts | 2 +- src/web/Gestures.ts | 41 ++++++++++++++++++ src/web/constants.ts | 2 +- src/web/handlers/GestureHandler.ts | 13 ++++-- src/web/handlers/GestureHandlerInterface.ts | 7 +-- src/web/interfaces.ts | 15 +++---- src/web/tools/GestureHandlerDelegate.ts | 5 +-- src/web/tools/GestureHandlerWebDelegate.ts | 5 ++- src/web/tools/NodeManager.ts | 2 +- src/web/tools/PointerEventManager.ts | 8 +--- src/web_hammer/NodeManager.ts | 2 +- 15 files changed, 85 insertions(+), 79 deletions(-) create mode 100644 src/web/Gestures.ts diff --git a/src/RNGestureHandlerModule.web.ts b/src/RNGestureHandlerModule.web.ts index 8d6347d016..64b7dc12d7 100644 --- a/src/RNGestureHandlerModule.web.ts +++ b/src/RNGestureHandlerModule.web.ts @@ -2,54 +2,13 @@ import React from 'react'; import { ActionType } from './ActionType'; import { isNewWebImplementationEnabled } from './EnableNewWebImplementation'; - -//GestureHandlers +import { Gestures, HammerGestures } from './web/Gestures'; +import GestureHandlerInterface from './web/handlers/GestureHandlerInterface'; +import { Config } from './web/interfaces'; import InteractionManager from './web/tools/InteractionManager'; import NodeManager from './web/tools/NodeManager'; -import PanGestureHandler from './web/handlers/PanGestureHandler'; -import TapGestureHandler from './web/handlers/TapGestureHandler'; -import LongPressGestureHandler from './web/handlers/LongPressGestureHandler'; -import PinchGestureHandler from './web/handlers/PinchGestureHandler'; -import RotationGestureHandler from './web/handlers/RotationGestureHandler'; -import FlingGestureHandler from './web/handlers/FlingGestureHandler'; -import NativeViewGestureHandler from './web/handlers/NativeViewGestureHandler'; -import ManualGestureHandler from './web/handlers/ManualGestureHandler'; -import HoverGestureHandler from './web/handlers/HoverGestureHandler'; - -//Hammer Handlers import * as HammerNodeManager from './web_hammer/NodeManager'; -import HammerNativeViewGestureHandler from './web_hammer/NativeViewGestureHandler'; -import HammerPanGestureHandler from './web_hammer/PanGestureHandler'; -import HammerTapGestureHandler from './web_hammer/TapGestureHandler'; -import HammerLongPressGestureHandler from './web_hammer/LongPressGestureHandler'; -import HammerPinchGestureHandler from './web_hammer/PinchGestureHandler'; -import HammerRotationGestureHandler from './web_hammer/RotationGestureHandler'; -import HammerFlingGestureHandler from './web_hammer/FlingGestureHandler'; -import { Config } from './web/interfaces'; import { GestureHandlerWebDelegate } from './web/tools/GestureHandlerWebDelegate'; -import GestureHandlerInterface from './web/handlers/GestureHandlerInterface'; - -export const Gestures = { - NativeViewGestureHandler, - PanGestureHandler, - TapGestureHandler, - LongPressGestureHandler, - PinchGestureHandler, - RotationGestureHandler, - FlingGestureHandler, - ManualGestureHandler, - HoverGestureHandler, -}; - -export const HammerGestures = { - NativeViewGestureHandler: HammerNativeViewGestureHandler, - PanGestureHandler: HammerPanGestureHandler, - TapGestureHandler: HammerTapGestureHandler, - LongPressGestureHandler: HammerLongPressGestureHandler, - PinchGestureHandler: HammerPinchGestureHandler, - RotationGestureHandler: HammerRotationGestureHandler, - FlingGestureHandler: HammerFlingGestureHandler, -}; export default { handleSetJSResponder(tag: number, blockNativeResponder: boolean) { diff --git a/src/components/DrawerLayout.tsx b/src/components/DrawerLayout.tsx index 3d6148d851..5ceb54581a 100644 --- a/src/components/DrawerLayout.tsx +++ b/src/components/DrawerLayout.tsx @@ -28,6 +28,7 @@ import { HandlerStateChangeEvent, UserSelect, ActiveCursor, + MouseButton, } from '../handlers/gestureHandlerCommon'; import { PanGestureHandler, @@ -38,7 +39,6 @@ import { TapGestureHandlerEventPayload, } from '../handlers/TapGestureHandler'; import { State } from '../State'; -import { MouseButton } from '../web/interfaces'; const DRAG_TOSS = 0.05; diff --git a/src/handlers/gestureHandlerCommon.ts b/src/handlers/gestureHandlerCommon.ts index 5fb4889b91..80a113613a 100644 --- a/src/handlers/gestureHandlerCommon.ts +++ b/src/handlers/gestureHandlerCommon.ts @@ -12,7 +12,7 @@ import { handlerIDToTag } from './handlersRegistry'; import { toArray } from '../utils'; import RNGestureHandlerModule from '../RNGestureHandlerModule'; import { ghQueueMicrotask } from '../ghQueueMicrotask'; -import { MouseButton } from '../web/interfaces'; +// import { MouseButton } from '../web/interfaces'; const commonProps = [ 'id', @@ -111,6 +111,15 @@ export type ActiveCursor = | 'zoom-in' | 'zoom-out'; +export enum MouseButton { + LEFT = 1, + RIGHT = 2, + MIDDLE = 4, + BUTTON_4 = 8, + BUTTON_5 = 16, + ALL = 31, +} + //TODO(TS) events in handlers export interface GestureEvent> { diff --git a/src/handlers/gestures/gesture.ts b/src/handlers/gestures/gesture.ts index b1cec76983..69d7ed3ee7 100644 --- a/src/handlers/gestures/gesture.ts +++ b/src/handlers/gestures/gesture.ts @@ -7,6 +7,7 @@ import { GestureStateChangeEvent, GestureUpdateEvent, ActiveCursor, + MouseButton, } from '../gestureHandlerCommon'; import { getNextHandlerTag } from '../handlersRegistry'; import { GestureStateManagerType } from './gestureStateManager'; @@ -17,7 +18,6 @@ import { RotationGestureHandlerEventPayload } from '../RotationGestureHandler'; import { TapGestureHandlerEventPayload } from '../TapGestureHandler'; import { NativeViewGestureHandlerPayload } from '../NativeViewGestureHandler'; import { isRemoteDebuggingEnabled } from '../../utils'; -import { MouseButton } from '../../web/interfaces'; export type GestureType = | BaseGesture> diff --git a/src/index.ts b/src/index.ts index 49fd999c64..ab4d591e96 100644 --- a/src/index.ts +++ b/src/index.ts @@ -2,7 +2,6 @@ import { initialize } from './init'; export { Directions } from './Directions'; export { State } from './State'; -export { MouseButton } from './web/interfaces'; export { default as gestureHandlerRootHOC } from './components/gestureHandlerRootHOC'; export { default as GestureHandlerRootView } from './components/GestureHandlerRootView'; export type { @@ -18,6 +17,7 @@ export type { // new api event types GestureUpdateEvent, GestureStateChangeEvent, + MouseButton, } from './handlers/gestureHandlerCommon'; export type { GestureType } from './handlers/gestures/gesture'; export type { diff --git a/src/web/Gestures.ts b/src/web/Gestures.ts new file mode 100644 index 0000000000..c939a210b0 --- /dev/null +++ b/src/web/Gestures.ts @@ -0,0 +1,41 @@ +// Gesture Handlers +import PanGestureHandler from './handlers/PanGestureHandler'; +import TapGestureHandler from './handlers/TapGestureHandler'; +import LongPressGestureHandler from './handlers/LongPressGestureHandler'; +import PinchGestureHandler from './handlers/PinchGestureHandler'; +import RotationGestureHandler from './handlers/RotationGestureHandler'; +import FlingGestureHandler from './handlers/FlingGestureHandler'; +import NativeViewGestureHandler from './handlers/NativeViewGestureHandler'; +import ManualGestureHandler from './handlers/ManualGestureHandler'; +import HoverGestureHandler from './handlers/HoverGestureHandler'; + +//Hammer Handlers +import HammerNativeViewGestureHandler from '../web_hammer/NativeViewGestureHandler'; +import HammerPanGestureHandler from '../web_hammer/PanGestureHandler'; +import HammerTapGestureHandler from '../web_hammer/TapGestureHandler'; +import HammerLongPressGestureHandler from '../web_hammer/LongPressGestureHandler'; +import HammerPinchGestureHandler from '../web_hammer/PinchGestureHandler'; +import HammerRotationGestureHandler from '../web_hammer/RotationGestureHandler'; +import HammerFlingGestureHandler from '../web_hammer/FlingGestureHandler'; + +export const Gestures = { + NativeViewGestureHandler, + PanGestureHandler, + TapGestureHandler, + LongPressGestureHandler, + PinchGestureHandler, + RotationGestureHandler, + FlingGestureHandler, + ManualGestureHandler, + HoverGestureHandler, +}; + +export const HammerGestures = { + NativeViewGestureHandler: HammerNativeViewGestureHandler, + PanGestureHandler: HammerPanGestureHandler, + TapGestureHandler: HammerTapGestureHandler, + LongPressGestureHandler: HammerLongPressGestureHandler, + PinchGestureHandler: HammerPinchGestureHandler, + RotationGestureHandler: HammerRotationGestureHandler, + FlingGestureHandler: HammerFlingGestureHandler, +}; diff --git a/src/web/constants.ts b/src/web/constants.ts index 51aba8a237..1ffadef3bf 100644 --- a/src/web/constants.ts +++ b/src/web/constants.ts @@ -1,4 +1,4 @@ -export const DEFAULT_TOUCH_SLOP = 15; +export const DEFAULT_TOUCH_SLOP = 5; export const Direction = { RIGHT: 1, diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index c3c8d0ddea..b3fd164cae 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -10,7 +10,6 @@ import { PointerType, TouchEventType, EventTypes, - MouseButton, } from '../interfaces'; import EventManager from '../tools/EventManager'; import GestureHandlerOrchestrator from '../tools/GestureHandlerOrchestrator'; @@ -18,6 +17,7 @@ import InteractionManager from '../tools/InteractionManager'; import PointerTracker, { TrackerElement } from '../tools/PointerTracker'; import { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; import GestureHandlerInterface from './GestureHandlerInterface'; +import { MouseButton } from '../../handlers/gestureHandlerCommon'; export default abstract class GestureHandler implements GestureHandlerInterface @@ -43,9 +43,11 @@ export default abstract class GestureHandler protected shouldResetProgress = false; protected pointerType: PointerType = PointerType.NONE; - protected delegate: GestureHandlerDelegate; + protected delegate: GestureHandlerDelegate; - public constructor(delegate: GestureHandlerDelegate) { + public constructor( + delegate: GestureHandlerDelegate + ) { this.delegate = delegate; } @@ -780,7 +782,10 @@ export default abstract class GestureHandler return this.config; } - public getDelegate(): GestureHandlerDelegate { + public getDelegate(): GestureHandlerDelegate< + unknown, + GestureHandlerInterface + > { return this.delegate; } diff --git a/src/web/handlers/GestureHandlerInterface.ts b/src/web/handlers/GestureHandlerInterface.ts index 86825ff0d2..1e8e9e4399 100644 --- a/src/web/handlers/GestureHandlerInterface.ts +++ b/src/web/handlers/GestureHandlerInterface.ts @@ -1,15 +1,16 @@ /* eslint-disable @typescript-eslint/no-empty-function */ +import { MouseButton } from '../../handlers/gestureHandlerCommon'; import { State } from '../../State'; -import { Config, MouseButton, PointerType } from '../interfaces'; +import { Config, PointerType } from '../interfaces'; import EventManager from '../tools/EventManager'; -import { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; +import type { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; import PointerTracker from '../tools/PointerTracker'; export default interface GestureHandlerInterface { getTag: () => number; getState: () => State; getConfig: () => Config; - getDelegate: () => GestureHandlerDelegate; + getDelegate: () => GestureHandlerDelegate; attachEventManager: (manager: EventManager) => void; diff --git a/src/web/interfaces.ts b/src/web/interfaces.ts index 43c44baa95..344173db86 100644 --- a/src/web/interfaces.ts +++ b/src/web/interfaces.ts @@ -1,4 +1,8 @@ -import { UserSelect, ActiveCursor } from '../handlers/gestureHandlerCommon'; +import { + UserSelect, + ActiveCursor, + MouseButton, +} from '../handlers/gestureHandlerCommon'; import { Directions } from '../Directions'; import { State } from '../State'; @@ -131,15 +135,6 @@ export interface AdaptedEvent { touchEventType?: TouchEventType; } -export enum MouseButton { - LEFT = 1, - RIGHT = 2, - MIDDLE = 4, - BUTTON_4 = 8, - BUTTON_5 = 16, - ALL = 31, -} - export enum EventTypes { DOWN, ADDITIONAL_POINTER_DOWN, diff --git a/src/web/tools/GestureHandlerDelegate.ts b/src/web/tools/GestureHandlerDelegate.ts index 3b1e8a72ec..2144786811 100644 --- a/src/web/tools/GestureHandlerDelegate.ts +++ b/src/web/tools/GestureHandlerDelegate.ts @@ -1,4 +1,3 @@ -import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; import { Config } from '../interfaces'; export interface MeasureResult { @@ -8,10 +7,10 @@ export interface MeasureResult { height: number; } -export interface GestureHandlerDelegate { +export interface GestureHandlerDelegate { getView(): T; - init(viewRef: number, handler: GestureHandlerInterface): void; + init(viewRef: number, handler: S): void; isPointerInBounds({ x, y }: { x: number; y: number }): boolean; measureView(): MeasureResult; reset(): void; diff --git a/src/web/tools/GestureHandlerWebDelegate.ts b/src/web/tools/GestureHandlerWebDelegate.ts index 67775da0d6..3d937d5964 100644 --- a/src/web/tools/GestureHandlerWebDelegate.ts +++ b/src/web/tools/GestureHandlerWebDelegate.ts @@ -9,10 +9,11 @@ import TouchEventManager from './TouchEventManager'; import { State } from '../../State'; import { isPointerInBounds } from '../utils'; import EventManager from './EventManager'; -import { Config, MouseButton } from '../interfaces'; +import { Config } from '../interfaces'; +import { MouseButton } from '../../handlers/gestureHandlerCommon'; export class GestureHandlerWebDelegate - implements GestureHandlerDelegate + implements GestureHandlerDelegate { private view!: HTMLElement; private gestureHandler!: GestureHandlerInterface; diff --git a/src/web/tools/NodeManager.ts b/src/web/tools/NodeManager.ts index ca452324e6..1dee22dbf2 100644 --- a/src/web/tools/NodeManager.ts +++ b/src/web/tools/NodeManager.ts @@ -1,5 +1,5 @@ import { ValueOf } from '../../typeUtils'; -import { Gestures } from '../../RNGestureHandlerModule.web'; +import { Gestures } from '../Gestures'; // eslint-disable-next-line @typescript-eslint/no-extraneous-class export default abstract class NodeManager { diff --git a/src/web/tools/PointerEventManager.ts b/src/web/tools/PointerEventManager.ts index 9cc4e91206..9d8d61c519 100644 --- a/src/web/tools/PointerEventManager.ts +++ b/src/web/tools/PointerEventManager.ts @@ -1,11 +1,7 @@ -import { - AdaptedEvent, - EventTypes, - MouseButton, - PointerType, -} from '../interfaces'; +import { AdaptedEvent, EventTypes, PointerType } from '../interfaces'; import EventManager from './EventManager'; import { isPointerInBounds } from '../utils'; +import { MouseButton } from '../../handlers/gestureHandlerCommon'; const POINTER_CAPTURE_EXCLUDE_LIST = new Set(['SELECT', 'INPUT']); diff --git a/src/web_hammer/NodeManager.ts b/src/web_hammer/NodeManager.ts index 163693851b..664d874938 100644 --- a/src/web_hammer/NodeManager.ts +++ b/src/web_hammer/NodeManager.ts @@ -1,5 +1,5 @@ import { ValueOf } from '../typeUtils'; -import { HammerGestures } from '../RNGestureHandlerModule.web'; +import { HammerGestures } from '../web/Gestures'; const gestures: Record< number, From 3bc54186ea4b4e86c4c3e29748bab70a33b4fcc3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Fri, 1 Mar 2024 11:36:00 +0100 Subject: [PATCH 03/20] Last circular dep in new implementation --- src/handlers/createHandler.tsx | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/src/handlers/createHandler.tsx b/src/handlers/createHandler.tsx index 7f991fed1c..e1e568293a 100644 --- a/src/handlers/createHandler.tsx +++ b/src/handlers/createHandler.tsx @@ -8,7 +8,6 @@ import { // @ts-ignore - it isn't typed by TS & don't have definitelyTyped types import deepEqual from 'lodash/isEqual'; import RNGestureHandlerModule from '../RNGestureHandlerModule'; -import type RNGestureHandlerModuleWeb from '../RNGestureHandlerModule.web'; import { State } from '../State'; import { handlerIDToTag, @@ -313,9 +312,17 @@ export default function createHandler< this.viewTag = newViewTag; if (Platform.OS === 'web') { + type AttachGestureHandlerWeb = ( + handlerTag: number, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + newView: any, + _actionType: ActionType, + propsRef: React.RefObject + ) => void; + // typecast due to dynamic resolution, attachGestureHandler should have web version signature in this branch ( - RNGestureHandlerModule.attachGestureHandler as typeof RNGestureHandlerModuleWeb.attachGestureHandler + RNGestureHandlerModule.attachGestureHandler as AttachGestureHandlerWeb )( this.handlerTag, newViewTag, From 6f7e58759b004ed6b24006d5b04aaaa038426591 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Fri, 1 Mar 2024 11:59:16 +0100 Subject: [PATCH 04/20] Add madge --- package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/package.json b/package.json index c6ea122430..3ce5d83ada 100644 --- a/package.json +++ b/package.json @@ -63,6 +63,7 @@ "hoist-non-react-statics": "^3.3.0", "invariant": "^2.2.4", "lodash": "^4.17.21", + "madge": "^6.1.0", "prop-types": "^15.7.2" }, "jest": { From 495aae8d7daec42ebcbd7def6804d093dd451a0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Fri, 1 Mar 2024 15:12:38 +0100 Subject: [PATCH 05/20] Remove unused eslint rule --- src/web/handlers/GestureHandlerInterface.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/src/web/handlers/GestureHandlerInterface.ts b/src/web/handlers/GestureHandlerInterface.ts index 19b61bdec6..d1eee05a89 100644 --- a/src/web/handlers/GestureHandlerInterface.ts +++ b/src/web/handlers/GestureHandlerInterface.ts @@ -1,4 +1,3 @@ -/* eslint-disable @typescript-eslint/no-empty-function */ import { PointerType } from '../../PointerType'; import { MouseButton } from '../../handlers/gestureHandlerCommon'; import { State } from '../../State'; From fdb46b8f8ba812029ff62d642255d063cdafa7ac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 5 Mar 2024 17:15:04 +0100 Subject: [PATCH 06/20] Bring back old touch slop value --- src/web/constants.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/web/constants.ts b/src/web/constants.ts index 1ffadef3bf..51aba8a237 100644 --- a/src/web/constants.ts +++ b/src/web/constants.ts @@ -1,4 +1,4 @@ -export const DEFAULT_TOUCH_SLOP = 5; +export const DEFAULT_TOUCH_SLOP = 15; export const Direction = { RIGHT: 1, From 7f92fc9757b90690d8c34897ed70e9035308e8af Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 5 Mar 2024 17:35:50 +0100 Subject: [PATCH 07/20] Minor changes --- src/RNGestureHandlerModule.web.ts | 9 ++++----- src/web/handlers/GestureHandlerInterface.ts | 15 +++++++++------ src/web/tools/NodeManager.ts | 5 +++-- 3 files changed, 16 insertions(+), 13 deletions(-) diff --git a/src/RNGestureHandlerModule.web.ts b/src/RNGestureHandlerModule.web.ts index 64b7dc12d7..bdf885f988 100644 --- a/src/RNGestureHandlerModule.web.ts +++ b/src/RNGestureHandlerModule.web.ts @@ -1,10 +1,9 @@ import React from 'react'; -import { ActionType } from './ActionType'; +import type { ActionType } from './ActionType'; import { isNewWebImplementationEnabled } from './EnableNewWebImplementation'; import { Gestures, HammerGestures } from './web/Gestures'; -import GestureHandlerInterface from './web/handlers/GestureHandlerInterface'; -import { Config } from './web/interfaces'; +import type { Config } from './web/interfaces'; import InteractionManager from './web/tools/InteractionManager'; import NodeManager from './web/tools/NodeManager'; import * as HammerNodeManager from './web_hammer/NodeManager'; @@ -35,7 +34,7 @@ export default { new GestureClass(new GestureHandlerWebDelegate()) ); InteractionManager.getInstance().configureInteractions( - NodeManager.getHandler(handlerTag) as GestureHandlerInterface, + NodeManager.getHandler(handlerTag), config as unknown as Config ); } else { @@ -80,7 +79,7 @@ export default { NodeManager.getHandler(handlerTag).updateGestureConfig(newConfig); InteractionManager.getInstance().configureInteractions( - NodeManager.getHandler(handlerTag) as GestureHandlerInterface, + NodeManager.getHandler(handlerTag), newConfig ); } else { diff --git a/src/web/handlers/GestureHandlerInterface.ts b/src/web/handlers/GestureHandlerInterface.ts index d1eee05a89..c8c1f2f573 100644 --- a/src/web/handlers/GestureHandlerInterface.ts +++ b/src/web/handlers/GestureHandlerInterface.ts @@ -1,10 +1,10 @@ -import { PointerType } from '../../PointerType'; -import { MouseButton } from '../../handlers/gestureHandlerCommon'; -import { State } from '../../State'; -import { Config } from '../interfaces'; -import EventManager from '../tools/EventManager'; +import type { PointerType } from '../../PointerType'; +import type { MouseButton } from '../../handlers/gestureHandlerCommon'; +import type { State } from '../../State'; +import type { Config } from '../interfaces'; +import type EventManager from '../tools/EventManager'; import type { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; -import PointerTracker from '../tools/PointerTracker'; +import type PointerTracker from '../tools/PointerTracker'; export default interface GestureHandlerInterface { getTag: () => number; @@ -24,6 +24,7 @@ export default interface GestureHandlerInterface { begin: () => void; activate: () => void; + end: () => void; fail: () => void; cancel: () => void; @@ -42,4 +43,6 @@ export default interface GestureHandlerInterface { shouldBeCancelledByOther: (handler: GestureHandlerInterface) => boolean; sendEvent: (newState: State, oldState: State) => void; + + updateGestureConfig: (config: Config) => void; } diff --git a/src/web/tools/NodeManager.ts b/src/web/tools/NodeManager.ts index 1dee22dbf2..d37e461718 100644 --- a/src/web/tools/NodeManager.ts +++ b/src/web/tools/NodeManager.ts @@ -1,5 +1,6 @@ import { ValueOf } from '../../typeUtils'; import { Gestures } from '../Gestures'; +import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; // eslint-disable-next-line @typescript-eslint/no-extraneous-class export default abstract class NodeManager { @@ -8,9 +9,9 @@ export default abstract class NodeManager { InstanceType> > = {}; - public static getHandler(tag: number) { + public static getHandler(tag: number): GestureHandlerInterface { if (tag in this.gestures) { - return this.gestures[tag]; + return this.gestures[tag] as GestureHandlerInterface; } throw new Error(`No handler for tag ${tag}`); From 8c57e5d07d60f8f2c9723068ac21f102d2b6f714 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 5 Mar 2024 17:42:38 +0100 Subject: [PATCH 08/20] Remove unnecessary casts --- src/web/handlers/GestureHandler.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index ca78991eb7..26c10b3458 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -242,7 +242,7 @@ export default abstract class GestureHandler } return InteractionManager.getInstance().shouldWaitForHandlerFailure( - this as GestureHandlerInterface, + this, handler ); } @@ -255,7 +255,7 @@ export default abstract class GestureHandler } return InteractionManager.getInstance().shouldRequireHandlerToWaitForFailure( - this as GestureHandlerInterface, + this, handler ); } @@ -268,7 +268,7 @@ export default abstract class GestureHandler } return InteractionManager.getInstance().shouldRecognizeSimultaneously( - this as GestureHandlerInterface, + this, handler ); } @@ -279,7 +279,7 @@ export default abstract class GestureHandler } return InteractionManager.getInstance().shouldHandlerBeCancelledBy( - this as GestureHandlerInterface, + this, handler ); } From f8faba28f625d50598b85a1e3ec8747bb9c56b98 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 5 Mar 2024 17:54:37 +0100 Subject: [PATCH 09/20] Move type out of function --- src/handlers/createHandler.tsx | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/handlers/createHandler.tsx b/src/handlers/createHandler.tsx index abe10b8bb6..c938663944 100644 --- a/src/handlers/createHandler.tsx +++ b/src/handlers/createHandler.tsx @@ -153,6 +153,14 @@ type InternalEventHandlers = { onGestureHandlerStateChange?: (event: any) => void; }; +type AttachGestureHandlerWeb = ( + handlerTag: number, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + newView: any, + _actionType: ActionType, + propsRef: React.RefObject +) => void; + const UNRESOLVED_REFS_RETRY_LIMIT = 1; // TODO(TS) - make sure that BaseGestureHandlerProps doesn't need other generic parameter to work with custom properties. @@ -317,14 +325,6 @@ export default function createHandler< this.viewTag = newViewTag; if (Platform.OS === 'web') { - type AttachGestureHandlerWeb = ( - handlerTag: number, - // eslint-disable-next-line @typescript-eslint/no-explicit-any - newView: any, - _actionType: ActionType, - propsRef: React.RefObject - ) => void; - // typecast due to dynamic resolution, attachGestureHandler should have web version signature in this branch ( RNGestureHandlerModule.attachGestureHandler as AttachGestureHandlerWeb From abe6a113553cc43b25adb5f846dfba79e494509b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Wed, 6 Mar 2024 08:18:49 +0100 Subject: [PATCH 10/20] Add madge as dev dependency --- package.json | 2 +- yarn.lock | 639 ++++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 632 insertions(+), 9 deletions(-) diff --git a/package.json b/package.json index 3ce5d83ada..a1c97f0fc7 100644 --- a/package.json +++ b/package.json @@ -63,7 +63,6 @@ "hoist-non-react-statics": "^3.3.0", "invariant": "^2.2.4", "lodash": "^4.17.21", - "madge": "^6.1.0", "prop-types": "^15.7.2" }, "jest": { @@ -99,6 +98,7 @@ "husky": "^8.0.1", "jest": "^26.6.3", "lint-staged": "^12.3.2", + "madge": "^6.1.0", "prettier": "^2.7.1", "react": "18.2.0", "react-dom": "^16.12.0", diff --git a/yarn.lock b/yarn.lock index 212f29b977..ad489de204 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1129,6 +1129,11 @@ chalk "^2.4.2" js-tokens "^4.0.0" +"@babel/parser@^7.0.0", "@babel/parser@^7.21.4": + version "7.24.0" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.24.0.tgz#26a3d1ff49031c53a97d03b604375f028746a9ac" + integrity sha512-QuP/FxEAzMSjXygs8v4N9dvdXzEHN4W1oF3PxuWAtPo08UdM17u89RDMgjLn/mlc56iM0HlLmVkO/wgR+rDgHg== + "@babel/parser@^7.1.0": version "7.10.5" resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.10.5.tgz#e7c6bf5a7deff957cec9f04b551e2762909d826b" @@ -2920,6 +2925,14 @@ exec-sh "^0.3.2" minimist "^1.2.0" +"@dependents/detective-less@^3.0.1": + version "3.0.2" + resolved "https://registry.yarnpkg.com/@dependents/detective-less/-/detective-less-3.0.2.tgz#c6e46997010fe03a5dc98351a7e99a46d34f5832" + integrity sha512-1YUvQ+e0eeTWAHoN8Uz2x2U37jZs6IGutiIE5LXId7cxfUGhtZjzxE06FdUiuiRrW+UE0vNCdSNPH2lY4dQCOQ== + dependencies: + gonzales-pe "^4.3.0" + node-source-walk "^5.0.1" + "@egjs/hammerjs@^2.0.17": version "2.0.17" resolved "https://registry.yarnpkg.com/@egjs/hammerjs/-/hammerjs-2.0.17.tgz#5dc02af75a6a06e4c2db0202cae38c9263895124" @@ -4120,7 +4133,12 @@ resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.10.1.tgz#dca9bd4cb8c067fc85304a31f38ec4766ba2d1ea" integrity sha512-ZvxQ2QMy49bIIBpTqFiOenucqUyjTQ0WNLhBM6X1fh1NNlYAC6Kxsx8bRTY3jdYsYg44a0Z/uEgQkohbR0H87Q== -"@typescript-eslint/typescript-estree@4.33.0": +"@typescript-eslint/types@5.62.0": + version "5.62.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.62.0.tgz#258607e60effa309f067608931c3df6fed41fd2f" + integrity sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ== + +"@typescript-eslint/typescript-estree@4.33.0", "@typescript-eslint/typescript-estree@^4.33.0": version "4.33.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-4.33.0.tgz#0dfb51c2908f68c5c08d82aefeaf166a17c24609" integrity sha512-rkWRY1MPFzjwnEVHsxGemDzqqddw2QbTJlICPD9p9I9LfsO8fdmfQPOX3uKfUaGRDFJbfrtm/sXhVXN4E+bzCA== @@ -4146,6 +4164,19 @@ semver "^7.3.5" tsutils "^3.21.0" +"@typescript-eslint/typescript-estree@^5.55.0": + version "5.62.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz#7d17794b77fabcac615d6a48fb143330d962eb9b" + integrity sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA== + dependencies: + "@typescript-eslint/types" "5.62.0" + "@typescript-eslint/visitor-keys" "5.62.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + semver "^7.3.7" + tsutils "^3.21.0" + "@typescript-eslint/utils@^5.10.0": version "5.10.1" resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.10.1.tgz#fa682a33af47080ba2c4368ee0ad2128213a1196" @@ -4174,6 +4205,14 @@ "@typescript-eslint/types" "5.10.1" eslint-visitor-keys "^3.0.0" +"@typescript-eslint/visitor-keys@5.62.0": + version "5.62.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz#2174011917ce582875954ffe2f6912d5931e353e" + integrity sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw== + dependencies: + "@typescript-eslint/types" "5.62.0" + eslint-visitor-keys "^3.3.0" + "@unimodules/core@~4.0.0": version "4.0.0" resolved "https://registry.yarnpkg.com/@unimodules/core/-/core-4.0.0.tgz#898dafa5a121e7d6d7d4acd9c0c38d12f7da5b19" @@ -4369,6 +4408,11 @@ ansi-styles@^6.0.0: resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-6.1.0.tgz#87313c102b8118abd57371afab34618bf7350ed3" integrity sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ== +any-promise@^1.1.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f" + integrity sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A== + anymatch@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-2.0.0.tgz#bcb24b4f37934d9aa7ac17b4adaf89e7c76ef2eb" @@ -4383,6 +4427,11 @@ anymatch@^3.0.3: normalize-path "^3.0.0" picomatch "^2.0.4" +app-module-path@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/app-module-path/-/app-module-path-2.2.0.tgz#641aa55dfb7d6a6f0a8141c4b9c0aa50b6c24dd5" + integrity sha512-gkco+qxENJV+8vFcDiiFhuoSvRXb2a/QPqpSoWhVz829VNJfOTnELbBmPmNKFxf3xdNnw4DWCkzkDaavcX/1YQ== + appdirsjs@^1.2.4: version "1.2.6" resolved "https://registry.yarnpkg.com/appdirsjs/-/appdirsjs-1.2.6.tgz#fccf9ee543315492867cacfcfd4a2b32257d30ac" @@ -4471,6 +4520,21 @@ assign-symbols@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367" +ast-module-types@^2.7.1: + version "2.7.1" + resolved "https://registry.yarnpkg.com/ast-module-types/-/ast-module-types-2.7.1.tgz#3f7989ef8dfa1fdb82dfe0ab02bdfc7c77a57dd3" + integrity sha512-Rnnx/4Dus6fn7fTqdeLEAn5vUll5w7/vts0RN608yFa6si/rDOUonlIIiwugHBFWjylHjxm9owoSZn71KwG4gw== + +ast-module-types@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/ast-module-types/-/ast-module-types-3.0.0.tgz#9a6d8a80f438b6b8fe4995699d700297f398bf81" + integrity sha512-CMxMCOCS+4D+DkOQfuZf+vLrSEmY/7xtORwdxs4wtcC1wVgvk2MqFFTwQCFhvWsI4KPU9lcWXPI8DgRiz+xetQ== + +ast-module-types@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/ast-module-types/-/ast-module-types-4.0.0.tgz#17e1cadd5b5b108e7295b0cf0cff21ccc226b639" + integrity sha512-Kd0o8r6CDazJGCRzs8Ivpn0xj19oNKrULhoJFzhGjRsLpekF2zyZs9Ukz+JvZhWD6smszfepakTFhAaYpsI12g== + ast-types@0.15.2: version "0.15.2" resolved "https://registry.yarnpkg.com/ast-types/-/ast-types-0.15.2.tgz#39ae4809393c4b16df751ee563411423e85fb49d" @@ -4942,7 +5006,7 @@ chalk@^3.0.0: ansi-styles "^4.1.0" supports-color "^7.1.0" -chalk@^4.0.2, chalk@^4.1.2: +chalk@^4.0.2, chalk@^4.1.1, chalk@^4.1.2: version "4.1.2" resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== @@ -5141,7 +5205,7 @@ color-name@1.1.3: resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= -color-name@~1.1.4: +color-name@^1.1.4, color-name@~1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== @@ -5172,17 +5236,22 @@ command-exists@^1.2.8: resolved "https://registry.yarnpkg.com/command-exists/-/command-exists-1.2.9.tgz#c50725af3808c8ab0260fd60b01fbfa25b954f69" integrity sha512-LTQ/SGc+s0Xc0Fu5WaKnR0YiygZkm9eKFvyS+fRsU7/ZWFF8ykFM6Pc9aCVf1+xasOOZpO3BAVgVrKvsqKHV7w== -commander@^2.20.0: +commander@^2.16.0, commander@^2.20.0, commander@^2.20.3, commander@^2.8.1: version "2.20.3" resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33" integrity sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ== +commander@^7.2.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/commander/-/commander-7.2.0.tgz#a36cb57d0b501ce108e4d20559a150a391d97ab7" + integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== + commander@^8.3.0: version "8.3.0" resolved "https://registry.yarnpkg.com/commander/-/commander-8.3.0.tgz#4837ea1b2da67b9c616a67afbb0fafee567bca66" integrity sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww== -commander@^9.4.1: +commander@^9.4.1, commander@^9.5.0: version "9.5.0" resolved "https://registry.yarnpkg.com/commander/-/commander-9.5.0.tgz#bc08d1eb5cedf7ccb797a96199d41c7bc3e60d30" integrity sha512-KRs7WVDKg86PWiuAqhDrAQnTXZKraVcCc6vFdL14qrZ/DcWwuRo7VoiYXalXO7S5GKpqYiVEwCbgFDfxNHKJBQ== @@ -5419,6 +5488,13 @@ debug@4.1.1, debug@^4.1.1: dependencies: ms "^2.1.1" +debug@^4.0.0, debug@^4.3.4: + version "4.3.4" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + debug@^4.0.1: version "4.3.1" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.1.tgz#f0d229c505e0c6d8c49ac553d1b13dc183f6b2ee" @@ -5552,6 +5628,17 @@ depd@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" +dependency-tree@^9.0.0: + version "9.0.0" + resolved "https://registry.yarnpkg.com/dependency-tree/-/dependency-tree-9.0.0.tgz#9288dd6daf35f6510c1ea30d9894b75369aa50a2" + integrity sha512-osYHZJ1fBSon3lNLw70amAXsQ+RGzXsPvk9HbBgTLbp/bQBmpH5mOmsUvqXU+YEWVU0ZLewsmzOET/8jWswjDQ== + dependencies: + commander "^2.20.3" + debug "^4.3.1" + filing-cabinet "^3.0.1" + precinct "^9.0.0" + typescript "^4.0.0" + deprecated-obj@1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/deprecated-obj/-/deprecated-obj-1.0.1.tgz#d7051278d2c141dc672ac3410d06642e990003b7" @@ -5590,6 +5677,151 @@ detect-repo-changelog@1.0.1: lodash.find "^4.6.0" pify "^2.3.0" +detective-amd@^3.1.0: + version "3.1.2" + resolved "https://registry.yarnpkg.com/detective-amd/-/detective-amd-3.1.2.tgz#bf55eb5291c218b76d6224a3d07932ef13a9a357" + integrity sha512-jffU26dyqJ37JHR/o44La6CxtrDf3Rt9tvd2IbImJYxWKTMdBjctp37qoZ6ZcY80RHg+kzWz4bXn39e4P7cctQ== + dependencies: + ast-module-types "^3.0.0" + escodegen "^2.0.0" + get-amd-module-type "^3.0.0" + node-source-walk "^4.2.0" + +detective-amd@^4.0.1, detective-amd@^4.1.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/detective-amd/-/detective-amd-4.2.0.tgz#21c43465669f06cf894eef047a27e6e72ba6bc13" + integrity sha512-RbuEJHz78A8nW7CklkqTzd8lDCN42En53dgEIsya0DilpkwslamSZDasLg8dJyxbw46OxhSQeY+C2btdSkCvQQ== + dependencies: + ast-module-types "^4.0.0" + escodegen "^2.0.0" + get-amd-module-type "^4.1.0" + node-source-walk "^5.0.1" + +detective-cjs@^3.1.1: + version "3.1.3" + resolved "https://registry.yarnpkg.com/detective-cjs/-/detective-cjs-3.1.3.tgz#50e107d67b37f459b0ec02966ceb7e20a73f268b" + integrity sha512-ljs7P0Yj9MK64B7G0eNl0ThWSYjhAaSYy+fQcpzaKalYl/UoQBOzOeLCSFEY1qEBhziZ3w7l46KG/nH+s+L7BQ== + dependencies: + ast-module-types "^3.0.0" + node-source-walk "^4.0.0" + +detective-cjs@^4.0.0, detective-cjs@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/detective-cjs/-/detective-cjs-4.1.0.tgz#56b1558ca0910933c7fc47c740b957f0280ff302" + integrity sha512-QxzMwt5MfPLwS7mG30zvnmOvHLx5vyVvjsAV6gQOyuMoBR5G1DhS1eJZ4P10AlH+HSnk93mTcrg3l39+24XCtg== + dependencies: + ast-module-types "^4.0.0" + node-source-walk "^5.0.1" + +detective-es6@^2.2.1: + version "2.2.2" + resolved "https://registry.yarnpkg.com/detective-es6/-/detective-es6-2.2.2.tgz#ee5f880981d9fecae9a694007029a2f6f26d8d28" + integrity sha512-eZUKCUsbHm8xoeoCM0z6JFwvDfJ5Ww5HANo+jPR7AzkFpW9Mun3t/TqIF2jjeWa2TFbAiGaWESykf2OQp3oeMw== + dependencies: + node-source-walk "^4.0.0" + +detective-es6@^3.0.0, detective-es6@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/detective-es6/-/detective-es6-3.0.1.tgz#53a15fbb2f298c4a106d9fe7427da8a57162dde6" + integrity sha512-evPeYIEdK1jK3Oji5p0hX4sPV/1vK+o4ihcWZkMQE6voypSW/cIBiynOLxQk5KOOQbdP8oOAsYqouMTYO5l1sw== + dependencies: + node-source-walk "^5.0.0" + +detective-less@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/detective-less/-/detective-less-1.0.2.tgz#a68af9ca5f69d74b7d0aa190218b211d83b4f7e3" + integrity sha512-Rps1xDkEEBSq3kLdsdnHZL1x2S4NGDcbrjmd4q+PykK5aJwDdP5MBgrJw1Xo+kyUHuv3JEzPqxr+Dj9ryeDRTA== + dependencies: + debug "^4.0.0" + gonzales-pe "^4.2.3" + node-source-walk "^4.0.0" + +detective-postcss@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/detective-postcss/-/detective-postcss-4.0.0.tgz#24e69b465e5fefe7a6afd05f7e894e34595dbf51" + integrity sha512-Fwc/g9VcrowODIAeKRWZfVA/EufxYL7XfuqJQFroBKGikKX83d2G7NFw6kDlSYGG3LNQIyVa+eWv1mqre+v4+A== + dependencies: + debug "^4.1.1" + is-url "^1.2.4" + postcss "^8.1.7" + postcss-values-parser "^2.0.1" + +detective-postcss@^6.1.0, detective-postcss@^6.1.1: + version "6.1.3" + resolved "https://registry.yarnpkg.com/detective-postcss/-/detective-postcss-6.1.3.tgz#51a2d4419327ad85d0af071c7054c79fafca7e73" + integrity sha512-7BRVvE5pPEvk2ukUWNQ+H2XOq43xENWbH0LcdCE14mwgTBEAMoAx+Fc1rdp76SmyZ4Sp48HlV7VedUnP6GA1Tw== + dependencies: + is-url "^1.2.4" + postcss "^8.4.23" + postcss-values-parser "^6.0.2" + +detective-sass@^3.0.1: + version "3.0.2" + resolved "https://registry.yarnpkg.com/detective-sass/-/detective-sass-3.0.2.tgz#e0f35aac79a4d2f6409c284d95b8f7ecd5973afd" + integrity sha512-DNVYbaSlmti/eztFGSfBw4nZvwsTaVXEQ4NsT/uFckxhJrNRFUh24d76KzoCC3aarvpZP9m8sC2L1XbLej4F7g== + dependencies: + gonzales-pe "^4.3.0" + node-source-walk "^4.0.0" + +detective-sass@^4.0.1, detective-sass@^4.1.1: + version "4.1.3" + resolved "https://registry.yarnpkg.com/detective-sass/-/detective-sass-4.1.3.tgz#6cdcc27ae8a90d15704e0ba83683048f77f10b75" + integrity sha512-xGRbwGaGte57gvEqM8B9GDiURY3El/H49vA6g9wFkxq9zalmTlTAuqWu+BsH0iwonGPruLt55tZZDEZqPc6lag== + dependencies: + gonzales-pe "^4.3.0" + node-source-walk "^5.0.1" + +detective-scss@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/detective-scss/-/detective-scss-2.0.2.tgz#7d2a642616d44bf677963484fa8754d9558b8235" + integrity sha512-hDWnWh/l0tht/7JQltumpVea/inmkBaanJUcXRB9kEEXVwVUMuZd6z7eusQ6GcBFrfifu3pX/XPyD7StjbAiBg== + dependencies: + gonzales-pe "^4.3.0" + node-source-walk "^4.0.0" + +detective-scss@^3.0.0, detective-scss@^3.0.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/detective-scss/-/detective-scss-3.1.1.tgz#b49f05cadfb0837b04e23baba292581b7c7f65e1" + integrity sha512-FWkfru1jZBhUeuBsOeGKXKAVDrzYFSQFK2o2tuG/nCCFQ0U/EcXC157MNAcR5mmj+mCeneZzlkBOFJTesDjrww== + dependencies: + gonzales-pe "^4.3.0" + node-source-walk "^5.0.1" + +detective-stylus@^1.0.0: + version "1.0.3" + resolved "https://registry.yarnpkg.com/detective-stylus/-/detective-stylus-1.0.3.tgz#20a702936c9fd7d4203fd7a903314b5dd43ac713" + integrity sha512-4/bfIU5kqjwugymoxLXXLltzQNeQfxGoLm2eIaqtnkWxqbhap9puDVpJPVDx96hnptdERzS5Cy6p9N8/08A69Q== + +detective-stylus@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/detective-stylus/-/detective-stylus-2.0.1.tgz#d528dfa7ef3c4eb2fbc9a7249d54906ec4e05d09" + integrity sha512-/Tvs1pWLg8eYwwV6kZQY5IslGaYqc/GACxjcaGudiNtN5nKCH6o2WnJK3j0gA3huCnoQcbv8X7oz/c1lnvE3zQ== + +detective-stylus@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/detective-stylus/-/detective-stylus-3.0.0.tgz#c869795a7d6df7043ab6aee8b1a6f3dd66764232" + integrity sha512-1xYTzbrduExqMYmte7Qk99IRA3Aa6oV7PYzd+3yDcQXkmENvyGF/arripri6lxRDdNYEb4fZFuHtNRAXbz3iAA== + +detective-typescript@^7.0.0: + version "7.0.2" + resolved "https://registry.yarnpkg.com/detective-typescript/-/detective-typescript-7.0.2.tgz#c6e00b4c28764741ef719662250e6b014a5f3c8e" + integrity sha512-unqovnhxzvkCz3m1/W4QW4qGsvXCU06aU2BAm8tkza+xLnp9SOFnob2QsTxUv5PdnQKfDvWcv9YeOeFckWejwA== + dependencies: + "@typescript-eslint/typescript-estree" "^4.33.0" + ast-module-types "^2.7.1" + node-source-walk "^4.2.0" + typescript "^3.9.10" + +detective-typescript@^9.0.0, detective-typescript@^9.1.1: + version "9.1.1" + resolved "https://registry.yarnpkg.com/detective-typescript/-/detective-typescript-9.1.1.tgz#b99c0122cbb35b39de2c5f58447f1e93ac28c6d5" + integrity sha512-Uc1yVutTF0RRm1YJ3g//i1Cn2vx1kwHj15cnzQP6ff5koNzQ0idc1zAC73ryaWEulA0ElRXFTq6wOqe8vUQ3MA== + dependencies: + "@typescript-eslint/typescript-estree" "^5.55.0" + ast-module-types "^4.0.0" + node-source-walk "^5.0.1" + typescript "^4.9.5" + diff-sequences@^24.9.0: version "24.9.0" resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-24.9.0.tgz#5715d6244e2aa65f48bba0bc972db0b0b11e95b5" @@ -5716,6 +5948,14 @@ end-of-stream@^1.1.0: dependencies: once "^1.4.0" +enhanced-resolve@^5.8.3: + version "5.15.1" + resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.15.1.tgz#384391e025f099e67b4b00bfd7f0906a408214e1" + integrity sha512-3d3JRbwsCLJsYgvb6NuWEG44jjPSOMuS73L/6+7BZuoKm3W+qXnSoIYVHi8dG7Qcg4inAY4jbzkZ7MnskePeDg== + dependencies: + graceful-fs "^4.2.4" + tapable "^2.2.0" + enquirer@^2.3.5: version "2.3.6" resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.3.6.tgz#2a7fe5dd634a1e4125a975ec994ff5456dc3734d" @@ -6053,6 +6293,11 @@ eslint-visitor-keys@^3.0.0: resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.2.0.tgz#6fbb166a6798ee5991358bc2daa1ba76cc1254a1" integrity sha512-IOzT0X126zn7ALX0dwFiUQEdsfzrm4+ISsQS8nukaJXwEyYKRSnEIIDULYg1mCtGp7UUXgfGl7BIolXREQK+XQ== +eslint-visitor-keys@^3.3.0: + version "3.4.3" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800" + integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== + eslint@^7.32.0: version "7.32.0" resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.32.0.tgz#c6d328a14be3fb08c8d1d21e12c02fdb7a2a812d" @@ -6531,6 +6776,25 @@ filelist@^1.0.1: dependencies: minimatch "^5.0.1" +filing-cabinet@^3.0.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/filing-cabinet/-/filing-cabinet-3.3.1.tgz#45d87bb273a0e0a7dd6ac6bac9111059186e2e9c" + integrity sha512-renEK4Hh6DUl9Vl22Y3cxBq1yh8oNvbAdXnhih0wVpmea+uyKjC9K4QeRjUaybIiIewdzfum+Fg15ZqJ/GyCaA== + dependencies: + app-module-path "^2.2.0" + commander "^2.20.3" + debug "^4.3.3" + enhanced-resolve "^5.8.3" + is-relative-path "^1.0.2" + module-definition "^3.3.1" + module-lookup-amd "^7.0.1" + resolve "^1.21.0" + resolve-dependency-path "^2.0.0" + sass-lookup "^3.0.0" + stylus-lookup "^3.0.1" + tsconfig-paths "^3.10.1" + typescript "^3.9.7" + fill-range@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7" @@ -6620,6 +6884,11 @@ flatted@^3.1.0: resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.1.0.tgz#a5d06b4a8b01e3a63771daa5cb7a1903e2e57067" integrity sha512-tW+UkmtNg/jv9CSofAKvgVcO7c2URjhTdW1ZTkcAritblu8tajiYy7YisnIflEwtKssCtOxpnBRoCB7iap0/TA== +flatten@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/flatten/-/flatten-1.0.3.tgz#c1283ac9f27b368abc1e36d1ff7b04501a30356b" + integrity sha512-dVsPA/UwQ8+2uoFe5GHtiBMu48dWLTdsuEd7CKGlZlD78r1TTWBvDuFaFGKCo/ZfEr95Uk56vZoX86OsHkUeIg== + flow-enums-runtime@^0.0.6: version "0.0.6" resolved "https://registry.yarnpkg.com/flow-enums-runtime/-/flow-enums-runtime-0.0.6.tgz#5bb0cd1b0a3e471330f4d109039b7eba5cb3e787" @@ -6710,6 +6979,11 @@ function-bind@^1.1.1: resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== +function-bind@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" + integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== + functional-red-black-tree@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" @@ -6720,6 +6994,22 @@ gensync@^1.0.0-beta.1, gensync@^1.0.0-beta.2: resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== +get-amd-module-type@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/get-amd-module-type/-/get-amd-module-type-3.0.2.tgz#46550cee2b8e1fa4c3f2c8a5753c36990aa49ab0" + integrity sha512-PcuKwB8ouJnKuAPn6Hk3UtdfKoUV3zXRqVEvj8XGIXqjWfgd1j7QGdXy5Z9OdQfzVt1Sk29HVe/P+X74ccOuqw== + dependencies: + ast-module-types "^3.0.0" + node-source-walk "^4.2.2" + +get-amd-module-type@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/get-amd-module-type/-/get-amd-module-type-4.1.0.tgz#af1396d02cd935cb6fafdc4a5282395db3422db6" + integrity sha512-0e/eK6vTGCnSfQ6eYs3wtH05KotJYIP7ZIZEueP/KlA+0dIAEs8bYFvOd/U56w1vfjhJqBagUxVMyy9Tr/cViQ== + dependencies: + ast-module-types "^4.0.0" + node-source-walk "^5.0.1" + get-caller-file@^2.0.1, get-caller-file@^2.0.5: version "2.0.5" resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" @@ -6751,6 +7041,11 @@ get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: has "^1.0.3" has-symbols "^1.0.1" +get-own-enumerable-property-symbols@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz#b5fde77f22cbe35f390b4e089922c50bce6ef664" + integrity sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g== + get-package-type@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" @@ -6879,7 +7174,7 @@ globby@11.0.1, globby@^11.0.1: merge2 "^1.3.0" slash "^3.0.0" -globby@^11.0.3, globby@^11.0.4: +globby@^11.0.3, globby@^11.0.4, globby@^11.1.0: version "11.1.0" resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== @@ -6891,6 +7186,13 @@ globby@^11.0.3, globby@^11.0.4: merge2 "^1.4.1" slash "^3.0.0" +gonzales-pe@^4.2.3, gonzales-pe@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/gonzales-pe/-/gonzales-pe-4.3.0.tgz#fe9dec5f3c557eead09ff868c65826be54d067b3" + integrity sha512-otgSPpUmdWJ43VXyiNgEYE4luzHCL2pz4wQ0OnDluC6Eg4Ko3Vexy/SrSynglw/eR+OhkzmqFCZa/OFa/RgAOQ== + dependencies: + minimist "^1.2.5" + got@11.5.0: version "11.5.0" resolved "https://registry.yarnpkg.com/got/-/got-11.5.0.tgz#55dd61050f666679f46c49c877e1b2e064a7a523" @@ -7016,6 +7318,13 @@ has@^1.0.3: dependencies: function-bind "^1.1.1" +hasown@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.1.tgz#26f48f039de2c0f8d3356c223fb8d50253519faa" + integrity sha512-1/th4MHjnwncwXsIW6QMzlvYL9kG5e/CpVvLRZe4XPa8TOUNbCELqmvhDmnkNsAjwaG4+I8gJJL0JBvTTLO9qA== + dependencies: + function-bind "^1.1.2" + hermes-estree@0.15.0: version "0.15.0" resolved "https://registry.yarnpkg.com/hermes-estree/-/hermes-estree-0.15.0.tgz#e32f6210ab18c7b705bdcb375f7700f2db15d6ba" @@ -7230,6 +7539,11 @@ indent-string@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" +indexes-of@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/indexes-of/-/indexes-of-1.0.1.tgz#f30f716c8e2bd346c7b67d3df3915566a7c05607" + integrity sha512-bup+4tap3Hympa+JBJUG7XuOsdNQ6fxt0MHyXMKuLBKn0OqsTfvUxkUrroEX1+B2VsSHvCjiIcZVxRtYa4nllA== + inflight@^1.0.4: version "1.0.6" resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" @@ -7370,6 +7684,13 @@ is-core-module@^2.1.0: dependencies: has "^1.0.3" +is-core-module@^2.13.0: + version "2.13.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.13.1.tgz#ad0d7532c6fea9da1ebdc82742d74525c6273384" + integrity sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw== + dependencies: + hasown "^2.0.0" + is-core-module@^2.2.0: version "2.8.0" resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.8.0.tgz#0321336c3d0925e497fd97f5d95cb114a5ccd548" @@ -7529,7 +7850,7 @@ is-number@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" -is-obj@^1.0.0: +is-obj@^1.0.0, is-obj@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f" @@ -7583,10 +7904,20 @@ is-regex@^1.1.4: call-bind "^1.0.2" has-tostringtag "^1.0.0" +is-regexp@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz#fd2d883545c46bac5a633e7b9a09e87fa2cb5069" + integrity sha512-7zjFAPO4/gwyQAAgRRmqeEeyIICSdmCqa3tsVHMdBzaXXRiqopZL4Cyghg/XulGWrtABTpbnYYzzIRffLkP4oA== + is-regular-file@^1.0.1: version "1.1.1" resolved "https://registry.yarnpkg.com/is-regular-file/-/is-regular-file-1.1.1.tgz#ffcf9cae56ec63bc55b17d6fed1af441986dab66" +is-relative-path@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-relative-path/-/is-relative-path-1.0.2.tgz#091b46a0d67c1ed0fe85f1f8cfdde006bb251d46" + integrity sha512-i1h+y50g+0hRbBD+dbnInl3JlJ702aar58snAeX+MxBAPvzXGej7sYoPMhlnykabt0ZzCJNBEyzMlekuQZN7fA== + is-relative@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/is-relative/-/is-relative-1.0.0.tgz#a1bb6935ce8c5dba1e8b9754b9b2dcc020e2260d" @@ -7654,6 +7985,16 @@ is-unicode-supported@^0.1.0: resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== +is-url-superb@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/is-url-superb/-/is-url-superb-4.0.0.tgz#b54d1d2499bb16792748ac967aa3ecb41a33a8c2" + integrity sha512-GI+WjezhPPcbM+tqE9LnmsY5qqjwHzTvjJ36wxYX5ujNXefSUJ/T17r5bqDV8yLhcgB59KTPNOc9O9cmHTPWsA== + +is-url@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/is-url/-/is-url-1.2.4.tgz#04a4df46d28c4cff3d73d01ff06abeb318a1aa52" + integrity sha512-ITvGim8FhRiYe4IQ5uHSkj7pVaPDrCTkNd3yq3cV7iZAcJdHTUMPMEHcqSOy9xZ9qFenQCvi+2wjH9a1nXqHww== + is-weakref@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" @@ -8388,6 +8729,13 @@ json5@^1.0.1: dependencies: minimist "^1.2.0" +json5@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.2.tgz#63d98d60f21b313b77c4d6da18bfa69d80e1d593" + integrity sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA== + dependencies: + minimist "^1.2.0" + json5@^2.1.2, json5@^2.1.3: version "2.2.0" resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.0.tgz#2dfefe720c6ba525d9ebd909950f0515316c89a3" @@ -8675,6 +9023,34 @@ macos-release@^2.2.0: version "2.4.0" resolved "https://registry.yarnpkg.com/macos-release/-/macos-release-2.4.0.tgz#837b39fc01785c3584f103c5599e0f0c8068b49e" +madge@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/madge/-/madge-6.1.0.tgz#9835bb53f2e00d184914c2b007b50736a964d297" + integrity sha512-irWhT5RpFOc6lkzGHKLihonCVgM0YtfNUh4IrFeW3EqHpnt/JHUG3z26j8PeJEktCGB4tmGOOOJi1Rl/ACWucQ== + dependencies: + chalk "^4.1.1" + commander "^7.2.0" + commondir "^1.0.1" + debug "^4.3.1" + dependency-tree "^9.0.0" + detective-amd "^4.0.1" + detective-cjs "^4.0.0" + detective-es6 "^3.0.0" + detective-less "^1.0.2" + detective-postcss "^6.1.0" + detective-sass "^4.0.1" + detective-scss "^3.0.0" + detective-stylus "^2.0.1" + detective-typescript "^9.0.0" + ora "^5.4.1" + pluralize "^8.0.0" + precinct "^8.1.0" + pretty-ms "^7.0.1" + rc "^1.2.7" + stream-to-array "^2.3.0" + ts-graphviz "^1.5.0" + walkdir "^0.4.1" + make-dir@^2.0.0, make-dir@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" @@ -9072,6 +9448,11 @@ minimist@^1.1.1, minimist@^1.2.0, minimist@^1.2.5: resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== +minimist@^1.2.6: + version "1.2.8" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" + integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== + mixin-deep@^1.2.0: version "1.3.2" resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" @@ -9090,6 +9471,33 @@ mkdirp@^1.0.4: resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== +module-definition@^3.3.1: + version "3.4.0" + resolved "https://registry.yarnpkg.com/module-definition/-/module-definition-3.4.0.tgz#953a3861f65df5e43e80487df98bb35b70614c2b" + integrity sha512-XxJ88R1v458pifaSkPNLUTdSPNVGMP2SXVncVmApGO+gAfrLANiYe6JofymCzVceGOMwQE2xogxBSc8uB7XegA== + dependencies: + ast-module-types "^3.0.0" + node-source-walk "^4.0.0" + +module-definition@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/module-definition/-/module-definition-4.1.0.tgz#148ff9348e3401867229dcbe5947f4f6d5ccd3a2" + integrity sha512-rHXi/DpMcD2qcKbPCTklDbX9lBKJrUSl971TW5l6nMpqKCIlzJqmQ8cfEF5M923h2OOLHPDVlh5pJxNyV+AJlw== + dependencies: + ast-module-types "^4.0.0" + node-source-walk "^5.0.1" + +module-lookup-amd@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/module-lookup-amd/-/module-lookup-amd-7.0.1.tgz#d67c1a93f2ff8e38b8774b99a638e9a4395774b2" + integrity sha512-w9mCNlj0S8qviuHzpakaLVc+/7q50jl9a/kmJ/n8bmXQZgDPkQHnPBb8MUOYh3WpAYkXuNc2c+khsozhIp/amQ== + dependencies: + commander "^2.8.1" + debug "^4.1.0" + glob "^7.1.6" + requirejs "^2.3.5" + requirejs-config-file "^4.0.0" + ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" @@ -9111,6 +9519,11 @@ mute-stream@0.0.8: version "0.0.8" resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.8.tgz#1630c42b2251ff81e2a283de96a5497ea92e5e0d" +nanoid@^3.3.7: + version "3.3.7" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.7.tgz#d0c301a691bc8d54efa0a2226ccf3fe2fd656bd8" + integrity sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g== + nanomatch@^1.2.9: version "1.2.13" resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" @@ -9214,6 +9627,20 @@ node-releases@^2.0.6: resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.8.tgz#0f349cdc8fcfa39a92ac0be9bc48b7706292b9ae" integrity sha512-dFSmB8fFHEH/s81Xi+Y/15DQY6VHW81nXRj86EMSL3lmuTmK1e+aT4wrFCkTbm+gSwkw4KpX+rT/pMM2c1mF+A== +node-source-walk@^4.0.0, node-source-walk@^4.2.0, node-source-walk@^4.2.2: + version "4.3.0" + resolved "https://registry.yarnpkg.com/node-source-walk/-/node-source-walk-4.3.0.tgz#8336b56cfed23ac5180fe98f1e3bb6b11fd5317c" + integrity sha512-8Q1hXew6ETzqKRAs3jjLioSxNfT1cx74ooiF8RlAONwVMcfq+UdzLC2eB5qcPldUxaE5w3ytLkrmV1TGddhZTA== + dependencies: + "@babel/parser" "^7.0.0" + +node-source-walk@^5.0.0, node-source-walk@^5.0.1: + version "5.0.2" + resolved "https://registry.yarnpkg.com/node-source-walk/-/node-source-walk-5.0.2.tgz#0eb439ce378946ce531e07a6a0073d06288396dd" + integrity sha512-Y4jr/8SRS5hzEdZ7SGuvZGwfORvNsSsNRwDXx5WisiqzsVfeftDvRgfeqWNgZvWSJbgubTRVRYBzK6UO+ErqjA== + dependencies: + "@babel/parser" "^7.21.4" + node-stream-zip@^1.9.1: version "1.12.0" resolved "https://registry.yarnpkg.com/node-stream-zip/-/node-stream-zip-1.12.0.tgz#f69af78799531b928662f4900d345387fa0b3777" @@ -9604,6 +10031,11 @@ parse-json@^4.0.0: error-ex "^1.3.1" json-parse-better-errors "^1.0.1" +parse-ms@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/parse-ms/-/parse-ms-2.1.0.tgz#348565a753d4391fa524029956b172cb7753097d" + integrity sha512-kHt7kzLoS9VBZfUsiKjv43mr91ea+U05EyKkEtqp7vNbHxmaVuEqN7XxeEVnGrMtYOAxGrDElSi96K7EgO1zCA== + parse-path@^4.0.0: version "4.0.1" resolved "https://registry.yarnpkg.com/parse-path/-/parse-path-4.0.1.tgz#0ec769704949778cb3b8eda5e994c32073a1adff" @@ -9742,15 +10174,84 @@ pkg-up@^3.1.0: dependencies: find-up "^3.0.0" +pluralize@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/pluralize/-/pluralize-8.0.0.tgz#1a6fa16a38d12a1901e0320fa017051c539ce3b1" + integrity sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA== + posix-character-classes@^0.1.0: version "0.1.1" resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" +postcss-values-parser@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/postcss-values-parser/-/postcss-values-parser-2.0.1.tgz#da8b472d901da1e205b47bdc98637b9e9e550e5f" + integrity sha512-2tLuBsA6P4rYTNKCXYG/71C7j1pU6pK503suYOmn4xYrQIzW+opD+7FAFNuGSdZC/3Qfy334QbeMu7MEb8gOxg== + dependencies: + flatten "^1.0.2" + indexes-of "^1.0.1" + uniq "^1.0.1" + +postcss-values-parser@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/postcss-values-parser/-/postcss-values-parser-6.0.2.tgz#636edc5b86c953896f1bb0d7a7a6615df00fb76f" + integrity sha512-YLJpK0N1brcNJrs9WatuJFtHaV9q5aAOj+S4DI5S7jgHlRfm0PIbDCAFRYMQD5SHq7Fy6xsDhyutgS0QOAs0qw== + dependencies: + color-name "^1.1.4" + is-url-superb "^4.0.0" + quote-unquote "^1.0.0" + +postcss@^8.1.7, postcss@^8.4.23: + version "8.4.35" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.35.tgz#60997775689ce09011edf083a549cea44aabe2f7" + integrity sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA== + dependencies: + nanoid "^3.3.7" + picocolors "^1.0.0" + source-map-js "^1.0.2" + pouchdb-collections@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/pouchdb-collections/-/pouchdb-collections-1.0.1.tgz#fe63a17da977611abef7cb8026cb1a9553fd8359" integrity sha1-/mOhfal3YRq+98uAJssalVP9g1k= +precinct@^8.1.0: + version "8.3.1" + resolved "https://registry.yarnpkg.com/precinct/-/precinct-8.3.1.tgz#94b99b623df144eed1ce40e0801c86078466f0dc" + integrity sha512-pVppfMWLp2wF68rwHqBIpPBYY8Kd12lDhk8LVQzOwqllifVR15qNFyod43YLyFpurKRZQKnE7E4pofAagDOm2Q== + dependencies: + commander "^2.20.3" + debug "^4.3.3" + detective-amd "^3.1.0" + detective-cjs "^3.1.1" + detective-es6 "^2.2.1" + detective-less "^1.0.2" + detective-postcss "^4.0.0" + detective-sass "^3.0.1" + detective-scss "^2.0.1" + detective-stylus "^1.0.0" + detective-typescript "^7.0.0" + module-definition "^3.3.1" + node-source-walk "^4.2.0" + +precinct@^9.0.0: + version "9.2.1" + resolved "https://registry.yarnpkg.com/precinct/-/precinct-9.2.1.tgz#db0a67abff7b0a9a3b2b1ac33d170e8a5fcac7b2" + integrity sha512-uzKHaTyiVejWW7VJtHInb9KBUq9yl9ojxXGujhjhDmPon2wgZPBKQIKR+6csGqSlUeGXAA4MEFnU6DesxZib+A== + dependencies: + "@dependents/detective-less" "^3.0.1" + commander "^9.5.0" + detective-amd "^4.1.0" + detective-cjs "^4.1.0" + detective-es6 "^3.0.1" + detective-postcss "^6.1.1" + detective-sass "^4.1.1" + detective-scss "^3.0.1" + detective-stylus "^3.0.0" + detective-typescript "^9.1.1" + module-definition "^4.1.0" + node-source-walk "^5.0.1" + prelude-ls@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" @@ -9823,6 +10324,13 @@ pretty-format@^29.7.0: ansi-styles "^5.0.0" react-is "^18.0.0" +pretty-ms@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/pretty-ms/-/pretty-ms-7.0.1.tgz#7d903eaab281f7d8e03c66f867e239dc32fb73e8" + integrity sha512-973driJZvxiGOQ5ONsFhOF/DtzPMOMtgC11kCpUrPGMTgqp2q/1gwzCquocrN33is0VZ5GFHXZYMM9l6h67v2Q== + dependencies: + parse-ms "^2.1.0" + process-nextick-args@~2.0.0: version "2.0.1" resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" @@ -9940,6 +10448,11 @@ quick-lru@^5.1.1: version "5.1.1" resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" +quote-unquote@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/quote-unquote/-/quote-unquote-1.0.0.tgz#67a9a77148effeaf81a4d428404a710baaac8a0b" + integrity sha512-twwRO/ilhlG/FIgYeKGFqyHhoEhqgnKVkcmqMKi2r524gz3ZbDTcyFt38E9xjJI2vT+KbRNHVbnJ/e0I25Azwg== + ramda@^0.26.1: version "0.26.1" resolved "https://registry.yarnpkg.com/ramda/-/ramda-0.26.1.tgz#8d41351eb8111c55353617fc3bbffad8e4d35d06" @@ -9949,7 +10462,7 @@ range-parser@~1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" -rc@^1.2.8: +rc@^1.2.7, rc@^1.2.8: version "1.2.8" resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" dependencies: @@ -10440,6 +10953,19 @@ require-main-filename@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-2.0.0.tgz#d0b329ecc7cc0f61649f62215be69af54aa8989b" +requirejs-config-file@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/requirejs-config-file/-/requirejs-config-file-4.0.0.tgz#4244da5dd1f59874038cc1091d078d620abb6ebc" + integrity sha512-jnIre8cbWOyvr8a5F2KuqBnY+SDA4NXr/hzEZJG79Mxm2WiFQz2dzhC8ibtPJS7zkmBEl1mxSwp5HhC1W4qpxw== + dependencies: + esprima "^4.0.0" + stringify-object "^3.2.1" + +requirejs@^2.3.5: + version "2.3.6" + resolved "https://registry.yarnpkg.com/requirejs/-/requirejs-2.3.6.tgz#e5093d9601c2829251258c0b9445d4d19fa9e7c9" + integrity sha512-ipEzlWQe6RK3jkzikgCupiTbTvm4S0/CAU5GlgptkN5SO6F3u0UD0K18wy6ErDqiCyP4J4YYe1HuAShvsxePLg== + requires-port@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" @@ -10461,6 +10987,11 @@ resolve-cwd@^3.0.0: dependencies: resolve-from "^5.0.0" +resolve-dependency-path@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/resolve-dependency-path/-/resolve-dependency-path-2.0.0.tgz#11700e340717b865d216c66cabeb4a2a3c696736" + integrity sha512-DIgu+0Dv+6v2XwRaNWnumKu7GPufBBOr5I1gRPJHkvghrfCGOooJODFvgFimX/KRxk9j0whD2MnKHzM1jYvk9w== + resolve-from@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz#b22c7af7d9d6881bc8b6e653335eebcb0a188748" @@ -10508,6 +11039,15 @@ resolve@^1.18.1, resolve@^1.20.0: path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" +resolve@^1.21.0: + version "1.22.8" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.8.tgz#b6c87a9f2aa06dfab52e3d70ac8cde321fa5a48d" + integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== + dependencies: + is-core-module "^2.13.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + resolve@^2.0.0-next.3: version "2.0.0-next.3" resolved "https://registry.yarnpkg.com/resolve/-/resolve-2.0.0-next.3.tgz#d41016293d4a8586a39ca5d9b5f15cbea1f55e46" @@ -10626,6 +11166,13 @@ sane@^4.0.3: minimist "^1.1.1" walker "~1.0.5" +sass-lookup@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/sass-lookup/-/sass-lookup-3.0.0.tgz#3b395fa40569738ce857bc258e04df2617c48cac" + integrity sha512-TTsus8CfFRn1N44bvdEai1no6PqdmDiQUiqW5DlpmtT+tYnIt1tXtDIph5KA1efC+LmioJXSnCtUVpcK9gaKIg== + dependencies: + commander "^2.16.0" + saxes@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/saxes/-/saxes-5.0.1.tgz#eebab953fa3b7608dbe94e5dadb15c888fa6696d" @@ -10689,6 +11236,13 @@ semver@^7.2.1, semver@^7.3.2, semver@^7.3.5, semver@^7.5.2: dependencies: lru-cache "^6.0.0" +semver@^7.3.7: + version "7.6.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.6.0.tgz#1a46a4db4bffcccd97b743b5005c8325f23d4e2d" + integrity sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg== + dependencies: + lru-cache "^6.0.0" + send@0.17.1: version "0.17.1" resolved "https://registry.yarnpkg.com/send/-/send-0.17.1.tgz#c1d8b059f7900f7466dd4938bdc44e11ddb376c8" @@ -10877,6 +11431,11 @@ snapdragon@^0.8.1: source-map-resolve "^0.5.0" use "^3.1.0" +source-map-js@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" + integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw== + source-map-resolve@^0.5.0: version "0.5.3" resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a" @@ -10988,6 +11547,13 @@ static-extend@^0.1.1: version "1.5.0" resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" +stream-to-array@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/stream-to-array/-/stream-to-array-2.3.0.tgz#bbf6b39f5f43ec30bc71babcb37557acecf34353" + integrity sha512-UsZtOYEn4tWU2RGLOXr/o/xjRBftZRlG3dEWoaHr8j4GuypJ3isitGbVyjQKAuMu+xbiop8q224TjiZWc4XTZA== + dependencies: + any-promise "^1.1.0" + string-argv@^0.3.1: version "0.3.1" resolved "https://registry.yarnpkg.com/string-argv/-/string-argv-0.3.1.tgz#95e2fbec0427ae19184935f816d74aaa4c5c19da" @@ -11102,6 +11668,15 @@ string_decoder@~1.1.1: dependencies: safe-buffer "~5.1.0" +stringify-object@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" + integrity sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw== + dependencies: + get-own-enumerable-property-symbols "^3.0.0" + is-obj "^1.0.1" + is-regexp "^1.0.0" + strip-ansi@^5.0.0, strip-ansi@^5.1.0, strip-ansi@^5.2.0: version "5.2.0" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" @@ -11163,6 +11738,14 @@ strnum@^1.0.5: resolved "https://registry.yarnpkg.com/strnum/-/strnum-1.0.5.tgz#5c4e829fe15ad4ff0d20c3db5ac97b73c9b072db" integrity sha512-J8bbNyKKXl5qYcR36TIO8W3mVGVHrmmxsd5PAItGkmyzwJvybiw2IVq5nqd0i4LSNSkB/sx9VHllbfFdr9k1JA== +stylus-lookup@^3.0.1: + version "3.0.2" + resolved "https://registry.yarnpkg.com/stylus-lookup/-/stylus-lookup-3.0.2.tgz#c9eca3ff799691020f30b382260a67355fefdddd" + integrity sha512-oEQGHSjg/AMaWlKe7gqsnYzan8DLcGIHe0dUaFkucZZ14z4zjENRlQMCHT4FNsiWnJf17YN9OvrCfCoi7VvOyg== + dependencies: + commander "^2.8.1" + debug "^4.1.0" + sudo-prompt@^9.0.0: version "9.2.1" resolved "https://registry.yarnpkg.com/sudo-prompt/-/sudo-prompt-9.2.1.tgz#77efb84309c9ca489527a4e749f287e6bdd52afd" @@ -11229,6 +11812,11 @@ table@^6.0.9: string-width "^4.2.3" strip-ansi "^6.0.1" +tapable@^2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.2.1.tgz#1967a73ef4060a82f12ab96af86d52fdb76eeca0" + integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== + temp-dir@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/temp-dir/-/temp-dir-2.0.0.tgz#bde92b05bdfeb1516e804c9c00ad45177f31321e" @@ -11367,6 +11955,21 @@ tr46@^2.1.0: dependencies: punycode "^2.1.1" +ts-graphviz@^1.5.0: + version "1.8.2" + resolved "https://registry.yarnpkg.com/ts-graphviz/-/ts-graphviz-1.8.2.tgz#6c4768d05f8a36e37abe34855ffe89a4c4bd96cc" + integrity sha512-5YhbFoHmjxa7pgQLkB07MtGnGJ/yhvjmc9uhsnDBEICME6gkPf83SBwLDQqGDoCa3XzUMWLk1AU2Wn1u1naDtA== + +tsconfig-paths@^3.10.1: + version "3.15.0" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz#5299ec605e55b1abb23ec939ef15edaf483070d4" + integrity sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg== + dependencies: + "@types/json5" "^0.0.29" + json5 "^1.0.2" + minimist "^1.2.6" + strip-bom "^3.0.0" + tsconfig-paths@^3.9.0: version "3.9.0" resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz#098547a6c4448807e8fcb8eae081064ee9a3c90b" @@ -11454,6 +12057,16 @@ typescript@5.0.4: resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.0.4.tgz#b217fd20119bd61a94d4011274e0ab369058da3b" integrity sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw== +typescript@^3.9.10, typescript@^3.9.7: + version "3.9.10" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.10.tgz#70f3910ac7a51ed6bef79da7800690b19bf778b8" + integrity sha512-w6fIxVE/H1PkLKcCPsFqKE7Kv7QUwhU8qQY2MueZXWx5cPZdwFupLgKK3vntcK98BtNHZtAF4LA/yl2a7k8R6Q== + +typescript@^4.0.0, typescript@^4.9.5: + version "4.9.5" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" + integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== + ua-parser-js@^0.7.18, ua-parser-js@^0.7.19, ua-parser-js@^0.7.30: version "0.7.33" resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-0.7.33.tgz#1d04acb4ccef9293df6f70f2c3d22f3030d8b532" @@ -11579,6 +12192,11 @@ union-value@^1.0.0: is-extendable "^0.1.1" set-value "^2.0.1" +uniq@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/uniq/-/uniq-1.0.1.tgz#b31c5ae8254844a3a8281541ce2b04b865a734ff" + integrity sha512-Gw+zz50YNKPDKXs+9d+aKAjVwpjNwqzvNpLigIruT4HA9lMZNdMqs9x07kKHB/L9WRzqp4+DlTU5s4wG2esdoA== + unique-string@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" @@ -11745,6 +12363,11 @@ w3c-xmlserializer@^2.0.0: dependencies: xml-name-validator "^3.0.0" +walkdir@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/walkdir/-/walkdir-0.4.1.tgz#dc119f83f4421df52e3061e514228a2db20afa39" + integrity sha512-3eBwRyEln6E1MSzcxcVpQIhRG8Q1jLvEqRmCZqS3dsfXEDR/AhOF4d+jHg1qvDCpYaVRZjENPQyrVxAkQqxPgQ== + walker@^1.0.7, walker@~1.0.5: version "1.0.7" resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.7.tgz#2f7f9b8fd10d677262b18a884e28d19618e028fb" From e193aba17184a77d3545ec8515ec3d9bedd606ee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Wed, 6 Mar 2024 08:26:52 +0100 Subject: [PATCH 11/20] Rename interface --- src/web/handlers/GestureHandler.ts | 33 ++++-------- ...dlerInterface.ts => GestureHandlerType.ts} | 10 ++-- src/web/tools/GestureHandlerOrchestrator.ts | 50 +++++++++---------- src/web/tools/GestureHandlerWebDelegate.ts | 8 +-- src/web/tools/InteractionManager.ts | 23 ++++----- src/web/tools/NodeManager.ts | 6 +-- 6 files changed, 57 insertions(+), 73 deletions(-) rename src/web/handlers/{GestureHandlerInterface.ts => GestureHandlerType.ts} (79%) diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index 26c10b3458..96d392cafc 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -15,13 +15,11 @@ import GestureHandlerOrchestrator from '../tools/GestureHandlerOrchestrator'; import InteractionManager from '../tools/InteractionManager'; import PointerTracker, { TrackerElement } from '../tools/PointerTracker'; import { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; -import GestureHandlerInterface from './GestureHandlerInterface'; +import GestureHandlerType from './GestureHandlerType'; import { MouseButton } from '../../handlers/gestureHandlerCommon'; import { PointerType } from '../../PointerType'; -export default abstract class GestureHandler - implements GestureHandlerInterface -{ +export default abstract class GestureHandler implements GestureHandlerType { private lastSentState: State | null = null; protected currentState: State = State.UNDETERMINED; @@ -43,10 +41,10 @@ export default abstract class GestureHandler protected shouldResetProgress = false; protected pointerType: PointerType = PointerType.MOUSE; - protected delegate: GestureHandlerDelegate; + protected delegate: GestureHandlerDelegate; public constructor( - delegate: GestureHandlerDelegate + delegate: GestureHandlerDelegate ) { this.delegate = delegate; } @@ -61,7 +59,7 @@ export default abstract class GestureHandler this.currentState = State.UNDETERMINED; - this.delegate.init(viewRef, this as GestureHandlerInterface); + this.delegate.init(viewRef, this as GestureHandlerType); } public attachEventManager(manager: EventManager): void { @@ -234,9 +232,7 @@ export default abstract class GestureHandler this.activationIndex = value; } - public shouldWaitForHandlerFailure( - handler: GestureHandlerInterface - ): boolean { + public shouldWaitForHandlerFailure(handler: GestureHandlerType): boolean { if (handler === this) { return false; } @@ -247,9 +243,7 @@ export default abstract class GestureHandler ); } - public shouldRequireToWaitForFailure( - handler: GestureHandlerInterface - ): boolean { + public shouldRequireToWaitForFailure(handler: GestureHandlerType): boolean { if (handler === this) { return false; } @@ -260,9 +254,7 @@ export default abstract class GestureHandler ); } - public shouldRecognizeSimultaneously( - handler: GestureHandlerInterface - ): boolean { + public shouldRecognizeSimultaneously(handler: GestureHandlerType): boolean { if (handler === this) { return true; } @@ -273,7 +265,7 @@ export default abstract class GestureHandler ); } - public shouldBeCancelledByOther(handler: GestureHandlerInterface): boolean { + public shouldBeCancelledByOther(handler: GestureHandlerType): boolean { if (handler === this) { return false; } @@ -622,7 +614,7 @@ export default abstract class GestureHandler break; case State.UNDETERMINED: GestureHandlerOrchestrator.getInstance().removeHandlerFromOrchestrator( - this as GestureHandlerInterface + this as GestureHandlerType ); break; default: @@ -783,10 +775,7 @@ export default abstract class GestureHandler return this.config; } - public getDelegate(): GestureHandlerDelegate< - unknown, - GestureHandlerInterface - > { + public getDelegate(): GestureHandlerDelegate { return this.delegate; } diff --git a/src/web/handlers/GestureHandlerInterface.ts b/src/web/handlers/GestureHandlerType.ts similarity index 79% rename from src/web/handlers/GestureHandlerInterface.ts rename to src/web/handlers/GestureHandlerType.ts index c8c1f2f573..0ee427a6ed 100644 --- a/src/web/handlers/GestureHandlerInterface.ts +++ b/src/web/handlers/GestureHandlerType.ts @@ -6,7 +6,7 @@ import type EventManager from '../tools/EventManager'; import type { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; import type PointerTracker from '../tools/PointerTracker'; -export default interface GestureHandlerInterface { +export default interface GestureHandlerType { getTag: () => number; getState: () => State; getConfig: () => Config; @@ -37,10 +37,10 @@ export default interface GestureHandlerInterface { setActivationIndex: (value: number) => void; setShouldResetProgress: (value: boolean) => void; - shouldWaitForHandlerFailure: (handler: GestureHandlerInterface) => boolean; - shouldRequireToWaitForFailure: (handler: GestureHandlerInterface) => boolean; - shouldRecognizeSimultaneously: (handler: GestureHandlerInterface) => boolean; - shouldBeCancelledByOther: (handler: GestureHandlerInterface) => boolean; + shouldWaitForHandlerFailure: (handler: GestureHandlerType) => boolean; + shouldRequireToWaitForFailure: (handler: GestureHandlerType) => boolean; + shouldRecognizeSimultaneously: (handler: GestureHandlerType) => boolean; + shouldBeCancelledByOther: (handler: GestureHandlerType) => boolean; sendEvent: (newState: State, oldState: State) => void; diff --git a/src/web/tools/GestureHandlerOrchestrator.ts b/src/web/tools/GestureHandlerOrchestrator.ts index af90927029..a3be3d5cea 100644 --- a/src/web/tools/GestureHandlerOrchestrator.ts +++ b/src/web/tools/GestureHandlerOrchestrator.ts @@ -1,14 +1,14 @@ import { PointerType } from '../../PointerType'; import { State } from '../../State'; -import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; +import type GestureHandlerType from '../handlers/GestureHandlerType'; import PointerTracker from './PointerTracker'; export default class GestureHandlerOrchestrator { private static instance: GestureHandlerOrchestrator; - private gestureHandlers: GestureHandlerInterface[] = []; - private awaitingHandlers: GestureHandlerInterface[] = []; + private gestureHandlers: GestureHandlerType[] = []; + private awaitingHandlers: GestureHandlerType[] = []; private handlingChangeSemaphore = 0; private activationIndex = 0; @@ -23,14 +23,14 @@ export default class GestureHandlerOrchestrator { } } - private cleanHandler(handler: GestureHandlerInterface): void { + private cleanHandler(handler: GestureHandlerType): void { handler.reset(); handler.setActive(false); handler.setAwaiting(false); handler.setActivationIndex(Number.MAX_VALUE); } - public removeHandlerFromOrchestrator(handler: GestureHandlerInterface): void { + public removeHandlerFromOrchestrator(handler: GestureHandlerType): void { this.gestureHandlers.splice(this.gestureHandlers.indexOf(handler), 1); this.awaitingHandlers.splice(this.awaitingHandlers.indexOf(handler), 1); } @@ -50,7 +50,7 @@ export default class GestureHandlerOrchestrator { } } - private hasOtherHandlerToWaitFor(handler: GestureHandlerInterface): boolean { + private hasOtherHandlerToWaitFor(handler: GestureHandlerType): boolean { let hasToWait = false; this.gestureHandlers.forEach((otherHandler) => { if ( @@ -67,7 +67,7 @@ export default class GestureHandlerOrchestrator { } private shouldBeCancelledByFinishedHandler( - handler: GestureHandlerInterface + handler: GestureHandlerType ): boolean { return this.gestureHandlers.some( (otherHandler) => @@ -76,7 +76,7 @@ export default class GestureHandlerOrchestrator { ); } - private tryActivate(handler: GestureHandlerInterface): void { + private tryActivate(handler: GestureHandlerType): void { if (this.shouldBeCancelledByFinishedHandler(handler)) { handler.cancel(); return; @@ -102,7 +102,7 @@ export default class GestureHandlerOrchestrator { } } - private shouldActivate(handler: GestureHandlerInterface): boolean { + private shouldActivate(handler: GestureHandlerType): boolean { for (const otherHandler of this.gestureHandlers) { if (this.shouldHandlerBeCancelledBy(handler, otherHandler)) { return false; @@ -112,7 +112,7 @@ export default class GestureHandlerOrchestrator { return true; } - private cleanupAwaitingHandlers(handler: GestureHandlerInterface): void { + private cleanupAwaitingHandlers(handler: GestureHandlerType): void { for (let i = 0; i < this.awaitingHandlers.length; ++i) { if ( !this.awaitingHandlers[i].isAwaiting() && @@ -125,7 +125,7 @@ export default class GestureHandlerOrchestrator { } public onHandlerStateChange( - handler: GestureHandlerInterface, + handler: GestureHandlerType, newState: State, oldState: State, sendIfDisabled?: boolean @@ -183,7 +183,7 @@ export default class GestureHandlerOrchestrator { } } - private makeActive(handler: GestureHandlerInterface): void { + private makeActive(handler: GestureHandlerType): void { const currentState = handler.getState(); handler.setActive(true); @@ -222,7 +222,7 @@ export default class GestureHandlerOrchestrator { } } - private addAwaitingHandler(handler: GestureHandlerInterface): void { + private addAwaitingHandler(handler: GestureHandlerType): void { let alreadyExists = false; this.awaitingHandlers.forEach((otherHandler) => { @@ -242,7 +242,7 @@ export default class GestureHandlerOrchestrator { handler.setActivationIndex(this.activationIndex++); } - public recordHandlerIfNotPresent(handler: GestureHandlerInterface): void { + public recordHandlerIfNotPresent(handler: GestureHandlerType): void { let alreadyExists = false; this.gestureHandlers.forEach((otherHandler) => { @@ -264,8 +264,8 @@ export default class GestureHandlerOrchestrator { } private shouldHandlerWaitForOther( - handler: GestureHandlerInterface, - otherHandler: GestureHandlerInterface + handler: GestureHandlerType, + otherHandler: GestureHandlerType ): boolean { return ( handler !== otherHandler && @@ -275,8 +275,8 @@ export default class GestureHandlerOrchestrator { } private canRunSimultaneously( - gh1: GestureHandlerInterface, - gh2: GestureHandlerInterface + gh1: GestureHandlerType, + gh2: GestureHandlerType ): boolean { return ( gh1 === gh2 || @@ -286,8 +286,8 @@ export default class GestureHandlerOrchestrator { } private shouldHandlerBeCancelledBy( - handler: GestureHandlerInterface, - otherHandler: GestureHandlerInterface + handler: GestureHandlerType, + otherHandler: GestureHandlerType ): boolean { if (this.canRunSimultaneously(handler, otherHandler)) { return false; @@ -315,8 +315,8 @@ export default class GestureHandlerOrchestrator { } private checkOverlap( - handler: GestureHandlerInterface, - otherHandler: GestureHandlerInterface + handler: GestureHandlerType, + otherHandler: GestureHandlerType ): boolean { // If handlers don't have common pointers, default return value is false. // However, if at least on pointer overlaps with both handlers, we return true @@ -370,10 +370,8 @@ export default class GestureHandlerOrchestrator { // This became a problem because handler was left at active state without any signal to end or fail // To handle this, when new touch event is received, we loop through active handlers and check which type of // pointer they're using. If there are any handler with mouse/pen as a pointer, we cancel them - public cancelMouseAndPenGestures( - currentHandler: GestureHandlerInterface - ): void { - this.gestureHandlers.forEach((handler: GestureHandlerInterface) => { + public cancelMouseAndPenGestures(currentHandler: GestureHandlerType): void { + this.gestureHandlers.forEach((handler: GestureHandlerType) => { if ( handler.getPointerType() !== PointerType.MOUSE && handler.getPointerType() !== PointerType.STYLUS diff --git a/src/web/tools/GestureHandlerWebDelegate.ts b/src/web/tools/GestureHandlerWebDelegate.ts index f7496aa1ef..2a18c590b6 100644 --- a/src/web/tools/GestureHandlerWebDelegate.ts +++ b/src/web/tools/GestureHandlerWebDelegate.ts @@ -1,5 +1,5 @@ import { findNodeHandle } from 'react-native'; -import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; +import type GestureHandlerType from '../handlers/GestureHandlerType'; import { GestureHandlerDelegate, MeasureResult, @@ -13,17 +13,17 @@ import { Config } from '../interfaces'; import { MouseButton } from '../../handlers/gestureHandlerCommon'; export class GestureHandlerWebDelegate - implements GestureHandlerDelegate + implements GestureHandlerDelegate { private view!: HTMLElement; - private gestureHandler!: GestureHandlerInterface; + private gestureHandler!: GestureHandlerType; private eventManagers: EventManager[] = []; getView(): HTMLElement { return this.view; } - init(viewRef: number, handler: GestureHandlerInterface): void { + init(viewRef: number, handler: GestureHandlerType): void { if (!viewRef) { throw new Error( `Cannot find HTML Element for handler ${handler.getTag()}` diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index eaa0c8741e..b828e60bb2 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -1,4 +1,4 @@ -import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; +import type GestureHandlerType from '../handlers/GestureHandlerType'; import { Config, Handler } from '../interfaces'; export default class InteractionManager { @@ -11,10 +11,7 @@ export default class InteractionManager { // eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function private constructor() {} - public configureInteractions( - handler: GestureHandlerInterface, - config: Config - ) { + public configureInteractions(handler: GestureHandlerType, config: Config) { this.dropRelationsForHandlerWithTag(handler.getTag()); if (config.waitFor) { @@ -60,8 +57,8 @@ export default class InteractionManager { } public shouldWaitForHandlerFailure( - handler: GestureHandlerInterface, - otherHandler: GestureHandlerInterface + handler: GestureHandlerType, + otherHandler: GestureHandlerType ): boolean { const waitFor: number[] | undefined = this.waitForRelations.get( handler.getTag() @@ -75,8 +72,8 @@ export default class InteractionManager { } public shouldRecognizeSimultaneously( - handler: GestureHandlerInterface, - otherHandler: GestureHandlerInterface + handler: GestureHandlerType, + otherHandler: GestureHandlerType ): boolean { const simultaneousHandlers: number[] | undefined = this.simultaneousRelations.get(handler.getTag()); @@ -89,8 +86,8 @@ export default class InteractionManager { } public shouldRequireHandlerToWaitForFailure( - handler: GestureHandlerInterface, - otherHandler: GestureHandlerInterface + handler: GestureHandlerType, + otherHandler: GestureHandlerType ): boolean { const waitFor: number[] | undefined = this.blocksHandlersRelations.get( handler.getTag() @@ -104,8 +101,8 @@ export default class InteractionManager { } public shouldHandlerBeCancelledBy( - _handler: GestureHandlerInterface, - _otherHandler: GestureHandlerInterface + _handler: GestureHandlerType, + _otherHandler: GestureHandlerType ): boolean { //TODO: Implement logic return false; diff --git a/src/web/tools/NodeManager.ts b/src/web/tools/NodeManager.ts index d37e461718..01139d4f34 100644 --- a/src/web/tools/NodeManager.ts +++ b/src/web/tools/NodeManager.ts @@ -1,6 +1,6 @@ import { ValueOf } from '../../typeUtils'; import { Gestures } from '../Gestures'; -import type GestureHandlerInterface from '../handlers/GestureHandlerInterface'; +import type GestureHandlerType from '../handlers/GestureHandlerType'; // eslint-disable-next-line @typescript-eslint/no-extraneous-class export default abstract class NodeManager { @@ -9,9 +9,9 @@ export default abstract class NodeManager { InstanceType> > = {}; - public static getHandler(tag: number): GestureHandlerInterface { + public static getHandler(tag: number): GestureHandlerType { if (tag in this.gestures) { - return this.gestures[tag] as GestureHandlerInterface; + return this.gestures[tag] as GestureHandlerType; } throw new Error(`No handler for tag ${tag}`); From 18bef7fcc81bac3446c81bc4f27ce1c71fddd1d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Wed, 6 Mar 2024 08:28:31 +0100 Subject: [PATCH 12/20] Add new line --- src/handlers/gestureHandlerCommon.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/handlers/gestureHandlerCommon.ts b/src/handlers/gestureHandlerCommon.ts index 0527fc242d..aaac5b8b98 100644 --- a/src/handlers/gestureHandlerCommon.ts +++ b/src/handlers/gestureHandlerCommon.ts @@ -121,6 +121,7 @@ export enum MouseButton { BUTTON_5 = 16, ALL = 31, } + export type TouchAction = | 'auto' | 'none' From dad9b78df28ca35666cb8216fa5dcddb93500a6f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Wed, 6 Mar 2024 08:32:00 +0100 Subject: [PATCH 13/20] Remove another unnecessary cast --- src/web/handlers/GestureHandler.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index 96d392cafc..3fe233655c 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -59,7 +59,7 @@ export default abstract class GestureHandler implements GestureHandlerType { this.currentState = State.UNDETERMINED; - this.delegate.init(viewRef, this as GestureHandlerType); + this.delegate.init(viewRef, this); } public attachEventManager(manager: EventManager): void { From 4741d677fc8e549012d5aea20c232627193704b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Wed, 6 Mar 2024 08:33:38 +0100 Subject: [PATCH 14/20] Yet another unnecessary cast --- src/web/handlers/GestureHandler.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index 3fe233655c..09f80f23b6 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -614,7 +614,7 @@ export default abstract class GestureHandler implements GestureHandlerType { break; case State.UNDETERMINED: GestureHandlerOrchestrator.getInstance().removeHandlerFromOrchestrator( - this as GestureHandlerType + this ); break; default: From 050189e29a3513052eafffd976d89a7a1daa87b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 12 Mar 2024 16:48:58 +0100 Subject: [PATCH 15/20] Change GestureHandlerType to IGestureHandler --- src/web/handlers/GestureHandler.ts | 18 +++---- ...stureHandlerType.ts => IGestureHandler.ts} | 10 ++-- src/web/tools/GestureHandlerOrchestrator.ts | 48 +++++++++---------- src/web/tools/GestureHandlerWebDelegate.ts | 8 ++-- src/web/tools/InteractionManager.ts | 20 ++++---- src/web/tools/NodeManager.ts | 6 +-- 6 files changed, 55 insertions(+), 55 deletions(-) rename src/web/handlers/{GestureHandlerType.ts => IGestureHandler.ts} (80%) diff --git a/src/web/handlers/GestureHandler.ts b/src/web/handlers/GestureHandler.ts index 09f80f23b6..507369461c 100644 --- a/src/web/handlers/GestureHandler.ts +++ b/src/web/handlers/GestureHandler.ts @@ -15,11 +15,11 @@ import GestureHandlerOrchestrator from '../tools/GestureHandlerOrchestrator'; import InteractionManager from '../tools/InteractionManager'; import PointerTracker, { TrackerElement } from '../tools/PointerTracker'; import { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; -import GestureHandlerType from './GestureHandlerType'; +import IGestureHandler from './IGestureHandler'; import { MouseButton } from '../../handlers/gestureHandlerCommon'; import { PointerType } from '../../PointerType'; -export default abstract class GestureHandler implements GestureHandlerType { +export default abstract class GestureHandler implements IGestureHandler { private lastSentState: State | null = null; protected currentState: State = State.UNDETERMINED; @@ -41,10 +41,10 @@ export default abstract class GestureHandler implements GestureHandlerType { protected shouldResetProgress = false; protected pointerType: PointerType = PointerType.MOUSE; - protected delegate: GestureHandlerDelegate; + protected delegate: GestureHandlerDelegate; public constructor( - delegate: GestureHandlerDelegate + delegate: GestureHandlerDelegate ) { this.delegate = delegate; } @@ -232,7 +232,7 @@ export default abstract class GestureHandler implements GestureHandlerType { this.activationIndex = value; } - public shouldWaitForHandlerFailure(handler: GestureHandlerType): boolean { + public shouldWaitForHandlerFailure(handler: IGestureHandler): boolean { if (handler === this) { return false; } @@ -243,7 +243,7 @@ export default abstract class GestureHandler implements GestureHandlerType { ); } - public shouldRequireToWaitForFailure(handler: GestureHandlerType): boolean { + public shouldRequireToWaitForFailure(handler: IGestureHandler): boolean { if (handler === this) { return false; } @@ -254,7 +254,7 @@ export default abstract class GestureHandler implements GestureHandlerType { ); } - public shouldRecognizeSimultaneously(handler: GestureHandlerType): boolean { + public shouldRecognizeSimultaneously(handler: IGestureHandler): boolean { if (handler === this) { return true; } @@ -265,7 +265,7 @@ export default abstract class GestureHandler implements GestureHandlerType { ); } - public shouldBeCancelledByOther(handler: GestureHandlerType): boolean { + public shouldBeCancelledByOther(handler: IGestureHandler): boolean { if (handler === this) { return false; } @@ -775,7 +775,7 @@ export default abstract class GestureHandler implements GestureHandlerType { return this.config; } - public getDelegate(): GestureHandlerDelegate { + public getDelegate(): GestureHandlerDelegate { return this.delegate; } diff --git a/src/web/handlers/GestureHandlerType.ts b/src/web/handlers/IGestureHandler.ts similarity index 80% rename from src/web/handlers/GestureHandlerType.ts rename to src/web/handlers/IGestureHandler.ts index 0ee427a6ed..53c886f3e0 100644 --- a/src/web/handlers/GestureHandlerType.ts +++ b/src/web/handlers/IGestureHandler.ts @@ -6,7 +6,7 @@ import type EventManager from '../tools/EventManager'; import type { GestureHandlerDelegate } from '../tools/GestureHandlerDelegate'; import type PointerTracker from '../tools/PointerTracker'; -export default interface GestureHandlerType { +export default interface IGestureHandler { getTag: () => number; getState: () => State; getConfig: () => Config; @@ -37,10 +37,10 @@ export default interface GestureHandlerType { setActivationIndex: (value: number) => void; setShouldResetProgress: (value: boolean) => void; - shouldWaitForHandlerFailure: (handler: GestureHandlerType) => boolean; - shouldRequireToWaitForFailure: (handler: GestureHandlerType) => boolean; - shouldRecognizeSimultaneously: (handler: GestureHandlerType) => boolean; - shouldBeCancelledByOther: (handler: GestureHandlerType) => boolean; + shouldWaitForHandlerFailure: (handler: IGestureHandler) => boolean; + shouldRequireToWaitForFailure: (handler: IGestureHandler) => boolean; + shouldRecognizeSimultaneously: (handler: IGestureHandler) => boolean; + shouldBeCancelledByOther: (handler: IGestureHandler) => boolean; sendEvent: (newState: State, oldState: State) => void; diff --git a/src/web/tools/GestureHandlerOrchestrator.ts b/src/web/tools/GestureHandlerOrchestrator.ts index a3be3d5cea..6b4d91d90d 100644 --- a/src/web/tools/GestureHandlerOrchestrator.ts +++ b/src/web/tools/GestureHandlerOrchestrator.ts @@ -1,14 +1,14 @@ import { PointerType } from '../../PointerType'; import { State } from '../../State'; -import type GestureHandlerType from '../handlers/GestureHandlerType'; +import type IGestureHandler from '../handlers/IGestureHandler'; import PointerTracker from './PointerTracker'; export default class GestureHandlerOrchestrator { private static instance: GestureHandlerOrchestrator; - private gestureHandlers: GestureHandlerType[] = []; - private awaitingHandlers: GestureHandlerType[] = []; + private gestureHandlers: IGestureHandler[] = []; + private awaitingHandlers: IGestureHandler[] = []; private handlingChangeSemaphore = 0; private activationIndex = 0; @@ -23,14 +23,14 @@ export default class GestureHandlerOrchestrator { } } - private cleanHandler(handler: GestureHandlerType): void { + private cleanHandler(handler: IGestureHandler): void { handler.reset(); handler.setActive(false); handler.setAwaiting(false); handler.setActivationIndex(Number.MAX_VALUE); } - public removeHandlerFromOrchestrator(handler: GestureHandlerType): void { + public removeHandlerFromOrchestrator(handler: IGestureHandler): void { this.gestureHandlers.splice(this.gestureHandlers.indexOf(handler), 1); this.awaitingHandlers.splice(this.awaitingHandlers.indexOf(handler), 1); } @@ -50,7 +50,7 @@ export default class GestureHandlerOrchestrator { } } - private hasOtherHandlerToWaitFor(handler: GestureHandlerType): boolean { + private hasOtherHandlerToWaitFor(handler: IGestureHandler): boolean { let hasToWait = false; this.gestureHandlers.forEach((otherHandler) => { if ( @@ -67,7 +67,7 @@ export default class GestureHandlerOrchestrator { } private shouldBeCancelledByFinishedHandler( - handler: GestureHandlerType + handler: IGestureHandler ): boolean { return this.gestureHandlers.some( (otherHandler) => @@ -76,7 +76,7 @@ export default class GestureHandlerOrchestrator { ); } - private tryActivate(handler: GestureHandlerType): void { + private tryActivate(handler: IGestureHandler): void { if (this.shouldBeCancelledByFinishedHandler(handler)) { handler.cancel(); return; @@ -102,7 +102,7 @@ export default class GestureHandlerOrchestrator { } } - private shouldActivate(handler: GestureHandlerType): boolean { + private shouldActivate(handler: IGestureHandler): boolean { for (const otherHandler of this.gestureHandlers) { if (this.shouldHandlerBeCancelledBy(handler, otherHandler)) { return false; @@ -112,7 +112,7 @@ export default class GestureHandlerOrchestrator { return true; } - private cleanupAwaitingHandlers(handler: GestureHandlerType): void { + private cleanupAwaitingHandlers(handler: IGestureHandler): void { for (let i = 0; i < this.awaitingHandlers.length; ++i) { if ( !this.awaitingHandlers[i].isAwaiting() && @@ -125,7 +125,7 @@ export default class GestureHandlerOrchestrator { } public onHandlerStateChange( - handler: GestureHandlerType, + handler: IGestureHandler, newState: State, oldState: State, sendIfDisabled?: boolean @@ -183,7 +183,7 @@ export default class GestureHandlerOrchestrator { } } - private makeActive(handler: GestureHandlerType): void { + private makeActive(handler: IGestureHandler): void { const currentState = handler.getState(); handler.setActive(true); @@ -222,7 +222,7 @@ export default class GestureHandlerOrchestrator { } } - private addAwaitingHandler(handler: GestureHandlerType): void { + private addAwaitingHandler(handler: IGestureHandler): void { let alreadyExists = false; this.awaitingHandlers.forEach((otherHandler) => { @@ -242,7 +242,7 @@ export default class GestureHandlerOrchestrator { handler.setActivationIndex(this.activationIndex++); } - public recordHandlerIfNotPresent(handler: GestureHandlerType): void { + public recordHandlerIfNotPresent(handler: IGestureHandler): void { let alreadyExists = false; this.gestureHandlers.forEach((otherHandler) => { @@ -264,8 +264,8 @@ export default class GestureHandlerOrchestrator { } private shouldHandlerWaitForOther( - handler: GestureHandlerType, - otherHandler: GestureHandlerType + handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { return ( handler !== otherHandler && @@ -275,8 +275,8 @@ export default class GestureHandlerOrchestrator { } private canRunSimultaneously( - gh1: GestureHandlerType, - gh2: GestureHandlerType + gh1: IGestureHandler, + gh2: IGestureHandler ): boolean { return ( gh1 === gh2 || @@ -286,8 +286,8 @@ export default class GestureHandlerOrchestrator { } private shouldHandlerBeCancelledBy( - handler: GestureHandlerType, - otherHandler: GestureHandlerType + handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { if (this.canRunSimultaneously(handler, otherHandler)) { return false; @@ -315,8 +315,8 @@ export default class GestureHandlerOrchestrator { } private checkOverlap( - handler: GestureHandlerType, - otherHandler: GestureHandlerType + handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { // If handlers don't have common pointers, default return value is false. // However, if at least on pointer overlaps with both handlers, we return true @@ -370,8 +370,8 @@ export default class GestureHandlerOrchestrator { // This became a problem because handler was left at active state without any signal to end or fail // To handle this, when new touch event is received, we loop through active handlers and check which type of // pointer they're using. If there are any handler with mouse/pen as a pointer, we cancel them - public cancelMouseAndPenGestures(currentHandler: GestureHandlerType): void { - this.gestureHandlers.forEach((handler: GestureHandlerType) => { + public cancelMouseAndPenGestures(currentHandler: IGestureHandler): void { + this.gestureHandlers.forEach((handler: IGestureHandler) => { if ( handler.getPointerType() !== PointerType.MOUSE && handler.getPointerType() !== PointerType.STYLUS diff --git a/src/web/tools/GestureHandlerWebDelegate.ts b/src/web/tools/GestureHandlerWebDelegate.ts index 2a18c590b6..16fb273575 100644 --- a/src/web/tools/GestureHandlerWebDelegate.ts +++ b/src/web/tools/GestureHandlerWebDelegate.ts @@ -1,5 +1,5 @@ import { findNodeHandle } from 'react-native'; -import type GestureHandlerType from '../handlers/GestureHandlerType'; +import type IGestureHandler from '../handlers/IGestureHandler'; import { GestureHandlerDelegate, MeasureResult, @@ -13,17 +13,17 @@ import { Config } from '../interfaces'; import { MouseButton } from '../../handlers/gestureHandlerCommon'; export class GestureHandlerWebDelegate - implements GestureHandlerDelegate + implements GestureHandlerDelegate { private view!: HTMLElement; - private gestureHandler!: GestureHandlerType; + private gestureHandler!: IGestureHandler; private eventManagers: EventManager[] = []; getView(): HTMLElement { return this.view; } - init(viewRef: number, handler: GestureHandlerType): void { + init(viewRef: number, handler: IGestureHandler): void { if (!viewRef) { throw new Error( `Cannot find HTML Element for handler ${handler.getTag()}` diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index 22fef56584..45112b611d 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -1,4 +1,4 @@ -import type GestureHandlerType from '../handlers/GestureHandlerType'; +import type IGestureHandler from '../handlers/IGestureHandler'; import { State } from '../../State'; import NativeViewGestureHandler from '../handlers/NativeViewGestureHandler'; import { Config, Handler } from '../interfaces'; @@ -13,7 +13,7 @@ export default class InteractionManager { // eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function private constructor() {} - public configureInteractions(handler: GestureHandlerType, config: Config) { + public configureInteractions(handler: IGestureHandler, config: Config) { this.dropRelationsForHandlerWithTag(handler.getTag()); if (config.waitFor) { @@ -59,8 +59,8 @@ export default class InteractionManager { } public shouldWaitForHandlerFailure( - handler: GestureHandlerType, - otherHandler: GestureHandlerType + handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { const waitFor: number[] | undefined = this.waitForRelations.get( handler.getTag() @@ -74,8 +74,8 @@ export default class InteractionManager { } public shouldRecognizeSimultaneously( - handler: GestureHandlerType, - otherHandler: GestureHandlerType + handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { const simultaneousHandlers: number[] | undefined = this.simultaneousRelations.get(handler.getTag()); @@ -88,8 +88,8 @@ export default class InteractionManager { } public shouldRequireHandlerToWaitForFailure( - handler: GestureHandlerType, - otherHandler: GestureHandlerType + handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { const waitFor: number[] | undefined = this.blocksHandlersRelations.get( handler.getTag() @@ -103,8 +103,8 @@ export default class InteractionManager { } public shouldHandlerBeCancelledBy( - _handler: GestureHandlerType, - otherHandler: GestureHandlerType + _handler: IGestureHandler, + otherHandler: IGestureHandler ): boolean { return ( otherHandler instanceof NativeViewGestureHandler && diff --git a/src/web/tools/NodeManager.ts b/src/web/tools/NodeManager.ts index 01139d4f34..43aa80ea70 100644 --- a/src/web/tools/NodeManager.ts +++ b/src/web/tools/NodeManager.ts @@ -1,6 +1,6 @@ import { ValueOf } from '../../typeUtils'; import { Gestures } from '../Gestures'; -import type GestureHandlerType from '../handlers/GestureHandlerType'; +import type IGestureHandler from '../handlers/IGestureHandler'; // eslint-disable-next-line @typescript-eslint/no-extraneous-class export default abstract class NodeManager { @@ -9,9 +9,9 @@ export default abstract class NodeManager { InstanceType> > = {}; - public static getHandler(tag: number): GestureHandlerType { + public static getHandler(tag: number): IGestureHandler { if (tag in this.gestures) { - return this.gestures[tag] as GestureHandlerType; + return this.gestures[tag] as IGestureHandler; } throw new Error(`No handler for tag ${tag}`); From dbd44e21e969dc6e93f40ea031282b19175bd844 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 12 Mar 2024 16:51:48 +0100 Subject: [PATCH 16/20] Change type parameters --- src/web/tools/GestureHandlerDelegate.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/web/tools/GestureHandlerDelegate.ts b/src/web/tools/GestureHandlerDelegate.ts index 2144786811..04e6f6f797 100644 --- a/src/web/tools/GestureHandlerDelegate.ts +++ b/src/web/tools/GestureHandlerDelegate.ts @@ -7,10 +7,10 @@ export interface MeasureResult { height: number; } -export interface GestureHandlerDelegate { - getView(): T; +export interface GestureHandlerDelegate { + getView(): TComponent; - init(viewRef: number, handler: S): void; + init(viewRef: number, handler: THandler): void; isPointerInBounds({ x, y }: { x: number; y: number }): boolean; measureView(): MeasureResult; reset(): void; From 87d1ad18433a72182a58bb9a786f690ed07dae0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 12 Mar 2024 17:23:51 +0100 Subject: [PATCH 17/20] Remove last circular dependency --- src/web/handlers/IGestureHandler.ts | 2 ++ src/web/tools/InteractionManager.ts | 10 ++++------ 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/web/handlers/IGestureHandler.ts b/src/web/handlers/IGestureHandler.ts index 53c886f3e0..376e139529 100644 --- a/src/web/handlers/IGestureHandler.ts +++ b/src/web/handlers/IGestureHandler.ts @@ -45,4 +45,6 @@ export default interface IGestureHandler { sendEvent: (newState: State, oldState: State) => void; updateGestureConfig: (config: Config) => void; + + isButton?: () => boolean; } diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index 45112b611d..21a11571d8 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -1,6 +1,5 @@ import type IGestureHandler from '../handlers/IGestureHandler'; import { State } from '../../State'; -import NativeViewGestureHandler from '../handlers/NativeViewGestureHandler'; import { Config, Handler } from '../interfaces'; export default class InteractionManager { @@ -106,11 +105,10 @@ export default class InteractionManager { _handler: IGestureHandler, otherHandler: IGestureHandler ): boolean { - return ( - otherHandler instanceof NativeViewGestureHandler && - otherHandler.getState() === State.ACTIVE && - !otherHandler.isButton() - ); + const isActive = otherHandler.getState() === State.ACTIVE; + const isButton = !!otherHandler.isButton?.(); + + return isActive && !isButton; } public dropRelationsForHandlerWithTag(handlerTag: number): void { From f0b2d3e96dbb5752e08d189db27918600f0a6f45 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 12 Mar 2024 17:27:54 +0100 Subject: [PATCH 18/20] Fix condition --- src/web/tools/InteractionManager.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index 21a11571d8..2188fa5a25 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -105,10 +105,12 @@ export default class InteractionManager { _handler: IGestureHandler, otherHandler: IGestureHandler ): boolean { + const isNativeHandler = + otherHandler.constructor.name === 'NativeViewGestureHandler'; const isActive = otherHandler.getState() === State.ACTIVE; const isButton = !!otherHandler.isButton?.(); - return isActive && !isButton; + return isNativeHandler && isActive && !isButton; } public dropRelationsForHandlerWithTag(handlerTag: number): void { From 89337e2553cb74ab31602a4295fa4281cebdb9e0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 12 Mar 2024 17:54:39 +0100 Subject: [PATCH 19/20] Add comment --- src/web/tools/InteractionManager.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index 2188fa5a25..8270471f6d 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -105,6 +105,7 @@ export default class InteractionManager { _handler: IGestureHandler, otherHandler: IGestureHandler ): boolean { + // We check constructor name instead of using `instanceof` in order do avoid circular dependencies const isNativeHandler = otherHandler.constructor.name === 'NativeViewGestureHandler'; const isActive = otherHandler.getState() === State.ACTIVE; From c392a94089df0e392f4f910682b4154da4504fbb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Tue, 12 Mar 2024 17:55:08 +0100 Subject: [PATCH 20/20] Change comparison --- src/web/tools/InteractionManager.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/web/tools/InteractionManager.ts b/src/web/tools/InteractionManager.ts index 8270471f6d..6b65c3a7b6 100644 --- a/src/web/tools/InteractionManager.ts +++ b/src/web/tools/InteractionManager.ts @@ -109,7 +109,7 @@ export default class InteractionManager { const isNativeHandler = otherHandler.constructor.name === 'NativeViewGestureHandler'; const isActive = otherHandler.getState() === State.ACTIVE; - const isButton = !!otherHandler.isButton?.(); + const isButton = otherHandler.isButton?.() === true; return isNativeHandler && isActive && !isButton; }