react-native-gesture-handler 2.26.0 → 2.27.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (415) hide show
  1. package/README.md +69 -0
  2. package/android/src/main/jni/CMakeLists.txt +7 -26
  3. package/lib/commonjs/components/Pressable/Pressable.js +139 -188
  4. package/lib/commonjs/components/Pressable/Pressable.js.map +1 -1
  5. package/lib/commonjs/components/Pressable/StateMachine.js +38 -0
  6. package/lib/commonjs/components/Pressable/StateMachine.js.map +1 -0
  7. package/lib/commonjs/components/Pressable/stateDefinitions.js +88 -0
  8. package/lib/commonjs/components/Pressable/stateDefinitions.js.map +1 -0
  9. package/lib/commonjs/components/Pressable/utils.js +1 -1
  10. package/lib/commonjs/components/Pressable/utils.js.map +1 -1
  11. package/lib/commonjs/handlers/gestures/forceTouchGesture.js +12 -0
  12. package/lib/commonjs/handlers/gestures/forceTouchGesture.js.map +1 -1
  13. package/lib/commonjs/handlers/gestures/gestureObjects.js +3 -1
  14. package/lib/commonjs/handlers/gestures/gestureObjects.js.map +1 -1
  15. package/lib/commonjs/web/detectors/RotationGestureDetector.js +3 -0
  16. package/lib/commonjs/web/detectors/RotationGestureDetector.js.map +1 -1
  17. package/lib/commonjs/web/handlers/FlingGestureHandler.js +3 -0
  18. package/lib/commonjs/web/handlers/FlingGestureHandler.js.map +1 -1
  19. package/lib/commonjs/web/handlers/GestureHandler.js +6 -6
  20. package/lib/commonjs/web/handlers/GestureHandler.js.map +1 -1
  21. package/lib/commonjs/web/handlers/PanGestureHandler.js +24 -33
  22. package/lib/commonjs/web/handlers/PanGestureHandler.js.map +1 -1
  23. package/lib/commonjs/web/handlers/TapGestureHandler.js +15 -17
  24. package/lib/commonjs/web/handlers/TapGestureHandler.js.map +1 -1
  25. package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js +1 -1
  26. package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js.map +1 -1
  27. package/lib/commonjs/web/tools/PointerEventManager.js +1 -1
  28. package/lib/commonjs/web/tools/PointerEventManager.js.map +1 -1
  29. package/lib/commonjs/web/tools/PointerTracker.js +12 -11
  30. package/lib/commonjs/web/tools/PointerTracker.js.map +1 -1
  31. package/lib/commonjs/web/tools/Vector.js +1 -1
  32. package/lib/commonjs/web/tools/Vector.js.map +1 -1
  33. package/lib/module/components/Pressable/Pressable.js +141 -190
  34. package/lib/module/components/Pressable/Pressable.js.map +1 -1
  35. package/lib/module/components/Pressable/StateMachine.js +34 -0
  36. package/lib/module/components/Pressable/StateMachine.js.map +1 -0
  37. package/lib/module/components/Pressable/stateDefinitions.js +83 -0
  38. package/lib/module/components/Pressable/stateDefinitions.js.map +1 -0
  39. package/lib/module/components/Pressable/utils.js +1 -1
  40. package/lib/module/components/Pressable/utils.js.map +1 -1
  41. package/lib/module/handlers/gestures/forceTouchGesture.js +13 -0
  42. package/lib/module/handlers/gestures/forceTouchGesture.js.map +1 -1
  43. package/lib/module/handlers/gestures/gestureObjects.js +3 -1
  44. package/lib/module/handlers/gestures/gestureObjects.js.map +1 -1
  45. package/lib/module/web/detectors/RotationGestureDetector.js +3 -0
  46. package/lib/module/web/detectors/RotationGestureDetector.js.map +1 -1
  47. package/lib/module/web/handlers/FlingGestureHandler.js +3 -0
  48. package/lib/module/web/handlers/FlingGestureHandler.js.map +1 -1
  49. package/lib/module/web/handlers/GestureHandler.js +6 -6
  50. package/lib/module/web/handlers/GestureHandler.js.map +1 -1
  51. package/lib/module/web/handlers/PanGestureHandler.js +24 -33
  52. package/lib/module/web/handlers/PanGestureHandler.js.map +1 -1
  53. package/lib/module/web/handlers/TapGestureHandler.js +15 -17
  54. package/lib/module/web/handlers/TapGestureHandler.js.map +1 -1
  55. package/lib/module/web/tools/GestureHandlerOrchestrator.js +1 -1
  56. package/lib/module/web/tools/GestureHandlerOrchestrator.js.map +1 -1
  57. package/lib/module/web/tools/PointerEventManager.js +1 -1
  58. package/lib/module/web/tools/PointerEventManager.js.map +1 -1
  59. package/lib/module/web/tools/PointerTracker.js +12 -11
  60. package/lib/module/web/tools/PointerTracker.js.map +1 -1
  61. package/lib/module/web/tools/Vector.js +1 -1
  62. package/lib/module/web/tools/Vector.js.map +1 -1
  63. package/lib/typescript/ActionType.d.ts +0 -1
  64. package/lib/typescript/ActionType.js +6 -0
  65. package/lib/typescript/Directions.d.ts +0 -1
  66. package/lib/typescript/Directions.js +18 -0
  67. package/lib/typescript/EnableNewWebImplementation.d.ts +0 -1
  68. package/lib/typescript/EnableNewWebImplementation.js +30 -0
  69. package/lib/typescript/GestureHandlerRootViewContext.d.ts +0 -1
  70. package/lib/typescript/GestureHandlerRootViewContext.js +2 -0
  71. package/lib/typescript/PlatformConstants.d.ts +0 -1
  72. package/lib/typescript/PlatformConstants.js +3 -0
  73. package/lib/typescript/PlatformConstants.web.d.ts +0 -1
  74. package/lib/typescript/PlatformConstants.web.js +5 -0
  75. package/lib/typescript/PointerType.d.ts +0 -1
  76. package/lib/typescript/PointerType.js +8 -0
  77. package/lib/typescript/RNGestureHandlerModule.d.ts +0 -1
  78. package/lib/typescript/RNGestureHandlerModule.js +4 -0
  79. package/lib/typescript/RNGestureHandlerModule.web.d.ts +0 -1
  80. package/lib/typescript/RNGestureHandlerModule.web.js +92 -0
  81. package/lib/typescript/RNGestureHandlerModule.windows.d.ts +0 -1
  82. package/lib/typescript/RNGestureHandlerModule.windows.js +47 -0
  83. package/lib/typescript/RNRenderer.d.ts +0 -1
  84. package/lib/typescript/RNRenderer.js +3 -0
  85. package/lib/typescript/RNRenderer.web.d.ts +0 -1
  86. package/lib/typescript/RNRenderer.web.js +3 -0
  87. package/lib/typescript/State.d.ts +0 -1
  88. package/lib/typescript/State.js +9 -0
  89. package/lib/typescript/TouchEventType.d.ts +0 -1
  90. package/lib/typescript/TouchEventType.js +7 -0
  91. package/lib/typescript/components/DrawerLayout.d.ts +0 -1
  92. package/lib/typescript/components/DrawerLayout.js +417 -0
  93. package/lib/typescript/components/GestureButtons.d.ts +0 -1
  94. package/lib/typescript/components/GestureButtons.js +165 -0
  95. package/lib/typescript/components/GestureButtonsProps.d.ts +0 -1
  96. package/lib/typescript/components/GestureButtonsProps.js +1 -0
  97. package/lib/typescript/components/GestureComponents.d.ts +0 -1
  98. package/lib/typescript/components/GestureComponents.js +67 -0
  99. package/lib/typescript/components/GestureComponents.web.d.ts +0 -1
  100. package/lib/typescript/components/GestureComponents.web.js +21 -0
  101. package/lib/typescript/components/GestureHandlerButton.d.ts +0 -1
  102. package/lib/typescript/components/GestureHandlerButton.js +2 -0
  103. package/lib/typescript/components/GestureHandlerButton.web.d.ts +0 -1
  104. package/lib/typescript/components/GestureHandlerButton.web.js +3 -0
  105. package/lib/typescript/components/GestureHandlerRootView.android.d.ts +0 -1
  106. package/lib/typescript/components/GestureHandlerRootView.android.js +17 -0
  107. package/lib/typescript/components/GestureHandlerRootView.d.ts +0 -1
  108. package/lib/typescript/components/GestureHandlerRootView.js +16 -0
  109. package/lib/typescript/components/GestureHandlerRootView.web.d.ts +0 -1
  110. package/lib/typescript/components/GestureHandlerRootView.web.js +11 -0
  111. package/lib/typescript/components/Pressable/Pressable.d.ts +1 -3
  112. package/lib/typescript/components/Pressable/Pressable.d.ts.map +1 -1
  113. package/lib/typescript/components/Pressable/Pressable.js +231 -0
  114. package/lib/typescript/components/Pressable/PressableProps.d.ts +15 -2
  115. package/lib/typescript/components/Pressable/PressableProps.d.ts.map +1 -1
  116. package/lib/typescript/components/Pressable/PressableProps.js +1 -0
  117. package/lib/typescript/components/Pressable/StateMachine.d.ts +14 -0
  118. package/lib/typescript/components/Pressable/StateMachine.d.ts.map +1 -0
  119. package/lib/typescript/components/Pressable/StateMachine.js +34 -0
  120. package/lib/typescript/components/Pressable/index.d.ts +0 -1
  121. package/lib/typescript/components/Pressable/index.js +1 -0
  122. package/lib/typescript/components/Pressable/stateDefinitions.d.ts +9 -0
  123. package/lib/typescript/components/Pressable/stateDefinitions.d.ts.map +1 -0
  124. package/lib/typescript/components/Pressable/stateDefinitions.js +104 -0
  125. package/lib/typescript/components/Pressable/utils.d.ts +3 -7
  126. package/lib/typescript/components/Pressable/utils.d.ts.map +1 -1
  127. package/lib/typescript/components/Pressable/utils.js +80 -0
  128. package/lib/typescript/components/ReanimatedDrawerLayout.d.ts +0 -1
  129. package/lib/typescript/components/ReanimatedDrawerLayout.js +364 -0
  130. package/lib/typescript/components/ReanimatedSwipeable.d.ts +0 -1
  131. package/lib/typescript/components/ReanimatedSwipeable.js +400 -0
  132. package/lib/typescript/components/Swipeable.d.ts +0 -1
  133. package/lib/typescript/components/Swipeable.js +287 -0
  134. package/lib/typescript/components/Text.d.ts +0 -1
  135. package/lib/typescript/components/Text.js +38 -0
  136. package/lib/typescript/components/gestureHandlerRootHOC.d.ts +0 -1
  137. package/lib/typescript/components/gestureHandlerRootHOC.js +18 -0
  138. package/lib/typescript/components/touchables/ExtraButtonProps.d.ts +0 -1
  139. package/lib/typescript/components/touchables/ExtraButtonProps.js +1 -0
  140. package/lib/typescript/components/touchables/GenericTouchable.d.ts +0 -1
  141. package/lib/typescript/components/touchables/GenericTouchable.js +221 -0
  142. package/lib/typescript/components/touchables/GenericTouchableProps.d.ts +0 -1
  143. package/lib/typescript/components/touchables/GenericTouchableProps.js +1 -0
  144. package/lib/typescript/components/touchables/TouchableHighlight.d.ts +0 -1
  145. package/lib/typescript/components/touchables/TouchableHighlight.js +75 -0
  146. package/lib/typescript/components/touchables/TouchableNativeFeedback.android.d.ts +0 -1
  147. package/lib/typescript/components/touchables/TouchableNativeFeedback.android.js +65 -0
  148. package/lib/typescript/components/touchables/TouchableNativeFeedback.d.ts +0 -1
  149. package/lib/typescript/components/touchables/TouchableNativeFeedback.js +6 -0
  150. package/lib/typescript/components/touchables/TouchableNativeFeedbackProps.d.ts +0 -1
  151. package/lib/typescript/components/touchables/TouchableNativeFeedbackProps.js +1 -0
  152. package/lib/typescript/components/touchables/TouchableOpacity.d.ts +0 -1
  153. package/lib/typescript/components/touchables/TouchableOpacity.js +51 -0
  154. package/lib/typescript/components/touchables/TouchableWithoutFeedback.d.ts +0 -1
  155. package/lib/typescript/components/touchables/TouchableWithoutFeedback.js +10 -0
  156. package/lib/typescript/components/touchables/index.d.ts +0 -1
  157. package/lib/typescript/components/touchables/index.js +4 -0
  158. package/lib/typescript/components/utils.d.ts +0 -1
  159. package/lib/typescript/components/utils.js +11 -0
  160. package/lib/typescript/findNodeHandle.d.ts +0 -1
  161. package/lib/typescript/findNodeHandle.js +2 -0
  162. package/lib/typescript/findNodeHandle.web.d.ts +0 -1
  163. package/lib/typescript/findNodeHandle.web.js +31 -0
  164. package/lib/typescript/getShadowNodeFromRef.d.ts +0 -1
  165. package/lib/typescript/getShadowNodeFromRef.js +45 -0
  166. package/lib/typescript/getShadowNodeFromRef.web.d.ts +0 -1
  167. package/lib/typescript/getShadowNodeFromRef.web.js +7 -0
  168. package/lib/typescript/ghQueueMicrotask.d.ts +0 -1
  169. package/lib/typescript/ghQueueMicrotask.js +7 -0
  170. package/lib/typescript/handlers/FlingGestureHandler.d.ts +0 -1
  171. package/lib/typescript/handlers/FlingGestureHandler.js +19 -0
  172. package/lib/typescript/handlers/ForceTouchGestureHandler.d.ts +0 -1
  173. package/lib/typescript/handlers/ForceTouchGestureHandler.js +37 -0
  174. package/lib/typescript/handlers/GestureHandlerEventPayload.d.ts +3 -1
  175. package/lib/typescript/handlers/GestureHandlerEventPayload.d.ts.map +1 -1
  176. package/lib/typescript/handlers/GestureHandlerEventPayload.js +1 -0
  177. package/lib/typescript/handlers/LongPressGestureHandler.d.ts +0 -1
  178. package/lib/typescript/handlers/LongPressGestureHandler.js +22 -0
  179. package/lib/typescript/handlers/NativeViewGestureHandler.d.ts +0 -1
  180. package/lib/typescript/handlers/NativeViewGestureHandler.js +20 -0
  181. package/lib/typescript/handlers/PanGestureHandler.d.ts +0 -1
  182. package/lib/typescript/handlers/PanGestureHandler.js +128 -0
  183. package/lib/typescript/handlers/PinchGestureHandler.d.ts +0 -1
  184. package/lib/typescript/handlers/PinchGestureHandler.js +12 -0
  185. package/lib/typescript/handlers/PressabilityDebugView.d.ts +0 -1
  186. package/lib/typescript/handlers/PressabilityDebugView.js +2 -0
  187. package/lib/typescript/handlers/PressabilityDebugView.web.d.ts +0 -1
  188. package/lib/typescript/handlers/PressabilityDebugView.web.js +4 -0
  189. package/lib/typescript/handlers/RotationGestureHandler.d.ts +0 -1
  190. package/lib/typescript/handlers/RotationGestureHandler.js +12 -0
  191. package/lib/typescript/handlers/TapGestureHandler.d.ts +0 -1
  192. package/lib/typescript/handlers/TapGestureHandler.js +26 -0
  193. package/lib/typescript/handlers/createHandler.d.ts +0 -1
  194. package/lib/typescript/handlers/createHandler.js +375 -0
  195. package/lib/typescript/handlers/createNativeWrapper.d.ts +0 -1
  196. package/lib/typescript/handlers/createNativeWrapper.js +67 -0
  197. package/lib/typescript/handlers/customDirectEventTypes.d.ts +0 -1
  198. package/lib/typescript/handlers/customDirectEventTypes.js +2 -0
  199. package/lib/typescript/handlers/customDirectEventTypes.web.d.ts +0 -1
  200. package/lib/typescript/handlers/customDirectEventTypes.web.js +4 -0
  201. package/lib/typescript/handlers/gestureHandlerCommon.d.ts +0 -1
  202. package/lib/typescript/handlers/gestureHandlerCommon.js +42 -0
  203. package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts +9 -1
  204. package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts.map +1 -1
  205. package/lib/typescript/handlers/gestureHandlerTypesCompat.js +1 -0
  206. package/lib/typescript/handlers/gestures/GestureDetector/Wrap.d.ts +0 -1
  207. package/lib/typescript/handlers/gestures/GestureDetector/Wrap.js +22 -0
  208. package/lib/typescript/handlers/gestures/GestureDetector/Wrap.web.d.ts +0 -1
  209. package/lib/typescript/handlers/gestures/GestureDetector/Wrap.web.js +24 -0
  210. package/lib/typescript/handlers/gestures/GestureDetector/attachHandlers.d.ts +0 -1
  211. package/lib/typescript/handlers/gestures/GestureDetector/attachHandlers.js +55 -0
  212. package/lib/typescript/handlers/gestures/GestureDetector/dropHandlers.d.ts +0 -1
  213. package/lib/typescript/handlers/gestures/GestureDetector/dropHandlers.js +12 -0
  214. package/lib/typescript/handlers/gestures/GestureDetector/index.d.ts +0 -1
  215. package/lib/typescript/handlers/gestures/GestureDetector/index.js +114 -0
  216. package/lib/typescript/handlers/gestures/GestureDetector/needsToReattach.d.ts +0 -1
  217. package/lib/typescript/handlers/gestures/GestureDetector/needsToReattach.js +18 -0
  218. package/lib/typescript/handlers/gestures/GestureDetector/types.d.ts +0 -1
  219. package/lib/typescript/handlers/gestures/GestureDetector/types.js +1 -0
  220. package/lib/typescript/handlers/gestures/GestureDetector/updateHandlers.d.ts +0 -1
  221. package/lib/typescript/handlers/gestures/GestureDetector/updateHandlers.js +54 -0
  222. package/lib/typescript/handlers/gestures/GestureDetector/useAnimatedGesture.d.ts +0 -1
  223. package/lib/typescript/handlers/gestures/GestureDetector/useAnimatedGesture.js +137 -0
  224. package/lib/typescript/handlers/gestures/GestureDetector/useDetectorUpdater.d.ts +0 -1
  225. package/lib/typescript/handlers/gestures/GestureDetector/useDetectorUpdater.js +48 -0
  226. package/lib/typescript/handlers/gestures/GestureDetector/useMountReactions.d.ts +0 -1
  227. package/lib/typescript/handlers/gestures/GestureDetector/useMountReactions.js +35 -0
  228. package/lib/typescript/handlers/gestures/GestureDetector/useViewRefHandler.d.ts +0 -1
  229. package/lib/typescript/handlers/gestures/GestureDetector/useViewRefHandler.js +32 -0
  230. package/lib/typescript/handlers/gestures/GestureDetector/utils.d.ts +0 -1
  231. package/lib/typescript/handlers/gestures/GestureDetector/utils.js +140 -0
  232. package/lib/typescript/handlers/gestures/eventReceiver.d.ts +0 -1
  233. package/lib/typescript/handlers/gestures/eventReceiver.js +105 -0
  234. package/lib/typescript/handlers/gestures/flingGesture.d.ts +0 -1
  235. package/lib/typescript/handlers/gestures/flingGesture.js +27 -0
  236. package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts +9 -1
  237. package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts.map +1 -1
  238. package/lib/typescript/handlers/gestures/forceTouchGesture.js +57 -0
  239. package/lib/typescript/handlers/gestures/gesture.d.ts +0 -1
  240. package/lib/typescript/handlers/gestures/gesture.js +303 -0
  241. package/lib/typescript/handlers/gestures/gestureComposition.d.ts +0 -1
  242. package/lib/typescript/handlers/gestures/gestureComposition.js +78 -0
  243. package/lib/typescript/handlers/gestures/gestureObjects.d.ts +3 -2
  244. package/lib/typescript/handlers/gestures/gestureObjects.d.ts.map +1 -1
  245. package/lib/typescript/handlers/gestures/gestureObjects.js +125 -0
  246. package/lib/typescript/handlers/gestures/gestureStateManager.d.ts +0 -1
  247. package/lib/typescript/handlers/gestures/gestureStateManager.js +60 -0
  248. package/lib/typescript/handlers/gestures/gestureStateManager.web.d.ts +0 -1
  249. package/lib/typescript/handlers/gestures/gestureStateManager.web.js +19 -0
  250. package/lib/typescript/handlers/gestures/hoverGesture.d.ts +0 -1
  251. package/lib/typescript/handlers/gestures/hoverGesture.js +45 -0
  252. package/lib/typescript/handlers/gestures/longPressGesture.d.ts +0 -1
  253. package/lib/typescript/handlers/gestures/longPressGesture.js +35 -0
  254. package/lib/typescript/handlers/gestures/manualGesture.d.ts +0 -1
  255. package/lib/typescript/handlers/gestures/manualGesture.js +16 -0
  256. package/lib/typescript/handlers/gestures/nativeGesture.d.ts +0 -1
  257. package/lib/typescript/handlers/gestures/nativeGesture.js +24 -0
  258. package/lib/typescript/handlers/gestures/panGesture.d.ts +0 -1
  259. package/lib/typescript/handlers/gestures/panGesture.js +181 -0
  260. package/lib/typescript/handlers/gestures/pinchGesture.d.ts +0 -1
  261. package/lib/typescript/handlers/gestures/pinchGesture.js +27 -0
  262. package/lib/typescript/handlers/gestures/reanimatedWrapper.d.ts +0 -1
  263. package/lib/typescript/handlers/gestures/reanimatedWrapper.js +23 -0
  264. package/lib/typescript/handlers/gestures/rotationGesture.d.ts +0 -1
  265. package/lib/typescript/handlers/gestures/rotationGesture.js +27 -0
  266. package/lib/typescript/handlers/gestures/tapGesture.d.ts +0 -1
  267. package/lib/typescript/handlers/gestures/tapGesture.js +72 -0
  268. package/lib/typescript/handlers/getNextHandlerTag.d.ts +0 -1
  269. package/lib/typescript/handlers/getNextHandlerTag.js +4 -0
  270. package/lib/typescript/handlers/handlersRegistry.d.ts +0 -1
  271. package/lib/typescript/handlers/handlersRegistry.js +36 -0
  272. package/lib/typescript/handlers/utils.d.ts +0 -1
  273. package/lib/typescript/handlers/utils.js +58 -0
  274. package/lib/typescript/index.d.ts +0 -1
  275. package/lib/typescript/index.js +28 -0
  276. package/lib/typescript/init.d.ts +0 -1
  277. package/lib/typescript/init.js +15 -0
  278. package/lib/typescript/jestUtils/index.d.ts +0 -1
  279. package/lib/typescript/jestUtils/index.js +1 -0
  280. package/lib/typescript/jestUtils/jestUtils.d.ts +0 -1
  281. package/lib/typescript/jestUtils/jestUtils.js +290 -0
  282. package/lib/typescript/mocks.d.ts +0 -1
  283. package/lib/typescript/mocks.js +59 -0
  284. package/lib/typescript/mountRegistry.d.ts +0 -1
  285. package/lib/typescript/mountRegistry.js +29 -0
  286. package/lib/typescript/specs/NativeRNGestureHandlerModule.d.ts +0 -1
  287. package/lib/typescript/specs/NativeRNGestureHandlerModule.js +2 -0
  288. package/lib/typescript/specs/RNGestureHandlerButtonNativeComponent.d.ts +0 -1
  289. package/lib/typescript/specs/RNGestureHandlerButtonNativeComponent.js +2 -0
  290. package/lib/typescript/specs/RNGestureHandlerRootViewNativeComponent.d.ts +0 -1
  291. package/lib/typescript/specs/RNGestureHandlerRootViewNativeComponent.js +2 -0
  292. package/lib/typescript/typeUtils.d.ts +0 -1
  293. package/lib/typescript/typeUtils.js +1 -0
  294. package/lib/typescript/utils.d.ts +0 -1
  295. package/lib/typescript/utils.js +80 -0
  296. package/lib/typescript/web/Gestures.d.ts +0 -1
  297. package/lib/typescript/web/Gestures.js +38 -0
  298. package/lib/typescript/web/constants.d.ts +0 -1
  299. package/lib/typescript/web/constants.js +2 -0
  300. package/lib/typescript/web/detectors/RotationGestureDetector.d.ts +0 -1
  301. package/lib/typescript/web/detectors/RotationGestureDetector.d.ts.map +1 -1
  302. package/lib/typescript/web/detectors/RotationGestureDetector.js +122 -0
  303. package/lib/typescript/web/detectors/ScaleGestureDetector.d.ts +0 -1
  304. package/lib/typescript/web/detectors/ScaleGestureDetector.js +117 -0
  305. package/lib/typescript/web/handlers/FlingGestureHandler.d.ts +0 -1
  306. package/lib/typescript/web/handlers/FlingGestureHandler.d.ts.map +1 -1
  307. package/lib/typescript/web/handlers/FlingGestureHandler.js +133 -0
  308. package/lib/typescript/web/handlers/GestureHandler.d.ts +0 -1
  309. package/lib/typescript/web/handlers/GestureHandler.d.ts.map +1 -1
  310. package/lib/typescript/web/handlers/GestureHandler.js +656 -0
  311. package/lib/typescript/web/handlers/HoverGestureHandler.d.ts +0 -1
  312. package/lib/typescript/web/handlers/HoverGestureHandler.js +37 -0
  313. package/lib/typescript/web/handlers/IGestureHandler.d.ts +0 -1
  314. package/lib/typescript/web/handlers/IGestureHandler.js +1 -0
  315. package/lib/typescript/web/handlers/LongPressGestureHandler.d.ts +0 -1
  316. package/lib/typescript/web/handlers/LongPressGestureHandler.js +136 -0
  317. package/lib/typescript/web/handlers/ManualGestureHandler.d.ts +0 -1
  318. package/lib/typescript/web/handlers/ManualGestureHandler.js +29 -0
  319. package/lib/typescript/web/handlers/NativeViewGestureHandler.d.ts +0 -1
  320. package/lib/typescript/web/handlers/NativeViewGestureHandler.js +133 -0
  321. package/lib/typescript/web/handlers/PanGestureHandler.d.ts +2 -1
  322. package/lib/typescript/web/handlers/PanGestureHandler.d.ts.map +1 -1
  323. package/lib/typescript/web/handlers/PanGestureHandler.js +420 -0
  324. package/lib/typescript/web/handlers/PinchGestureHandler.d.ts +0 -1
  325. package/lib/typescript/web/handlers/PinchGestureHandler.js +117 -0
  326. package/lib/typescript/web/handlers/RotationGestureHandler.d.ts +0 -1
  327. package/lib/typescript/web/handlers/RotationGestureHandler.js +122 -0
  328. package/lib/typescript/web/handlers/TapGestureHandler.d.ts +1 -1
  329. package/lib/typescript/web/handlers/TapGestureHandler.d.ts.map +1 -1
  330. package/lib/typescript/web/handlers/TapGestureHandler.js +202 -0
  331. package/lib/typescript/web/interfaces.d.ts +0 -1
  332. package/lib/typescript/web/interfaces.js +25 -0
  333. package/lib/typescript/web/tools/CircularBuffer.d.ts +0 -1
  334. package/lib/typescript/web/tools/CircularBuffer.js +37 -0
  335. package/lib/typescript/web/tools/EventManager.d.ts +0 -1
  336. package/lib/typescript/web/tools/EventManager.js +85 -0
  337. package/lib/typescript/web/tools/GestureHandlerDelegate.d.ts +0 -1
  338. package/lib/typescript/web/tools/GestureHandlerDelegate.js +1 -0
  339. package/lib/typescript/web/tools/GestureHandlerOrchestrator.d.ts +0 -1
  340. package/lib/typescript/web/tools/GestureHandlerOrchestrator.d.ts.map +1 -1
  341. package/lib/typescript/web/tools/GestureHandlerOrchestrator.js +273 -0
  342. package/lib/typescript/web/tools/GestureHandlerWebDelegate.d.ts +0 -1
  343. package/lib/typescript/web/tools/GestureHandlerWebDelegate.js +169 -0
  344. package/lib/typescript/web/tools/InteractionManager.d.ts +0 -1
  345. package/lib/typescript/web/tools/InteractionManager.js +91 -0
  346. package/lib/typescript/web/tools/KeyboardEventManager.d.ts +0 -1
  347. package/lib/typescript/web/tools/KeyboardEventManager.js +73 -0
  348. package/lib/typescript/web/tools/LeastSquareSolver.d.ts +0 -1
  349. package/lib/typescript/web/tools/LeastSquareSolver.js +147 -0
  350. package/lib/typescript/web/tools/NodeManager.d.ts +0 -1
  351. package/lib/typescript/web/tools/NodeManager.js +28 -0
  352. package/lib/typescript/web/tools/PointerEventManager.d.ts +0 -1
  353. package/lib/typescript/web/tools/PointerEventManager.js +179 -0
  354. package/lib/typescript/web/tools/PointerTracker.d.ts +3 -4
  355. package/lib/typescript/web/tools/PointerTracker.d.ts.map +1 -1
  356. package/lib/typescript/web/tools/PointerTracker.js +161 -0
  357. package/lib/typescript/web/tools/Vector.d.ts +1 -2
  358. package/lib/typescript/web/tools/Vector.js +43 -0
  359. package/lib/typescript/web/tools/VelocityTracker.d.ts +0 -1
  360. package/lib/typescript/web/tools/VelocityTracker.js +76 -0
  361. package/lib/typescript/web/tools/WheelEventManager.d.ts +0 -1
  362. package/lib/typescript/web/tools/WheelEventManager.js +40 -0
  363. package/lib/typescript/web/utils.d.ts +0 -1
  364. package/lib/typescript/web/utils.js +233 -0
  365. package/lib/typescript/web_hammer/DiscreteGestureHandler.d.ts +0 -1
  366. package/lib/typescript/web_hammer/DiscreteGestureHandler.js +48 -0
  367. package/lib/typescript/web_hammer/DraggingGestureHandler.d.ts +0 -1
  368. package/lib/typescript/web_hammer/DraggingGestureHandler.js +25 -0
  369. package/lib/typescript/web_hammer/Errors.d.ts +0 -1
  370. package/lib/typescript/web_hammer/Errors.js +5 -0
  371. package/lib/typescript/web_hammer/FlingGestureHandler.d.ts +0 -1
  372. package/lib/typescript/web_hammer/FlingGestureHandler.js +119 -0
  373. package/lib/typescript/web_hammer/GestureHandler.d.ts +0 -1
  374. package/lib/typescript/web_hammer/GestureHandler.js +469 -0
  375. package/lib/typescript/web_hammer/IndiscreteGestureHandler.d.ts +0 -1
  376. package/lib/typescript/web_hammer/IndiscreteGestureHandler.js +26 -0
  377. package/lib/typescript/web_hammer/LongPressGestureHandler.d.ts +0 -1
  378. package/lib/typescript/web_hammer/LongPressGestureHandler.js +46 -0
  379. package/lib/typescript/web_hammer/NativeViewGestureHandler.d.ts +0 -1
  380. package/lib/typescript/web_hammer/NativeViewGestureHandler.js +40 -0
  381. package/lib/typescript/web_hammer/NodeManager.d.ts +0 -1
  382. package/lib/typescript/web_hammer/NodeManager.js +28 -0
  383. package/lib/typescript/web_hammer/PanGestureHandler.d.ts +0 -1
  384. package/lib/typescript/web_hammer/PanGestureHandler.js +151 -0
  385. package/lib/typescript/web_hammer/PinchGestureHandler.d.ts +0 -1
  386. package/lib/typescript/web_hammer/PinchGestureHandler.js +19 -0
  387. package/lib/typescript/web_hammer/PressGestureHandler.d.ts +0 -1
  388. package/lib/typescript/web_hammer/PressGestureHandler.js +133 -0
  389. package/lib/typescript/web_hammer/RotationGestureHandler.d.ts +0 -1
  390. package/lib/typescript/web_hammer/RotationGestureHandler.js +20 -0
  391. package/lib/typescript/web_hammer/TapGestureHandler.d.ts +0 -1
  392. package/lib/typescript/web_hammer/TapGestureHandler.js +142 -0
  393. package/lib/typescript/web_hammer/constants.d.ts +0 -1
  394. package/lib/typescript/web_hammer/constants.js +42 -0
  395. package/lib/typescript/web_hammer/utils.d.ts +0 -1
  396. package/lib/typescript/web_hammer/utils.js +15 -0
  397. package/package.json +4 -2
  398. package/src/components/Pressable/Pressable.tsx +357 -445
  399. package/src/components/Pressable/PressableProps.tsx +15 -0
  400. package/src/components/Pressable/StateMachine.tsx +49 -0
  401. package/src/components/Pressable/stateDefinitions.ts +125 -0
  402. package/src/components/Pressable/utils.ts +11 -7
  403. package/src/handlers/GestureHandlerEventPayload.ts +3 -0
  404. package/src/handlers/gestureHandlerTypesCompat.ts +9 -0
  405. package/src/handlers/gestures/forceTouchGesture.ts +9 -0
  406. package/src/handlers/gestures/gestureObjects.ts +3 -1
  407. package/src/web/detectors/RotationGestureDetector.ts +4 -0
  408. package/src/web/handlers/FlingGestureHandler.ts +4 -0
  409. package/src/web/handlers/GestureHandler.ts +9 -3
  410. package/src/web/handlers/PanGestureHandler.ts +25 -36
  411. package/src/web/handlers/TapGestureHandler.ts +14 -19
  412. package/src/web/tools/GestureHandlerOrchestrator.ts +1 -0
  413. package/src/web/tools/PointerEventManager.ts +1 -1
  414. package/src/web/tools/PointerTracker.ts +17 -15
  415. package/src/web/tools/Vector.ts +1 -1
