@opengovsg/oui 0.0.0-snapshot-20250812083020 → 0.0.0-snapshot-20250813172831

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 (147) hide show
  1. package/dist/cjs/badge/badge.cjs +4 -4
  2. package/dist/cjs/badge/use-badge.cjs +6 -6
  3. package/dist/cjs/banner/banner.cjs +3 -3
  4. package/dist/cjs/button/button.cjs +4 -4
  5. package/dist/cjs/calendar/calendar-bottom-content.cjs +2 -2
  6. package/dist/cjs/calendar/calendar-header.cjs +2 -2
  7. package/dist/cjs/calendar/calendar-month-day-selector.cjs +4 -4
  8. package/dist/cjs/calendar/calendar.cjs +4 -4
  9. package/dist/cjs/calendar/hooks/use-calendar-selectors.cjs +4 -4
  10. package/dist/cjs/calendar/utils.cjs +3 -3
  11. package/dist/cjs/checkbox/checkbox-group-style-context.cjs +16 -0
  12. package/dist/cjs/checkbox/checkbox.cjs +94 -0
  13. package/dist/cjs/checkbox/index.cjs +12 -0
  14. package/dist/cjs/combo-box/combo-box-fuzzy.cjs +6 -6
  15. package/dist/cjs/combo-box/combo-box-item.cjs +2 -2
  16. package/dist/cjs/combo-box/combo-box.cjs +4 -4
  17. package/dist/cjs/date-field/date-field.cjs +3 -3
  18. package/dist/cjs/date-picker/date-picker.cjs +3 -3
  19. package/dist/cjs/date-range-picker/date-range-picker.cjs +5 -5
  20. package/dist/cjs/govt-banner/govt-banner.cjs +3 -3
  21. package/dist/cjs/hooks/use-callback-ref.cjs +4 -4
  22. package/dist/cjs/hooks/use-controllable-state.cjs +2 -2
  23. package/dist/cjs/index.cjs +56 -39
  24. package/dist/cjs/input/input.cjs +2 -2
  25. package/dist/cjs/menu/menu.cjs +7 -7
  26. package/dist/cjs/node_modules/.pnpm/@react-aria_focus@3.20.5_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/focus/dist/useFocusRing.cjs +45 -0
  27. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/context.cjs +21 -0
  28. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/textSelection.cjs +72 -0
  29. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useFocus.cjs +60 -0
  30. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useFocusVisible.cjs +210 -0
  31. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useFocusWithin.cjs +100 -0
  32. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useHover.cjs +152 -0
  33. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/usePress.cjs +676 -0
  34. package/dist/cjs/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/utils.cjs +160 -0
  35. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_check_private_redeclaration.cjs +9 -0
  36. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_apply_descriptor_get.cjs +9 -0
  37. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_apply_descriptor_set.cjs +16 -0
  38. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_extract_field_descriptor.cjs +9 -0
  39. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_get.cjs +11 -0
  40. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_init.cjs +10 -0
  41. package/dist/cjs/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_set.cjs +12 -0
  42. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/Icon.cjs +4 -4
  43. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/createLucideIcon.cjs +3 -3
  44. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/chevrons-right.cjs +22 -0
  45. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/ellipsis.cjs +23 -0
  46. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/minus.cjs +19 -0
  47. package/dist/cjs/pagination/hooks/use-pagination.cjs +117 -0
  48. package/dist/cjs/pagination/index.cjs +17 -0
  49. package/dist/cjs/pagination/pagination-cursor.cjs +18 -0
  50. package/dist/cjs/pagination/pagination-item.cjs +18 -0
  51. package/dist/cjs/pagination/pagination.cjs +263 -0
  52. package/dist/cjs/pagination/use-pagination-item.cjs +87 -0
  53. package/dist/cjs/pagination/use-pagination.cjs +251 -0
  54. package/dist/cjs/range-calendar/range-calendar.cjs +6 -6
  55. package/dist/cjs/ripple/use-ripple.cjs +4 -4
  56. package/dist/cjs/select/select.cjs +3 -3
  57. package/dist/cjs/spinner/use-spinner.cjs +3 -3
  58. package/dist/cjs/system/react-utils/context.cjs +3 -3
  59. package/dist/cjs/system/react-utils/dom-props.cjs +186 -0
  60. package/dist/cjs/system/react-utils/filter-dom-props.cjs +46 -0
  61. package/dist/cjs/system/react-utils/index.cjs +2 -0
  62. package/dist/cjs/system/react-utils/refs.cjs +3 -3
  63. package/dist/cjs/system/utils.cjs +3 -3
  64. package/dist/cjs/tabs/tabs.cjs +2 -2
  65. package/dist/cjs/tag-field/tag-field-item.cjs +2 -2
  66. package/dist/cjs/tag-field/tag-field-list.cjs +4 -4
  67. package/dist/cjs/tag-field/tag-field-root.cjs +14 -14
  68. package/dist/cjs/tag-field/tag-field-state-context.cjs +2 -2
  69. package/dist/cjs/tag-field/tag-field-tag-list.cjs +3 -3
  70. package/dist/cjs/tag-field/tag-field-trigger.cjs +2 -2
  71. package/dist/cjs/tag-field/tag-field.cjs +4 -4
  72. package/dist/cjs/tag-field/use-tag-field-state.cjs +6 -6
  73. package/dist/cjs/tag-field/use-tag-field.cjs +4 -4
  74. package/dist/cjs/text-area/text-area.cjs +2 -2
  75. package/dist/cjs/toggle/toggle.cjs +3 -3
  76. package/dist/esm/button/button.js +1 -1
  77. package/dist/esm/calendar/calendar-month-day-selector.js +2 -2
  78. package/dist/esm/checkbox/checkbox-group-style-context.js +13 -0
  79. package/dist/esm/checkbox/checkbox.js +91 -0
  80. package/dist/esm/checkbox/index.js +3 -0
  81. package/dist/esm/combo-box/combo-box.js +1 -1
  82. package/dist/esm/date-picker/date-picker.js +1 -1
  83. package/dist/esm/date-range-picker/date-range-picker.js +2 -2
  84. package/dist/esm/index.js +19 -12
  85. package/dist/esm/menu/menu.js +1 -1
  86. package/dist/esm/node_modules/.pnpm/@react-aria_focus@3.20.5_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/focus/dist/useFocusRing.js +43 -0
  87. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/context.js +19 -0
  88. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/textSelection.js +69 -0
  89. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useFocus.js +58 -0
  90. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useFocusVisible.js +205 -0
  91. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useFocusWithin.js +98 -0
  92. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/useHover.js +150 -0
  93. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/usePress.js +674 -0
  94. package/dist/esm/node_modules/.pnpm/@react-aria_interactions@3.25.3_react-dom@19.0.0_react@19.0.0__react@19.0.0/node_modules/@react-aria/interactions/dist/utils.js +155 -0
  95. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_check_private_redeclaration.js +7 -0
  96. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_apply_descriptor_get.js +7 -0
  97. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_apply_descriptor_set.js +14 -0
  98. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_extract_field_descriptor.js +7 -0
  99. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_get.js +9 -0
  100. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_init.js +8 -0
  101. package/dist/esm/node_modules/.pnpm/@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_set.js +10 -0
  102. package/dist/esm/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/chevrons-right.js +17 -0
  103. package/dist/esm/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/ellipsis.js +18 -0
  104. package/dist/esm/node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/minus.js +14 -0
  105. package/dist/esm/pagination/hooks/use-pagination.js +114 -0
  106. package/dist/esm/pagination/index.js +6 -0
  107. package/dist/esm/pagination/pagination-cursor.js +16 -0
  108. package/dist/esm/pagination/pagination-item.js +16 -0
  109. package/dist/esm/pagination/pagination.js +261 -0
  110. package/dist/esm/pagination/use-pagination-item.js +85 -0
  111. package/dist/esm/pagination/use-pagination.js +248 -0
  112. package/dist/esm/select/select.js +1 -1
  113. package/dist/esm/system/react-utils/dom-props.js +183 -0
  114. package/dist/esm/system/react-utils/filter-dom-props.js +44 -0
  115. package/dist/esm/system/react-utils/index.js +1 -0
  116. package/dist/esm/tag-field/tag-field.js +2 -2
  117. package/dist/types/checkbox/checkbox-group-style-context.d.ts +6 -0
  118. package/dist/types/checkbox/checkbox-group-style-context.d.ts.map +1 -0
  119. package/dist/types/checkbox/checkbox.d.ts +19 -0
  120. package/dist/types/checkbox/checkbox.d.ts.map +1 -0
  121. package/dist/types/checkbox/index.d.ts +3 -0
  122. package/dist/types/checkbox/index.d.ts.map +1 -0
  123. package/dist/types/index.d.mts +2 -0
  124. package/dist/types/index.d.ts +2 -0
  125. package/dist/types/index.d.ts.map +1 -1
  126. package/dist/types/pagination/hooks/use-pagination.d.ts +51 -0
  127. package/dist/types/pagination/hooks/use-pagination.d.ts.map +1 -0
  128. package/dist/types/pagination/index.d.ts +7 -0
  129. package/dist/types/pagination/index.d.ts.map +1 -0
  130. package/dist/types/pagination/pagination-cursor.d.ts +9 -0
  131. package/dist/types/pagination/pagination-cursor.d.ts.map +1 -0
  132. package/dist/types/pagination/pagination-item.d.ts +5 -0
  133. package/dist/types/pagination/pagination-item.d.ts.map +1 -0
  134. package/dist/types/pagination/pagination.d.ts +5 -0
  135. package/dist/types/pagination/pagination.d.ts.map +1 -0
  136. package/dist/types/pagination/use-pagination-item.d.ts +51 -0
  137. package/dist/types/pagination/use-pagination-item.d.ts.map +1 -0
  138. package/dist/types/pagination/use-pagination.d.ts +353 -0
  139. package/dist/types/pagination/use-pagination.d.ts.map +1 -0
  140. package/dist/types/system/react-utils/context.d.ts.map +1 -1
  141. package/dist/types/system/react-utils/dom-props.d.ts +3 -0
  142. package/dist/types/system/react-utils/dom-props.d.ts.map +1 -0
  143. package/dist/types/system/react-utils/filter-dom-props.d.ts +39 -0
  144. package/dist/types/system/react-utils/filter-dom-props.d.ts.map +1 -0
  145. package/dist/types/system/react-utils/index.d.ts +1 -0
  146. package/dist/types/system/react-utils/index.d.ts.map +1 -1
  147. package/package.json +8 -6
