@fluentui-react-native/menu 1.4.28 → 1.4.30

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 (241) hide show
  1. package/CHANGELOG.json +79 -1
  2. package/CHANGELOG.md +26 -2
  3. package/SPEC.md +46 -0
  4. package/lib/Menu/Menu.d.ts +4 -0
  5. package/lib/Menu/Menu.d.ts.map +1 -0
  6. package/lib/Menu/Menu.js +35 -0
  7. package/lib/Menu/Menu.js.map +1 -0
  8. package/lib/Menu/Menu.types.d.ts +40 -0
  9. package/lib/Menu/Menu.types.d.ts.map +1 -0
  10. package/lib/Menu/Menu.types.js +2 -0
  11. package/lib/Menu/Menu.types.js.map +1 -0
  12. package/lib/Menu/index.d.ts +6 -0
  13. package/lib/Menu/index.d.ts.map +1 -0
  14. package/lib/Menu/index.js +5 -0
  15. package/lib/Menu/index.js.map +1 -0
  16. package/lib/Menu/useMenu.d.ts +3 -0
  17. package/lib/Menu/useMenu.d.ts.map +1 -0
  18. package/lib/Menu/useMenu.js +76 -0
  19. package/lib/Menu/useMenu.js.map +1 -0
  20. package/lib/Menu/useMenuContextValue.d.ts +4 -0
  21. package/lib/Menu/useMenuContextValue.d.ts.map +1 -0
  22. package/lib/Menu/useMenuContextValue.js +8 -0
  23. package/lib/Menu/useMenuContextValue.js.map +1 -0
  24. package/lib/MenuDivider/MenuDivider.d.ts +2 -0
  25. package/lib/MenuDivider/MenuDivider.d.ts.map +1 -0
  26. package/lib/MenuDivider/MenuDivider.js +15 -0
  27. package/lib/MenuDivider/MenuDivider.js.map +1 -0
  28. package/lib/MenuDivider/MenuDivider.styling.d.ts +4 -0
  29. package/lib/MenuDivider/MenuDivider.styling.d.ts.map +1 -0
  30. package/lib/MenuDivider/MenuDivider.styling.js +19 -0
  31. package/lib/MenuDivider/MenuDivider.styling.js.map +1 -0
  32. package/lib/MenuDivider/MenuDivider.types.d.ts +21 -0
  33. package/lib/MenuDivider/MenuDivider.types.d.ts.map +1 -0
  34. package/lib/MenuDivider/MenuDivider.types.js +2 -0
  35. package/lib/MenuDivider/MenuDivider.types.js.map +1 -0
  36. package/lib/MenuDivider/MenuDividerTokens.d.ts +5 -0
  37. package/lib/MenuDivider/MenuDividerTokens.d.ts.map +1 -0
  38. package/lib/MenuDivider/MenuDividerTokens.js +7 -0
  39. package/lib/MenuDivider/MenuDividerTokens.js.map +1 -0
  40. package/lib/MenuDivider/MenuDividerTokens.macos.d.ts +5 -0
  41. package/lib/MenuDivider/MenuDividerTokens.macos.d.ts.map +1 -0
  42. package/lib/MenuDivider/MenuDividerTokens.macos.js +7 -0
  43. package/lib/MenuDivider/MenuDividerTokens.macos.js.map +1 -0
  44. package/lib/MenuDivider/MenuDividerTokens.win32.d.ts +5 -0
  45. package/lib/MenuDivider/MenuDividerTokens.win32.d.ts.map +1 -0
  46. package/lib/MenuDivider/MenuDividerTokens.win32.js +7 -0
  47. package/lib/MenuDivider/MenuDividerTokens.win32.js.map +1 -0
  48. package/lib/MenuDivider/index.d.ts +4 -0
  49. package/lib/MenuDivider/index.d.ts.map +1 -0
  50. package/lib/MenuDivider/index.js +3 -0
  51. package/lib/MenuDivider/index.js.map +1 -0
  52. package/lib/MenuItem/MenuItem.d.ts +7 -0
  53. package/lib/MenuItem/MenuItem.d.ts.map +1 -0
  54. package/lib/MenuItem/MenuItem.js +58 -0
  55. package/lib/MenuItem/MenuItem.js.map +1 -0
  56. package/lib/MenuItem/MenuItem.styling.d.ts +5 -0
  57. package/lib/MenuItem/MenuItem.styling.d.ts.map +1 -0
  58. package/lib/MenuItem/MenuItem.styling.js +50 -0
  59. package/lib/MenuItem/MenuItem.styling.js.map +1 -0
  60. package/lib/MenuItem/MenuItem.types.d.ts +98 -0
  61. package/lib/MenuItem/MenuItem.types.d.ts.map +1 -0
  62. package/lib/MenuItem/MenuItem.types.js +2 -0
  63. package/lib/MenuItem/MenuItem.types.js.map +1 -0
  64. package/lib/MenuItem/MenuItemTokens.d.ts +5 -0
  65. package/lib/MenuItem/MenuItemTokens.d.ts.map +1 -0
  66. package/lib/MenuItem/MenuItemTokens.js +39 -0
  67. package/lib/MenuItem/MenuItemTokens.js.map +1 -0
  68. package/lib/MenuItem/MenuItemTokens.macos.d.ts +5 -0
  69. package/lib/MenuItem/MenuItemTokens.macos.d.ts.map +1 -0
  70. package/lib/MenuItem/MenuItemTokens.macos.js +34 -0
  71. package/lib/MenuItem/MenuItemTokens.macos.js.map +1 -0
  72. package/lib/MenuItem/MenuItemTokens.win32.d.ts +5 -0
  73. package/lib/MenuItem/MenuItemTokens.win32.d.ts.map +1 -0
  74. package/lib/MenuItem/MenuItemTokens.win32.js +40 -0
  75. package/lib/MenuItem/MenuItemTokens.win32.js.map +1 -0
  76. package/lib/MenuItem/index.d.ts +5 -0
  77. package/lib/MenuItem/index.d.ts.map +1 -0
  78. package/lib/MenuItem/index.js +4 -0
  79. package/lib/MenuItem/index.js.map +1 -0
  80. package/lib/MenuItem/useMenuItem.d.ts +7 -0
  81. package/lib/MenuItem/useMenuItem.d.ts.map +1 -0
  82. package/lib/MenuItem/useMenuItem.js +74 -0
  83. package/lib/MenuItem/useMenuItem.js.map +1 -0
  84. package/lib/MenuItemCheckbox/MenuItemCheckbox.d.ts +7 -0
  85. package/lib/MenuItemCheckbox/MenuItemCheckbox.d.ts.map +1 -0
  86. package/lib/MenuItemCheckbox/MenuItemCheckbox.js +37 -0
  87. package/lib/MenuItemCheckbox/MenuItemCheckbox.js.map +1 -0
  88. package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.d.ts +5 -0
  89. package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.d.ts.map +1 -0
  90. package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.js +40 -0
  91. package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.js.map +1 -0
  92. package/lib/MenuItemCheckbox/MenuItemCheckbox.types.d.ts +66 -0
  93. package/lib/MenuItemCheckbox/MenuItemCheckbox.types.d.ts.map +1 -0
  94. package/lib/MenuItemCheckbox/MenuItemCheckbox.types.js +2 -0
  95. package/lib/MenuItemCheckbox/MenuItemCheckbox.types.js.map +1 -0
  96. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.d.ts +5 -0
  97. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.d.ts.map +1 -0
  98. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.js +51 -0
  99. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.js.map +1 -0
  100. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.d.ts +5 -0
  101. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.d.ts.map +1 -0
  102. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js +49 -0
  103. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js.map +1 -0
  104. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.d.ts +5 -0
  105. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.d.ts.map +1 -0
  106. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js +52 -0
  107. package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js.map +1 -0
  108. package/lib/MenuItemCheckbox/index.d.ts +5 -0
  109. package/lib/MenuItemCheckbox/index.d.ts.map +1 -0
  110. package/lib/MenuItemCheckbox/index.js +4 -0
  111. package/lib/MenuItemCheckbox/index.js.map +1 -0
  112. package/lib/MenuItemCheckbox/useMenuItemCheckbox.d.ts +13 -0
  113. package/lib/MenuItemCheckbox/useMenuItemCheckbox.d.ts.map +1 -0
  114. package/lib/MenuItemCheckbox/useMenuItemCheckbox.js +85 -0
  115. package/lib/MenuItemCheckbox/useMenuItemCheckbox.js.map +1 -0
  116. package/lib/MenuItemRadio/MenuItemRadio.d.ts +4 -0
  117. package/lib/MenuItemRadio/MenuItemRadio.d.ts.map +1 -0
  118. package/lib/MenuItemRadio/MenuItemRadio.js +12 -0
  119. package/lib/MenuItemRadio/MenuItemRadio.js.map +1 -0
  120. package/lib/MenuItemRadio/index.d.ts +3 -0
  121. package/lib/MenuItemRadio/index.d.ts.map +1 -0
  122. package/lib/MenuItemRadio/index.js +3 -0
  123. package/lib/MenuItemRadio/index.js.map +1 -0
  124. package/lib/MenuItemRadio/useMenuItemRadio.d.ts +3 -0
  125. package/lib/MenuItemRadio/useMenuItemRadio.d.ts.map +1 -0
  126. package/lib/MenuItemRadio/useMenuItemRadio.js +30 -0
  127. package/lib/MenuItemRadio/useMenuItemRadio.js.map +1 -0
  128. package/lib/MenuList/MenuList.d.ts +4 -0
  129. package/lib/MenuList/MenuList.d.ts.map +1 -0
  130. package/lib/MenuList/MenuList.js +68 -0
  131. package/lib/MenuList/MenuList.js.map +1 -0
  132. package/lib/MenuList/MenuList.styling.d.ts +5 -0
  133. package/lib/MenuList/MenuList.styling.d.ts.map +1 -0
  134. package/lib/MenuList/MenuList.styling.js +17 -0
  135. package/lib/MenuList/MenuList.styling.js.map +1 -0
  136. package/lib/MenuList/MenuList.types.d.ts +77 -0
  137. package/lib/MenuList/MenuList.types.d.ts.map +1 -0
  138. package/lib/MenuList/MenuList.types.js +2 -0
  139. package/lib/MenuList/MenuList.types.js.map +1 -0
  140. package/lib/MenuList/MenuListTokens.d.ts +5 -0
  141. package/lib/MenuList/MenuListTokens.d.ts.map +1 -0
  142. package/lib/MenuList/MenuListTokens.js +9 -0
  143. package/lib/MenuList/MenuListTokens.js.map +1 -0
  144. package/lib/MenuList/MenuListTokens.macos.d.ts +5 -0
  145. package/lib/MenuList/MenuListTokens.macos.d.ts.map +1 -0
  146. package/lib/MenuList/MenuListTokens.macos.js +7 -0
  147. package/lib/MenuList/MenuListTokens.macos.js.map +1 -0
  148. package/lib/MenuList/MenuListTokens.win32.d.ts +5 -0
  149. package/lib/MenuList/MenuListTokens.win32.d.ts.map +1 -0
  150. package/lib/MenuList/MenuListTokens.win32.js +12 -0
  151. package/lib/MenuList/MenuListTokens.win32.js.map +1 -0
  152. package/lib/MenuList/index.d.ts +6 -0
  153. package/lib/MenuList/index.d.ts.map +1 -0
  154. package/lib/MenuList/index.js +5 -0
  155. package/lib/MenuList/index.js.map +1 -0
  156. package/lib/MenuList/useMenuList.d.ts +3 -0
  157. package/lib/MenuList/useMenuList.d.ts.map +1 -0
  158. package/lib/MenuList/useMenuList.js +109 -0
  159. package/lib/MenuList/useMenuList.js.map +1 -0
  160. package/lib/MenuList/useMenuListContextValue.d.ts +4 -0
  161. package/lib/MenuList/useMenuListContextValue.d.ts.map +1 -0
  162. package/lib/MenuList/useMenuListContextValue.js +5 -0
  163. package/lib/MenuList/useMenuListContextValue.js.map +1 -0
  164. package/lib/MenuPopover/MenuPopover.d.ts +4 -0
  165. package/lib/MenuPopover/MenuPopover.d.ts.map +1 -0
  166. package/lib/MenuPopover/MenuPopover.js +44 -0
  167. package/lib/MenuPopover/MenuPopover.js.map +1 -0
  168. package/lib/MenuPopover/MenuPopover.types.d.ts +10 -0
  169. package/lib/MenuPopover/MenuPopover.types.d.ts.map +1 -0
  170. package/lib/MenuPopover/MenuPopover.types.js +2 -0
  171. package/lib/MenuPopover/MenuPopover.types.js.map +1 -0
  172. package/lib/MenuPopover/MenuPopoverTokens.d.ts +3 -0
  173. package/lib/MenuPopover/MenuPopoverTokens.d.ts.map +1 -0
  174. package/lib/MenuPopover/MenuPopoverTokens.js +4 -0
  175. package/lib/MenuPopover/MenuPopoverTokens.js.map +1 -0
  176. package/lib/MenuPopover/index.d.ts +5 -0
  177. package/lib/MenuPopover/index.d.ts.map +1 -0
  178. package/lib/MenuPopover/index.js +4 -0
  179. package/lib/MenuPopover/index.js.map +1 -0
  180. package/lib/MenuPopover/useMenuPopover.d.ts +3 -0
  181. package/lib/MenuPopover/useMenuPopover.d.ts.map +1 -0
  182. package/lib/MenuPopover/useMenuPopover.js +92 -0
  183. package/lib/MenuPopover/useMenuPopover.js.map +1 -0
  184. package/lib/MenuTrigger/MenuTrigger.d.ts +5 -0
  185. package/lib/MenuTrigger/MenuTrigger.d.ts.map +1 -0
  186. package/lib/MenuTrigger/MenuTrigger.js +20 -0
  187. package/lib/MenuTrigger/MenuTrigger.js.map +1 -0
  188. package/lib/MenuTrigger/MenuTrigger.types.d.ts +28 -0
  189. package/lib/MenuTrigger/MenuTrigger.types.d.ts.map +1 -0
  190. package/lib/MenuTrigger/MenuTrigger.types.js +2 -0
  191. package/lib/MenuTrigger/MenuTrigger.types.js.map +1 -0
  192. package/lib/MenuTrigger/index.d.ts +5 -0
  193. package/lib/MenuTrigger/index.d.ts.map +1 -0
  194. package/lib/MenuTrigger/index.js +4 -0
  195. package/lib/MenuTrigger/index.js.map +1 -0
  196. package/lib/MenuTrigger/useMenuTrigger.d.ts +3 -0
  197. package/lib/MenuTrigger/useMenuTrigger.d.ts.map +1 -0
  198. package/lib/MenuTrigger/useMenuTrigger.js +79 -0
  199. package/lib/MenuTrigger/useMenuTrigger.js.map +1 -0
  200. package/lib/MenuTrigger/useMergeRefs.d.ts +20 -0
  201. package/lib/MenuTrigger/useMergeRefs.d.ts.map +1 -0
  202. package/lib/MenuTrigger/useMergeRefs.js +36 -0
  203. package/lib/MenuTrigger/useMergeRefs.js.map +1 -0
  204. package/lib/__tests__/Menu.test.d.ts +2 -0
  205. package/lib/__tests__/Menu.test.d.ts.map +1 -0
  206. package/lib/__tests__/Menu.test.js +145 -0
  207. package/lib/__tests__/Menu.test.js.map +1 -0
  208. package/lib/consts.d.ts +2 -0
  209. package/lib/consts.d.ts.map +1 -0
  210. package/lib/consts.js +6 -0
  211. package/lib/consts.js.map +1 -0
  212. package/lib/context/index.d.ts +4 -0
  213. package/lib/context/index.d.ts.map +1 -0
  214. package/lib/context/index.js +4 -0
  215. package/lib/context/index.js.map +1 -0
  216. package/lib/context/menuContext.d.ts +16 -0
  217. package/lib/context/menuContext.d.ts.map +1 -0
  218. package/lib/context/menuContext.js +20 -0
  219. package/lib/context/menuContext.js.map +1 -0
  220. package/lib/context/menuListContext.d.ts +14 -0
  221. package/lib/context/menuListContext.d.ts.map +1 -0
  222. package/lib/context/menuListContext.js +15 -0
  223. package/lib/context/menuListContext.js.map +1 -0
  224. package/lib/context/menuTriggerContext.d.ts +9 -0
  225. package/lib/context/menuTriggerContext.d.ts.map +1 -0
  226. package/lib/context/menuTriggerContext.js +9 -0
  227. package/lib/context/menuTriggerContext.js.map +1 -0
  228. package/lib/index.d.ts +10 -0
  229. package/lib/index.d.ts.map +1 -0
  230. package/lib/index.js +10 -0
  231. package/lib/index.js.map +1 -0
  232. package/lib-commonjs/MenuItem/MenuItem.types.d.ts +12 -0
  233. package/lib-commonjs/MenuItem/MenuItem.types.d.ts.map +1 -1
  234. package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.types.d.ts +6 -0
  235. package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.types.d.ts.map +1 -1
  236. package/lib-commonjs/MenuList/MenuList.types.d.ts +3 -0
  237. package/lib-commonjs/MenuList/MenuList.types.d.ts.map +1 -1
  238. package/package.json +9 -9
  239. package/src/MenuItem/MenuItem.types.ts +14 -0
  240. package/src/MenuItemCheckbox/MenuItemCheckbox.types.ts +8 -0
  241. package/src/MenuList/MenuList.types.ts +4 -0