@@ -0,0 +1,202 @@
1
+ import { State } from '../../State';
2
+ import { EventTypes } from '../interfaces';
3
+ import GestureHandler from './GestureHandler';
4
+ const DEFAULT_MAX_DURATION_MS = 500;
5
+ const DEFAULT_MAX_DELAY_MS = 500;
6
+ const DEFAULT_NUMBER_OF_TAPS = 1;
7
+ const DEFAULT_MIN_NUMBER_OF_POINTERS = 1;
8
+ export default class TapGestureHandler extends GestureHandler {
9
+ maxDeltaX = Number.MIN_SAFE_INTEGER;
10
+ maxDeltaY = Number.MIN_SAFE_INTEGER;
11
+ maxDistSq = Number.MIN_SAFE_INTEGER;
12
+ maxDurationMs = DEFAULT_MAX_DURATION_MS;
13
+ maxDelayMs = DEFAULT_MAX_DELAY_MS;
14
+ numberOfTaps = DEFAULT_NUMBER_OF_TAPS;
15
+ minNumberOfPointers = DEFAULT_MIN_NUMBER_OF_POINTERS;
16
+ currentMaxNumberOfPointers = 1;
17
+ startX = 0;
18
+ startY = 0;
19
+ offsetX = 0;
20
+ offsetY = 0;
21
+ lastX = 0;
22
+ lastY = 0;
23
+ waitTimeout;
24
+ delayTimeout;
25
+ tapsSoFar = 0;
26
+ updateGestureConfig({ enabled = true, ...props }) {
27
+ super.updateGestureConfig({ enabled: enabled, ...props });
28
+ if (this.config.numberOfTaps !== undefined) {
29
+ this.numberOfTaps = this.config.numberOfTaps;
30
+ }
31
+ if (this.config.maxDurationMs !== undefined) {
32
+ this.maxDurationMs = this.config.maxDurationMs;
33
+ }
34
+ if (this.config.maxDelayMs !== undefined) {
35
+ this.maxDelayMs = this.config.maxDelayMs;
36
+ }
37
+ if (this.config.maxDeltaX !== undefined) {
38
+ this.maxDeltaX = this.config.maxDeltaX;
39
+ }
40
+ if (this.config.maxDeltaY !== undefined) {
41
+ this.maxDeltaY = this.config.maxDeltaY;
42
+ }
43
+ if (this.config.maxDist !== undefined) {
44
+ this.maxDistSq = this.config.maxDist * this.config.maxDist;
45
+ }
46
+ if (this.config.minPointers !== undefined) {
47
+ this.minNumberOfPointers = this.config.minPointers;
48
+ }
49
+ }
50
+ resetConfig() {
51
+ super.resetConfig();
52
+ this.maxDeltaX = Number.MIN_SAFE_INTEGER;
53
+ this.maxDeltaY = Number.MIN_SAFE_INTEGER;
54
+ this.maxDistSq = Number.MIN_SAFE_INTEGER;
55
+ this.maxDurationMs = DEFAULT_MAX_DURATION_MS;
56
+ this.maxDelayMs = DEFAULT_MAX_DELAY_MS;
57
+ this.numberOfTaps = DEFAULT_NUMBER_OF_TAPS;
58
+ this.minNumberOfPointers = DEFAULT_MIN_NUMBER_OF_POINTERS;
59
+ }
60
+ clearTimeouts() {
61
+ clearTimeout(this.waitTimeout);
62
+ clearTimeout(this.delayTimeout);
63
+ }
64
+ startTap() {
65
+ this.clearTimeouts();
66
+ this.waitTimeout = setTimeout(() => this.fail(), this.maxDurationMs);
67
+ }
68
+ endTap() {
69
+ this.clearTimeouts();
70
+ if (++this.tapsSoFar === this.numberOfTaps &&
71
+ this.currentMaxNumberOfPointers >= this.minNumberOfPointers) {
72
+ this.activate();
73
+ }
74
+ else {
75
+ this.delayTimeout = setTimeout(() => this.fail(), this.maxDelayMs);
76
+ }
77
+ }
78
+ updateLastCoords() {
79
+ const { x, y } = this.tracker.getAbsoluteCoordsAverage();
80
+ this.lastX = x;
81
+ this.lastY = y;
82
+ }
83
+ // Handling Events
84
+ onPointerDown(event) {
85
+ if (!this.isButtonInConfig(event.button)) {
86
+ return;
87
+ }
88
+ this.tracker.addToTracker(event);
89
+ super.onPointerDown(event);
90
+ this.trySettingPosition(event);
91
+ this.startX = event.x;
92
+ this.startY = event.y;
93
+ this.lastX = event.x;
94
+ this.lastY = event.y;
95
+ this.updateState(event);
96
+ this.tryToSendTouchEvent(event);
97
+ }
98
+ onPointerAdd(event) {
99
+ super.onPointerAdd(event);
100
+ this.tracker.addToTracker(event);
101
+ this.trySettingPosition(event);
102
+ this.offsetX += this.lastX - this.startX;
103
+ this.offsetY += this.lastY - this.startY;
104
+ this.updateLastCoords();
105
+ this.startX = this.lastX;
106
+ this.startY = this.lastY;
107
+ this.updateState(event);
108
+ }
109
+ onPointerUp(event) {
110
+ super.onPointerUp(event);
111
+ this.updateLastCoords();
112
+ this.tracker.removeFromTracker(event.pointerId);
113
+ this.updateState(event);
114
+ }
115
+ onPointerRemove(event) {
116
+ super.onPointerRemove(event);
117
+ this.tracker.removeFromTracker(event.pointerId);
118
+ this.offsetX += this.lastX - this.startX;
119
+ this.offsetY += this.lastY = this.startY;
120
+ this.updateLastCoords();
121
+ this.startX = this.lastX;
122
+ this.startY = this.lastY;
123
+ this.updateState(event);
124
+ }
125
+ onPointerMove(event) {
126
+ this.trySettingPosition(event);
127
+ this.tracker.track(event);
128
+ this.updateLastCoords();
129
+ this.updateState(event);
130
+ super.onPointerMove(event);
131
+ }
132
+ onPointerOutOfBounds(event) {
133
+ this.trySettingPosition(event);
134
+ this.tracker.track(event);
135
+ this.updateLastCoords();
136
+ this.updateState(event);
137
+ super.onPointerOutOfBounds(event);
138
+ }
139
+ updateState(event) {
140
+ if (this.currentMaxNumberOfPointers < this.tracker.trackedPointersCount) {
141
+ this.currentMaxNumberOfPointers = this.tracker.trackedPointersCount;
142
+ }
143
+ if (this.shouldFail()) {
144
+ this.fail();
145
+ return;
146
+ }
147
+ switch (this.state) {
148
+ case State.UNDETERMINED:
149
+ if (event.eventType === EventTypes.DOWN) {
150
+ this.begin();
151
+ }
152
+ this.startTap();
153
+ break;
154
+ case State.BEGAN:
155
+ if (event.eventType === EventTypes.UP) {
156
+ this.endTap();
157
+ }
158
+ if (event.eventType === EventTypes.DOWN) {
159
+ this.startTap();
160
+ }
161
+ break;
162
+ default:
163
+ break;
164
+ }
165
+ }
166
+ trySettingPosition(event) {
167
+ if (this.state !== State.UNDETERMINED) {
168
+ return;
169
+ }
170
+ this.offsetX = 0;
171
+ this.offsetY = 0;
172
+ this.startX = event.x;
173
+ this.startY = event.y;
174
+ }
175
+ shouldFail() {
176
+ const dx = this.lastX - this.startX + this.offsetX;
177
+ if (this.maxDeltaX !== Number.MIN_SAFE_INTEGER &&
178
+ Math.abs(dx) > this.maxDeltaX) {
179
+ return true;
180
+ }
181
+ const dy = this.lastY - this.startY + this.offsetY;
182
+ if (this.maxDeltaY !== Number.MIN_SAFE_INTEGER &&
183
+ Math.abs(dy) > this.maxDeltaY) {
184
+ return true;
185
+ }
186
+ const distSq = dy * dy + dx * dx;
187
+ return (this.maxDistSq !== Number.MIN_SAFE_INTEGER && distSq > this.maxDistSq);
188
+ }
189
+ activate() {
190
+ super.activate();
191
+ this.end();
192
+ }
193
+ onCancel() {
194
+ this.resetProgress();
195
+ this.clearTimeouts();
196
+ }
197
+ resetProgress() {
198
+ this.clearTimeouts();
199
+ this.tapsSoFar = 0;
200
+ this.currentMaxNumberOfPointers = 0;
201
+ }
202
+ }
@@ -155,4 +155,3 @@ export type SVGRef = {
155
155
  };
