@react-spectrum/menu 3.16.1-nightly.4321 → 3.17.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 (188) hide show
  1. package/dist/ar-AE.main.js +8 -0
  2. package/dist/ar-AE.main.js.map +1 -0
  3. package/dist/ar-AE.mjs +10 -0
  4. package/dist/ar-AE.module.js +10 -0
  5. package/dist/ar-AE.module.js.map +1 -0
  6. package/dist/bg-BG.main.js +8 -0
  7. package/dist/bg-BG.main.js.map +1 -0
  8. package/dist/bg-BG.mjs +10 -0
  9. package/dist/bg-BG.module.js +10 -0
  10. package/dist/bg-BG.module.js.map +1 -0
  11. package/dist/cs-CZ.main.js +8 -0
  12. package/dist/cs-CZ.main.js.map +1 -0
  13. package/dist/cs-CZ.mjs +10 -0
  14. package/dist/cs-CZ.module.js +10 -0
  15. package/dist/cs-CZ.module.js.map +1 -0
  16. package/dist/da-DK.main.js +8 -0
  17. package/dist/da-DK.main.js.map +1 -0
  18. package/dist/da-DK.mjs +10 -0
  19. package/dist/da-DK.module.js +10 -0
  20. package/dist/da-DK.module.js.map +1 -0
  21. package/dist/de-DE.main.js +8 -0
  22. package/dist/de-DE.main.js.map +1 -0
  23. package/dist/de-DE.mjs +10 -0
  24. package/dist/de-DE.module.js +10 -0
  25. package/dist/de-DE.module.js.map +1 -0
  26. package/dist/el-GR.main.js +8 -0
  27. package/dist/el-GR.main.js.map +1 -0
  28. package/dist/el-GR.mjs +10 -0
  29. package/dist/el-GR.module.js +10 -0
  30. package/dist/el-GR.module.js.map +1 -0
  31. package/dist/en-US.main.js +8 -0
  32. package/dist/en-US.main.js.map +1 -0
  33. package/dist/en-US.mjs +10 -0
  34. package/dist/en-US.module.js +10 -0
  35. package/dist/en-US.module.js.map +1 -0
  36. package/dist/es-ES.main.js +8 -0
  37. package/dist/es-ES.main.js.map +1 -0
  38. package/dist/es-ES.mjs +10 -0
  39. package/dist/es-ES.module.js +10 -0
  40. package/dist/es-ES.module.js.map +1 -0
  41. package/dist/et-EE.main.js +8 -0
  42. package/dist/et-EE.main.js.map +1 -0
  43. package/dist/et-EE.mjs +10 -0
  44. package/dist/et-EE.module.js +10 -0
  45. package/dist/et-EE.module.js.map +1 -0
  46. package/dist/fi-FI.main.js +8 -0
  47. package/dist/fi-FI.main.js.map +1 -0
  48. package/dist/fi-FI.mjs +10 -0
  49. package/dist/fi-FI.module.js +10 -0
  50. package/dist/fi-FI.module.js.map +1 -0
  51. package/dist/fr-FR.main.js +8 -0
  52. package/dist/fr-FR.main.js.map +1 -0
  53. package/dist/fr-FR.mjs +10 -0
  54. package/dist/fr-FR.module.js +10 -0
  55. package/dist/fr-FR.module.js.map +1 -0
  56. package/dist/he-IL.main.js +8 -0
  57. package/dist/he-IL.main.js.map +1 -0
  58. package/dist/he-IL.mjs +10 -0
  59. package/dist/he-IL.module.js +10 -0
  60. package/dist/he-IL.module.js.map +1 -0
  61. package/dist/hr-HR.main.js +8 -0
  62. package/dist/hr-HR.main.js.map +1 -0
  63. package/dist/hr-HR.mjs +10 -0
  64. package/dist/hr-HR.module.js +10 -0
  65. package/dist/hr-HR.module.js.map +1 -0
  66. package/dist/hu-HU.main.js +8 -0
  67. package/dist/hu-HU.main.js.map +1 -0
  68. package/dist/hu-HU.mjs +10 -0
  69. package/dist/hu-HU.module.js +10 -0
  70. package/dist/hu-HU.module.js.map +1 -0
  71. package/dist/import.mjs +458 -332
  72. package/dist/it-IT.main.js +8 -0
  73. package/dist/it-IT.main.js.map +1 -0
  74. package/dist/it-IT.mjs +10 -0
  75. package/dist/it-IT.module.js +10 -0
  76. package/dist/it-IT.module.js.map +1 -0
  77. package/dist/ja-JP.main.js +8 -0
  78. package/dist/ja-JP.main.js.map +1 -0
  79. package/dist/ja-JP.mjs +10 -0
  80. package/dist/ja-JP.module.js +10 -0
  81. package/dist/ja-JP.module.js.map +1 -0
  82. package/dist/ko-KR.main.js +8 -0
  83. package/dist/ko-KR.main.js.map +1 -0
  84. package/dist/ko-KR.mjs +10 -0
  85. package/dist/ko-KR.module.js +10 -0
  86. package/dist/ko-KR.module.js.map +1 -0
  87. package/dist/lt-LT.main.js +8 -0
  88. package/dist/lt-LT.main.js.map +1 -0
  89. package/dist/lt-LT.mjs +10 -0
  90. package/dist/lt-LT.module.js +10 -0
  91. package/dist/lt-LT.module.js.map +1 -0
  92. package/dist/lv-LV.main.js +8 -0
  93. package/dist/lv-LV.main.js.map +1 -0
  94. package/dist/lv-LV.mjs +10 -0
  95. package/dist/lv-LV.module.js +10 -0
  96. package/dist/lv-LV.module.js.map +1 -0
  97. package/dist/main.css +545 -1
  98. package/dist/main.css.map +1 -0
  99. package/dist/main.js +452 -325
  100. package/dist/main.js.map +1 -1
  101. package/dist/module.js +458 -332
  102. package/dist/module.js.map +1 -1
  103. package/dist/nb-NO.main.js +8 -0
  104. package/dist/nb-NO.main.js.map +1 -0
  105. package/dist/nb-NO.mjs +10 -0
  106. package/dist/nb-NO.module.js +10 -0
  107. package/dist/nb-NO.module.js.map +1 -0
  108. package/dist/nl-NL.main.js +8 -0
  109. package/dist/nl-NL.main.js.map +1 -0
  110. package/dist/nl-NL.mjs +10 -0
  111. package/dist/nl-NL.module.js +10 -0
  112. package/dist/nl-NL.module.js.map +1 -0
  113. package/dist/pl-PL.main.js +8 -0
  114. package/dist/pl-PL.main.js.map +1 -0
  115. package/dist/pl-PL.mjs +10 -0
  116. package/dist/pl-PL.module.js +10 -0
  117. package/dist/pl-PL.module.js.map +1 -0
  118. package/dist/pt-BR.main.js +8 -0
  119. package/dist/pt-BR.main.js.map +1 -0
  120. package/dist/pt-BR.mjs +10 -0
  121. package/dist/pt-BR.module.js +10 -0
  122. package/dist/pt-BR.module.js.map +1 -0
  123. package/dist/pt-PT.main.js +8 -0
  124. package/dist/pt-PT.main.js.map +1 -0
  125. package/dist/pt-PT.mjs +10 -0
  126. package/dist/pt-PT.module.js +10 -0
  127. package/dist/pt-PT.module.js.map +1 -0
  128. package/dist/ro-RO.main.js +8 -0
  129. package/dist/ro-RO.main.js.map +1 -0
  130. package/dist/ro-RO.mjs +10 -0
  131. package/dist/ro-RO.module.js +10 -0
  132. package/dist/ro-RO.module.js.map +1 -0
  133. package/dist/ru-RU.main.js +8 -0
  134. package/dist/ru-RU.main.js.map +1 -0
  135. package/dist/ru-RU.mjs +10 -0
  136. package/dist/ru-RU.module.js +10 -0
  137. package/dist/ru-RU.module.js.map +1 -0
  138. package/dist/sk-SK.main.js +8 -0
  139. package/dist/sk-SK.main.js.map +1 -0
  140. package/dist/sk-SK.mjs +10 -0
  141. package/dist/sk-SK.module.js +10 -0
  142. package/dist/sk-SK.module.js.map +1 -0
  143. package/dist/sl-SI.main.js +8 -0
  144. package/dist/sl-SI.main.js.map +1 -0
  145. package/dist/sl-SI.mjs +10 -0
  146. package/dist/sl-SI.module.js +10 -0
  147. package/dist/sl-SI.module.js.map +1 -0
  148. package/dist/sr-SP.main.js +8 -0
  149. package/dist/sr-SP.main.js.map +1 -0
  150. package/dist/sr-SP.mjs +10 -0
  151. package/dist/sr-SP.module.js +10 -0
  152. package/dist/sr-SP.module.js.map +1 -0
  153. package/dist/sv-SE.main.js +8 -0
  154. package/dist/sv-SE.main.js.map +1 -0
  155. package/dist/sv-SE.mjs +10 -0
  156. package/dist/sv-SE.module.js +10 -0
  157. package/dist/sv-SE.module.js.map +1 -0
  158. package/dist/tr-TR.main.js +8 -0
  159. package/dist/tr-TR.main.js.map +1 -0
  160. package/dist/tr-TR.mjs +10 -0
  161. package/dist/tr-TR.module.js +10 -0
  162. package/dist/tr-TR.module.js.map +1 -0
  163. package/dist/types.d.ts +13 -3
  164. package/dist/types.d.ts.map +1 -1
  165. package/dist/uk-UA.main.js +8 -0
  166. package/dist/uk-UA.main.js.map +1 -0
  167. package/dist/uk-UA.mjs +10 -0
  168. package/dist/uk-UA.module.js +10 -0
  169. package/dist/uk-UA.module.js.map +1 -0
  170. package/dist/zh-CN.main.js +8 -0
  171. package/dist/zh-CN.main.js.map +1 -0
  172. package/dist/zh-CN.mjs +10 -0
  173. package/dist/zh-CN.module.js +10 -0
  174. package/dist/zh-CN.module.js.map +1 -0
  175. package/dist/zh-TW.main.js +8 -0
  176. package/dist/zh-TW.main.js.map +1 -0
  177. package/dist/zh-TW.mjs +10 -0
  178. package/dist/zh-TW.module.js +10 -0
  179. package/dist/zh-TW.module.js.map +1 -0
  180. package/package.json +24 -24
  181. package/src/ActionMenu.tsx +1 -1
  182. package/src/ContextualHelpTrigger.tsx +127 -57
  183. package/src/Menu.tsx +87 -12
  184. package/src/MenuItem.tsx +27 -22
  185. package/src/MenuTrigger.tsx +3 -3
  186. package/src/SubmenuTrigger.tsx +167 -0
  187. package/src/context.ts +21 -13
  188. package/src/index.ts +2 -0