@@ -0,0 +1,37 @@
1
+ import { __assign, __rest } from "tslib";
2
+ import { Image, Pressable, View } from 'react-native';
3
+ import { compose, mergeProps, withSlots } from '@fluentui-react-native/framework';
4
+ import { IconV1 as Icon } from '@fluentui-react-native/icon';
5
+ import { TextV1 as Text } from '@fluentui-react-native/text';
6
+ import { SvgXml } from 'react-native-svg';
7
+ import { stylingSettings } from './MenuItemCheckbox.styling';
8
+ import { menuItemCheckboxName } from './MenuItemCheckbox.types';
9
+ import { useMenuItemCheckbox } from './useMenuItemCheckbox';
10
+ import { getAccessibilityLabel, getTooltip } from '../MenuItem/MenuItem';
11
+ export var MenuItemCheckbox = compose(__assign(__assign({ displayName: menuItemCheckboxName }, stylingSettings), { slots: {
12
+ root: Pressable,
13
+ checkmark: SvgXml,
14
+ content: Text,
15
+ iconPlaceholder: View,
16
+ imgIcon: Image,
17
+ fontOrSvgIcon: Icon,
18
+ }, useRender: function (userProps, useSlots) {
19
+ var menuItem = useMenuItemCheckbox(userProps);
20
+ var Slots = useSlots(userProps, function (layer) { return menuItem.state[layer] || userProps[layer]; });
21
+ return menuItemFinalRender(menuItem, Slots);
22
+ } }));
23
+ export var menuItemFinalRender = function (menuItem, Slots) {
24
+ return function (final, children) {
25
+ var _a = mergeProps(menuItem.props, final), accessibilityLabel = _a.accessibilityLabel, icon = _a.icon, tooltip = _a.tooltip, mergedProps = __rest(_a, ["accessibilityLabel", "icon", "tooltip"]);
26
+ var checkmarkXml = "\n <svg>\n <path fill='currentColor' d='M9.85355 3.14645C10.0488 3.34171 10.0488 3.65829 9.85355 3.85355L5.35355 8.35355C5.15829 8.54882 4.84171 8.54882 4.64645 8.35355L2.64645 6.35355C2.45118 6.15829 2.45118 5.84171 2.64645 5.64645C2.84171 5.45118 3.15829 5.45118 3.35355 5.64645L5 7.29289L9.14645 3.14645C9.34171 2.95118 9.65829 2.95118 9.85355 3.14645Z' />\n </svg>";
27
+ var label = getAccessibilityLabel(accessibilityLabel, children[0]);
28
+ var tooltipResult = getTooltip(tooltip, menuItem.state.hasTooltips, children[0]);
29
+ return (withSlots(Slots.root, __assign({}, mergedProps, { accessibilityLabel: label }),
30
+ withSlots(Slots.checkmark, { accessible: false, xml: checkmarkXml }),
31
+ (icon || menuItem.state.hasIcons) && (withSlots(Slots.iconPlaceholder, { accessible: false },
32
+ icon && icon.source && withSlots(Slots.imgIcon, __assign({ accessible: false }, icon)),
33
+ icon && (icon.svgSource || icon.fontSource) && withSlots(Slots.fontOrSvgIcon, __assign({ accessible: false }, icon)))),
34
+ children && (withSlots(Slots.content, { accessible: false, tooltip: tooltipResult }, children))));
35
+ };
36
+ };
37
+ //# sourceMappingURL=MenuItemCheckbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckbox.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckbox.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { UseStylingOptions } from '@fluentui-react-native/framework';
2
+ import type { MenuItemCheckboxProps, MenuItemCheckboxTokens, MenuItemCheckboxSlotProps } from './MenuItemCheckbox.types';
3
+ export declare const menuItemCheckboxStates: (keyof MenuItemCheckboxTokens)[];
4
+ export declare const stylingSettings: UseStylingOptions<MenuItemCheckboxProps, MenuItemCheckboxSlotProps, MenuItemCheckboxTokens>;
5
+ //# sourceMappingURL=MenuItemCheckbox.styling.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckbox.styling.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckbox.styling.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAS,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAIjF,OAAO,KAAK,EAAE,qBAAqB,EAAE,sBAAsB,EAAE,yBAAyB,EAAE,MAAM,0BAA0B,CAAC;AAIzH,eAAO,MAAM,sBAAsB,EAAE,CAAC,MAAM,sBAAsB,CAAC,EAA6D,CAAC;AAEjI,eAAO,MAAM,eAAe,EAAE,iBAAiB,CAAC,qBAAqB,EAAE,yBAAyB,EAAE,sBAAsB,CA6DvH,CAAC"}
@@ -0,0 +1,40 @@
1
+ import { __assign, __spreadArray } from "tslib";
2
+ import { buildProps } from '@fluentui-react-native/framework';
3
+ import { borderStyles, fontStyles, layoutStyles } from '@fluentui-react-native/tokens';
4
+ import { menuItemCheckboxName } from './MenuItemCheckbox.types';
5
+ import { defaultMenuItemCheckboxTokens } from './MenuItemCheckboxTokens';
6
+ export var menuItemCheckboxStates = ['hovered', 'focused', 'pressed', 'disabled', 'checked'];
7
+ export var stylingSettings = {
8
+ tokens: [defaultMenuItemCheckboxTokens, menuItemCheckboxName],
9
+ states: menuItemCheckboxStates,
10
+ slotProps: {
11
+ root: buildProps(function (tokens, theme) { return ({
12
+ style: __assign(__assign({ alignItems: 'center', backgroundColor: tokens.backgroundColor, display: 'flex', flexDirection: 'row' }, layoutStyles.from(tokens, theme)), borderStyles.from(tokens, theme)),
13
+ }); }, __spreadArray(__spreadArray(['backgroundColor'], borderStyles.keys, true), layoutStyles.keys, true)),
14
+ checkmark: buildProps(function (tokens) { return ({
15
+ opacity: tokens.checkmarkVisibility,
16
+ color: tokens.color,
17
+ height: tokens.checkmarkSize,
18
+ width: tokens.checkmarkSize,
19
+ viewBox: '0 0 ' + (tokens.checkmarkSize - tokens.checkmarkPadding * 2) + ' ' + (tokens.checkmarkSize - tokens.checkmarkPadding * 2),
20
+ style: { marginEnd: tokens.gap },
21
+ }); }, ['checkmarkPadding', 'checkmarkSize', 'checkmarkVisibility', 'color', 'gap']),
22
+ content: buildProps(function (tokens, theme) { return ({
23
+ style: __assign({ flexGrow: 1, color: tokens.color }, fontStyles.from(tokens, theme)),
24
+ }); }, __spreadArray(['color'], fontStyles.keys, true)),
25
+ iconPlaceholder: buildProps(function (tokens) { return ({
26
+ style: {
27
+ minHeight: tokens.iconSize,
28
+ minWidth: tokens.iconSize,
29
+ alignItems: 'center',
30
+ justifyContent: 'center',
31
+ marginEnd: tokens.gap,
32
+ },
33
+ }); }, ['checkmarkSize', 'gap']),
34
+ imgIcon: buildProps(function (tokens) { return ({
35
+ style: { tintColor: tokens.iconColor, height: tokens.iconSize, width: tokens.iconSize },
36
+ }); }, ['gap', 'iconColor', 'iconSize']),
37
+ fontOrSvgIcon: buildProps(function (tokens) { return ({ color: tokens.iconColor, size: tokens.iconSize }); }, ['gap', 'iconColor', 'iconSize']),
38
+ },
39
+ };
40
+ //# sourceMappingURL=MenuItemCheckbox.styling.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckbox.styling.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckbox.styling.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,66 @@
1
+ import type * as React from 'react';
2
+ import type { ColorValue, ImageProps } from 'react-native';
3
+ import type { IViewProps } from '@fluentui-react-native/adapters';
4
+ import type { IconPropsV1 as IconProps } from '@fluentui-react-native/icon';
5
+ import type { PressablePropsExtended, PressableState } from '@fluentui-react-native/interactive-hooks';
6
+ import type { TextProps } from '@fluentui-react-native/text';
7
+ import type { XmlProps } from 'react-native-svg';
8
+ import type { MenuItemProps, MenuItemTokens } from '../MenuItem/MenuItem.types';
9
+ export declare const menuItemCheckboxName = "MenuItemCheckbox";
10
+ export interface MenuItemCheckboxTokens extends Omit<MenuItemTokens, 'submenuIndicatorPadding' | 'submenuIndicatorSize' | 'disabled' | 'focused' | 'hovered' | 'pressed'> {
11
+ /**
12
+ * Color of the checkmark icon
13
+ */
14
+ checkmarkColor?: ColorValue;
15
+ /**
16
+ * Amount of space in pixels around the checkmark icon
17
+ */
18
+ checkmarkPadding?: number;
19
+ /**
20
+ * Visibility of the checkmark icon from 0 to 1
21
+ */
22
+ checkmarkVisibility?: number;
23
+ /**
24
+ * Color of the icon
25
+ */
26
+ iconColor?: ColorValue;
27
+ /**
28
+ * Size of the icon. Pixels for SVG and points for font icon.
29
+ */
30
+ iconSize?: number;
31
+ /**
32
+ * States of the item control
33
+ */
34
+ checked?: MenuItemCheckboxTokens;
35
+ disabled?: MenuItemCheckboxTokens;
36
+ focused?: MenuItemCheckboxTokens;
37
+ hovered?: MenuItemCheckboxTokens;
38
+ pressed?: MenuItemCheckboxTokens;
39
+ }
40
+ export interface MenuItemCheckboxProps extends MenuItemProps {
41
+ /**
42
+ * Identifier for the control
43
+ */
44
+ name: string;
45
+ }
46
+ export interface MenuItemCheckboxInfo {
47
+ props: MenuItemCheckboxProps & React.ComponentPropsWithRef<any>;
48
+ state: PressableState & {
49
+ hasIcons: boolean;
50
+ hasTooltips: boolean;
51
+ };
52
+ }
53
+ export interface MenuItemCheckboxSlotProps {
54
+ root: React.PropsWithRef<PressablePropsExtended>;
55
+ checkmark?: XmlProps;
56
+ content?: TextProps;
57
+ iconPlaceholder?: React.PropsWithRef<IViewProps>;
58
+ imgIcon?: ImageProps;
59
+ fontOrSvgIcon?: IconProps;
60
+ }
61
+ export interface MenuItemCheckboxType {
62
+ props: MenuItemCheckboxProps;
63
+ tokens: MenuItemCheckboxTokens;
64
+ slotProps: MenuItemCheckboxSlotProps;
65
+ }
66
+ //# sourceMappingURL=MenuItemCheckbox.types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckbox.types.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckbox.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAC;AACpC,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EAAE,WAAW,IAAI,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAC5E,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAC;AACvG,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAEhF,eAAO,MAAM,oBAAoB,qBAAqB,CAAC;AAEvD,MAAM,WAAW,sBACf,SAAQ,IAAI,CAAC,cAAc,EAAE,yBAAyB,GAAG,sBAAsB,GAAG,UAAU,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,CAAC;IACjI;;OAEG;IACH,cAAc,CAAC,EAAE,UAAU,CAAC;IAE5B;;OAEG;IACH,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAE1B;;OAEG;IACH,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAE7B;;OAEG;IACH,SAAS,CAAC,EAAE,UAAU,CAAC;IAEvB;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB;;OAEG;IACH,OAAO,CAAC,EAAE,sBAAsB,CAAC;IACjC,QAAQ,CAAC,EAAE,sBAAsB,CAAC;IAClC,OAAO,CAAC,EAAE,sBAAsB,CAAC;IACjC,OAAO,CAAC,EAAE,sBAAsB,CAAC;IACjC,OAAO,CAAC,EAAE,sBAAsB,CAAC;CAClC;AAED,MAAM,WAAW,qBAAsB,SAAQ,aAAa;IAC1D;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,qBAAqB,GAAG,KAAK,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC;IAChE,KAAK,EAAE,cAAc,GAAG;QAAE,QAAQ,EAAE,OAAO,CAAC;QAAC,WAAW,EAAE,OAAO,CAAA;KAAE,CAAC;CACrE;AAED,MAAM,WAAW,yBAAyB;IACxC,IAAI,EAAE,KAAK,CAAC,YAAY,CAAC,sBAAsB,CAAC,CAAC;IACjD,SAAS,CAAC,EAAE,QAAQ,CAAC;IACrB,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,eAAe,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;IACjD,OAAO,CAAC,EAAE,UAAU,CAAC;IACrB,aAAa,CAAC,EAAE,SAAS,CAAC;CAC3B;AAED,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,qBAAqB,CAAC;IAC7B,MAAM,EAAE,sBAAsB,CAAC;IAC/B,SAAS,EAAE,yBAAyB,CAAC;CACtC"}
@@ -0,0 +1,2 @@
1
+ export var menuItemCheckboxName = 'MenuItemCheckbox';
2
+ //# sourceMappingURL=MenuItemCheckbox.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckbox.types.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckbox.types.ts"],"names":[],"mappings":"AAWA,MAAM,CAAC,IAAM,oBAAoB,GAAG,kBAAkB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { Theme } from '@fluentui-react-native/framework';
2
+ import type { TokenSettings } from '@fluentui-react-native/use-styling';
3
+ import type { MenuItemCheckboxTokens } from './MenuItemCheckbox.types';
4
+ export declare const defaultMenuItemCheckboxTokens: TokenSettings<MenuItemCheckboxTokens, Theme>;
5
+ //# sourceMappingURL=MenuItemCheckboxTokens.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckboxTokens.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckboxTokens.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAmB,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAE/E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAExE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAEvE,eAAO,MAAM,6BAA6B,EAAE,aAAa,CAAC,sBAAsB,EAAE,KAAK,CAgDrF,CAAC"}
@@ -0,0 +1,51 @@
1
+ import { globalTokens } from '@fluentui-react-native/theme-tokens';
2
+ export var defaultMenuItemCheckboxTokens = function (t) { return ({
3
+ backgroundColor: t.colors.neutralBackground1,
4
+ borderRadius: globalTokens.corner.radius40,
5
+ checkmarkPadding: globalTokens.sizeNone,
6
+ checkmarkSize: 16,
7
+ checkmarkVisibility: 0,
8
+ color: t.colors.neutralForeground2,
9
+ fontFamily: t.typography.families.primary,
10
+ fontSize: globalTokens.font.size300,
11
+ fontWeight: globalTokens.font.weight.regular,
12
+ gap: globalTokens.size40,
13
+ iconColor: t.colors.neutralForeground2,
14
+ iconSize: 16,
15
+ minHeight: 32,
16
+ minWidth: 160,
17
+ maxWidth: 300,
18
+ padding: globalTokens.size60,
19
+ hovered: {
20
+ backgroundColor: t.colors.neutralBackground1Hover,
21
+ color: t.colors.neutralForeground2Hover,
22
+ iconColor: t.colors.neutralForeground2Hover,
23
+ checked: {
24
+ checkmarkColor: t.colors.neutralForeground2Hover,
25
+ checkmarkVisibility: 1,
26
+ },
27
+ },
28
+ pressed: {
29
+ backgroundColor: t.colors.neutralBackground1Pressed,
30
+ color: t.colors.neutralForeground2Pressed,
31
+ iconColor: t.colors.neutralForeground2Pressed,
32
+ checked: {
33
+ checkmarkColor: t.colors.neutralForeground2Pressed,
34
+ checkmarkVisibility: 1,
35
+ },
36
+ },
37
+ disabled: {
38
+ backgroundColor: t.colors.neutralBackground1,
39
+ color: t.colors.neutralForegroundDisabled,
40
+ iconColor: t.colors.neutralForegroundDisabled,
41
+ checked: {
42
+ checkmarkColor: t.colors.neutralForegroundDisabled,
43
+ checkmarkVisibility: 1,
44
+ },
45
+ },
46
+ checked: {
47
+ checkmarkColor: t.colors.neutralForeground2,
48
+ checkmarkVisibility: 1,
49
+ },
50
+ }); };
51
+ //# sourceMappingURL=MenuItemCheckboxTokens.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckboxTokens.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckboxTokens.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,IAAM,6BAA6B,GAAiD,UAAC,CAAQ,IAA6B,OAAA,CAAC;IAChI,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IAC5C,YAAY,EAAE,YAAY,CAAC,MAAM,CAAC,QAAQ;IAC1C,gBAAgB,EAAE,YAAY,CAAC,QAAQ;IACvC,aAAa,EAAE,EAAE;IACjB,mBAAmB,EAAE,CAAC;IACtB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IAClC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO;IACzC,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO;IACnC,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAA0B;IAC/D,GAAG,EAAE,YAAY,CAAC,MAAM;IACxB,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IACtC,QAAQ,EAAE,EAAE;IACZ,SAAS,EAAE,EAAE;IACb,QAAQ,EAAE,GAAG;IACb,QAAQ,EAAE,GAAG;IACb,OAAO,EAAE,YAAY,CAAC,MAAM;IAC5B,OAAO,EAAE;QACP,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;QACjD,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;QACvC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;QAC3C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;YAChD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,OAAO,EAAE;QACP,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QACnD,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QACzC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QAC7C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;YAClD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,QAAQ,EAAE;QACR,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;QAC5C,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QACzC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QAC7C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;YAClD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,OAAO,EAAE;QACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;QAC3C,mBAAmB,EAAE,CAAC;KACvB;CACF,CAAC,EAhD+H,CAgD/H,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { Theme } from '@fluentui-react-native/framework';
2
+ import type { TokenSettings } from '@fluentui-react-native/use-styling';
3
+ import type { MenuItemCheckboxTokens } from './MenuItemCheckbox.types';
4
+ export declare const defaultMenuItemCheckboxTokens: TokenSettings<MenuItemCheckboxTokens, Theme>;
5
+ //# sourceMappingURL=MenuItemCheckboxTokens.macos.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckboxTokens.macos.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckboxTokens.macos.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAmB,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAE/E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAExE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAEvE,eAAO,MAAM,6BAA6B,EAAE,aAAa,CAAC,sBAAsB,EAAE,KAAK,CA8CrF,CAAC"}
@@ -0,0 +1,49 @@
1
+ import { globalTokens } from '@fluentui-react-native/theme-tokens';
2
+ export var defaultMenuItemCheckboxTokens = function (t) { return ({
3
+ backgroundColor: t.colors.transparentBackground,
4
+ borderRadius: 5,
5
+ checkmarkPadding: globalTokens.sizeNone,
6
+ checkmarkSize: 16,
7
+ checkmarkVisibility: 0,
8
+ color: t.colors.neutralForeground2,
9
+ fontFamily: t.typography.families.primary,
10
+ fontSize: globalTokens.font.size300,
11
+ fontWeight: globalTokens.font.weight.regular,
12
+ gap: globalTokens.size40,
13
+ iconColor: t.colors.neutralForeground2,
14
+ iconSize: 16,
15
+ paddingHorizontal: 5,
16
+ paddingVertical: 3,
17
+ focused: {
18
+ backgroundColor: t.colors.brandBackground,
19
+ color: t.colors.brandedContent,
20
+ iconColor: t.colors.brandedContent,
21
+ checked: {
22
+ checkmarkColor: t.colors.neutralForeground2Hover,
23
+ checkmarkVisibility: 1,
24
+ },
25
+ },
26
+ pressed: {
27
+ backgroundColor: t.colors.brandBackgroundPressed,
28
+ color: t.colors.brandedPressedContent,
29
+ iconColor: t.colors.brandedPressedContent,
30
+ checked: {
31
+ checkmarkColor: t.colors.brandedPressedContent,
32
+ checkmarkVisibility: 1,
33
+ },
34
+ },
35
+ disabled: {
36
+ backgroundColor: t.colors.transparentBackground,
37
+ color: t.colors.brandForeground1Disabled,
38
+ iconColor: t.colors.brandForeground1Disabled,
39
+ checked: {
40
+ checkmarkColor: t.colors.brandForeground1Disabled,
41
+ checkmarkVisibility: 1,
42
+ },
43
+ },
44
+ checked: {
45
+ checkmarkColor: t.colors.neutralForeground2,
46
+ checkmarkVisibility: 1,
47
+ },
48
+ }); };
49
+ //# sourceMappingURL=MenuItemCheckboxTokens.macos.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckboxTokens.macos.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckboxTokens.macos.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,IAAM,6BAA6B,GAAiD,UAAC,CAAQ,IAA6B,OAAA,CAAC;IAChI,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,qBAAqB;IAC/C,YAAY,EAAE,CAAC;IACf,gBAAgB,EAAE,YAAY,CAAC,QAAQ;IACvC,aAAa,EAAE,EAAE;IACjB,mBAAmB,EAAE,CAAC;IACtB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IAClC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO;IACzC,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO;IACnC,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAA0B;IAC/D,GAAG,EAAE,YAAY,CAAC,MAAM;IACxB,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IACtC,QAAQ,EAAE,EAAE;IACZ,iBAAiB,EAAE,CAAC;IACpB,eAAe,EAAE,CAAC;IAClB,OAAO,EAAE;QACP,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,eAAe;QACzC,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc;QAC9B,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc;QAClC,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;YAChD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,OAAO,EAAE;QACP,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,sBAAsB;QAChD,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,qBAAqB;QACrC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,qBAAqB;QACzC,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,qBAAqB;YAC9C,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,QAAQ,EAAE;QACR,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,qBAAqB;QAC/C,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,wBAAwB;QACxC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,wBAAwB;QAC5C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,wBAAwB;YACjD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,OAAO,EAAE;QACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;QAC3C,mBAAmB,EAAE,CAAC;KACvB;CACF,CAAC,EA9C+H,CA8C/H,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { Theme } from '@fluentui-react-native/framework';
2
+ import type { TokenSettings } from '@fluentui-react-native/use-styling';
3
+ import type { MenuItemCheckboxTokens } from './MenuItemCheckbox.types';
4
+ export declare const defaultMenuItemCheckboxTokens: TokenSettings<MenuItemCheckboxTokens, Theme>;
5
+ //# sourceMappingURL=MenuItemCheckboxTokens.win32.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckboxTokens.win32.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckboxTokens.win32.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAmB,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAE/E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAExE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAEvE,eAAO,MAAM,6BAA6B,EAAE,aAAa,CAAC,sBAAsB,EAAE,KAAK,CAiDrF,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { globalTokens } from '@fluentui-react-native/theme-tokens';
2
+ export var defaultMenuItemCheckboxTokens = function (t) { return ({
3
+ backgroundColor: t.colors.neutralBackground1,
4
+ borderRadius: globalTokens.corner.radiusNone,
5
+ checkmarkPadding: globalTokens.size20,
6
+ checkmarkSize: 16,
7
+ checkmarkVisibility: 0,
8
+ color: t.colors.neutralForeground1,
9
+ fontFamily: t.typography.families.primary,
10
+ fontSize: globalTokens.font.size200,
11
+ fontWeight: globalTokens.font.weight.regular,
12
+ gap: globalTokens.size40,
13
+ iconColor: t.colors.neutralForeground1,
14
+ iconSize: 16,
15
+ minHeight: 24,
16
+ minWidth: 160,
17
+ maxWidth: 300,
18
+ padding: globalTokens.size40,
19
+ paddingHorizontal: globalTokens.size80,
20
+ pressed: {
21
+ backgroundColor: t.colors.neutralBackground1Pressed,
22
+ color: t.colors.neutralForeground1Pressed,
23
+ iconColor: t.colors.neutralForeground1Pressed,
24
+ checked: {
25
+ checkmarkColor: t.colors.neutralForeground1Pressed,
26
+ checkmarkVisibility: 1,
27
+ },
28
+ },
29
+ disabled: {
30
+ backgroundColor: t.colors.neutralBackground1,
31
+ color: t.colors.neutralForegroundDisabled,
32
+ iconColor: t.colors.neutralForegroundDisabled,
33
+ checked: {
34
+ checkmarkColor: t.colors.neutralForegroundDisabled,
35
+ checkmarkVisibility: 1,
36
+ },
37
+ },
38
+ focused: {
39
+ backgroundColor: t.colors.neutralBackground1Hover,
40
+ color: t.colors.neutralForeground1Hover,
41
+ iconColor: t.colors.neutralForeground1Hover,
42
+ checked: {
43
+ checkmarkColor: t.colors.neutralForeground1Hover,
44
+ checkmarkVisibility: 1,
45
+ },
46
+ },
47
+ checked: {
48
+ checkmarkColor: t.colors.neutralForeground1,
49
+ checkmarkVisibility: 1,
50
+ },
51
+ }); };
52
+ //# sourceMappingURL=MenuItemCheckboxTokens.win32.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemCheckboxTokens.win32.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/MenuItemCheckboxTokens.win32.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,IAAM,6BAA6B,GAAiD,UAAC,CAAQ,IAA6B,OAAA,CAAC;IAChI,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IAC5C,YAAY,EAAE,YAAY,CAAC,MAAM,CAAC,UAAU;IAC5C,gBAAgB,EAAE,YAAY,CAAC,MAAM;IACrC,aAAa,EAAE,EAAE;IACjB,mBAAmB,EAAE,CAAC;IACtB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IAClC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO;IACzC,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO;IACnC,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAA0B;IAC/D,GAAG,EAAE,YAAY,CAAC,MAAM;IACxB,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;IACtC,QAAQ,EAAE,EAAE;IACZ,SAAS,EAAE,EAAE;IACb,QAAQ,EAAE,GAAG;IACb,QAAQ,EAAE,GAAG;IACb,OAAO,EAAE,YAAY,CAAC,MAAM;IAC5B,iBAAiB,EAAE,YAAY,CAAC,MAAM;IACtC,OAAO,EAAE;QACP,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QACnD,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QACzC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QAC7C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;YAClD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,QAAQ,EAAE;QACR,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;QAC5C,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QACzC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;QAC7C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,yBAAyB;YAClD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,OAAO,EAAE;QACP,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;QACjD,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;QACvC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;QAC3C,OAAO,EAAE;YACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,uBAAuB;YAChD,mBAAmB,EAAE,CAAC;SACvB;KACF;IACD,OAAO,EAAE;QACP,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,kBAAkB;QAC3C,mBAAmB,EAAE,CAAC;KACvB;CACF,CAAC,EAjD+H,CAiD/H,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { MenuItemCheckbox } from './MenuItemCheckbox';
2
+ export { menuItemCheckboxName } from './MenuItemCheckbox.types';
3
+ export type { MenuItemCheckboxProps, MenuItemCheckboxInfo, MenuItemCheckboxTokens, MenuItemCheckboxSlotProps, MenuItemCheckboxType, } from './MenuItemCheckbox.types';
4
+ export { useMenuItemCheckbox, useMenuCheckboxInteraction } from './useMenuItemCheckbox';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,YAAY,EACV,qBAAqB,EACrB,oBAAoB,EACpB,sBAAsB,EACtB,yBAAyB,EACzB,oBAAoB,GACrB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,mBAAmB,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { MenuItemCheckbox } from './MenuItemCheckbox';
2
+ export { menuItemCheckboxName } from './MenuItemCheckbox.types';
3
+ export { useMenuItemCheckbox, useMenuCheckboxInteraction } from './useMenuItemCheckbox';
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAQhE,OAAO,EAAE,mBAAmB,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { InteractionEvent } from '@fluentui-react-native/interactive-hooks';
2
+ import type { MenuItemCheckboxProps, MenuItemCheckboxInfo } from './MenuItemCheckbox.types';
3
+ export declare const useMenuItemCheckbox: (props: MenuItemCheckboxProps) => MenuItemCheckboxInfo;
4
+ /**
5
+ * Create interactivity and accessibility props to be passed into the inner render.
6
+ * This logic is shared between Checkbox and Radio versions of MenuItem.
7
+ *
8
+ * @param props Props passed into the outer compoennt
9
+ * @param toggleCallback Function to be called when item is toggled
10
+ * @returns Props and additional state needed to render the component
11
+ */
12
+ export declare const useMenuCheckboxInteraction: (props: MenuItemCheckboxProps, toggleCallback: (e: InteractionEvent) => void) => MenuItemCheckboxInfo;
13
+ //# sourceMappingURL=useMenuItemCheckbox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMenuItemCheckbox.d.ts","sourceRoot":"","sources":["../../src/MenuItemCheckbox/useMenuItemCheckbox.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,gBAAgB,EAAiB,MAAM,0CAA0C,CAAC;AAGhG,OAAO,KAAK,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAO5F,eAAO,MAAM,mBAAmB,UAAW,qBAAqB,KAAG,oBAgBlE,CAAC;AAUF;;;;;;;GAOG;AACH,eAAO,MAAM,0BAA0B,UAC9B,qBAAqB,sBACR,gBAAgB,KAAK,IAAI,KAC5C,oBA8FF,CAAC"}
@@ -0,0 +1,85 @@
1
+ import { __assign, __rest, __spreadArray } from "tslib";
2
+ import * as React from 'react';
3
+ import { I18nManager, Platform } from 'react-native';
4
+ import { memoize } from '@fluentui-react-native/framework';
5
+ import { usePressableState, useKeyDownProps, useOnPressWithFocus, useViewCommandFocus } from '@fluentui-react-native/interactive-hooks';
6
+ import { useMenuContext } from '../context/menuContext';
7
+ import { useMenuListContext } from '../context/menuListContext';
8
+ import { submenuTriggerKeys, triggerKeys, useHoverFocusEffect } from '../MenuItem/useMenuItem';
9
+ var defaultAccessibilityActions = [{ name: 'Toggle' }];
10
+ export var useMenuItemCheckbox = function (props) {
11
+ var _a;
12
+ var disabled = props.disabled, name = props.name;
13
+ var context = useMenuListContext();
14
+ var checked = (_a = context.checked) === null || _a === void 0 ? void 0 : _a[name];
15
+ var onCheckedChange = context.onCheckedChange;
16
+ var toggleChecked = React.useCallback(function (e) {
17
+ if (!disabled) {
18
+ onCheckedChange(e, name, !checked);
19
+ }
20
+ }, [checked, disabled, name, onCheckedChange]);
21
+ return useMenuCheckboxInteraction(props, toggleChecked);
22
+ };
23
+ var getAccessibilityState = memoize(getAccessibilityStateWorker);
24
+ function getAccessibilityStateWorker(disabled, checked, accessibilityState) {
25
+ if (accessibilityState) {
26
+ return __assign({ disabled: disabled, checked: checked }, accessibilityState);
27
+ }
28
+ return { disabled: disabled, checked: checked };
29
+ }
30
+ /**
31
+ * Create interactivity and accessibility props to be passed into the inner render.
32
+ * This logic is shared between Checkbox and Radio versions of MenuItem.
33
+ *
34
+ * @param props Props passed into the outer compoennt
35
+ * @param toggleCallback Function to be called when item is toggled
36
+ * @returns Props and additional state needed to render the component
37
+ */
38
+ export var useMenuCheckboxInteraction = function (props, toggleCallback) {
39
+ var defaultComponentRef = React.useRef(null);
40
+ var accessibilityActions = props.accessibilityActions, accessibilityLabel = props.accessibilityLabel, accessibilityState = props.accessibilityState, accessible = props.accessible, _a = props.componentRef, componentRef = _a === void 0 ? defaultComponentRef : _a, disabled = props.disabled, name = props.name, onAccessibilityAction = props.onAccessibilityAction, rest = __rest(props, ["accessibilityActions", "accessibilityLabel", "accessibilityState", "accessible", "componentRef", "disabled", "name", "onAccessibilityAction"]);
41
+ var isSubmenu = useMenuContext().isSubmenu;
42
+ var _b = useMenuListContext(), checked = _b.checked, hasIcons = _b.hasIcons, hasTooltips = _b.hasTooltips, onArrowClose = _b.onArrowClose;
43
+ var isChecked = checked === null || checked === void 0 ? void 0 : checked[name];
44
+ // Ensure focus is placed on checkbox after click
45
+ var toggleCheckedWithFocus = useOnPressWithFocus(componentRef, toggleCallback);
46
+ var pressable = usePressableState(__assign(__assign({}, rest), { onPress: toggleCheckedWithFocus }));
47
+ var buttonRef = useViewCommandFocus(componentRef);
48
+ var onKeysPressed = React.useCallback(function (e) {
49
+ var invokeKey = e.nativeEvent.key === ' ' || e.nativeEvent.key === 'Enter';
50
+ if (!disabled && invokeKey) {
51
+ toggleCallback(e);
52
+ return;
53
+ }
54
+ var isRtl = I18nManager.isRTL;
55
+ var isArrowClose = isSubmenu && ((isRtl && e.nativeEvent.key === 'ArrowRight') || (!isRtl && e.nativeEvent.key === 'ArrowLeft'));
56
+ if (isArrowClose) {
57
+ onArrowClose === null || onArrowClose === void 0 ? void 0 : onArrowClose(e);
58
+ }
59
+ }, [disabled, isSubmenu, onArrowClose, toggleCallback]);
60
+ var keys = disabled ? [] : isSubmenu ? submenuTriggerKeys : triggerKeys;
61
+ var onKeyProps = useKeyDownProps.apply(void 0, __spreadArray([onKeysPressed], keys, false));
62
+ var accessibilityActionsProp = accessibilityActions
63
+ ? __spreadArray(__spreadArray([], defaultAccessibilityActions, true), accessibilityActions, true) : defaultAccessibilityActions;
64
+ var onAccessibilityActionProp = React.useCallback(function (event) {
65
+ if (!disabled) {
66
+ if (event.nativeEvent.actionName === 'Toggle') {
67
+ toggleCallback(event);
68
+ }
69
+ onAccessibilityAction && onAccessibilityAction(event);
70
+ }
71
+ }, [disabled, toggleCallback, onAccessibilityAction]);
72
+ useHoverFocusEffect(pressable.state.hovered, componentRef);
73
+ var state = __assign(__assign({}, pressable.state), { checked: isChecked, disabled: disabled, hasIcons: hasIcons, hasTooltips: hasTooltips });
74
+ return {
75
+ props: __assign(__assign(__assign({}, pressable.props), { accessible: accessible !== null && accessible !== void 0 ? accessible : true, accessibilityActions: accessibilityActionsProp, accessibilityLabel: accessibilityLabel, accessibilityRole: 'menuitem', accessibilityState: getAccessibilityState(disabled, state.checked, accessibilityState), disabled: disabled, enableFocusRing: Platform.select({
76
+ macos: false,
77
+ default: !pressable.state.hovered, // win32
78
+ }), focusable: Platform.select({
79
+ macos: !disabled,
80
+ default: true, // win32
81
+ }), onAccessibilityAction: onAccessibilityActionProp, ref: buttonRef }), onKeyProps),
82
+ state: state,
83
+ };
84
+ };
85
+ //# sourceMappingURL=useMenuItemCheckbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMenuItemCheckbox.js","sourceRoot":"","sources":["../../src/MenuItemCheckbox/useMenuItemCheckbox.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { MenuItemCheckboxProps } from '../MenuItemCheckbox/MenuItemCheckbox.types';
2
+ export declare const menuItemRadioName = "MenuItemRadio";
3
+ export declare const MenuItemRadio: import("@fluentui-react-native/composition").ComposeFactoryComponent<MenuItemCheckboxProps, import("../MenuItemCheckbox/MenuItemCheckbox.types").MenuItemCheckboxSlotProps, import("../MenuItemCheckbox/MenuItemCheckbox.types").MenuItemCheckboxTokens, import("@fluentui-react-native/framework").Theme, object>;
4
+ //# sourceMappingURL=MenuItemRadio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemRadio.d.ts","sourceRoot":"","sources":["../../src/MenuItemRadio/MenuItemRadio.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,qBAAqB,EAAwB,MAAM,4CAA4C,CAAC;AAE9G,eAAO,MAAM,iBAAiB,kBAAkB,CAAC;AAEjD,eAAO,MAAM,aAAa,oTAQxB,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { useMenuItemRadio } from './useMenuItemRadio';
2
+ import { MenuItemCheckbox, menuItemFinalRender } from '../MenuItemCheckbox/MenuItemCheckbox';
3
+ export var menuItemRadioName = 'MenuItemRadio';
4
+ export var MenuItemRadio = MenuItemCheckbox.compose({
5
+ displayName: menuItemRadioName,
6
+ useRender: function (userProps, useSlots) {
7
+ var menuItem = useMenuItemRadio(userProps);
8
+ var Slots = useSlots(userProps, function (layer) { return menuItem.state[layer]; });
9
+ return menuItemFinalRender(menuItem, Slots);
10
+ },
11
+ });
12
+ //# sourceMappingURL=MenuItemRadio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuItemRadio.js","sourceRoot":"","sources":["../../src/MenuItemRadio/MenuItemRadio.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAG7F,MAAM,CAAC,IAAM,iBAAiB,GAAG,eAAe,CAAC;AAEjD,MAAM,CAAC,IAAM,aAAa,GAAG,gBAAgB,CAAC,OAAO,CAAC;IACpD,WAAW,EAAE,iBAAiB;IAC9B,SAAS,EAAE,UAAC,SAAgC,EAAE,QAAwC;QACpF,IAAM,QAAQ,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAC7C,IAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,EAAE,UAAC,KAAK,IAAc,OAAA,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAArB,CAAqB,CAAC,CAAC;QAE7E,OAAO,mBAAmB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC9C,CAAC;CACF,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { MenuItemRadio, menuItemRadioName } from './MenuItemRadio';
2
+ export { useMenuItemRadio } from './useMenuItemRadio';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/MenuItemRadio/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { MenuItemRadio, menuItemRadioName } from './MenuItemRadio';
2
+ export { useMenuItemRadio } from './useMenuItemRadio';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/MenuItemRadio/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { MenuItemCheckboxProps, MenuItemCheckboxInfo } from '../MenuItemCheckbox/MenuItemCheckbox.types';
2
+ export declare const useMenuItemRadio: (props: MenuItemCheckboxProps) => MenuItemCheckboxInfo;
3
+ //# sourceMappingURL=useMenuItemRadio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMenuItemRadio.d.ts","sourceRoot":"","sources":["../../src/MenuItemRadio/useMenuItemRadio.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,4CAA4C,CAAC;AAG9G,eAAO,MAAM,gBAAgB,UAAW,qBAAqB,KAAG,oBA+B/D,CAAC"}
@@ -0,0 +1,30 @@
1
+ import * as React from 'react';
2
+ import { useMenuContext } from '../context/menuContext';
3
+ import { useMenuListContext } from '../context/menuListContext';
4
+ import { useMenuCheckboxInteraction } from '../MenuItemCheckbox/useMenuItemCheckbox';
5
+ export var useMenuItemRadio = function (props) {
6
+ var disabled = props.disabled, name = props.name, persistOnClick = props.persistOnClick;
7
+ var context = useMenuContext();
8
+ var listContext = useMenuListContext();
9
+ var selectRadio = listContext.selectRadio;
10
+ var setOpen = context.setOpen;
11
+ var shouldPersist = context.persistOnItemClick;
12
+ shouldPersist = persistOnClick !== null && persistOnClick !== void 0 ? persistOnClick : shouldPersist;
13
+ var toggleChecked = React.useCallback(function (e) {
14
+ if (!disabled) {
15
+ selectRadio(e, name);
16
+ if (!shouldPersist) {
17
+ setOpen(e, false /*isOpen*/, true /*bubble*/);
18
+ }
19
+ }
20
+ }, [disabled, name, selectRadio, setOpen, shouldPersist]);
21
+ // Explicitly only run on mount and unmount
22
+ React.useEffect(function () {
23
+ listContext.addRadioItem(name);
24
+ return function () {
25
+ listContext.removeRadioItem(name);
26
+ };
27
+ }, []); // eslint-disable-line react-hooks/exhaustive-deps
28
+ return useMenuCheckboxInteraction(props, toggleChecked);
29
+ };
30
+ //# sourceMappingURL=useMenuItemRadio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMenuItemRadio.js","sourceRoot":"","sources":["../../src/MenuItemRadio/useMenuItemRadio.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAEhE,OAAO,EAAE,0BAA0B,EAAE,MAAM,yCAAyC,CAAC;AAErF,MAAM,CAAC,IAAM,gBAAgB,GAAG,UAAC,KAA4B;IACnD,IAAA,QAAQ,GAA2B,KAAK,SAAhC,EAAE,IAAI,GAAqB,KAAK,KAA1B,EAAE,cAAc,GAAK,KAAK,eAAV,CAAW;IACjD,IAAM,OAAO,GAAG,cAAc,EAAE,CAAC;IACjC,IAAM,WAAW,GAAG,kBAAkB,EAAE,CAAC;IACzC,IAAM,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC;IAC5C,IAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAChC,IAAI,aAAa,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAC/C,aAAa,GAAG,cAAc,aAAd,cAAc,cAAd,cAAc,GAAI,aAAa,CAAC;IAEhD,IAAM,aAAa,GAAG,KAAK,CAAC,WAAW,CACrC,UAAC,CAAmB;QAClB,IAAI,CAAC,QAAQ,EAAE;YACb,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YACrB,IAAI,CAAC,aAAa,EAAE;gBAClB,OAAO,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;aAC/C;SACF;IACH,CAAC,EACD,CAAC,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,aAAa,CAAC,CACtD,CAAC;IAEF,2CAA2C;IAC3C,KAAK,CAAC,SAAS,CAAC;QACd,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAE/B,OAAO;YACL,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACpC,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,kDAAkD;IAE1D,OAAO,0BAA0B,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;AAC1D,CAAC,CAAC"}