@@ -0,0 +1,674 @@
1
+ import { setEventTarget as $8a9cb279dc87e130$export$c2b7abe5d61ec696, createSyntheticEvent as $8a9cb279dc87e130$export$525bc4921d56d4a, preventFocus as $8a9cb279dc87e130$export$cabe61c495ee3649 } from './utils.js';
2
+ import { restoreTextSelection as $14c0b72509d70225$export$b0d6fa1ab32e3295, disableTextSelection as $14c0b72509d70225$export$16a4697467175487 } from './textSelection.js';
3
+ import { PressResponderContext as $ae1eeba8b9eafd08$export$5165eccb35aaadb5 } from './context.js';
4
+ import { _ as _class_private_field_get } from '../../../../../@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_get.js';
5
+ import { _ as _class_private_field_init } from '../../../../../@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_init.js';
6
+ import { _ as _class_private_field_set } from '../../../../../@swc_helpers@0.5.17/node_modules/@swc/helpers/esm/_class_private_field_set.js';
7
+ import { useGlobalListeners, useEffectEvent, nodeContains, getEventTarget, isVirtualPointerEvent, getOwnerDocument, focusWithoutScrolling, isVirtualClick, getOwnerWindow, mergeProps, useSyncRef, openLink, chain, isMac } from '@react-aria/utils';
8
+ import { flushSync } from 'react-dom';
9
+ import { useState, useRef, useMemo, useEffect, useContext } from 'react';
10
+
11
+ /*
12
+ * Copyright 2020 Adobe. All rights reserved.
13
+ * This file is licensed to you under the Apache License, Version 2.0 (the "License");
14
+ * you may not use this file except in compliance with the License. You may obtain a copy
15
+ * of the License at http://www.apache.org/licenses/LICENSE-2.0
16
+ *
17
+ * Unless required by applicable law or agreed to in writing, software distributed under
18
+ * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
19
+ * OF ANY KIND, either express or implied. See the License for the specific language
20
+ * governing permissions and limitations under the License.
21
+ */ // Portions of the code in this file are based on code from react.
22
+ // Original licensing for the following can be found in the
23
+ // NOTICE file in the root directory of this source tree.
24
+ // See https://github.com/facebook/react/tree/cc7c1aece46a6b69b41958d731e0fd27c94bfc6c/packages/react-interactions
25
+
26
+
27
+
28
+
29
+
30
+
31
+
32
+
33
+
34
+ function $f6c31cce2adf654f$var$usePressResponderContext(props) {
35
+ // Consume context from <PressResponder> and merge with props.
36
+ let context = (useContext)(($ae1eeba8b9eafd08$export$5165eccb35aaadb5));
37
+ if (context) {
38
+ let { register: register, ...contextProps } = context;
39
+ props = (mergeProps)(contextProps, props);
40
+ register();
41
+ }
42
+ (useSyncRef)(context, props.ref);
43
+ return props;
44
+ }
45
+ var $f6c31cce2adf654f$var$_shouldStopPropagation = /*#__PURE__*/ new WeakMap();
46
+ class $f6c31cce2adf654f$var$PressEvent {
47
+ continuePropagation() {
48
+ (_class_private_field_set)(this, $f6c31cce2adf654f$var$_shouldStopPropagation, false);
49
+ }
50
+ get shouldStopPropagation() {
51
+ return (_class_private_field_get)(this, $f6c31cce2adf654f$var$_shouldStopPropagation);
52
+ }
53
+ constructor(type, pointerType, originalEvent, state){
54
+ (_class_private_field_init)(this, $f6c31cce2adf654f$var$_shouldStopPropagation, {
55
+ writable: true,
56
+ value: void 0
57
+ });
58
+ (_class_private_field_set)(this, $f6c31cce2adf654f$var$_shouldStopPropagation, true);
59
+ var _state_target;
60
+ let currentTarget = (_state_target = state === null || state === void 0 ? void 0 : state.target) !== null && _state_target !== void 0 ? _state_target : originalEvent.currentTarget;
61
+ const rect = currentTarget === null || currentTarget === void 0 ? void 0 : currentTarget.getBoundingClientRect();
62
+ let x, y = 0;
63
+ let clientX, clientY = null;
64
+ if (originalEvent.clientX != null && originalEvent.clientY != null) {
65
+ clientX = originalEvent.clientX;
66
+ clientY = originalEvent.clientY;
67
+ }
68
+ if (rect) {
69
+ if (clientX != null && clientY != null) {
70
+ x = clientX - rect.left;
71
+ y = clientY - rect.top;
72
+ } else {
73
+ x = rect.width / 2;
74
+ y = rect.height / 2;
75
+ }
76
+ }
77
+ this.type = type;
78
+ this.pointerType = pointerType;
79
+ this.target = originalEvent.currentTarget;
80
+ this.shiftKey = originalEvent.shiftKey;
81
+ this.metaKey = originalEvent.metaKey;
82
+ this.ctrlKey = originalEvent.ctrlKey;
83
+ this.altKey = originalEvent.altKey;
84
+ this.x = x;
85
+ this.y = y;
86
+ }
87
+ }
88
+ const $f6c31cce2adf654f$var$LINK_CLICKED = Symbol('linkClicked');
89
+ const $f6c31cce2adf654f$var$STYLE_ID = 'react-aria-pressable-style';
90
+ const $f6c31cce2adf654f$var$PRESSABLE_ATTRIBUTE = 'data-react-aria-pressable';
91
+ function $f6c31cce2adf654f$export$45712eceda6fad21(props) {
92
+ let { onPress: onPress, onPressChange: onPressChange, onPressStart: onPressStart, onPressEnd: onPressEnd, onPressUp: onPressUp, onClick: onClick, isDisabled: isDisabled, isPressed: isPressedProp, preventFocusOnPress: preventFocusOnPress, shouldCancelOnPointerExit: shouldCancelOnPointerExit, allowTextSelectionOnPress: allowTextSelectionOnPress, ref: domRef, ...domProps } = $f6c31cce2adf654f$var$usePressResponderContext(props);
93
+ let [isPressed, setPressed] = (useState)(false);
94
+ let ref = (useRef)({
95
+ isPressed: false,
96
+ ignoreEmulatedMouseEvents: false,
97
+ didFirePressStart: false,
98
+ isTriggeringEvent: false,
99
+ activePointerId: null,
100
+ target: null,
101
+ isOverTarget: false,
102
+ pointerType: null,
103
+ disposables: []
104
+ });
105
+ let { addGlobalListener: addGlobalListener, removeAllGlobalListeners: removeAllGlobalListeners } = (useGlobalListeners)();
106
+ let triggerPressStart = (useEffectEvent)((originalEvent, pointerType)=>{
107
+ let state = ref.current;
108
+ if (isDisabled || state.didFirePressStart) return false;
109
+ let shouldStopPropagation = true;
110
+ state.isTriggeringEvent = true;
111
+ if (onPressStart) {
112
+ let event = new $f6c31cce2adf654f$var$PressEvent('pressstart', pointerType, originalEvent);
113
+ onPressStart(event);
114
+ shouldStopPropagation = event.shouldStopPropagation;
115
+ }
116
+ if (onPressChange) onPressChange(true);
117
+ state.isTriggeringEvent = false;
118
+ state.didFirePressStart = true;
119
+ setPressed(true);
120
+ return shouldStopPropagation;
121
+ });
122
+ let triggerPressEnd = (useEffectEvent)((originalEvent, pointerType, wasPressed = true)=>{
123
+ let state = ref.current;
124
+ if (!state.didFirePressStart) return false;
125
+ state.didFirePressStart = false;
126
+ state.isTriggeringEvent = true;
127
+ let shouldStopPropagation = true;
128
+ if (onPressEnd) {
129
+ let event = new $f6c31cce2adf654f$var$PressEvent('pressend', pointerType, originalEvent);
130
+ onPressEnd(event);
131
+ shouldStopPropagation = event.shouldStopPropagation;
132
+ }
133
+ if (onPressChange) onPressChange(false);
134
+ setPressed(false);
135
+ if (onPress && wasPressed && !isDisabled) {
136
+ let event = new $f6c31cce2adf654f$var$PressEvent('press', pointerType, originalEvent);
137
+ onPress(event);
138
+ shouldStopPropagation && (shouldStopPropagation = event.shouldStopPropagation);
139
+ }
140
+ state.isTriggeringEvent = false;
141
+ return shouldStopPropagation;
142
+ });
143
+ let triggerPressUp = (useEffectEvent)((originalEvent, pointerType)=>{
144
+ let state = ref.current;
145
+ if (isDisabled) return false;
146
+ if (onPressUp) {
147
+ state.isTriggeringEvent = true;
148
+ let event = new $f6c31cce2adf654f$var$PressEvent('pressup', pointerType, originalEvent);
149
+ onPressUp(event);
150
+ state.isTriggeringEvent = false;
151
+ return event.shouldStopPropagation;
152
+ }
153
+ return true;
154
+ });
155
+ let cancel = (useEffectEvent)((e)=>{
156
+ let state = ref.current;
157
+ if (state.isPressed && state.target) {
158
+ if (state.didFirePressStart && state.pointerType != null) triggerPressEnd($f6c31cce2adf654f$var$createEvent(state.target, e), state.pointerType, false);
159
+ state.isPressed = false;
160
+ state.isOverTarget = false;
161
+ state.activePointerId = null;
162
+ state.pointerType = null;
163
+ removeAllGlobalListeners();
164
+ if (!allowTextSelectionOnPress) ($14c0b72509d70225$export$b0d6fa1ab32e3295)(state.target);
165
+ for (let dispose of state.disposables)dispose();
166
+ state.disposables = [];
167
+ }
168
+ });
169
+ let cancelOnPointerExit = (useEffectEvent)((e)=>{
170
+ if (shouldCancelOnPointerExit) cancel(e);
171
+ });
172
+ let triggerClick = (useEffectEvent)((e)=>{
173
+ onClick === null || onClick === void 0 ? void 0 : onClick(e);
174
+ });
175
+ let triggerSyntheticClick = (useEffectEvent)((e, target)=>{
176
+ // Some third-party libraries pass in onClick instead of onPress.
177
+ // Create a fake mouse event and trigger onClick as well.
178
+ // This matches the browser's native activation behavior for certain elements (e.g. button).
179
+ // https://html.spec.whatwg.org/#activation
180
+ // https://html.spec.whatwg.org/#fire-a-synthetic-pointer-event
181
+ if (onClick) {
182
+ let event = new MouseEvent('click', e);
183
+ ($8a9cb279dc87e130$export$c2b7abe5d61ec696)(event, target);
184
+ onClick(($8a9cb279dc87e130$export$525bc4921d56d4a)(event));
185
+ }
186
+ });
187
+ let pressProps = (useMemo)(()=>{
188
+ let state = ref.current;
189
+ let pressProps = {
190
+ onKeyDown (e) {
191
+ if ($f6c31cce2adf654f$var$isValidKeyboardEvent(e.nativeEvent, e.currentTarget) && (nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) {
192
+ var _state_metaKeyEvents;
193
+ if ($f6c31cce2adf654f$var$shouldPreventDefaultKeyboard((getEventTarget)(e.nativeEvent), e.key)) e.preventDefault();
194
+ // If the event is repeating, it may have started on a different element
195
+ // after which focus moved to the current element. Ignore these events and
196
+ // only handle the first key down event.
197
+ let shouldStopPropagation = true;
198
+ if (!state.isPressed && !e.repeat) {
199
+ state.target = e.currentTarget;
200
+ state.isPressed = true;
201
+ state.pointerType = 'keyboard';
202
+ shouldStopPropagation = triggerPressStart(e, 'keyboard');
203
+ // Focus may move before the key up event, so register the event on the document
204
+ // instead of the same element where the key down event occurred. Make it capturing so that it will trigger
205
+ // before stopPropagation from useKeyboard on a child element may happen and thus we can still call triggerPress for the parent element.
206
+ let originalTarget = e.currentTarget;
207
+ let pressUp = (e)=>{
208
+ if ($f6c31cce2adf654f$var$isValidKeyboardEvent(e, originalTarget) && !e.repeat && (nodeContains)(originalTarget, (getEventTarget)(e)) && state.target) triggerPressUp($f6c31cce2adf654f$var$createEvent(state.target, e), 'keyboard');
209
+ };
210
+ addGlobalListener((getOwnerDocument)(e.currentTarget), 'keyup', (chain)(pressUp, onKeyUp), true);
211
+ }
212
+ if (shouldStopPropagation) e.stopPropagation();
213
+ // Keep track of the keydown events that occur while the Meta (e.g. Command) key is held.
214
+ // macOS has a bug where keyup events are not fired while the Meta key is down.
215
+ // When the Meta key itself is released we will get an event for that, and we'll act as if
216
+ // all of these other keys were released as well.
217
+ // https://bugs.chromium.org/p/chromium/issues/detail?id=1393524
218
+ // https://bugs.webkit.org/show_bug.cgi?id=55291
219
+ // https://bugzilla.mozilla.org/show_bug.cgi?id=1299553
220
+ if (e.metaKey && (isMac)()) (_state_metaKeyEvents = state.metaKeyEvents) === null || _state_metaKeyEvents === void 0 ? void 0 : _state_metaKeyEvents.set(e.key, e.nativeEvent);
221
+ } else if (e.key === 'Meta') state.metaKeyEvents = new Map();
222
+ },
223
+ onClick (e) {
224
+ if (e && !(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
225
+ if (e && e.button === 0 && !state.isTriggeringEvent && !(openLink).isOpening) {
226
+ let shouldStopPropagation = true;
227
+ if (isDisabled) e.preventDefault();
228
+ // If triggered from a screen reader or by using element.click(),
229
+ // trigger as if it were a keyboard click.
230
+ if (!state.ignoreEmulatedMouseEvents && !state.isPressed && (state.pointerType === 'virtual' || (isVirtualClick)(e.nativeEvent))) {
231
+ let stopPressStart = triggerPressStart(e, 'virtual');
232
+ let stopPressUp = triggerPressUp(e, 'virtual');
233
+ let stopPressEnd = triggerPressEnd(e, 'virtual');
234
+ triggerClick(e);
235
+ shouldStopPropagation = stopPressStart && stopPressUp && stopPressEnd;
236
+ } else if (state.isPressed && state.pointerType !== 'keyboard') {
237
+ let pointerType = state.pointerType || e.nativeEvent.pointerType || 'virtual';
238
+ let stopPressUp = triggerPressUp($f6c31cce2adf654f$var$createEvent(e.currentTarget, e), pointerType);
239
+ let stopPressEnd = triggerPressEnd($f6c31cce2adf654f$var$createEvent(e.currentTarget, e), pointerType, true);
240
+ shouldStopPropagation = stopPressUp && stopPressEnd;
241
+ state.isOverTarget = false;
242
+ triggerClick(e);
243
+ cancel(e);
244
+ }
245
+ state.ignoreEmulatedMouseEvents = false;
246
+ if (shouldStopPropagation) e.stopPropagation();
247
+ }
248
+ }
249
+ };
250
+ let onKeyUp = (e)=>{
251
+ var _state_metaKeyEvents;
252
+ if (state.isPressed && state.target && $f6c31cce2adf654f$var$isValidKeyboardEvent(e, state.target)) {
253
+ var _state_metaKeyEvents1;
254
+ if ($f6c31cce2adf654f$var$shouldPreventDefaultKeyboard((getEventTarget)(e), e.key)) e.preventDefault();
255
+ let target = (getEventTarget)(e);
256
+ let wasPressed = (nodeContains)(state.target, (getEventTarget)(e));
257
+ triggerPressEnd($f6c31cce2adf654f$var$createEvent(state.target, e), 'keyboard', wasPressed);
258
+ if (wasPressed) triggerSyntheticClick(e, state.target);
259
+ removeAllGlobalListeners();
260
+ // If a link was triggered with a key other than Enter, open the URL ourselves.
261
+ // This means the link has a role override, and the default browser behavior
262
+ // only applies when using the Enter key.
263
+ if (e.key !== 'Enter' && $f6c31cce2adf654f$var$isHTMLAnchorLink(state.target) && (nodeContains)(state.target, target) && !e[$f6c31cce2adf654f$var$LINK_CLICKED]) {
264
+ // Store a hidden property on the event so we only trigger link click once,
265
+ // even if there are multiple usePress instances attached to the element.
266
+ e[$f6c31cce2adf654f$var$LINK_CLICKED] = true;
267
+ (openLink)(state.target, e, false);
268
+ }
269
+ state.isPressed = false;
270
+ (_state_metaKeyEvents1 = state.metaKeyEvents) === null || _state_metaKeyEvents1 === void 0 ? void 0 : _state_metaKeyEvents1.delete(e.key);
271
+ } else if (e.key === 'Meta' && ((_state_metaKeyEvents = state.metaKeyEvents) === null || _state_metaKeyEvents === void 0 ? void 0 : _state_metaKeyEvents.size)) {
272
+ var _state_target;
273
+ // If we recorded keydown events that occurred while the Meta key was pressed,
274
+ // and those haven't received keyup events already, fire keyup events ourselves.
275
+ // See comment above for more info about the macOS bug causing this.
276
+ let events = state.metaKeyEvents;
277
+ state.metaKeyEvents = undefined;
278
+ for (let event of events.values())(_state_target = state.target) === null || _state_target === void 0 ? void 0 : _state_target.dispatchEvent(new KeyboardEvent('keyup', event));
279
+ }
280
+ };
281
+ if (typeof PointerEvent !== 'undefined') {
282
+ pressProps.onPointerDown = (e)=>{
283
+ // Only handle left clicks, and ignore events that bubbled through portals.
284
+ if (e.button !== 0 || !(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
285
+ // iOS safari fires pointer events from VoiceOver with incorrect coordinates/target.
286
+ // Ignore and let the onClick handler take care of it instead.
287
+ // https://bugs.webkit.org/show_bug.cgi?id=222627
288
+ // https://bugs.webkit.org/show_bug.cgi?id=223202
289
+ if ((isVirtualPointerEvent)(e.nativeEvent)) {
290
+ state.pointerType = 'virtual';
291
+ return;
292
+ }
293
+ state.pointerType = e.pointerType;
294
+ let shouldStopPropagation = true;
295
+ if (!state.isPressed) {
296
+ state.isPressed = true;
297
+ state.isOverTarget = true;
298
+ state.activePointerId = e.pointerId;
299
+ state.target = e.currentTarget;
300
+ if (!allowTextSelectionOnPress) ($14c0b72509d70225$export$16a4697467175487)(state.target);
301
+ shouldStopPropagation = triggerPressStart(e, state.pointerType);
302
+ // Release pointer capture so that touch interactions can leave the original target.
303
+ // This enables onPointerLeave and onPointerEnter to fire.
304
+ let target = (getEventTarget)(e.nativeEvent);
305
+ if ('releasePointerCapture' in target) target.releasePointerCapture(e.pointerId);
306
+ addGlobalListener((getOwnerDocument)(e.currentTarget), 'pointerup', onPointerUp, false);
307
+ addGlobalListener((getOwnerDocument)(e.currentTarget), 'pointercancel', onPointerCancel, false);
308
+ }
309
+ if (shouldStopPropagation) e.stopPropagation();
310
+ };
311
+ pressProps.onMouseDown = (e)=>{
312
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
313
+ if (e.button === 0) {
314
+ if (preventFocusOnPress) {
315
+ let dispose = ($8a9cb279dc87e130$export$cabe61c495ee3649)(e.target);
316
+ if (dispose) state.disposables.push(dispose);
317
+ }
318
+ e.stopPropagation();
319
+ }
320
+ };
321
+ pressProps.onPointerUp = (e)=>{
322
+ // iOS fires pointerup with zero width and height, so check the pointerType recorded during pointerdown.
323
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent)) || state.pointerType === 'virtual') return;
324
+ // Only handle left clicks. If isPressed is true, delay until onClick.
325
+ if (e.button === 0 && !state.isPressed) triggerPressUp(e, state.pointerType || e.pointerType);
326
+ };
327
+ pressProps.onPointerEnter = (e)=>{
328
+ if (e.pointerId === state.activePointerId && state.target && !state.isOverTarget && state.pointerType != null) {
329
+ state.isOverTarget = true;
330
+ triggerPressStart($f6c31cce2adf654f$var$createEvent(state.target, e), state.pointerType);
331
+ }
332
+ };
333
+ pressProps.onPointerLeave = (e)=>{
334
+ if (e.pointerId === state.activePointerId && state.target && state.isOverTarget && state.pointerType != null) {
335
+ state.isOverTarget = false;
336
+ triggerPressEnd($f6c31cce2adf654f$var$createEvent(state.target, e), state.pointerType, false);
337
+ cancelOnPointerExit(e);
338
+ }
339
+ };
340
+ let onPointerUp = (e)=>{
341
+ if (e.pointerId === state.activePointerId && state.isPressed && e.button === 0 && state.target) {
342
+ if ((nodeContains)(state.target, (getEventTarget)(e)) && state.pointerType != null) {
343
+ // Wait for onClick to fire onPress. This avoids browser issues when the DOM
344
+ // is mutated between onPointerUp and onClick, and is more compatible with third party libraries.
345
+ // https://github.com/adobe/react-spectrum/issues/1513
346
+ // https://issues.chromium.org/issues/40732224
347
+ // However, iOS and Android do not focus or fire onClick after a long press.
348
+ // We work around this by triggering a click ourselves after a timeout.
349
+ // This timeout is canceled during the click event in case the real one fires first.
350
+ // The timeout must be at least 32ms, because Safari on iOS delays the click event on
351
+ // non-form elements without certain ARIA roles (for hover emulation).
352
+ // https://github.com/WebKit/WebKit/blob/dccfae42bb29bd4bdef052e469f604a9387241c0/Source/WebKit/WebProcess/WebPage/ios/WebPageIOS.mm#L875-L892
353
+ let clicked = false;
354
+ let timeout = setTimeout(()=>{
355
+ if (state.isPressed && state.target instanceof HTMLElement) {
356
+ if (clicked) cancel(e);
357
+ else {
358
+ (focusWithoutScrolling)(state.target);
359
+ state.target.click();
360
+ }
361
+ }
362
+ }, 80);
363
+ // Use a capturing listener to track if a click occurred.
364
+ // If stopPropagation is called it may never reach our handler.
365
+ addGlobalListener(e.currentTarget, 'click', ()=>clicked = true, true);
366
+ state.disposables.push(()=>clearTimeout(timeout));
367
+ } else cancel(e);
368
+ // Ignore subsequent onPointerLeave event before onClick on touch devices.
369
+ state.isOverTarget = false;
370
+ }
371
+ };
372
+ let onPointerCancel = (e)=>{
373
+ cancel(e);
374
+ };
375
+ pressProps.onDragStart = (e)=>{
376
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
377
+ // Safari does not call onPointerCancel when a drag starts, whereas Chrome and Firefox do.
378
+ cancel(e);
379
+ };
380
+ } else if (process.env.NODE_ENV === 'test') {
381
+ // NOTE: this fallback branch is entirely used by unit tests.
382
+ // All browsers now support pointer events, but JSDOM still does not.
383
+ pressProps.onMouseDown = (e)=>{
384
+ // Only handle left clicks
385
+ if (e.button !== 0 || !(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
386
+ if (state.ignoreEmulatedMouseEvents) {
387
+ e.stopPropagation();
388
+ return;
389
+ }
390
+ state.isPressed = true;
391
+ state.isOverTarget = true;
392
+ state.target = e.currentTarget;
393
+ state.pointerType = (isVirtualClick)(e.nativeEvent) ? 'virtual' : 'mouse';
394
+ // Flush sync so that focus moved during react re-renders occurs before we yield back to the browser.
395
+ let shouldStopPropagation = (flushSync)(()=>triggerPressStart(e, state.pointerType));
396
+ if (shouldStopPropagation) e.stopPropagation();
397
+ if (preventFocusOnPress) {
398
+ let dispose = ($8a9cb279dc87e130$export$cabe61c495ee3649)(e.target);
399
+ if (dispose) state.disposables.push(dispose);
400
+ }
401
+ addGlobalListener((getOwnerDocument)(e.currentTarget), 'mouseup', onMouseUp, false);
402
+ };
403
+ pressProps.onMouseEnter = (e)=>{
404
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
405
+ let shouldStopPropagation = true;
406
+ if (state.isPressed && !state.ignoreEmulatedMouseEvents && state.pointerType != null) {
407
+ state.isOverTarget = true;
408
+ shouldStopPropagation = triggerPressStart(e, state.pointerType);
409
+ }
410
+ if (shouldStopPropagation) e.stopPropagation();
411
+ };
412
+ pressProps.onMouseLeave = (e)=>{
413
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
414
+ let shouldStopPropagation = true;
415
+ if (state.isPressed && !state.ignoreEmulatedMouseEvents && state.pointerType != null) {
416
+ state.isOverTarget = false;
417
+ shouldStopPropagation = triggerPressEnd(e, state.pointerType, false);
418
+ cancelOnPointerExit(e);
419
+ }
420
+ if (shouldStopPropagation) e.stopPropagation();
421
+ };
422
+ pressProps.onMouseUp = (e)=>{
423
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
424
+ if (!state.ignoreEmulatedMouseEvents && e.button === 0 && !state.isPressed) triggerPressUp(e, state.pointerType || 'mouse');
425
+ };
426
+ let onMouseUp = (e)=>{
427
+ // Only handle left clicks
428
+ if (e.button !== 0) return;
429
+ if (state.ignoreEmulatedMouseEvents) {
430
+ state.ignoreEmulatedMouseEvents = false;
431
+ return;
432
+ }
433
+ if (state.target && state.target.contains(e.target) && state.pointerType != null) ;
434
+ else cancel(e);
435
+ state.isOverTarget = false;
436
+ };
437
+ pressProps.onTouchStart = (e)=>{
438
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
439
+ let touch = $f6c31cce2adf654f$var$getTouchFromEvent(e.nativeEvent);
440
+ if (!touch) return;
441
+ state.activePointerId = touch.identifier;
442
+ state.ignoreEmulatedMouseEvents = true;
443
+ state.isOverTarget = true;
444
+ state.isPressed = true;
445
+ state.target = e.currentTarget;
446
+ state.pointerType = 'touch';
447
+ if (!allowTextSelectionOnPress) ($14c0b72509d70225$export$16a4697467175487)(state.target);
448
+ let shouldStopPropagation = triggerPressStart($f6c31cce2adf654f$var$createTouchEvent(state.target, e), state.pointerType);
449
+ if (shouldStopPropagation) e.stopPropagation();
450
+ addGlobalListener((getOwnerWindow)(e.currentTarget), 'scroll', onScroll, true);
451
+ };
452
+ pressProps.onTouchMove = (e)=>{
453
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
454
+ if (!state.isPressed) {
455
+ e.stopPropagation();
456
+ return;
457
+ }
458
+ let touch = $f6c31cce2adf654f$var$getTouchById(e.nativeEvent, state.activePointerId);
459
+ let shouldStopPropagation = true;
460
+ if (touch && $f6c31cce2adf654f$var$isOverTarget(touch, e.currentTarget)) {
461
+ if (!state.isOverTarget && state.pointerType != null) {
462
+ state.isOverTarget = true;
463
+ shouldStopPropagation = triggerPressStart($f6c31cce2adf654f$var$createTouchEvent(state.target, e), state.pointerType);
464
+ }
465
+ } else if (state.isOverTarget && state.pointerType != null) {
466
+ state.isOverTarget = false;
467
+ shouldStopPropagation = triggerPressEnd($f6c31cce2adf654f$var$createTouchEvent(state.target, e), state.pointerType, false);
468
+ cancelOnPointerExit($f6c31cce2adf654f$var$createTouchEvent(state.target, e));
469
+ }
470
+ if (shouldStopPropagation) e.stopPropagation();
471
+ };
472
+ pressProps.onTouchEnd = (e)=>{
473
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
474
+ if (!state.isPressed) {
475
+ e.stopPropagation();
476
+ return;
477
+ }
478
+ let touch = $f6c31cce2adf654f$var$getTouchById(e.nativeEvent, state.activePointerId);
479
+ let shouldStopPropagation = true;
480
+ if (touch && $f6c31cce2adf654f$var$isOverTarget(touch, e.currentTarget) && state.pointerType != null) {
481
+ triggerPressUp($f6c31cce2adf654f$var$createTouchEvent(state.target, e), state.pointerType);
482
+ shouldStopPropagation = triggerPressEnd($f6c31cce2adf654f$var$createTouchEvent(state.target, e), state.pointerType);
483
+ triggerSyntheticClick(e.nativeEvent, state.target);
484
+ } else if (state.isOverTarget && state.pointerType != null) shouldStopPropagation = triggerPressEnd($f6c31cce2adf654f$var$createTouchEvent(state.target, e), state.pointerType, false);
485
+ if (shouldStopPropagation) e.stopPropagation();
486
+ state.isPressed = false;
487
+ state.activePointerId = null;
488
+ state.isOverTarget = false;
489
+ state.ignoreEmulatedMouseEvents = true;
490
+ if (state.target && !allowTextSelectionOnPress) ($14c0b72509d70225$export$b0d6fa1ab32e3295)(state.target);
491
+ removeAllGlobalListeners();
492
+ };
493
+ pressProps.onTouchCancel = (e)=>{
494
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
495
+ e.stopPropagation();
496
+ if (state.isPressed) cancel($f6c31cce2adf654f$var$createTouchEvent(state.target, e));
497
+ };
498
+ let onScroll = (e)=>{
499
+ if (state.isPressed && (nodeContains)((getEventTarget)(e), state.target)) cancel({
500
+ currentTarget: state.target,
501
+ shiftKey: false,
502
+ ctrlKey: false,
503
+ metaKey: false,
504
+ altKey: false
505
+ });
506
+ };
507
+ pressProps.onDragStart = (e)=>{
508
+ if (!(nodeContains)(e.currentTarget, (getEventTarget)(e.nativeEvent))) return;
509
+ cancel(e);
510
+ };
511
+ }
512
+ return pressProps;
513
+ }, [
514
+ addGlobalListener,
515
+ isDisabled,
516
+ preventFocusOnPress,
517
+ removeAllGlobalListeners,
518
+ allowTextSelectionOnPress,
519
+ cancel,
520
+ cancelOnPointerExit,
521
+ triggerPressEnd,
522
+ triggerPressStart,
523
+ triggerPressUp,
524
+ triggerClick,
525
+ triggerSyntheticClick
526
+ ]);
527
+ // Avoid onClick delay for double tap to zoom by default.
528
+ (useEffect)(()=>{
529
+ if (!domRef || process.env.NODE_ENV === 'test') return;
530
+ const ownerDocument = (getOwnerDocument)(domRef.current);
531
+ if (!ownerDocument || !ownerDocument.head || ownerDocument.getElementById($f6c31cce2adf654f$var$STYLE_ID)) return;
532
+ const style = ownerDocument.createElement('style');
533
+ style.id = $f6c31cce2adf654f$var$STYLE_ID;
534
+ // touchAction: 'manipulation' is supposed to be equivalent, but in
535
+ // Safari it causes onPointerCancel not to fire on scroll.
536
+ // https://bugs.webkit.org/show_bug.cgi?id=240917
537
+ style.textContent = `
538
+ @layer {
539
+ [${$f6c31cce2adf654f$var$PRESSABLE_ATTRIBUTE}] {
540
+ touch-action: pan-x pan-y pinch-zoom;
541
+ }
542
+ }
543
+ `.trim();
544
+ ownerDocument.head.prepend(style);
545
+ }, [
546
+ domRef
547
+ ]);
548
+ // Remove user-select: none in case component unmounts immediately after pressStart
549
+ (useEffect)(()=>{
550
+ let state = ref.current;
551
+ return ()=>{
552
+ var _state_target;
553
+ if (!allowTextSelectionOnPress) ($14c0b72509d70225$export$b0d6fa1ab32e3295)((_state_target = state.target) !== null && _state_target !== void 0 ? _state_target : undefined);
554
+ for (let dispose of state.disposables)dispose();
555
+ state.disposables = [];
556
+ };
557
+ }, [
558
+ allowTextSelectionOnPress
559
+ ]);
560
+ return {
561
+ isPressed: isPressedProp || isPressed,
562
+ pressProps: (mergeProps)(domProps, pressProps, {
563
+ [$f6c31cce2adf654f$var$PRESSABLE_ATTRIBUTE]: true
564
+ })
565
+ };
566
+ }
567
+ function $f6c31cce2adf654f$var$isHTMLAnchorLink(target) {
568
+ return target.tagName === 'A' && target.hasAttribute('href');
569
+ }
570
+ function $f6c31cce2adf654f$var$isValidKeyboardEvent(event, currentTarget) {
571
+ const { key: key, code: code } = event;
572
+ const element = currentTarget;
573
+ const role = element.getAttribute('role');
574
+ // Accessibility for keyboards. Space and Enter only.
575
+ // "Spacebar" is for IE 11
576
+ return (key === 'Enter' || key === ' ' || key === 'Spacebar' || code === 'Space') && !(element instanceof (getOwnerWindow)(element).HTMLInputElement && !$f6c31cce2adf654f$var$isValidInputKey(element, key) || element instanceof (getOwnerWindow)(element).HTMLTextAreaElement || element.isContentEditable) && // Links should only trigger with Enter key
577
+ !((role === 'link' || !role && $f6c31cce2adf654f$var$isHTMLAnchorLink(element)) && key !== 'Enter');
578
+ }
579
+ function $f6c31cce2adf654f$var$getTouchFromEvent(event) {
580
+ const { targetTouches: targetTouches } = event;
581
+ if (targetTouches.length > 0) return targetTouches[0];
582
+ return null;
583
+ }
584
+ function $f6c31cce2adf654f$var$getTouchById(event, pointerId) {
585
+ const changedTouches = event.changedTouches;
586
+ for(let i = 0; i < changedTouches.length; i++){
587
+ const touch = changedTouches[i];
588
+ if (touch.identifier === pointerId) return touch;
589
+ }
590
+ return null;
591
+ }
592
+ function $f6c31cce2adf654f$var$createTouchEvent(target, e) {
593
+ let clientX = 0;
594
+ let clientY = 0;
595
+ if (e.targetTouches && e.targetTouches.length === 1) {
596
+ clientX = e.targetTouches[0].clientX;
597
+ clientY = e.targetTouches[0].clientY;
598
+ }
599
+ return {
600
+ currentTarget: target,
601
+ shiftKey: e.shiftKey,
602
+ ctrlKey: e.ctrlKey,
603
+ metaKey: e.metaKey,
604
+ altKey: e.altKey,
605
+ clientX: clientX,
606
+ clientY: clientY
607
+ };
608
+ }
609
+ function $f6c31cce2adf654f$var$createEvent(target, e) {
610
+ let clientX = e.clientX;
611
+ let clientY = e.clientY;
612
+ return {
613
+ currentTarget: target,
614
+ shiftKey: e.shiftKey,
615
+ ctrlKey: e.ctrlKey,
616
+ metaKey: e.metaKey,
617
+ altKey: e.altKey,
618
+ clientX: clientX,
619
+ clientY: clientY
620
+ };
621
+ }
622
+ function $f6c31cce2adf654f$var$getPointClientRect(point) {
623
+ let offsetX = 0;
624
+ let offsetY = 0;
625
+ if (point.width !== undefined) offsetX = point.width / 2;
626
+ else if (point.radiusX !== undefined) offsetX = point.radiusX;
627
+ if (point.height !== undefined) offsetY = point.height / 2;
628
+ else if (point.radiusY !== undefined) offsetY = point.radiusY;
629
+ return {
630
+ top: point.clientY - offsetY,
631
+ right: point.clientX + offsetX,
632
+ bottom: point.clientY + offsetY,
633
+ left: point.clientX - offsetX
634
+ };
635
+ }
636
+ function $f6c31cce2adf654f$var$areRectanglesOverlapping(a, b) {
637
+ // check if they cannot overlap on x axis
638
+ if (a.left > b.right || b.left > a.right) return false;
639
+ // check if they cannot overlap on y axis
640
+ if (a.top > b.bottom || b.top > a.bottom) return false;
641
+ return true;
642
+ }
643
+ function $f6c31cce2adf654f$var$isOverTarget(point, target) {
644
+ let rect = target.getBoundingClientRect();
645
+ let pointRect = $f6c31cce2adf654f$var$getPointClientRect(point);
646
+ return $f6c31cce2adf654f$var$areRectanglesOverlapping(rect, pointRect);
647
+ }
648
+ function $f6c31cce2adf654f$var$shouldPreventDefaultUp(target) {
649
+ if (target instanceof HTMLInputElement) return false;
650
+ if (target instanceof HTMLButtonElement) return target.type !== 'submit' && target.type !== 'reset';
651
+ if ($f6c31cce2adf654f$var$isHTMLAnchorLink(target)) return false;
652
+ return true;
653
+ }
654
+ function $f6c31cce2adf654f$var$shouldPreventDefaultKeyboard(target, key) {
655
+ if (target instanceof HTMLInputElement) return !$f6c31cce2adf654f$var$isValidInputKey(target, key);
656
+ return $f6c31cce2adf654f$var$shouldPreventDefaultUp(target);
657
+ }
658
+ const $f6c31cce2adf654f$var$nonTextInputTypes = new Set([
659
+ 'checkbox',
660
+ 'radio',
661
+ 'range',
662
+ 'color',
663
+ 'file',
664
+ 'image',
665
+ 'button',
666
+ 'submit',
667
+ 'reset'
668
+ ]);
669
+ function $f6c31cce2adf654f$var$isValidInputKey(target, key) {
670
+ // Only space should toggle checkboxes and radios, not enter.
671
+ return target.type === 'checkbox' || target.type === 'radio' ? key === ' ' : $f6c31cce2adf654f$var$nonTextInputTypes.has(target.type);
672
+ }
673
+
674
+ export { $f6c31cce2adf654f$export$45712eceda6fad21 as usePress };