@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
@@ -1,123 +0,0 @@
1
- import {MenuContext as $d94604d52c3e3feb$export$c7e742effb1c51e2} from "./context.mjs";
2
- import "./menu.2ec1fdaf.css";
3
- import $5R0iF$menu_vars_cssmodulejs from "./menu_vars_css.mjs";
4
- import {useDOMRef as $5R0iF$useDOMRef, useIsMobileDevice as $5R0iF$useIsMobileDevice, classNames as $5R0iF$classNames, unwrapDOMRef as $5R0iF$unwrapDOMRef, SlotProvider as $5R0iF$SlotProvider} from "@react-spectrum/utils";
5
- import {Tray as $5R0iF$Tray, Popover as $5R0iF$Popover} from "@react-spectrum/overlays";
6
- import {useInteractOutside as $5R0iF$useInteractOutside, PressResponder as $5R0iF$PressResponder} from "@react-aria/interactions";
7
- import $5R0iF$react, {forwardRef as $5R0iF$forwardRef, useRef as $5R0iF$useRef, Fragment as $5R0iF$Fragment} from "react";
8
- import {useMenuTrigger as $5R0iF$useMenuTrigger} from "@react-aria/menu";
9
- import {useMenuTriggerState as $5R0iF$useMenuTriggerState} from "@react-stately/menu";
10
-
11
-
12
- function $parcel$interopDefault(a) {
13
- return a && a.__esModule ? a.default : a;
14
- }
15
- /*
16
- * Copyright 2020 Adobe. All rights reserved.
17
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
18
- * you may not use this file except in compliance with the License. You may obtain a copy
19
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
20
- *
21
- * Unless required by applicable law or agreed to in writing, software distributed under
22
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
23
- * OF ANY KIND, either express or implied. See the License for the specific language
24
- * governing permissions and limitations under the License.
25
- */
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
- const $aa0b855f135b86e3$export$27d2ad3c5815583e = /*#__PURE__*/ (0, $5R0iF$forwardRef)(function MenuTrigger(props, ref) {
34
- let triggerRef = (0, $5R0iF$useRef)(null);
35
- let domRef = (0, $5R0iF$useDOMRef)(ref);
36
- let menuTriggerRef = domRef || triggerRef;
37
- let menuRef = (0, $5R0iF$useRef)(null);
38
- let { children: children, align: align = 'start', shouldFlip: shouldFlip = true, direction: direction = 'bottom', closeOnSelect: closeOnSelect, trigger: trigger = 'press' } = props;
39
- let [menuTrigger, menu] = (0, $5R0iF$react).Children.toArray(children);
40
- let state = (0, $5R0iF$useMenuTriggerState)(props);
41
- let { menuTriggerProps: menuTriggerProps, menuProps: menuProps } = (0, $5R0iF$useMenuTrigger)({
42
- trigger: trigger
43
- }, state, menuTriggerRef);
44
- let initialPlacement;
45
- switch(direction){
46
- case 'left':
47
- case 'right':
48
- case 'start':
49
- case 'end':
50
- initialPlacement = `${direction} ${align === 'end' ? 'bottom' : 'top'}`;
51
- break;
52
- case 'bottom':
53
- case 'top':
54
- default:
55
- initialPlacement = `${direction} ${align}`;
56
- }
57
- let isMobile = (0, $5R0iF$useIsMobileDevice)();
58
- let menuContext = {
59
- ...menuProps,
60
- ref: menuRef,
61
- onClose: state.close,
62
- closeOnSelect: closeOnSelect,
63
- autoFocus: state.focusStrategy || true,
64
- UNSAFE_style: isMobile ? {
65
- width: '100%',
66
- maxHeight: 'inherit'
67
- } : undefined,
68
- UNSAFE_className: (0, $5R0iF$classNames)((0, ($parcel$interopDefault($5R0iF$menu_vars_cssmodulejs))), {
69
- 'spectrum-Menu-popover': !isMobile
70
- }),
71
- state: state
72
- };
73
- // Close when clicking outside the root menu when a submenu is open.
74
- let rootOverlayRef = (0, $5R0iF$useRef)(null);
75
- let rootOverlayDomRef = (0, $5R0iF$unwrapDOMRef)(rootOverlayRef);
76
- (0, $5R0iF$useInteractOutside)({
77
- ref: rootOverlayDomRef,
78
- onInteractOutside: ()=>{
79
- state === null || state === void 0 ? void 0 : state.close();
80
- },
81
- isDisabled: !state.isOpen || state.expandedKeysStack.length === 0
82
- });
83
- // On small screen devices, the menu is rendered in a tray, otherwise a popover.
84
- let overlay;
85
- if (isMobile) overlay = /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$Tray), {
86
- state: state,
87
- isFixedHeight: true,
88
- ref: rootOverlayRef
89
- }, menu);
90
- else overlay = /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$Popover), {
91
- ref: rootOverlayRef,
92
- UNSAFE_style: {
93
- clipPath: 'unset',
94
- overflow: 'visible',
95
- filter: 'unset',
96
- borderWidth: '0px'
97
- },
98
- state: state,
99
- triggerRef: menuTriggerRef,
100
- scrollRef: menuRef,
101
- placement: initialPlacement,
102
- hideArrow: true,
103
- shouldFlip: shouldFlip,
104
- shouldContainFocus: true
105
- }, menu);
106
- return /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$Fragment), null, /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$SlotProvider), {
107
- slots: {
108
- actionButton: {
109
- holdAffordance: trigger === 'longPress'
110
- }
111
- }
112
- }, /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$PressResponder), {
113
- ...menuTriggerProps,
114
- ref: menuTriggerRef,
115
- isPressed: state.isOpen
116
- }, menuTrigger)), /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $d94604d52c3e3feb$export$c7e742effb1c51e2).Provider, {
117
- value: menuContext
118
- }, overlay));
119
- });
120
-
121
-
122
- export {$aa0b855f135b86e3$export$27d2ad3c5815583e as MenuTrigger};
123
- //# sourceMappingURL=MenuTrigger.module.js.map
@@ -1,123 +0,0 @@
1
- import {MenuContext as $d94604d52c3e3feb$export$c7e742effb1c51e2} from "./context.module.js";
2
- import "./menu.2ec1fdaf.css";
3
- import $5R0iF$menu_vars_cssmodulejs from "./menu_vars_css.module.js";
4
- import {useDOMRef as $5R0iF$useDOMRef, useIsMobileDevice as $5R0iF$useIsMobileDevice, classNames as $5R0iF$classNames, unwrapDOMRef as $5R0iF$unwrapDOMRef, SlotProvider as $5R0iF$SlotProvider} from "@react-spectrum/utils";
5
- import {Tray as $5R0iF$Tray, Popover as $5R0iF$Popover} from "@react-spectrum/overlays";
6
- import {useInteractOutside as $5R0iF$useInteractOutside, PressResponder as $5R0iF$PressResponder} from "@react-aria/interactions";
7
- import $5R0iF$react, {forwardRef as $5R0iF$forwardRef, useRef as $5R0iF$useRef, Fragment as $5R0iF$Fragment} from "react";
8
- import {useMenuTrigger as $5R0iF$useMenuTrigger} from "@react-aria/menu";
9
- import {useMenuTriggerState as $5R0iF$useMenuTriggerState} from "@react-stately/menu";
10
-
11
-
12
- function $parcel$interopDefault(a) {
13
- return a && a.__esModule ? a.default : a;
14
- }
15
- /*
16
- * Copyright 2020 Adobe. All rights reserved.
17
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
18
- * you may not use this file except in compliance with the License. You may obtain a copy
19
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
20
- *
21
- * Unless required by applicable law or agreed to in writing, software distributed under
22
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
23
- * OF ANY KIND, either express or implied. See the License for the specific language
24
- * governing permissions and limitations under the License.
25
- */
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
- const $aa0b855f135b86e3$export$27d2ad3c5815583e = /*#__PURE__*/ (0, $5R0iF$forwardRef)(function MenuTrigger(props, ref) {
34
- let triggerRef = (0, $5R0iF$useRef)(null);
35
- let domRef = (0, $5R0iF$useDOMRef)(ref);
36
- let menuTriggerRef = domRef || triggerRef;
37
- let menuRef = (0, $5R0iF$useRef)(null);
38
- let { children: children, align: align = 'start', shouldFlip: shouldFlip = true, direction: direction = 'bottom', closeOnSelect: closeOnSelect, trigger: trigger = 'press' } = props;
39
- let [menuTrigger, menu] = (0, $5R0iF$react).Children.toArray(children);
40
- let state = (0, $5R0iF$useMenuTriggerState)(props);
41
- let { menuTriggerProps: menuTriggerProps, menuProps: menuProps } = (0, $5R0iF$useMenuTrigger)({
42
- trigger: trigger
43
- }, state, menuTriggerRef);
44
- let initialPlacement;
45
- switch(direction){
46
- case 'left':
47
- case 'right':
48
- case 'start':
49
- case 'end':
50
- initialPlacement = `${direction} ${align === 'end' ? 'bottom' : 'top'}`;
51
- break;
52
- case 'bottom':
53
- case 'top':
54
- default:
55
- initialPlacement = `${direction} ${align}`;
56
- }
57
- let isMobile = (0, $5R0iF$useIsMobileDevice)();
58
- let menuContext = {
59
- ...menuProps,
60
- ref: menuRef,
61
- onClose: state.close,
62
- closeOnSelect: closeOnSelect,
63
- autoFocus: state.focusStrategy || true,
64
- UNSAFE_style: isMobile ? {
65
- width: '100%',
66
- maxHeight: 'inherit'
67
- } : undefined,
68
- UNSAFE_className: (0, $5R0iF$classNames)((0, ($parcel$interopDefault($5R0iF$menu_vars_cssmodulejs))), {
69
- 'spectrum-Menu-popover': !isMobile
70
- }),
71
- state: state
72
- };
73
- // Close when clicking outside the root menu when a submenu is open.
74
- let rootOverlayRef = (0, $5R0iF$useRef)(null);
75
- let rootOverlayDomRef = (0, $5R0iF$unwrapDOMRef)(rootOverlayRef);
76
- (0, $5R0iF$useInteractOutside)({
77
- ref: rootOverlayDomRef,
78
- onInteractOutside: ()=>{
79
- state === null || state === void 0 ? void 0 : state.close();
80
- },
81
- isDisabled: !state.isOpen || state.expandedKeysStack.length === 0
82
- });
83
- // On small screen devices, the menu is rendered in a tray, otherwise a popover.
84
- let overlay;
85
- if (isMobile) overlay = /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$Tray), {
86
- state: state,
87
- isFixedHeight: true,
88
- ref: rootOverlayRef
89
- }, menu);
90
- else overlay = /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$Popover), {
91
- ref: rootOverlayRef,
92
- UNSAFE_style: {
93
- clipPath: 'unset',
94
- overflow: 'visible',
95
- filter: 'unset',
96
- borderWidth: '0px'
97
- },
98
- state: state,
99
- triggerRef: menuTriggerRef,
100
- scrollRef: menuRef,
101
- placement: initialPlacement,
102
- hideArrow: true,
103
- shouldFlip: shouldFlip,
104
- shouldContainFocus: true
105
- }, menu);
106
- return /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$Fragment), null, /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$SlotProvider), {
107
- slots: {
108
- actionButton: {
109
- holdAffordance: trigger === 'longPress'
110
- }
111
- }
112
- }, /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $5R0iF$PressResponder), {
113
- ...menuTriggerProps,
114
- ref: menuTriggerRef,
115
- isPressed: state.isOpen
116
- }, menuTrigger)), /*#__PURE__*/ (0, $5R0iF$react).createElement((0, $d94604d52c3e3feb$export$c7e742effb1c51e2).Provider, {
117
- value: menuContext
118
- }, overlay));
119
- });
120
-
121
-
122
- export {$aa0b855f135b86e3$export$27d2ad3c5815583e as MenuTrigger};
123
- //# sourceMappingURL=MenuTrigger.module.js.map
@@ -1 +0,0 @@
1
- {"mappings":";;;;;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;;;AAkBM,MAAM,0DAAc,CAAA,GAAA,iBAAS,EAAE,SAAS,YAAY,KAA+B,EAAE,GAAwB;IAClH,IAAI,aAAa,CAAA,GAAA,aAAK,EAAe;IACrC,IAAI,SAAS,CAAA,GAAA,gBAAQ,EAAE;IACvB,IAAI,iBAAiB,UAAU;IAC/B,IAAI,UAAU,CAAA,GAAA,aAAK,EAAkB;IACrC,IAAI,YACF,QAAQ,SACR,QAAQ,qBACR,aAAa,iBACb,YAAY,yBACZ,aAAa,WACb,UAAU,SACX,GAAG;IAEJ,IAAI,CAAC,aAAa,KAAK,GAAG,CAAA,GAAA,YAAI,EAAE,QAAQ,CAAC,OAAO,CAAC;IACjD,IAAI,QAAQ,CAAA,GAAA,0BAAkB,EAAE;IAEhC,IAAI,oBAAC,gBAAgB,aAAE,SAAS,EAAC,GAAG,CAAA,GAAA,qBAAa,EAAE;iBAAC;IAAO,GAAG,OAAO;IAErE,IAAI;IACJ,OAAQ;QACN,KAAK;QACL,KAAK;QACL,KAAK;QACL,KAAK;YACH,mBAAmB,GAAG,UAAU,CAAC,EAAE,UAAU,QAAQ,WAAW,OAAO;YACvE;QACF,KAAK;QACL,KAAK;QACL;YACE,mBAAmB,GAAG,UAAU,CAAC,EAAE,OAAO;IAC9C;IAEA,IAAI,WAAW,CAAA,GAAA,wBAAgB;IAC/B,IAAI,cAAc;QAChB,GAAG,SAAS;QACZ,KAAK;QACL,SAAS,MAAM,KAAK;uBACpB;QACA,WAAW,MAAM,aAAa,IAAI;QAClC,cAAc,WAAW;YACvB,OAAO;YACP,WAAW;QACb,IAAI;QACJ,kBAAkB,CAAA,GAAA,iBAAS,EAAE,CAAA,GAAA,sDAAK,GAAG;YAAC,yBAAyB,CAAC;QAAQ;eACxE;IACF;IAEA,oEAAoE;IACpE,IAAI,iBAAiB,CAAA,GAAA,aAAK,EAAE;IAC5B,IAAI,oBAAoB,CAAA,GAAA,mBAAW,EAAE;IACrC,CAAA,GAAA,yBAAiB,EAAE;QACjB,KAAK;QACL,mBAAmB;YACjB,kBAAA,4BAAA,MAAO,KAAK;QACd;QACA,YAAY,CAAC,MAAM,MAAM,IAAI,MAAM,iBAAiB,CAAC,MAAM,KAAK;IAClE;IAEA,gFAAgF;IAChF,IAAI;IACJ,IAAI,UACF,wBACE,gCAAC,CAAA,GAAA,WAAG;QAAE,OAAO;QAAO,eAAA;QAAc,KAAK;OACpC;SAIL,wBACE,gCAAC,CAAA,GAAA,cAAM;QACL,KAAK;QACL,cAAc;YAAC,UAAU;YAAS,UAAU;YAAW,QAAQ;YAAS,aAAa;QAAK;QAC1F,OAAO;QACP,YAAY;QACZ,WAAW;QACX,WAAW;QACX,WAAA;QACA,YAAY;QACZ,oBAAA;OACC;IAKP,qBACE,gCAAC,CAAA,GAAA,eAAO,uBACN,gCAAC,CAAA,GAAA,mBAAW;QAAE,OAAO;YAAC,cAAc;gBAAC,gBAAgB,YAAY;YAAW;QAAC;qBAC3E,gCAAC,CAAA,GAAA,qBAAa;QAAG,GAAG,gBAAgB;QAAE,KAAK;QAAgB,WAAW,MAAM,MAAM;OAC/E,6BAGL,gCAAC,CAAA,GAAA,yCAAU,EAAE,QAAQ;QAAC,OAAO;OAC1B;AAIT","sources":["packages/@react-spectrum/menu/src/MenuTrigger.tsx"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {classNames, SlotProvider, unwrapDOMRef, useDOMRef, useIsMobileDevice} from '@react-spectrum/utils';\nimport {DOMRef} from '@react-types/shared';\nimport {MenuContext} from './context';\nimport {Placement} from '@react-types/overlays';\nimport {Popover, Tray} from '@react-spectrum/overlays';\nimport {PressResponder, useInteractOutside} from '@react-aria/interactions';\nimport React, {forwardRef, Fragment, useRef} from 'react';\nimport {SpectrumMenuTriggerProps} from '@react-types/menu';\nimport styles from '@adobe/spectrum-css-temp/components/menu/vars.css';\nimport {useMenuTrigger} from '@react-aria/menu';\nimport {useMenuTriggerState} from '@react-stately/menu';\n\n/**\n * The MenuTrigger serves as a wrapper around a Menu and its associated trigger,\n * linking the Menu's open state with the trigger's press state.\n */\nexport const MenuTrigger = forwardRef(function MenuTrigger(props: SpectrumMenuTriggerProps, ref: DOMRef<HTMLElement>) {\n let triggerRef = useRef<HTMLElement>(null);\n let domRef = useDOMRef(ref);\n let menuTriggerRef = domRef || triggerRef;\n let menuRef = useRef<HTMLDivElement>(null);\n let {\n children,\n align = 'start',\n shouldFlip = true,\n direction = 'bottom',\n closeOnSelect,\n trigger = 'press'\n } = props;\n\n let [menuTrigger, menu] = React.Children.toArray(children);\n let state = useMenuTriggerState(props);\n\n let {menuTriggerProps, menuProps} = useMenuTrigger({trigger}, state, menuTriggerRef);\n\n let initialPlacement: Placement;\n switch (direction) {\n case 'left':\n case 'right':\n case 'start':\n case 'end':\n initialPlacement = `${direction} ${align === 'end' ? 'bottom' : 'top'}` as Placement;\n break;\n case 'bottom':\n case 'top':\n default:\n initialPlacement = `${direction} ${align}` as Placement;\n }\n\n let isMobile = useIsMobileDevice();\n let menuContext = {\n ...menuProps,\n ref: menuRef,\n onClose: state.close,\n closeOnSelect,\n autoFocus: state.focusStrategy || true,\n UNSAFE_style: isMobile ? {\n width: '100%',\n maxHeight: 'inherit'\n } : undefined,\n UNSAFE_className: classNames(styles, {'spectrum-Menu-popover': !isMobile}),\n state\n };\n\n // Close when clicking outside the root menu when a submenu is open.\n let rootOverlayRef = useRef(null);\n let rootOverlayDomRef = unwrapDOMRef(rootOverlayRef);\n useInteractOutside({\n ref: rootOverlayDomRef,\n onInteractOutside: () => {\n state?.close();\n },\n isDisabled: !state.isOpen || state.expandedKeysStack.length === 0\n });\n\n // On small screen devices, the menu is rendered in a tray, otherwise a popover.\n let overlay;\n if (isMobile) {\n overlay = (\n <Tray state={state} isFixedHeight ref={rootOverlayRef}>\n {menu}\n </Tray>\n );\n } else {\n overlay = (\n <Popover\n ref={rootOverlayRef}\n UNSAFE_style={{clipPath: 'unset', overflow: 'visible', filter: 'unset', borderWidth: '0px'}}\n state={state}\n triggerRef={menuTriggerRef}\n scrollRef={menuRef}\n placement={initialPlacement}\n hideArrow\n shouldFlip={shouldFlip}\n shouldContainFocus>\n {menu}\n </Popover>\n );\n }\n\n return (\n <Fragment>\n <SlotProvider slots={{actionButton: {holdAffordance: trigger === 'longPress'}}}>\n <PressResponder {...menuTriggerProps} ref={menuTriggerRef} isPressed={state.isOpen}>\n {menuTrigger}\n </PressResponder>\n </SlotProvider>\n <MenuContext.Provider value={menuContext}>\n {overlay}\n </MenuContext.Provider>\n </Fragment>\n );\n});\n"],"names":[],"version":3,"file":"MenuTrigger.module.js.map"}
@@ -1,196 +0,0 @@
1
- require("./menu.57b3a408.css");
2
- var $d77aa5d771e2d5f7$exports = require("./overlays_css.main.js");
3
- require("./menu.2259a533.css");
4
- var $16e1dca4664d0b1c$exports = require("./popover_vars_css.main.js");
5
- var $986adbd937b58c55$exports = require("./Underlay.main.js");
6
- var $1092bc18146aeaca$exports = require("./usePopover.main.js");
7
- var $a8zXR$reactariaoverlays = require("@react-aria/overlays");
8
- var $a8zXR$reactspectrumutils = require("@react-spectrum/utils");
9
- var $a8zXR$reactariainteractions = require("@react-aria/interactions");
10
- var $a8zXR$reactariautils = require("@react-aria/utils");
11
- var $a8zXR$reactspectrumoverlays = require("@react-spectrum/overlays");
12
- var $a8zXR$react = require("react");
13
-
14
-
15
- function $parcel$interopDefault(a) {
16
- return a && a.__esModule ? a.default : a;
17
- }
18
-
19
- function $parcel$export(e, n, v, s) {
20
- Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
21
- }
22
-
23
- $parcel$export(module.exports, "Popover", () => $25179ade6a3f679b$export$5b6b19405a83ff9d);
24
- /*
25
- * Copyright 2020 Adobe. All rights reserved.
26
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
27
- * you may not use this file except in compliance with the License. You may obtain a copy
28
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
29
- *
30
- * Unless required by applicable law or agreed to in writing, software distributed under
31
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
32
- * OF ANY KIND, either express or implied. See the License for the specific language
33
- * governing permissions and limitations under the License.
34
- */
35
-
36
-
37
-
38
-
39
-
40
-
41
-
42
-
43
-
44
- /**
45
- * Arrow placement can be done pointing right or down because those paths start at 0, x or y. Because the
46
- * other two don't, they start at a fractional pixel value, it introduces rounding differences between browsers and
47
- * between display types (retina with subpixels vs not retina). By flipping them with CSS we can ensure that
48
- * the path always starts at 0 so that it perfectly overlaps the popover's border.
49
- * See bottom of file for more explanation.
50
- */ let $25179ade6a3f679b$var$arrowPlacement = {
51
- left: 'right',
52
- right: 'right',
53
- top: 'bottom',
54
- bottom: 'bottom'
55
- };
56
- const $25179ade6a3f679b$export$5b6b19405a83ff9d = /*#__PURE__*/ (0, $a8zXR$react.forwardRef)(function Popover(props, ref) {
57
- let { children: children, state: state, ...otherProps } = props;
58
- let domRef = (0, $a8zXR$reactspectrumutils.useDOMRef)(ref);
59
- let wrapperRef = (0, $a8zXR$react.useRef)(null);
60
- return /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement((0, $a8zXR$reactspectrumoverlays.Overlay), {
61
- ...otherProps,
62
- isOpen: state.isOpen,
63
- nodeRef: wrapperRef
64
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement($25179ade6a3f679b$var$PopoverWrapper, {
65
- ref: domRef,
66
- ...props,
67
- wrapperRef: wrapperRef
68
- }, children));
69
- });
70
- const $25179ade6a3f679b$var$PopoverWrapper = /*#__PURE__*/ (0, $a8zXR$react.forwardRef)((props, ref)=>{
71
- let { children: children, isOpen: isOpen, hideArrow: hideArrow, isNonModal: isNonModal, enableBothDismissButtons: enableBothDismissButtons, state: state, wrapperRef: wrapperRef, onDismissButtonPress: onDismissButtonPress = ()=>state.close() } = props;
72
- let { styleProps: styleProps } = (0, $a8zXR$reactspectrumutils.useStyleProps)(props);
73
- let objRef = (0, $a8zXR$reactariautils.useObjectRef)(ref);
74
- let { size: size, borderWidth: borderWidth, arrowRef: arrowRef } = $25179ade6a3f679b$var$useArrowSize();
75
- const borderRadius = $25179ade6a3f679b$var$usePopoverBorderRadius(objRef);
76
- let borderDiagonal = borderWidth * Math.SQRT2;
77
- let primary = size + borderDiagonal;
78
- let secondary = primary * 2;
79
- let { popoverProps: popoverProps, arrowProps: arrowProps, underlayProps: underlayProps, placement: placement } = (0, $1092bc18146aeaca$exports.usePopover)({
80
- ...props,
81
- popoverRef: objRef,
82
- maxHeight: undefined,
83
- arrowSize: hideArrow ? 0 : secondary,
84
- arrowBoundaryOffset: borderRadius
85
- }, state);
86
- let { focusWithinProps: focusWithinProps } = (0, $a8zXR$reactariainteractions.useFocusWithin)(props);
87
- // Attach Transition's nodeRef to outermost wrapper for node.reflow: https://github.com/reactjs/react-transition-group/blob/c89f807067b32eea6f68fd6c622190d88ced82e2/src/Transition.js#L231
88
- return /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement("div", {
89
- ref: wrapperRef
90
- }, !isNonModal && /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement((0, $986adbd937b58c55$exports.Underlay), {
91
- isTransparent: true,
92
- ...(0, $a8zXR$reactariautils.mergeProps)(underlayProps),
93
- isOpen: isOpen
94
- }), /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement("div", {
95
- ...styleProps,
96
- ...(0, $a8zXR$reactariautils.mergeProps)(popoverProps, focusWithinProps),
97
- style: {
98
- ...styleProps.style,
99
- ...popoverProps.style
100
- },
101
- ref: objRef,
102
- className: (0, $a8zXR$reactspectrumutils.classNames)((0, ($parcel$interopDefault($16e1dca4664d0b1c$exports))), 'spectrum-Popover', `spectrum-Popover--${placement}`, {
103
- 'spectrum-Popover--withTip': !hideArrow,
104
- 'is-open': isOpen,
105
- [`is-open--${placement}`]: isOpen
106
- }, (0, $a8zXR$reactspectrumutils.classNames)((0, ($parcel$interopDefault($d77aa5d771e2d5f7$exports))), 'spectrum-Popover', 'react-spectrum-Popover'), styleProps.className),
107
- role: "presentation",
108
- "data-testid": "popover"
109
- }, (!isNonModal || enableBothDismissButtons) && /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement((0, $a8zXR$reactariaoverlays.DismissButton), {
110
- onDismiss: onDismissButtonPress
111
- }), children, hideArrow ? null : /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement($25179ade6a3f679b$var$Arrow, {
112
- arrowProps: arrowProps,
113
- isLandscape: placement != null ? $25179ade6a3f679b$var$arrowPlacement[placement] === 'bottom' : false,
114
- arrowRef: arrowRef,
115
- primary: primary,
116
- secondary: secondary,
117
- borderDiagonal: borderDiagonal
118
- }), /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement((0, $a8zXR$reactariaoverlays.DismissButton), {
119
- onDismiss: onDismissButtonPress
120
- })));
121
- });
122
- function $25179ade6a3f679b$var$usePopoverBorderRadius(popoverRef) {
123
- let [borderRadius, setBorderRadius] = (0, $a8zXR$react.useState)(0);
124
- (0, $a8zXR$reactariautils.useLayoutEffect)(()=>{
125
- if (popoverRef.current) {
126
- let spectrumBorderRadius = window.getComputedStyle(popoverRef.current).borderRadius;
127
- if (spectrumBorderRadius !== '') setBorderRadius(parseInt(spectrumBorderRadius, 10));
128
- }
129
- }, [
130
- popoverRef
131
- ]);
132
- return borderRadius;
133
- }
134
- function $25179ade6a3f679b$var$useArrowSize() {
135
- let [size, setSize] = (0, $a8zXR$react.useState)(20);
136
- let [borderWidth, setBorderWidth] = (0, $a8zXR$react.useState)(1);
137
- let arrowRef = (0, $a8zXR$react.useRef)(null);
138
- // get the css value for the tip size and divide it by 2 for this arrow implementation
139
- (0, $a8zXR$reactariautils.useLayoutEffect)(()=>{
140
- if (arrowRef.current) {
141
- let spectrumTipWidth = window.getComputedStyle(arrowRef.current).getPropertyValue('--spectrum-popover-tip-size');
142
- if (spectrumTipWidth !== '') setSize(parseInt(spectrumTipWidth, 10) / 2);
143
- let spectrumBorderWidth = window.getComputedStyle(arrowRef.current).getPropertyValue('--spectrum-popover-tip-borderWidth');
144
- if (spectrumBorderWidth !== '') setBorderWidth(parseInt(spectrumBorderWidth, 10));
145
- }
146
- }, []);
147
- return {
148
- size: size,
149
- borderWidth: borderWidth,
150
- arrowRef: arrowRef
151
- };
152
- }
153
- function $25179ade6a3f679b$var$Arrow(props) {
154
- let { primary: primary, secondary: secondary, isLandscape: isLandscape, arrowProps: arrowProps, borderDiagonal: borderDiagonal, arrowRef: arrowRef } = props;
155
- let halfBorderDiagonal = borderDiagonal / 2;
156
- let primaryStart = 0;
157
- let primaryEnd = primary - halfBorderDiagonal;
158
- let secondaryStart = halfBorderDiagonal;
159
- let secondaryMiddle = secondary / 2;
160
- let secondaryEnd = secondary - halfBorderDiagonal;
161
- let pathData = isLandscape ? [
162
- 'M',
163
- secondaryStart,
164
- primaryStart,
165
- 'L',
166
- secondaryMiddle,
167
- primaryEnd,
168
- 'L',
169
- secondaryEnd,
170
- primaryStart
171
- ] : [
172
- 'M',
173
- primaryStart,
174
- secondaryStart,
175
- 'L',
176
- primaryEnd,
177
- secondaryMiddle,
178
- 'L',
179
- primaryStart,
180
- secondaryEnd
181
- ];
182
- /* use ceil because the svg needs to always accommodate the path inside it */ return /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement("svg", {
183
- xmlns: "http://www.w3.org/svg/2000",
184
- width: Math.ceil(isLandscape ? secondary : primary),
185
- height: Math.ceil(isLandscape ? primary : secondary),
186
- className: (0, $a8zXR$reactspectrumutils.classNames)((0, ($parcel$interopDefault($16e1dca4664d0b1c$exports))), 'spectrum-Popover-tip'),
187
- ref: arrowRef,
188
- ...arrowProps
189
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($a8zXR$react))).createElement("path", {
190
- className: (0, $a8zXR$reactspectrumutils.classNames)((0, ($parcel$interopDefault($16e1dca4664d0b1c$exports))), 'spectrum-Popover-tip-triangle'),
191
- d: pathData.join(' ')
192
- }));
193
- }
194
-
195
-
196
- //# sourceMappingURL=Popover.main.js.map
@@ -1 +0,0 @@
1
- {"mappings":"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","sources":["packages/@react-spectrum/menu/src/Popover.tsx"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaPopoverProps, DismissButton, PopoverAria} from '@react-aria/overlays';\nimport {classNames, useDOMRef, useStyleProps} from '@react-spectrum/utils';\nimport {DOMRef, RefObject, StyleProps} from '@react-types/shared';\nimport {FocusWithinProps, useFocusWithin} from '@react-aria/interactions';\nimport {mergeProps, useLayoutEffect, useObjectRef} from '@react-aria/utils';\nimport {Overlay} from '@react-spectrum/overlays';\nimport {OverlayTriggerState} from '@react-stately/overlays';\nimport overrideStyles from './overlays.css';\nimport React, {ForwardedRef, forwardRef, ReactNode, useRef, useState} from 'react';\nimport styles from '@adobe/spectrum-css-temp/components/popover/vars.css';\nimport {Underlay} from './Underlay';\nimport {usePopover} from './usePopover';\n\ninterface PopoverProps extends Omit<AriaPopoverProps, 'popoverRef' | 'maxHeight'>, FocusWithinProps, StyleProps {\n children: ReactNode,\n hideArrow?: boolean,\n state: OverlayTriggerState,\n shouldContainFocus?: boolean,\n onEntering?: () => void,\n onEnter?: () => void,\n onEntered?: () => void,\n onExiting?: () => void,\n onExited?: () => void,\n onExit?: () => void,\n container?: HTMLElement,\n disableFocusManagement?: boolean,\n enableBothDismissButtons?: boolean,\n onDismissButtonPress?: () => void\n}\n\ninterface PopoverWrapperProps extends PopoverProps, FocusWithinProps {\n isOpen?: boolean,\n wrapperRef: RefObject<HTMLDivElement | null>\n}\n\ninterface ArrowProps {\n arrowProps: PopoverAria['arrowProps'],\n isLandscape: boolean,\n arrowRef?: RefObject<SVGSVGElement | null>,\n primary: number,\n secondary: number,\n borderDiagonal: number\n}\n\n/**\n * Arrow placement can be done pointing right or down because those paths start at 0, x or y. Because the\n * other two don't, they start at a fractional pixel value, it introduces rounding differences between browsers and\n * between display types (retina with subpixels vs not retina). By flipping them with CSS we can ensure that\n * the path always starts at 0 so that it perfectly overlaps the popover's border.\n * See bottom of file for more explanation.\n */\nlet arrowPlacement = {\n left: 'right',\n right: 'right',\n top: 'bottom',\n bottom: 'bottom'\n};\n\nexport const Popover = forwardRef(function Popover(props: PopoverProps, ref: DOMRef<HTMLDivElement>) {\n let {\n children,\n state,\n ...otherProps\n } = props;\n let domRef = useDOMRef(ref);\n let wrapperRef = useRef<HTMLDivElement>(null);\n\n return (\n <Overlay {...otherProps} isOpen={state.isOpen} nodeRef={wrapperRef}>\n <PopoverWrapper ref={domRef} {...props} wrapperRef={wrapperRef}>\n {children}\n </PopoverWrapper>\n </Overlay>\n );\n});\n\nconst PopoverWrapper = forwardRef((props: PopoverWrapperProps, ref: ForwardedRef<HTMLDivElement | null>) => {\n let {\n children,\n isOpen,\n hideArrow,\n isNonModal,\n enableBothDismissButtons,\n state,\n wrapperRef,\n onDismissButtonPress = () => state.close()\n } = props;\n let {styleProps} = useStyleProps(props);\n let objRef = useObjectRef(ref);\n\n let {size, borderWidth, arrowRef} = useArrowSize();\n const borderRadius = usePopoverBorderRadius(objRef);\n let borderDiagonal = borderWidth * Math.SQRT2;\n let primary = size + borderDiagonal;\n let secondary = primary * 2;\n let {\n popoverProps,\n arrowProps,\n underlayProps,\n placement\n } = usePopover({\n ...props,\n popoverRef: objRef,\n maxHeight: undefined,\n arrowSize: hideArrow ? 0 : secondary,\n arrowBoundaryOffset: borderRadius\n }, state);\n let {focusWithinProps} = useFocusWithin(props);\n\n // Attach Transition's nodeRef to outermost wrapper for node.reflow: https://github.com/reactjs/react-transition-group/blob/c89f807067b32eea6f68fd6c622190d88ced82e2/src/Transition.js#L231\n return (\n <div ref={wrapperRef}>\n {!isNonModal && <Underlay isTransparent {...mergeProps(underlayProps)} isOpen={isOpen} /> }\n <div\n {...styleProps}\n {...mergeProps(popoverProps, focusWithinProps)}\n style={{\n ...styleProps.style,\n ...popoverProps.style\n }}\n ref={objRef}\n className={\n classNames(\n styles,\n 'spectrum-Popover',\n `spectrum-Popover--${placement}`,\n {\n 'spectrum-Popover--withTip': !hideArrow,\n 'is-open': isOpen,\n [`is-open--${placement}`]: isOpen\n },\n classNames(\n overrideStyles,\n 'spectrum-Popover',\n 'react-spectrum-Popover'\n ),\n styleProps.className\n )\n }\n role=\"presentation\"\n data-testid=\"popover\">\n {(!isNonModal || enableBothDismissButtons) && <DismissButton onDismiss={onDismissButtonPress} />}\n {children}\n {hideArrow ? null : (\n <Arrow\n arrowProps={arrowProps}\n isLandscape={placement != null ? arrowPlacement[placement] === 'bottom' : false}\n arrowRef={arrowRef}\n primary={primary}\n secondary={secondary}\n borderDiagonal={borderDiagonal} />\n )}\n <DismissButton onDismiss={onDismissButtonPress} />\n </div>\n </div>\n );\n});\n\nfunction usePopoverBorderRadius(popoverRef: RefObject<HTMLDivElement | null>) {\n let [borderRadius, setBorderRadius] = useState(0);\n useLayoutEffect(() => {\n if (popoverRef.current) {\n let spectrumBorderRadius = window.getComputedStyle(popoverRef.current).borderRadius;\n if (spectrumBorderRadius !== '') {\n setBorderRadius(parseInt(spectrumBorderRadius, 10));\n }\n }\n }, [popoverRef]);\n return borderRadius;\n}\n\nfunction useArrowSize() {\n let [size, setSize] = useState(20);\n let [borderWidth, setBorderWidth] = useState(1);\n let arrowRef = useRef<SVGSVGElement>(null);\n // get the css value for the tip size and divide it by 2 for this arrow implementation\n useLayoutEffect(() => {\n if (arrowRef.current) {\n let spectrumTipWidth = window.getComputedStyle(arrowRef.current)\n .getPropertyValue('--spectrum-popover-tip-size');\n if (spectrumTipWidth !== '') {\n setSize(parseInt(spectrumTipWidth, 10) / 2);\n }\n\n let spectrumBorderWidth = window.getComputedStyle(arrowRef.current)\n .getPropertyValue('--spectrum-popover-tip-borderWidth');\n if (spectrumBorderWidth !== '') {\n setBorderWidth(parseInt(spectrumBorderWidth, 10));\n }\n }\n }, []);\n return {size, borderWidth, arrowRef};\n}\n\nfunction Arrow(props: ArrowProps) {\n let {primary, secondary, isLandscape, arrowProps, borderDiagonal, arrowRef} = props;\n let halfBorderDiagonal = borderDiagonal / 2;\n\n let primaryStart = 0;\n let primaryEnd = primary - halfBorderDiagonal;\n\n let secondaryStart = halfBorderDiagonal;\n let secondaryMiddle = secondary / 2;\n let secondaryEnd = secondary - halfBorderDiagonal;\n\n let pathData = isLandscape ? [\n 'M', secondaryStart, primaryStart,\n 'L', secondaryMiddle, primaryEnd,\n 'L', secondaryEnd, primaryStart\n ] : [\n 'M', primaryStart, secondaryStart,\n 'L', primaryEnd, secondaryMiddle,\n 'L', primaryStart, secondaryEnd\n ];\n\n /* use ceil because the svg needs to always accommodate the path inside it */\n return (\n <svg\n xmlns=\"http://www.w3.org/svg/2000\"\n width={Math.ceil(isLandscape ? secondary : primary)}\n height={Math.ceil(isLandscape ? primary : secondary)}\n className={classNames(styles, 'spectrum-Popover-tip')}\n ref={arrowRef}\n {...arrowProps}>\n <path className={classNames(styles, 'spectrum-Popover-tip-triangle')} d={pathData.join(' ')} />\n </svg>\n );\n}\n"],"names":[],"version":3,"file":"Popover.main.js.map"}