156
156
  };
157
157
  export {};
158
- //# sourceMappingURL=interfaces.d.ts.map
@@ -0,0 +1,25 @@
1
+ export var EventTypes;
2
+ (function (EventTypes) {
3
+ EventTypes[EventTypes["DOWN"] = 0] = "DOWN";
4
+ EventTypes[EventTypes["ADDITIONAL_POINTER_DOWN"] = 1] = "ADDITIONAL_POINTER_DOWN";
5
+ EventTypes[EventTypes["UP"] = 2] = "UP";
6
+ EventTypes[EventTypes["ADDITIONAL_POINTER_UP"] = 3] = "ADDITIONAL_POINTER_UP";
7
+ EventTypes[EventTypes["MOVE"] = 4] = "MOVE";
8
+ EventTypes[EventTypes["ENTER"] = 5] = "ENTER";
9
+ EventTypes[EventTypes["LEAVE"] = 6] = "LEAVE";
10
+ EventTypes[EventTypes["CANCEL"] = 7] = "CANCEL";
11
+ })(EventTypes || (EventTypes = {}));
12
+ export var TouchEventType;
13
+ (function (TouchEventType) {
14
+ TouchEventType[TouchEventType["UNDETERMINED"] = 0] = "UNDETERMINED";
15
+ TouchEventType[TouchEventType["DOWN"] = 1] = "DOWN";
16
+ TouchEventType[TouchEventType["MOVE"] = 2] = "MOVE";
17
+ TouchEventType[TouchEventType["UP"] = 3] = "UP";
18
+ TouchEventType[TouchEventType["CANCELLED"] = 4] = "CANCELLED";
19
+ })(TouchEventType || (TouchEventType = {}));
20
+ export var WheelDevice;
21
+ (function (WheelDevice) {
22
+ WheelDevice[WheelDevice["UNDETERMINED"] = 0] = "UNDETERMINED";
23
+ WheelDevice[WheelDevice["MOUSE"] = 1] = "MOUSE";
24
+ WheelDevice[WheelDevice["TOUCHPAD"] = 2] = "TOUCHPAD";
25
+ })(WheelDevice || (WheelDevice = {}));
@@ -9,4 +9,3 @@ export default class CircularBuffer<T> {
9
9
  clear(): void;
10
10
  get size(): number;
11
11
  }