package/src/context.ts CHANGED
@@ -10,18 +10,20 @@
10
10
  * governing permissions and limitations under the License.
11
11
  */
12
12
 
13
- import {FocusStrategy} from '@react-types/shared';
14
- import {MenuTriggerState} from '@react-stately/menu';
13
+ import {DOMProps, FocusStrategy, HoverEvents, KeyboardEvents, PressEvents} from '@react-types/shared';
15
14
  import React, {HTMLAttributes, MutableRefObject, RefObject, useContext} from 'react';
15
+ import {RootMenuTriggerState} from '@react-stately/menu';
16
16
  import {TreeState} from '@react-stately/tree';
17
17
 
18
- export interface MenuContextValue extends Omit<HTMLAttributes<HTMLElement>, 'autoFocus'> {
18
+ export interface MenuContextValue extends Omit<HTMLAttributes<HTMLElement>, 'autoFocus' | 'onKeyDown'>, Pick<KeyboardEvents, 'onKeyDown'> {
19
19
  onClose?: () => void,
20
20
  closeOnSelect?: boolean,
21
21
  shouldFocusWrap?: boolean,
22
22
  autoFocus?: boolean | FocusStrategy,
23
23
  ref?: MutableRefObject<HTMLDivElement>,
24
- state?: MenuTriggerState
24
+ state?: RootMenuTriggerState,
25
+ onBackButtonPress?: () => void,
26
+ submenuLevel?: number
25
27
  }
26
28
 
27
29
  export const MenuContext = React.createContext<MenuContextValue>({});
@@ -30,26 +32,32 @@ export function useMenuContext(): MenuContextValue {
30
32
  return useContext(MenuContext);
31
33
  }
32
34
 
33
- export interface MenuDialogContextValue {
35
+ export interface SubmenuTriggerContextValue extends DOMProps, Pick<PressEvents, 'onPressStart' | 'onPress'>, Pick<HoverEvents, 'onHoverChange'>, Pick<KeyboardEvents, 'onKeyDown'> {
34
36
  isUnavailable?: boolean,
35
- triggerRef?: MutableRefObject<HTMLElement>
37
+ triggerRef?: MutableRefObject<HTMLElement>,
38
+ 'aria-expanded'?: boolean | 'true' | 'false',
39
+ 'aria-controls'?: string,
40
+ 'aria-haspopup'?: 'dialog' | 'menu',
41
+ isOpen?: boolean
36
42
  }
37
43
 
38
- export const MenuDialogContext = React.createContext<MenuDialogContextValue | undefined>(undefined);
44
+ export const SubmenuTriggerContext = React.createContext<SubmenuTriggerContextValue | undefined>(undefined);
39
45
 
40
- export function useMenuDialogContext(): MenuDialogContextValue {
41
- return useContext(MenuDialogContext);
46
+ export function useSubmenuTriggerContext(): SubmenuTriggerContextValue {
47
+ return useContext(SubmenuTriggerContext);
42
48
  }
43
49
 
44
50
  export interface MenuStateContextValue<T> {
45
51
  state?: TreeState<T>,
46
- container?: RefObject<HTMLElement>,
47
- menu?: RefObject<HTMLDivElement>
52
+ popoverContainerRef?: RefObject<HTMLElement>,
53
+ trayContainerRef?: RefObject<HTMLElement>,
54
+ menu?: RefObject<HTMLDivElement>,
55
+ submenu?: RefObject<HTMLDivElement>,
56
+ rootMenuTriggerState?: RootMenuTriggerState
48
57
  }
49
58
 
50
- export const MenuStateContext = React.createContext<MenuStateContextValue<any>>({});
59
+ export const MenuStateContext = React.createContext<MenuStateContextValue<any>>(undefined);
51
60
 
52
61
  export function useMenuStateContext<T>(): MenuStateContextValue<T> {
53
62
  return useContext(MenuStateContext);
54
63
  }
55
-
package/src/index.ts CHANGED
@@ -13,9 +13,11 @@
13
13
  /// <reference types="css-module-types" />
14
14
 
15
15
  export {MenuTrigger} from './MenuTrigger';
16
+ export {SubmenuTrigger} from './SubmenuTrigger';
16
17
  export {Menu} from './Menu';
17
18
  export {ActionMenu} from './ActionMenu';
18
19
  export {ContextualHelpTrigger} from './ContextualHelpTrigger';
19
20
  export {Item, Section} from '@react-stately/collections';
20
21
  export type {SpectrumActionMenuProps, SpectrumMenuProps, SpectrumMenuTriggerProps} from '@react-types/menu';
21
22
  export type {SpectrumMenuDialogTriggerProps} from './ContextualHelpTrigger';
23
+ export type {SpectrumSubmenuTriggerProps} from './SubmenuTrigger';