@react-spectrum/menu 3.22.10 → 3.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (305) hide show
  1. package/dist/import.mjs +6 -8
  2. package/dist/main.js +12 -14
  3. package/dist/main.js.map +1 -1
  4. package/dist/module.js +6 -8
  5. package/dist/module.js.map +1 -1
  6. package/dist/types/src/index.d.ts +8 -0
  7. package/package.json +14 -46
  8. package/src/index.ts +9 -9
  9. package/dist/ActionMenu.main.js +0 -67
  10. package/dist/ActionMenu.main.js.map +0 -1
  11. package/dist/ActionMenu.mjs +0 -62
  12. package/dist/ActionMenu.module.js +0 -62
  13. package/dist/ActionMenu.module.js.map +0 -1
  14. package/dist/ContextualHelpTrigger.main.js +0 -192
  15. package/dist/ContextualHelpTrigger.main.js.map +0 -1
  16. package/dist/ContextualHelpTrigger.mjs +0 -187
  17. package/dist/ContextualHelpTrigger.module.js +0 -187
  18. package/dist/ContextualHelpTrigger.module.js.map +0 -1
  19. package/dist/Menu.main.js +0 -235
  20. package/dist/Menu.main.js.map +0 -1
  21. package/dist/Menu.mjs +0 -229
  22. package/dist/Menu.module.js +0 -229
  23. package/dist/Menu.module.js.map +0 -1
  24. package/dist/MenuItem.main.js +0 -149
  25. package/dist/MenuItem.main.js.map +0 -1
  26. package/dist/MenuItem.mjs +0 -144
  27. package/dist/MenuItem.module.js +0 -144
  28. package/dist/MenuItem.module.js.map +0 -1
  29. package/dist/MenuSection.main.js +0 -81
  30. package/dist/MenuSection.main.js.map +0 -1
  31. package/dist/MenuSection.mjs +0 -76
  32. package/dist/MenuSection.module.js +0 -76
  33. package/dist/MenuSection.module.js.map +0 -1
  34. package/dist/MenuTrigger.main.js +0 -128
  35. package/dist/MenuTrigger.main.js.map +0 -1
  36. package/dist/MenuTrigger.mjs +0 -123
  37. package/dist/MenuTrigger.module.js +0 -123
  38. package/dist/MenuTrigger.module.js.map +0 -1
  39. package/dist/Popover.main.js +0 -196
  40. package/dist/Popover.main.js.map +0 -1
  41. package/dist/Popover.mjs +0 -191
  42. package/dist/Popover.module.js +0 -191
  43. package/dist/Popover.module.js.map +0 -1
  44. package/dist/SubmenuTrigger.main.js +0 -154
  45. package/dist/SubmenuTrigger.main.js.map +0 -1
  46. package/dist/SubmenuTrigger.mjs +0 -149
  47. package/dist/SubmenuTrigger.module.js +0 -149
  48. package/dist/SubmenuTrigger.module.js.map +0 -1
  49. package/dist/Underlay.main.js +0 -54
  50. package/dist/Underlay.main.js.map +0 -1
  51. package/dist/Underlay.mjs +0 -49
  52. package/dist/Underlay.module.js +0 -49
  53. package/dist/Underlay.module.js.map +0 -1
  54. package/dist/ar-AE.main.js +0 -8
  55. package/dist/ar-AE.main.js.map +0 -1
  56. package/dist/ar-AE.mjs +0 -10
  57. package/dist/ar-AE.module.js +0 -10
  58. package/dist/ar-AE.module.js.map +0 -1
  59. package/dist/bg-BG.main.js +0 -8
  60. package/dist/bg-BG.main.js.map +0 -1
  61. package/dist/bg-BG.mjs +0 -10
  62. package/dist/bg-BG.module.js +0 -10
  63. package/dist/bg-BG.module.js.map +0 -1
  64. package/dist/calculatePosition.main.js +0 -392
  65. package/dist/calculatePosition.main.js.map +0 -1
  66. package/dist/calculatePosition.mjs +0 -386
  67. package/dist/calculatePosition.module.js +0 -386
  68. package/dist/calculatePosition.module.js.map +0 -1
  69. package/dist/context.main.js +0 -43
  70. package/dist/context.main.js.map +0 -1
  71. package/dist/context.mjs +0 -29
  72. package/dist/context.module.js +0 -29
  73. package/dist/context.module.js.map +0 -1
  74. package/dist/contextualhelp_vars_css.main.js +0 -23
  75. package/dist/contextualhelp_vars_css.main.js.map +0 -1
  76. package/dist/contextualhelp_vars_css.mjs +0 -25
  77. package/dist/contextualhelp_vars_css.module.js +0 -25
  78. package/dist/contextualhelp_vars_css.module.js.map +0 -1
  79. package/dist/cs-CZ.main.js +0 -8
  80. package/dist/cs-CZ.main.js.map +0 -1
  81. package/dist/cs-CZ.mjs +0 -10
  82. package/dist/cs-CZ.module.js +0 -10
  83. package/dist/cs-CZ.module.js.map +0 -1
  84. package/dist/da-DK.main.js +0 -8
  85. package/dist/da-DK.main.js.map +0 -1
  86. package/dist/da-DK.mjs +0 -10
  87. package/dist/da-DK.module.js +0 -10
  88. package/dist/da-DK.module.js.map +0 -1
  89. package/dist/de-DE.main.js +0 -8
  90. package/dist/de-DE.main.js.map +0 -1
  91. package/dist/de-DE.mjs +0 -10
  92. package/dist/de-DE.module.js +0 -10
  93. package/dist/de-DE.module.js.map +0 -1
  94. package/dist/el-GR.main.js +0 -8
  95. package/dist/el-GR.main.js.map +0 -1
  96. package/dist/el-GR.mjs +0 -10
  97. package/dist/el-GR.module.js +0 -10
  98. package/dist/el-GR.module.js.map +0 -1
  99. package/dist/en-US.main.js +0 -8
  100. package/dist/en-US.main.js.map +0 -1
  101. package/dist/en-US.mjs +0 -10
  102. package/dist/en-US.module.js +0 -10
  103. package/dist/en-US.module.js.map +0 -1
  104. package/dist/es-ES.main.js +0 -8
  105. package/dist/es-ES.main.js.map +0 -1
  106. package/dist/es-ES.mjs +0 -10
  107. package/dist/es-ES.module.js +0 -10
  108. package/dist/es-ES.module.js.map +0 -1
  109. package/dist/et-EE.main.js +0 -8
  110. package/dist/et-EE.main.js.map +0 -1
  111. package/dist/et-EE.mjs +0 -10
  112. package/dist/et-EE.module.js +0 -10
  113. package/dist/et-EE.module.js.map +0 -1
  114. package/dist/fi-FI.main.js +0 -8
  115. package/dist/fi-FI.main.js.map +0 -1
  116. package/dist/fi-FI.mjs +0 -10
  117. package/dist/fi-FI.module.js +0 -10
  118. package/dist/fi-FI.module.js.map +0 -1
  119. package/dist/fr-FR.main.js +0 -8
  120. package/dist/fr-FR.main.js.map +0 -1
  121. package/dist/fr-FR.mjs +0 -10
  122. package/dist/fr-FR.module.js +0 -10
  123. package/dist/fr-FR.module.js.map +0 -1
  124. package/dist/he-IL.main.js +0 -8
  125. package/dist/he-IL.main.js.map +0 -1
  126. package/dist/he-IL.mjs +0 -10
  127. package/dist/he-IL.module.js +0 -10
  128. package/dist/he-IL.module.js.map +0 -1
  129. package/dist/hr-HR.main.js +0 -8
  130. package/dist/hr-HR.main.js.map +0 -1
  131. package/dist/hr-HR.mjs +0 -10
  132. package/dist/hr-HR.module.js +0 -10
  133. package/dist/hr-HR.module.js.map +0 -1
  134. package/dist/hu-HU.main.js +0 -8
  135. package/dist/hu-HU.main.js.map +0 -1
  136. package/dist/hu-HU.mjs +0 -10
  137. package/dist/hu-HU.module.js +0 -10
  138. package/dist/hu-HU.module.js.map +0 -1
  139. package/dist/intlStrings.main.js +0 -108
  140. package/dist/intlStrings.main.js.map +0 -1
  141. package/dist/intlStrings.mjs +0 -110
  142. package/dist/intlStrings.module.js +0 -110
  143. package/dist/intlStrings.module.js.map +0 -1
  144. package/dist/it-IT.main.js +0 -8
  145. package/dist/it-IT.main.js.map +0 -1
  146. package/dist/it-IT.mjs +0 -10
  147. package/dist/it-IT.module.js +0 -10
  148. package/dist/it-IT.module.js.map +0 -1
  149. package/dist/ja-JP.main.js +0 -8
  150. package/dist/ja-JP.main.js.map +0 -1
  151. package/dist/ja-JP.mjs +0 -10
  152. package/dist/ja-JP.module.js +0 -10
  153. package/dist/ja-JP.module.js.map +0 -1
  154. package/dist/ko-KR.main.js +0 -8
  155. package/dist/ko-KR.main.js.map +0 -1
  156. package/dist/ko-KR.mjs +0 -10
  157. package/dist/ko-KR.module.js +0 -10
  158. package/dist/ko-KR.module.js.map +0 -1
  159. package/dist/lt-LT.main.js +0 -8
  160. package/dist/lt-LT.main.js.map +0 -1
  161. package/dist/lt-LT.mjs +0 -10
  162. package/dist/lt-LT.module.js +0 -10
  163. package/dist/lt-LT.module.js.map +0 -1
  164. package/dist/lv-LV.main.js +0 -8
  165. package/dist/lv-LV.main.js.map +0 -1
  166. package/dist/lv-LV.mjs +0 -10
  167. package/dist/lv-LV.module.js +0 -10
  168. package/dist/lv-LV.module.js.map +0 -1
  169. package/dist/menu.2259a533.css +0 -210
  170. package/dist/menu.2259a533.css.map +0 -1
  171. package/dist/menu.2ec1fdaf.css +0 -570
  172. package/dist/menu.2ec1fdaf.css.map +0 -1
  173. package/dist/menu.359a0c0a.css +0 -131
  174. package/dist/menu.359a0c0a.css.map +0 -1
  175. package/dist/menu.57b3a408.css +0 -12
  176. package/dist/menu.57b3a408.css.map +0 -1
  177. package/dist/menu.5b49954a.css +0 -30
  178. package/dist/menu.5b49954a.css.map +0 -1
  179. package/dist/menu_vars_css.main.js +0 -177
  180. package/dist/menu_vars_css.main.js.map +0 -1
  181. package/dist/menu_vars_css.mjs +0 -179
  182. package/dist/menu_vars_css.module.js +0 -179
  183. package/dist/menu_vars_css.module.js.map +0 -1
  184. package/dist/nb-NO.main.js +0 -8
  185. package/dist/nb-NO.main.js.map +0 -1
  186. package/dist/nb-NO.mjs +0 -10
  187. package/dist/nb-NO.module.js +0 -10
  188. package/dist/nb-NO.module.js.map +0 -1
  189. package/dist/nl-NL.main.js +0 -8
  190. package/dist/nl-NL.main.js.map +0 -1
  191. package/dist/nl-NL.mjs +0 -10
  192. package/dist/nl-NL.module.js +0 -10
  193. package/dist/nl-NL.module.js.map +0 -1
  194. package/dist/overlays_css.main.js +0 -35
  195. package/dist/overlays_css.main.js.map +0 -1
  196. package/dist/overlays_css.mjs +0 -37
  197. package/dist/overlays_css.module.js +0 -37
  198. package/dist/overlays_css.module.js.map +0 -1
  199. package/dist/pl-PL.main.js +0 -8
  200. package/dist/pl-PL.main.js.map +0 -1
  201. package/dist/pl-PL.mjs +0 -10
  202. package/dist/pl-PL.module.js +0 -10
  203. package/dist/pl-PL.module.js.map +0 -1
  204. package/dist/popover_vars_css.main.js +0 -83
  205. package/dist/popover_vars_css.main.js.map +0 -1
  206. package/dist/popover_vars_css.mjs +0 -85
  207. package/dist/popover_vars_css.module.js +0 -85
  208. package/dist/popover_vars_css.module.js.map +0 -1
  209. package/dist/pt-BR.main.js +0 -8
  210. package/dist/pt-BR.main.js.map +0 -1
  211. package/dist/pt-BR.mjs +0 -10
  212. package/dist/pt-BR.module.js +0 -10
  213. package/dist/pt-BR.module.js.map +0 -1
  214. package/dist/pt-PT.main.js +0 -8
  215. package/dist/pt-PT.main.js.map +0 -1
  216. package/dist/pt-PT.mjs +0 -10
  217. package/dist/pt-PT.module.js +0 -10
  218. package/dist/pt-PT.module.js.map +0 -1
  219. package/dist/ro-RO.main.js +0 -8
  220. package/dist/ro-RO.main.js.map +0 -1
  221. package/dist/ro-RO.mjs +0 -10
  222. package/dist/ro-RO.module.js +0 -10
  223. package/dist/ro-RO.module.js.map +0 -1
  224. package/dist/ru-RU.main.js +0 -8
  225. package/dist/ru-RU.main.js.map +0 -1
  226. package/dist/ru-RU.mjs +0 -10
  227. package/dist/ru-RU.module.js +0 -10
  228. package/dist/ru-RU.module.js.map +0 -1
  229. package/dist/sk-SK.main.js +0 -8
  230. package/dist/sk-SK.main.js.map +0 -1
  231. package/dist/sk-SK.mjs +0 -10
  232. package/dist/sk-SK.module.js +0 -10
  233. package/dist/sk-SK.module.js.map +0 -1
  234. package/dist/sl-SI.main.js +0 -8
  235. package/dist/sl-SI.main.js.map +0 -1
  236. package/dist/sl-SI.mjs +0 -10
  237. package/dist/sl-SI.module.js +0 -10
  238. package/dist/sl-SI.module.js.map +0 -1
  239. package/dist/sr-SP.main.js +0 -8
  240. package/dist/sr-SP.main.js.map +0 -1
  241. package/dist/sr-SP.mjs +0 -10
  242. package/dist/sr-SP.module.js +0 -10
  243. package/dist/sr-SP.module.js.map +0 -1
  244. package/dist/sv-SE.main.js +0 -8
  245. package/dist/sv-SE.main.js.map +0 -1
  246. package/dist/sv-SE.mjs +0 -10
  247. package/dist/sv-SE.module.js +0 -10
  248. package/dist/sv-SE.module.js.map +0 -1
  249. package/dist/tr-TR.main.js +0 -8
  250. package/dist/tr-TR.main.js.map +0 -1
  251. package/dist/tr-TR.mjs +0 -10
  252. package/dist/tr-TR.module.js +0 -10
  253. package/dist/tr-TR.module.js.map +0 -1
  254. package/dist/types.d.ts +0 -43
  255. package/dist/types.d.ts.map +0 -1
  256. package/dist/uk-UA.main.js +0 -8
  257. package/dist/uk-UA.main.js.map +0 -1
  258. package/dist/uk-UA.mjs +0 -10
  259. package/dist/uk-UA.module.js +0 -10
  260. package/dist/uk-UA.module.js.map +0 -1
  261. package/dist/underlay_vars_css.main.js +0 -50
  262. package/dist/underlay_vars_css.main.js.map +0 -1
  263. package/dist/underlay_vars_css.mjs +0 -52
  264. package/dist/underlay_vars_css.module.js +0 -52
  265. package/dist/underlay_vars_css.module.js.map +0 -1
  266. package/dist/useCloseOnScroll.main.js +0 -51
  267. package/dist/useCloseOnScroll.main.js.map +0 -1
  268. package/dist/useCloseOnScroll.mjs +0 -46
  269. package/dist/useCloseOnScroll.module.js +0 -46
  270. package/dist/useCloseOnScroll.module.js.map +0 -1
  271. package/dist/useOverlayPosition.main.js +0 -225
  272. package/dist/useOverlayPosition.main.js.map +0 -1
  273. package/dist/useOverlayPosition.mjs +0 -220
  274. package/dist/useOverlayPosition.module.js +0 -220
  275. package/dist/useOverlayPosition.module.js.map +0 -1
  276. package/dist/usePopover.main.js +0 -73
  277. package/dist/usePopover.main.js.map +0 -1
  278. package/dist/usePopover.mjs +0 -68
  279. package/dist/usePopover.module.js +0 -68
  280. package/dist/usePopover.module.js.map +0 -1
  281. package/dist/zh-CN.main.js +0 -8
  282. package/dist/zh-CN.main.js.map +0 -1
  283. package/dist/zh-CN.mjs +0 -10
  284. package/dist/zh-CN.module.js +0 -10
  285. package/dist/zh-CN.module.js.map +0 -1
  286. package/dist/zh-TW.main.js +0 -8
  287. package/dist/zh-TW.main.js.map +0 -1
  288. package/dist/zh-TW.mjs +0 -10
  289. package/dist/zh-TW.module.js +0 -10
  290. package/dist/zh-TW.module.js.map +0 -1
  291. package/src/ActionMenu.tsx +0 -58
  292. package/src/ContextualHelpTrigger.tsx +0 -194
  293. package/src/Menu.tsx +0 -228
  294. package/src/MenuItem.tsx +0 -159
  295. package/src/MenuSection.tsx +0 -100
  296. package/src/MenuTrigger.tsx +0 -125
  297. package/src/Popover.tsx +0 -240
  298. package/src/SubmenuTrigger.tsx +0 -154
  299. package/src/Underlay.tsx +0 -43
  300. package/src/calculatePosition.ts +0 -627
  301. package/src/context.ts +0 -63
  302. package/src/overlays.css +0 -32
  303. package/src/useCloseOnScroll.ts +0 -65
  304. package/src/useOverlayPosition.ts +0 -327
  305. package/src/usePopover.ts +0 -136