12
- //# sourceMappingURL=CircularBuffer.d.ts.map
@@ -0,0 +1,37 @@
1
+ export default class CircularBuffer {
2
+ capacity;
3
+ buffer;
4
+ index;
5
+ _size;
6
+ constructor(size) {
7
+ this.capacity = size;
8
+ this.buffer = new Array(size);
9
+ this.index = 0;
10
+ this._size = 0;
11
+ }
12
+ push(element) {
13
+ this.buffer[this.index] = element;
14
+ this.index = (this.index + 1) % this.capacity;
15
+ this._size = Math.min(this.size + 1, this.capacity);
16
+ }
17
+ get(at) {
18
+ if (this._size === this.capacity) {
19
+ let index = (this.index + at) % this.capacity;
20
+ if (index < 0) {
21
+ index += this.capacity;
22
+ }
23
+ return this.buffer[index];
24
+ }
25
+ else {
26
+ return this.buffer[at];
27
+ }
28
+ }
29
+ clear() {
30
+ this.buffer = new Array(this.capacity);
31
+ this.index = 0;
32
+ this._size = 0;
33
+ }
34
+ get size() {
35
+ return this._size;
36
+ }
37
+ }
@@ -37,4 +37,3 @@ export default abstract class EventManager<T> {
37
37
  resetManager(): void;
38
38
  }
39
39
  export {};
40
- //# sourceMappingURL=EventManager.d.ts.map
@@ -0,0 +1,85 @@
1
+ export default class EventManager {
2
+ view;
3
+ pointersInBounds = [];
4
+ activePointersCounter;
5
+ constructor(view) {
6
+ this.view = view;
7
+ this.activePointersCounter = 0;
8
+ }
9
+ onPointerDown(_event) { }
10
+ onPointerAdd(_event) { }
11
+ onPointerUp(_event) { }
12
+ onPointerRemove(_event) { }
13
+ onPointerMove(_event) { }
14
+ onPointerLeave(_event) { } // Called only when pointer is pressed (or touching)
15
+ onPointerEnter(_event) { } // Called only when pointer is pressed (or touching)
16
+ onPointerCancel(_event) {
17
+ // When pointer cancel is triggered and there are more pointers on the view, only one pointer is cancelled
18
+ // Because we want all pointers to be cancelled by that event, we are doing it manually by reseting handler and changing activePointersCounter to 0
19
+ // Events that correspond to removing the pointer (pointerup, touchend) have condition, that they don't perform any action when activePointersCounter
20
+ // is equal to 0. This prevents counter from going to negative values, when pointers are removed from view after one of them has been cancelled
21
+ }
22
+ onPointerOutOfBounds(_event) { }
23
+ onPointerMoveOver(_event) { }
24
+ onPointerMoveOut(_event) { }
25
+ onWheel(_event) { }
26
+ setOnPointerDown(callback) {
27
+ this.onPointerDown = callback;
28
+ }
29
+ setOnPointerAdd(callback) {
30
+ this.onPointerAdd = callback;
31
+ }
32
+ setOnPointerUp(callback) {
33
+ this.onPointerUp = callback;
34
+ }
35
+ setOnPointerRemove(callback) {
36
+ this.onPointerRemove = callback;
37
+ }
38
+ setOnPointerMove(callback) {
39
+ this.onPointerMove = callback;
40
+ }
41
+ setOnPointerLeave(callback) {
42
+ this.onPointerLeave = callback;
43
+ }
44
+ setOnPointerEnter(callback) {
45
+ this.onPointerEnter = callback;
46
+ }
47
+ setOnPointerCancel(callback) {
48
+ this.onPointerCancel = callback;
49
+ }
50
+ setOnPointerOutOfBounds(callback) {
51
+ this.onPointerOutOfBounds = callback;
52
+ }
53
+ setOnPointerMoveOver(callback) {
54
+ this.onPointerMoveOver = callback;
55
+ }
56
+ setOnPointerMoveOut(callback) {
57
+ this.onPointerMoveOut = callback;
58
+ }
59
+ setOnWheel(callback) {
60
+ this.onWheel = callback;
61
+ }
62
+ markAsInBounds(pointerId) {
63
+ if (this.pointersInBounds.indexOf(pointerId) >= 0) {
64
+ return;
65
+ }
66
+ this.pointersInBounds.push(pointerId);
67
+ }
68
+ markAsOutOfBounds(pointerId) {
69
+ const index = this.pointersInBounds.indexOf(pointerId);
70
+ if (index < 0) {
71
+ return;
72
+ }
73
+ this.pointersInBounds.splice(index, 1);
74
+ }
75
+ resetManager() {
76
+ // Reseting activePointersCounter is necessary to make gestures such as pinch work properly
77
+ // There are gestures that end when there is still one active pointer (like pinch/rotation)
78
+ // When these gestures end, they are reset, but they still receive events from pointer that is active
79
+ // This causes trouble, since only onPointerDown registers gesture in orchestrator, and while gestures receive
80
+ // Events from active pointer after they finished, next pointerdown event will be registered as additional pointer, not the first one
81
+ // This casues trouble like gestures getting stuck in END state, even though they should have gone to UNDETERMINED
82
+ this.activePointersCounter = 0;
83
+ this.pointersInBounds = [];
84
+ }
85
+ }
@@ -22,4 +22,3 @@ export interface GestureHandlerDelegate<TComponent, THandler> {
22
22
  onEnabledChange(enabled: boolean): void;
23
23
  destroy(config: Config): void;
24
24
  }