package/src/Popover.tsx DELETED
@@ -1,240 +0,0 @@
1
- /*
2
- * Copyright 2020 Adobe. All rights reserved.
3
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
- * you may not use this file except in compliance with the License. You may obtain a copy
5
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
6
- *
7
- * Unless required by applicable law or agreed to in writing, software distributed under
8
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
- * OF ANY KIND, either express or implied. See the License for the specific language
10
- * governing permissions and limitations under the License.
11
- */
12
-
13
- import {AriaPopoverProps, DismissButton, PopoverAria} from '@react-aria/overlays';
14
- import {classNames, useDOMRef, useStyleProps} from '@react-spectrum/utils';
15
- import {DOMRef, RefObject, StyleProps} from '@react-types/shared';
16
- import {FocusWithinProps, useFocusWithin} from '@react-aria/interactions';
17
- import {mergeProps, useLayoutEffect, useObjectRef} from '@react-aria/utils';
18
- import {Overlay} from '@react-spectrum/overlays';
19
- import {OverlayTriggerState} from '@react-stately/overlays';
20
- import overrideStyles from './overlays.css';
21
- import React, {ForwardedRef, forwardRef, ReactNode, useRef, useState} from 'react';
22
- import styles from '@adobe/spectrum-css-temp/components/popover/vars.css';
23
- import {Underlay} from './Underlay';
24
- import {usePopover} from './usePopover';
25
-
26
- interface PopoverProps extends Omit<AriaPopoverProps, 'popoverRef' | 'maxHeight'>, FocusWithinProps, StyleProps {
27
- children: ReactNode,
28
- hideArrow?: boolean,
29
- state: OverlayTriggerState,
30
- shouldContainFocus?: boolean,
31
- onEntering?: () => void,
32
- onEnter?: () => void,
33
- onEntered?: () => void,
34
- onExiting?: () => void,
35
- onExited?: () => void,
36
- onExit?: () => void,
37
- container?: HTMLElement,
38
- disableFocusManagement?: boolean,
39
- enableBothDismissButtons?: boolean,
40
- onDismissButtonPress?: () => void
41
- }
42
-
43
- interface PopoverWrapperProps extends PopoverProps, FocusWithinProps {
44
- isOpen?: boolean,
45
- wrapperRef: RefObject<HTMLDivElement | null>
46
- }
47
-
48
- interface ArrowProps {
49
- arrowProps: PopoverAria['arrowProps'],
50
- isLandscape: boolean,
51
- arrowRef?: RefObject<SVGSVGElement | null>,
52
- primary: number,
53
- secondary: number,
54
- borderDiagonal: number
55
- }
56
-
57
- /**
58
- * Arrow placement can be done pointing right or down because those paths start at 0, x or y. Because the
59
- * other two don't, they start at a fractional pixel value, it introduces rounding differences between browsers and
60
- * between display types (retina with subpixels vs not retina). By flipping them with CSS we can ensure that
61
- * the path always starts at 0 so that it perfectly overlaps the popover's border.
62
- * See bottom of file for more explanation.
63
- */
64
- let arrowPlacement = {
65
- left: 'right',
66
- right: 'right',
67
- top: 'bottom',
68
- bottom: 'bottom'
69
- };
70
-
71
- export const Popover = forwardRef(function Popover(props: PopoverProps, ref: DOMRef<HTMLDivElement>) {
72
- let {
73
- children,
74
- state,
75
- ...otherProps
76
- } = props;
77
- let domRef = useDOMRef(ref);
78
- let wrapperRef = useRef<HTMLDivElement>(null);
79
-
80
- return (
81
- <Overlay {...otherProps} isOpen={state.isOpen} nodeRef={wrapperRef}>
82
- <PopoverWrapper ref={domRef} {...props} wrapperRef={wrapperRef}>
83
- {children}
84
- </PopoverWrapper>
85
- </Overlay>
86
- );
87
- });
88
-
89
- const PopoverWrapper = forwardRef((props: PopoverWrapperProps, ref: ForwardedRef<HTMLDivElement | null>) => {
90
- let {
91
- children,
92
- isOpen,
93
- hideArrow,
94
- isNonModal,
95
- enableBothDismissButtons,
96
- state,
97
- wrapperRef,
98
- onDismissButtonPress = () => state.close()
99
- } = props;
100
- let {styleProps} = useStyleProps(props);
101
- let objRef = useObjectRef(ref);
102
-
103
- let {size, borderWidth, arrowRef} = useArrowSize();
104
- const borderRadius = usePopoverBorderRadius(objRef);
105
- let borderDiagonal = borderWidth * Math.SQRT2;
106
- let primary = size + borderDiagonal;
107
- let secondary = primary * 2;
108
- let {
109
- popoverProps,
110
- arrowProps,
111
- underlayProps,
112
- placement
113
- } = usePopover({
114
- ...props,
115
- popoverRef: objRef,
116
- maxHeight: undefined,
117
- arrowSize: hideArrow ? 0 : secondary,
118
- arrowBoundaryOffset: borderRadius
119
- }, state);
120
- let {focusWithinProps} = useFocusWithin(props);
121
-
122
- // Attach Transition's nodeRef to outermost wrapper for node.reflow: https://github.com/reactjs/react-transition-group/blob/c89f807067b32eea6f68fd6c622190d88ced82e2/src/Transition.js#L231
123
- return (
124
- <div ref={wrapperRef}>
125
- {!isNonModal && <Underlay isTransparent {...mergeProps(underlayProps)} isOpen={isOpen} /> }
126
- <div
127
- {...styleProps}
128
- {...mergeProps(popoverProps, focusWithinProps)}
129
- style={{
130
- ...styleProps.style,
131
- ...popoverProps.style
132
- }}
133
- ref={objRef}
134
- className={
135
- classNames(
136
- styles,
137
- 'spectrum-Popover',
138
- `spectrum-Popover--${placement}`,
139
- {
140
- 'spectrum-Popover--withTip': !hideArrow,
141
- 'is-open': isOpen,
142
- [`is-open--${placement}`]: isOpen
143
- },
144
- classNames(
145
- overrideStyles,
146
- 'spectrum-Popover',
147
- 'react-spectrum-Popover'
148
- ),
149
- styleProps.className
150
- )
151
- }
152
- role="presentation"
153
- data-testid="popover">
154
- {(!isNonModal || enableBothDismissButtons) && <DismissButton onDismiss={onDismissButtonPress} />}
155
- {children}
156
- {hideArrow ? null : (
157
- <Arrow
158
- arrowProps={arrowProps}
159
- isLandscape={placement != null ? arrowPlacement[placement] === 'bottom' : false}
160
- arrowRef={arrowRef}
161
- primary={primary}
162
- secondary={secondary}
163
- borderDiagonal={borderDiagonal} />
164
- )}
165
- <DismissButton onDismiss={onDismissButtonPress} />
166
- </div>
167
- </div>
168
- );
169
- });
170
-
171
- function usePopoverBorderRadius(popoverRef: RefObject<HTMLDivElement | null>) {
172
- let [borderRadius, setBorderRadius] = useState(0);
173
- useLayoutEffect(() => {
174
- if (popoverRef.current) {
175
- let spectrumBorderRadius = window.getComputedStyle(popoverRef.current).borderRadius;
176
- if (spectrumBorderRadius !== '') {
177
- setBorderRadius(parseInt(spectrumBorderRadius, 10));
178
- }
179
- }
180
- }, [popoverRef]);
181
- return borderRadius;
182
- }
183
-
184
- function useArrowSize() {
185
- let [size, setSize] = useState(20);
186
- let [borderWidth, setBorderWidth] = useState(1);
187
- let arrowRef = useRef<SVGSVGElement>(null);
188
- // get the css value for the tip size and divide it by 2 for this arrow implementation
189
- useLayoutEffect(() => {
190
- if (arrowRef.current) {
191
- let spectrumTipWidth = window.getComputedStyle(arrowRef.current)
192
- .getPropertyValue('--spectrum-popover-tip-size');
193
- if (spectrumTipWidth !== '') {
194
- setSize(parseInt(spectrumTipWidth, 10) / 2);
195
- }
196
-
197
- let spectrumBorderWidth = window.getComputedStyle(arrowRef.current)
198
- .getPropertyValue('--spectrum-popover-tip-borderWidth');
199
- if (spectrumBorderWidth !== '') {
200
- setBorderWidth(parseInt(spectrumBorderWidth, 10));
201
- }
202
- }
203
- }, []);
204
- return {size, borderWidth, arrowRef};
205
- }
206
-
207
- function Arrow(props: ArrowProps) {
208
- let {primary, secondary, isLandscape, arrowProps, borderDiagonal, arrowRef} = props;
209
- let halfBorderDiagonal = borderDiagonal / 2;
210
-
211
- let primaryStart = 0;
212
- let primaryEnd = primary - halfBorderDiagonal;
213
-
214
- let secondaryStart = halfBorderDiagonal;
215
- let secondaryMiddle = secondary / 2;
216
- let secondaryEnd = secondary - halfBorderDiagonal;
217
-
218
- let pathData = isLandscape ? [
219
- 'M', secondaryStart, primaryStart,
220
- 'L', secondaryMiddle, primaryEnd,
221
- 'L', secondaryEnd, primaryStart
222
- ] : [
223
- 'M', primaryStart, secondaryStart,
224
- 'L', primaryEnd, secondaryMiddle,
225
- 'L', primaryStart, secondaryEnd
226
- ];
227
-
228
- /* use ceil because the svg needs to always accommodate the path inside it */
229
- return (
230
- <svg
231
- xmlns="http://www.w3.org/svg/2000"
232
- width={Math.ceil(isLandscape ? secondary : primary)}
233
- height={Math.ceil(isLandscape ? primary : secondary)}
234
- className={classNames(styles, 'spectrum-Popover-tip')}
235
- ref={arrowRef}
236
- {...arrowProps}>
237
- <path className={classNames(styles, 'spectrum-Popover-tip-triangle')} d={pathData.join(' ')} />
238
- </svg>
239
- );
240
- }
@@ -1,154 +0,0 @@
1
- /*
2
- * Copyright 2020 Adobe. All rights reserved.
3
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
- * you may not use this file except in compliance with the License. You may obtain a copy
5
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
6
- *
7
- * Unless required by applicable law or agreed to in writing, software distributed under
8
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
- * OF ANY KIND, either express or implied. See the License for the specific language
10
- * governing permissions and limitations under the License.
11
- */
12
-
13
- import {classNames, useIsMobileDevice} from '@react-spectrum/utils';
14
- import {Key} from '@react-types/shared';
15
- import {MenuContext, SubmenuTriggerContext, useMenuStateContext} from './context';
16
- import {mergeProps, nodeContains} from '@react-aria/utils';
17
- import {Popover} from './Popover';
18
- import React, {type JSX, ReactElement, useRef} from 'react';
19
- import ReactDOM from 'react-dom';
20
- import styles from '@adobe/spectrum-css-temp/components/menu/vars.css';
21
- import {useLocale} from '@react-aria/i18n';
22
- import {useSubmenuTrigger} from '@react-aria/menu';
23
- import {useSubmenuTriggerState} from '@react-stately/menu';
24
-
25
- interface SubmenuTriggerProps {
26
- /**
27
- * The contents of the SubmenuTrigger - an Item and a Menu.
28
- */
29
- children: ReactElement<any>[],
30
- targetKey: Key
31
- }
32
-
33
- export interface SpectrumSubmenuTriggerProps extends Omit<SubmenuTriggerProps, 'targetKey'> {}
34
-
35
- function SubmenuTrigger(props: SubmenuTriggerProps) {
36
- let triggerRef = useRef<HTMLDivElement>(null);
37
- let {
38
- children,
39
- targetKey
40
- } = props;
41
-
42
- let [menuTrigger, menu] = React.Children.toArray(children);
43
- let {popoverContainer, trayContainerRef, menu: parentMenuRef, submenu: menuRef, rootMenuTriggerState} = useMenuStateContext()!;
44
- let submenuTriggerState = useSubmenuTriggerState({triggerKey: targetKey}, rootMenuTriggerState!);
45
- let {submenuTriggerProps, submenuProps, popoverProps} = useSubmenuTrigger({
46
- parentMenuRef,
47
- submenuRef: menuRef
48
- }, submenuTriggerState, triggerRef);
49
- let isMobile = useIsMobileDevice();
50
- let onBackButtonPress = () => {
51
- submenuTriggerState.close();
52
- if (parentMenuRef.current && !nodeContains(parentMenuRef.current, document.activeElement)) {
53
- parentMenuRef.current.focus();
54
- }
55
- };
56
-
57
- let {direction} = useLocale();
58
- let mobileSubmenuKeyDown = (e: KeyboardEvent) => {
59
- switch (e.key) {
60
- case 'ArrowLeft':
61
- if (direction === 'ltr') {
62
- triggerRef.current?.focus();
63
- }
64
- break;
65
- case 'ArrowRight':
66
- if (direction === 'rtl') {
67
- triggerRef.current?.focus();
68
- }
69
- break;
70
- }
71
- };
72
-
73
- let overlay;
74
-
75
- if (isMobile) {
76
- delete submenuTriggerProps.onBlur;
77
- delete submenuTriggerProps.onHoverChange;
78
- submenuProps.autoFocus ??= true;
79
- if (trayContainerRef.current && submenuTriggerState.isOpen) {
80
- overlay = ReactDOM.createPortal(menu, trayContainerRef.current);
81
- }
82
- } else {
83
- let onDismissButtonPress = () => {
84
- submenuTriggerState.close();
85
- parentMenuRef.current?.focus();
86
- };
87
-
88
- overlay = (
89
- <Popover
90
- {...popoverProps}
91
- onDismissButtonPress={onDismissButtonPress}
92
- UNSAFE_className={classNames(styles, 'spectrum-Submenu-popover')}
93
- container={popoverContainer!}
94
- containerPadding={0}
95
- enableBothDismissButtons
96
- UNSAFE_style={{clipPath: 'unset', overflow: 'visible', borderWidth: '0px'}}
97
- state={submenuTriggerState}
98
- triggerRef={triggerRef}
99
- scrollRef={menuRef}
100
- placement="end top"
101
- hideArrow>
102
- {menu}
103
- </Popover>
104
- );
105
- }
106
-
107
- let menuContext = {
108
- ...mergeProps(submenuProps, {
109
- ref: menuRef,
110
- UNSAFE_style: isMobile ? {
111
- width: '100%',
112
- maxHeight: 'inherit'
113
- } : undefined,
114
- UNSAFE_className: classNames(styles, {'spectrum-Menu-popover': !isMobile}),
115
- ...(isMobile && {
116
- onBackButtonPress,
117
- onKeyDown: mobileSubmenuKeyDown
118
- })
119
- })
120
- };
121
-
122
- return (
123
- <>
124
- <SubmenuTriggerContext.Provider value={{triggerRef, ...submenuTriggerProps}}>{menuTrigger}</SubmenuTriggerContext.Provider>
125
- <MenuContext.Provider value={menuContext}>
126
- {overlay}
127
- </MenuContext.Provider>
128
- </>
129
- );
130
- }
131
-
132
- SubmenuTrigger.getCollectionNode = function* (props: SpectrumSubmenuTriggerProps) {
133
- let childArray: ReactElement[] = [];
134
- React.Children.forEach(props.children, child => {
135
- if (React.isValidElement(child)) {
136
- childArray.push(child);
137
- }
138
- });
139
- let [trigger] = childArray;
140
- let [, content] = props.children as [ReactElement, ReactElement];
141
-
142
- yield {
143
- element: React.cloneElement(trigger, {...trigger.props as any, hasChildItems: true, isTrigger: true}),
144
- wrapper: (element) => (
145
- <SubmenuTrigger key={element.key} targetKey={element.key} {...props}>
146
- {element}
147
- {content}
148
- </SubmenuTrigger>
149
- )
150
- };
151
- };
152
-
153
- let _SubmenuTrigger = SubmenuTrigger as unknown as (props: SpectrumSubmenuTriggerProps) => JSX.Element;
154
- export {_SubmenuTrigger as SubmenuTrigger};
package/src/Underlay.tsx DELETED
@@ -1,43 +0,0 @@
1
- /*
2
- * Copyright 2020 Adobe. All rights reserved.
3
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
- * you may not use this file except in compliance with the License. You may obtain a copy
5
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
6
- *
7
- * Unless required by applicable law or agreed to in writing, software distributed under
8
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
- * OF ANY KIND, either express or implied. See the License for the specific language
10
- * governing permissions and limitations under the License.
11
- */
12
-
13
- import {classNames} from '@react-spectrum/utils';
14
- import {isScrollable} from '@react-aria/utils';
15
- import React, {JSX} from 'react';
16
- import underlayStyles from '@adobe/spectrum-css-temp/components/underlay/vars.css';
17
-
18
- interface UnderlayProps {
19
- isOpen?: boolean,
20
- isTransparent?: boolean
21
- }
22
-
23
- export function Underlay({isOpen, isTransparent, ...otherProps}: UnderlayProps): JSX.Element {
24
- let pageHeight: number | undefined = undefined;
25
- if (typeof document !== 'undefined') {
26
- let scrollingElement = isScrollable(document.body) ? document.body : document.scrollingElement || document.documentElement;
27
- // Prevent Firefox from adding scrollbars when the page has a fractional height.
28
- let fractionalHeightDifference = scrollingElement.getBoundingClientRect().height % 1;
29
- pageHeight = scrollingElement.scrollHeight - fractionalHeightDifference;
30
- }
31
-
32
- return (
33
- <div
34
- data-testid="underlay"
35
- {...otherProps}
36
- // Cover the entire document so iOS 26 Safari doesn't clip the underlay to the inner viewport.
37
- style={{height: pageHeight}}
38
- className={classNames(underlayStyles, 'spectrum-Underlay', {
39
- 'is-open': isOpen,
40
- 'spectrum-Underlay--transparent': isTransparent
41
- })} />
42
- );
43
- }