25
- //# sourceMappingURL=GestureHandlerDelegate.d.ts.map
@@ -0,0 +1 @@
1
+ export {};
@@ -29,4 +29,3 @@ export default class GestureHandlerOrchestrator {
29
29
  cancelMouseAndPenGestures(currentHandler: IGestureHandler): void;
30
30
  static get instance(): GestureHandlerOrchestrator;
31
31
  }
32
- //# sourceMappingURL=GestureHandlerOrchestrator.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"GestureHandlerOrchestrator.d.ts","sourceRoot":"","sources":["../../../../src/web/tools/GestureHandlerOrchestrator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,KAAK,eAAe,MAAM,6BAA6B,CAAC;AAG/D,MAAM,CAAC,OAAO,OAAO,0BAA0B;IAC7C,OAAO,CAAC,MAAM,CAAC,SAAS,CAA6B;IAErD,OAAO,CAAC,eAAe,CAAyB;IAChD,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,oBAAoB,CAA0B;IAEtD,OAAO,CAAC,uBAAuB,CAAK;IACpC,OAAO,CAAC,eAAe,CAAK;IAI5B,OAAO;IAEP,OAAO,CAAC,+BAA+B;IAMvC,OAAO,CAAC,YAAY;IAOb,6BAA6B,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAcpE,OAAO,CAAC,uBAAuB;IAiB/B,OAAO,CAAC,wBAAwB;IAWhC,OAAO,CAAC,kCAAkC;IAa1C,OAAO,CAAC,WAAW;IAgCnB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,uBAAuB;IAoBxB,oBAAoB,CACzB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,KAAK,EACf,QAAQ,EAAE,KAAK,EACf,cAAc,CAAC,EAAE,OAAO,GACvB,IAAI;IA8DP,OAAO,CAAC,UAAU;IAuClB,OAAO,CAAC,kBAAkB;IAYnB,yBAAyB,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAYhE,OAAO,CAAC,yBAAyB;IAWjC,OAAO,CAAC,oBAAoB;IAW5B,OAAO,CAAC,0BAA0B;IAyBlC,OAAO,CAAC,YAAY;IAsBpB,OAAO,CAAC,UAAU;IAYX,yBAAyB,CAAC,cAAc,EAAE,eAAe,GAAG,IAAI;IAwBvE,WAAkB,QAAQ,IAAI,0BAA0B,CAMvD;CACF"}
1
+ {"version":3,"file":"GestureHandlerOrchestrator.d.ts","sourceRoot":"","sources":["../../../../src/web/tools/GestureHandlerOrchestrator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,KAAK,eAAe,MAAM,6BAA6B,CAAC;AAG/D,MAAM,CAAC,OAAO,OAAO,0BAA0B;IAC7C,OAAO,CAAC,MAAM,CAAC,SAAS,CAA6B;IAErD,OAAO,CAAC,eAAe,CAAyB;IAChD,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,oBAAoB,CAA0B;IAEtD,OAAO,CAAC,uBAAuB,CAAK;IACpC,OAAO,CAAC,eAAe,CAAK;IAI5B,OAAO;IAEP,OAAO,CAAC,+BAA+B;IAMvC,OAAO,CAAC,YAAY;IAOb,6BAA6B,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAcpE,OAAO,CAAC,uBAAuB;IAiB/B,OAAO,CAAC,wBAAwB;IAWhC,OAAO,CAAC,kCAAkC;IAa1C,OAAO,CAAC,WAAW;IAgCnB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,uBAAuB;IAoBxB,oBAAoB,CACzB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,KAAK,EACf,QAAQ,EAAE,KAAK,EACf,cAAc,CAAC,EAAE,OAAO,GACvB,IAAI;IA8DP,OAAO,CAAC,UAAU;IAuClB,OAAO,CAAC,kBAAkB;IAYnB,yBAAyB,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAYhE,OAAO,CAAC,yBAAyB;IAWjC,OAAO,CAAC,oBAAoB;IAW5B,OAAO,CAAC,0BAA0B;IAyBlC,OAAO,CAAC,YAAY;IAuBpB,OAAO,CAAC,UAAU;IAYX,yBAAyB,CAAC,cAAc,EAAE,eAAe,GAAG,IAAI;IAwBvE,WAAkB,QAAQ,IAAI,0BAA0B,CAMvD;CACF"}
@@ -0,0 +1,273 @@
1
+ import { PointerType } from '../../PointerType';
2
+ import { State } from '../../State';
3
+ import PointerTracker from './PointerTracker';
4
+ export default class GestureHandlerOrchestrator {
5
+ static _instance;
6
+ gestureHandlers = [];
7
+ awaitingHandlers = [];
8
+ awaitingHandlersTags = new Set();
9
+ handlingChangeSemaphore = 0;
10
+ activationIndex = 0;
11
+ // Private beacuse of Singleton
12
+ // eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function
13
+ constructor() { }
14
+ scheduleFinishedHandlersCleanup() {
15
+ if (this.handlingChangeSemaphore === 0) {
16
+ this.cleanupFinishedHandlers();
17
+ }
18
+ }
19
+ cleanHandler(handler) {
20
+ handler.reset();
21
+ handler.active = false;
22
+ handler.awaiting = false;
23
+ handler.activationIndex = Number.MAX_VALUE;
24
+ }
25
+ removeHandlerFromOrchestrator(handler) {
26
+ const indexInGestureHandlers = this.gestureHandlers.indexOf(handler);
27
+ const indexInAwaitingHandlers = this.awaitingHandlers.indexOf(handler);
28
+ if (indexInGestureHandlers >= 0) {
29
+ this.gestureHandlers.splice(indexInGestureHandlers, 1);
30
+ }
31
+ if (indexInAwaitingHandlers >= 0) {
32
+ this.awaitingHandlers.splice(indexInAwaitingHandlers, 1);
33
+ this.awaitingHandlersTags.delete(handler.handlerTag);
34
+ }
35
+ }
36
+ cleanupFinishedHandlers() {
37
+ const handlersToRemove = new Set();
38
+ for (let i = this.gestureHandlers.length - 1; i >= 0; --i) {
39
+ const handler = this.gestureHandlers[i];
40
+ if (this.isFinished(handler.state) && !handler.awaiting) {
41
+ this.cleanHandler(handler);
42
+ handlersToRemove.add(handler);
43
+ }
44
+ }
45
+ this.gestureHandlers = this.gestureHandlers.filter((handler) => !handlersToRemove.has(handler));
46
+ }
47
+ hasOtherHandlerToWaitFor(handler) {
48
+ const hasToWaitFor = (otherHandler) => {
49
+ return (!this.isFinished(otherHandler.state) &&
50
+ this.shouldHandlerWaitForOther(handler, otherHandler));
51
+ };
52
+ return this.gestureHandlers.some(hasToWaitFor);
53
+ }
54
+ shouldBeCancelledByFinishedHandler(handler) {
55
+ const shouldBeCancelled = (otherHandler) => {
56
+ return (this.shouldHandlerWaitForOther(handler, otherHandler) &&
57
+ otherHandler.state === State.END);
58
+ };
59
+ return this.gestureHandlers.some(shouldBeCancelled);
60
+ }
61
+ tryActivate(handler) {
62
+ if (this.shouldBeCancelledByFinishedHandler(handler)) {
63
+ handler.cancel();
64
+ return;
65
+ }
66
+ if (this.hasOtherHandlerToWaitFor(handler)) {
67
+ this.addAwaitingHandler(handler);
68
+ return;
69
+ }
70
+ const handlerState = handler.state;
71
+ if (handlerState === State.CANCELLED || handlerState === State.FAILED) {
72
+ return;
73
+ }
74
+ if (this.shouldActivate(handler)) {
75
+ this.makeActive(handler);
76
+ return;
77
+ }
78
+ if (handlerState === State.ACTIVE) {
79
+ handler.fail();
80
+ return;
81
+ }
82
+ if (handlerState === State.BEGAN) {
83
+ handler.cancel();
84
+ }
85
+ }
86
+ shouldActivate(handler) {
87
+ const shouldBeCancelledBy = (otherHandler) => {
88
+ return this.shouldHandlerBeCancelledBy(handler, otherHandler);
89
+ };
90
+ return !this.gestureHandlers.some(shouldBeCancelledBy);
91
+ }
92
+ cleanupAwaitingHandlers(handler) {
93
+ const shouldWait = (otherHandler) => {
94
+ return (!otherHandler.awaiting &&
95
+ this.shouldHandlerWaitForOther(otherHandler, handler));
96
+ };
97
+ for (const otherHandler of this.awaitingHandlers) {
98
+ if (shouldWait(otherHandler)) {
99
+ this.cleanHandler(otherHandler);
100
+ this.awaitingHandlersTags.delete(otherHandler.handlerTag);
101
+ }
102
+ }
103
+ this.awaitingHandlers = this.awaitingHandlers.filter((otherHandler) => this.awaitingHandlersTags.has(otherHandler.handlerTag));
104
+ }
105
+ onHandlerStateChange(handler, newState, oldState, sendIfDisabled) {
106
+ if (!handler.enabled && !sendIfDisabled) {
107
+ return;
108
+ }
109
+ this.handlingChangeSemaphore += 1;
110
+ if (this.isFinished(newState)) {
111
+ for (const otherHandler of this.awaitingHandlers) {
112
+ if (!this.shouldHandlerWaitForOther(otherHandler, handler) ||
113
+ !this.awaitingHandlersTags.has(otherHandler.handlerTag)) {
114
+ continue;
115
+ }
116
+ if (newState !== State.END) {
117
+ this.tryActivate(otherHandler);
118
+ continue;
119
+ }
120
+ otherHandler.cancel();
121
+ if (otherHandler.state === State.END) {
122
+ // Handle edge case, where discrete gestures end immediately after activation thus
123
+ // their state is set to END and when the gesture they are waiting for activates they
124
+ // should be cancelled, however `cancel` was never sent as gestures were already in the END state.
125
+ // Send synthetic BEGAN -> CANCELLED to properly handle JS logic
126
+ otherHandler.sendEvent(State.CANCELLED, State.BEGAN);
127
+ }
128
+ otherHandler.awaiting = false;
129
+ }
130
+ }
131
+ if (newState === State.ACTIVE) {
132
+ this.tryActivate(handler);
133
+ }
134
+ else if (oldState === State.ACTIVE || oldState === State.END) {
135
+ if (handler.active) {
136
+ handler.sendEvent(newState, oldState);
137
+ }
138
+ else if (oldState === State.ACTIVE &&
139
+ (newState === State.CANCELLED || newState === State.FAILED)) {
140
+ handler.sendEvent(newState, State.BEGAN);
141
+ }
142
+ }
143
+ else if (oldState !== State.UNDETERMINED ||
144
+ newState !== State.CANCELLED) {
145
+ handler.sendEvent(newState, oldState);
146
+ }
147
+ this.handlingChangeSemaphore -= 1;
148
+ this.scheduleFinishedHandlersCleanup();
149
+ if (!this.awaitingHandlers.includes(handler)) {
150
+ this.cleanupAwaitingHandlers(handler);
151
+ }
152
+ }
153
+ makeActive(handler) {
154
+ const currentState = handler.state;
155
+ handler.active = true;
156
+ handler.shouldResetProgress = true;
157
+ handler.activationIndex = this.activationIndex++;
158
+ for (let i = this.gestureHandlers.length - 1; i >= 0; --i) {
159
+ if (this.shouldHandlerBeCancelledBy(this.gestureHandlers[i], handler)) {
160
+ this.gestureHandlers[i].cancel();
161
+ }
162
+ }
163
+ for (const otherHandler of this.awaitingHandlers) {
164
+ if (this.shouldHandlerBeCancelledBy(otherHandler, handler)) {
165
+ otherHandler.awaiting = false;
166
+ }
167
+ }
168
+ handler.sendEvent(State.ACTIVE, State.BEGAN);
169
+ if (currentState !== State.ACTIVE) {
170
+ handler.sendEvent(State.END, State.ACTIVE);
171
+ if (currentState !== State.END) {
172
+ handler.sendEvent(State.UNDETERMINED, State.END);
173
+ }
174
+ }
175
+ if (!handler.awaiting) {
176
+ return;
177
+ }
178
+ handler.awaiting = false;
179
+ this.awaitingHandlers = this.awaitingHandlers.filter((otherHandler) => otherHandler !== handler);
180
+ }
181
+ addAwaitingHandler(handler) {
182
+ if (this.awaitingHandlers.includes(handler)) {
183
+ return;
184
+ }
185
+ this.awaitingHandlers.push(handler);
186
+ this.awaitingHandlersTags.add(handler.handlerTag);
187
+ handler.awaiting = true;
188
+ handler.activationIndex = this.activationIndex++;
189
+ }
190
+ recordHandlerIfNotPresent(handler) {
191
+ if (this.gestureHandlers.includes(handler)) {
192
+ return;
193
+ }
194
+ this.gestureHandlers.push(handler);
195
+ handler.active = false;
196
+ handler.awaiting = false;
197
+ handler.activationIndex = Number.MAX_SAFE_INTEGER;
198
+ }
199
+ shouldHandlerWaitForOther(handler, otherHandler) {
200
+ return (handler !== otherHandler &&
201
+ (handler.shouldWaitForHandlerFailure(otherHandler) ||
202
+ otherHandler.shouldRequireToWaitForFailure(handler)));
203
+ }
204
+ canRunSimultaneously(gh1, gh2) {
205
+ return (gh1 === gh2 ||
206
+ gh1.shouldRecognizeSimultaneously(gh2) ||
207
+ gh2.shouldRecognizeSimultaneously(gh1));
208
+ }
209
+ shouldHandlerBeCancelledBy(handler, otherHandler) {
210
+ if (this.canRunSimultaneously(handler, otherHandler)) {
211
+ return false;
212
+ }
213
+ if (handler.awaiting || handler.state === State.ACTIVE) {
214
+ return handler.shouldBeCancelledByOther(otherHandler);
215
+ }
216
+ const handlerPointers = handler.getTrackedPointersID();
217
+ const otherPointers = otherHandler.getTrackedPointersID();
218
+ if (!PointerTracker.shareCommonPointers(handlerPointers, otherPointers) &&
219
+ handler.delegate.view !== otherHandler.delegate.view) {
220
+ return this.checkOverlap(handler, otherHandler);
221
+ }
222
+ return true;
223
+ }
224
+ checkOverlap(handler, otherHandler) {
225
+ // If handlers don't have common pointers, default return value is false.
226
+ // However, if at least on pointer overlaps with both handlers, we return true
227
+ // This solves issue in overlapping parents example
228
+ // TODO: Find better way to handle that issue, for example by activation order and handler cancelling
229
+ const isPointerWithinBothBounds = (pointer) => {
230
+ const point = handler.tracker.getLastAbsoluteCoords(pointer);
231
+ return (point &&
232
+ handler.delegate.isPointerInBounds(point) &&
233
+ otherHandler.delegate.isPointerInBounds(point));
234
+ };
235
+ return handler.getTrackedPointersID().some(isPointerWithinBothBounds);
236
+ }
237
+ isFinished(state) {
238
+ return (state === State.END || state === State.FAILED || state === State.CANCELLED);
239
+ }
240
+ // This function is called when handler receives touchdown event
241
+ // If handler is using mouse or pen as a pointer and any handler receives touch event,
242
+ // mouse/pen event dissappears - it doesn't send onPointerCancel nor onPointerUp (and others)
243
+ // This became a problem because handler was left at active state without any signal to end or fail
244
+ // To handle this, when new touch event is received, we loop through active handlers and check which type of
245
+ // pointer they're using. If there are any handler with mouse/pen as a pointer, we cancel them
246
+ cancelMouseAndPenGestures(currentHandler) {
247
+ this.gestureHandlers.forEach((handler) => {
248
+ if (handler.pointerType !== PointerType.MOUSE &&
249
+ handler.pointerType !== PointerType.STYLUS) {
250
+ return;
251
+ }
252
+ if (handler !== currentHandler) {
253
+ handler.cancel();
254
+ }
255
+ else {
256
+ // Handler that received touch event should have its pointer tracker reset
257
+ // This allows handler to smoothly change from mouse/pen to touch
258
+ // The drawback is, that when we try to use mouse/pen one more time, it doesn't send onPointerDown at the first time
259
+ // so it is required to click two times to get handler to work
260
+ //
261
+ // However, handler will receive manually created onPointerEnter that is triggered in EventManager in onPointerMove method.
262
+ // There may be possibility to use that fact to make handler respond properly to first mouse click
263
+ handler.tracker.resetTracker();
264
+ }
265
+ });
266
+ }
267
+ static get instance() {
268
+ if (!GestureHandlerOrchestrator._instance) {
269
+ GestureHandlerOrchestrator._instance = new GestureHandlerOrchestrator();
270
+ }
271
+ return GestureHandlerOrchestrator._instance;
272
+ }
273
+ }
@@ -33,4 +33,3 @@ export declare class GestureHandlerWebDelegate implements GestureHandlerDelegate
33
33
  get view(): HTMLElement;
34
34
  set view(value: HTMLElement);
35
35
  }
36
- //# sourceMappingURL=GestureHandlerWebDelegate.d.ts.map