@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.
- package/CHANGELOG.json +79 -1
- package/CHANGELOG.md +26 -2
- package/SPEC.md +46 -0
- package/lib/Menu/Menu.d.ts +4 -0
- package/lib/Menu/Menu.d.ts.map +1 -0
- package/lib/Menu/Menu.js +35 -0
- package/lib/Menu/Menu.js.map +1 -0
- package/lib/Menu/Menu.types.d.ts +40 -0
- package/lib/Menu/Menu.types.d.ts.map +1 -0
- package/lib/Menu/Menu.types.js +2 -0
- package/lib/Menu/Menu.types.js.map +1 -0
- package/lib/Menu/index.d.ts +6 -0
- package/lib/Menu/index.d.ts.map +1 -0
- package/lib/Menu/index.js +5 -0
- package/lib/Menu/index.js.map +1 -0
- package/lib/Menu/useMenu.d.ts +3 -0
- package/lib/Menu/useMenu.d.ts.map +1 -0
- package/lib/Menu/useMenu.js +76 -0
- package/lib/Menu/useMenu.js.map +1 -0
- package/lib/Menu/useMenuContextValue.d.ts +4 -0
- package/lib/Menu/useMenuContextValue.d.ts.map +1 -0
- package/lib/Menu/useMenuContextValue.js +8 -0
- package/lib/Menu/useMenuContextValue.js.map +1 -0
- package/lib/MenuDivider/MenuDivider.d.ts +2 -0
- package/lib/MenuDivider/MenuDivider.d.ts.map +1 -0
- package/lib/MenuDivider/MenuDivider.js +15 -0
- package/lib/MenuDivider/MenuDivider.js.map +1 -0
- package/lib/MenuDivider/MenuDivider.styling.d.ts +4 -0
- package/lib/MenuDivider/MenuDivider.styling.d.ts.map +1 -0
- package/lib/MenuDivider/MenuDivider.styling.js +19 -0
- package/lib/MenuDivider/MenuDivider.styling.js.map +1 -0
- package/lib/MenuDivider/MenuDivider.types.d.ts +21 -0
- package/lib/MenuDivider/MenuDivider.types.d.ts.map +1 -0
- package/lib/MenuDivider/MenuDivider.types.js +2 -0
- package/lib/MenuDivider/MenuDivider.types.js.map +1 -0
- package/lib/MenuDivider/MenuDividerTokens.d.ts +5 -0
- package/lib/MenuDivider/MenuDividerTokens.d.ts.map +1 -0
- package/lib/MenuDivider/MenuDividerTokens.js +7 -0
- package/lib/MenuDivider/MenuDividerTokens.js.map +1 -0
- package/lib/MenuDivider/MenuDividerTokens.macos.d.ts +5 -0
- package/lib/MenuDivider/MenuDividerTokens.macos.d.ts.map +1 -0
- package/lib/MenuDivider/MenuDividerTokens.macos.js +7 -0
- package/lib/MenuDivider/MenuDividerTokens.macos.js.map +1 -0
- package/lib/MenuDivider/MenuDividerTokens.win32.d.ts +5 -0
- package/lib/MenuDivider/MenuDividerTokens.win32.d.ts.map +1 -0
- package/lib/MenuDivider/MenuDividerTokens.win32.js +7 -0
- package/lib/MenuDivider/MenuDividerTokens.win32.js.map +1 -0
- package/lib/MenuDivider/index.d.ts +4 -0
- package/lib/MenuDivider/index.d.ts.map +1 -0
- package/lib/MenuDivider/index.js +3 -0
- package/lib/MenuDivider/index.js.map +1 -0
- package/lib/MenuItem/MenuItem.d.ts +7 -0
- package/lib/MenuItem/MenuItem.d.ts.map +1 -0
- package/lib/MenuItem/MenuItem.js +58 -0
- package/lib/MenuItem/MenuItem.js.map +1 -0
- package/lib/MenuItem/MenuItem.styling.d.ts +5 -0
- package/lib/MenuItem/MenuItem.styling.d.ts.map +1 -0
- package/lib/MenuItem/MenuItem.styling.js +50 -0
- package/lib/MenuItem/MenuItem.styling.js.map +1 -0
- package/lib/MenuItem/MenuItem.types.d.ts +98 -0
- package/lib/MenuItem/MenuItem.types.d.ts.map +1 -0
- package/lib/MenuItem/MenuItem.types.js +2 -0
- package/lib/MenuItem/MenuItem.types.js.map +1 -0
- package/lib/MenuItem/MenuItemTokens.d.ts +5 -0
- package/lib/MenuItem/MenuItemTokens.d.ts.map +1 -0
- package/lib/MenuItem/MenuItemTokens.js +39 -0
- package/lib/MenuItem/MenuItemTokens.js.map +1 -0
- package/lib/MenuItem/MenuItemTokens.macos.d.ts +5 -0
- package/lib/MenuItem/MenuItemTokens.macos.d.ts.map +1 -0
- package/lib/MenuItem/MenuItemTokens.macos.js +34 -0
- package/lib/MenuItem/MenuItemTokens.macos.js.map +1 -0
- package/lib/MenuItem/MenuItemTokens.win32.d.ts +5 -0
- package/lib/MenuItem/MenuItemTokens.win32.d.ts.map +1 -0
- package/lib/MenuItem/MenuItemTokens.win32.js +40 -0
- package/lib/MenuItem/MenuItemTokens.win32.js.map +1 -0
- package/lib/MenuItem/index.d.ts +5 -0
- package/lib/MenuItem/index.d.ts.map +1 -0
- package/lib/MenuItem/index.js +4 -0
- package/lib/MenuItem/index.js.map +1 -0
- package/lib/MenuItem/useMenuItem.d.ts +7 -0
- package/lib/MenuItem/useMenuItem.d.ts.map +1 -0
- package/lib/MenuItem/useMenuItem.js +74 -0
- package/lib/MenuItem/useMenuItem.js.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.d.ts +7 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.js +37 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.js.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.d.ts +5 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.js +40 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.js.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.types.d.ts +66 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.types.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.types.js +2 -0
- package/lib/MenuItemCheckbox/MenuItemCheckbox.types.js.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.d.ts +5 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.js +51 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.js.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.d.ts +5 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js +49 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.d.ts +5 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js +52 -0
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js.map +1 -0
- package/lib/MenuItemCheckbox/index.d.ts +5 -0
- package/lib/MenuItemCheckbox/index.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/index.js +4 -0
- package/lib/MenuItemCheckbox/index.js.map +1 -0
- package/lib/MenuItemCheckbox/useMenuItemCheckbox.d.ts +13 -0
- package/lib/MenuItemCheckbox/useMenuItemCheckbox.d.ts.map +1 -0
- package/lib/MenuItemCheckbox/useMenuItemCheckbox.js +85 -0
- package/lib/MenuItemCheckbox/useMenuItemCheckbox.js.map +1 -0
- package/lib/MenuItemRadio/MenuItemRadio.d.ts +4 -0
- package/lib/MenuItemRadio/MenuItemRadio.d.ts.map +1 -0
- package/lib/MenuItemRadio/MenuItemRadio.js +12 -0
- package/lib/MenuItemRadio/MenuItemRadio.js.map +1 -0
- package/lib/MenuItemRadio/index.d.ts +3 -0
- package/lib/MenuItemRadio/index.d.ts.map +1 -0
- package/lib/MenuItemRadio/index.js +3 -0
- package/lib/MenuItemRadio/index.js.map +1 -0
- package/lib/MenuItemRadio/useMenuItemRadio.d.ts +3 -0
- package/lib/MenuItemRadio/useMenuItemRadio.d.ts.map +1 -0
- package/lib/MenuItemRadio/useMenuItemRadio.js +30 -0
- package/lib/MenuItemRadio/useMenuItemRadio.js.map +1 -0
- package/lib/MenuList/MenuList.d.ts +4 -0
- package/lib/MenuList/MenuList.d.ts.map +1 -0
- package/lib/MenuList/MenuList.js +68 -0
- package/lib/MenuList/MenuList.js.map +1 -0
- package/lib/MenuList/MenuList.styling.d.ts +5 -0
- package/lib/MenuList/MenuList.styling.d.ts.map +1 -0
- package/lib/MenuList/MenuList.styling.js +17 -0
- package/lib/MenuList/MenuList.styling.js.map +1 -0
- package/lib/MenuList/MenuList.types.d.ts +77 -0
- package/lib/MenuList/MenuList.types.d.ts.map +1 -0
- package/lib/MenuList/MenuList.types.js +2 -0
- package/lib/MenuList/MenuList.types.js.map +1 -0
- package/lib/MenuList/MenuListTokens.d.ts +5 -0
- package/lib/MenuList/MenuListTokens.d.ts.map +1 -0
- package/lib/MenuList/MenuListTokens.js +9 -0
- package/lib/MenuList/MenuListTokens.js.map +1 -0
- package/lib/MenuList/MenuListTokens.macos.d.ts +5 -0
- package/lib/MenuList/MenuListTokens.macos.d.ts.map +1 -0
- package/lib/MenuList/MenuListTokens.macos.js +7 -0
- package/lib/MenuList/MenuListTokens.macos.js.map +1 -0
- package/lib/MenuList/MenuListTokens.win32.d.ts +5 -0
- package/lib/MenuList/MenuListTokens.win32.d.ts.map +1 -0
- package/lib/MenuList/MenuListTokens.win32.js +12 -0
- package/lib/MenuList/MenuListTokens.win32.js.map +1 -0
- package/lib/MenuList/index.d.ts +6 -0
- package/lib/MenuList/index.d.ts.map +1 -0
- package/lib/MenuList/index.js +5 -0
- package/lib/MenuList/index.js.map +1 -0
- package/lib/MenuList/useMenuList.d.ts +3 -0
- package/lib/MenuList/useMenuList.d.ts.map +1 -0
- package/lib/MenuList/useMenuList.js +109 -0
- package/lib/MenuList/useMenuList.js.map +1 -0
- package/lib/MenuList/useMenuListContextValue.d.ts +4 -0
- package/lib/MenuList/useMenuListContextValue.d.ts.map +1 -0
- package/lib/MenuList/useMenuListContextValue.js +5 -0
- package/lib/MenuList/useMenuListContextValue.js.map +1 -0
- package/lib/MenuPopover/MenuPopover.d.ts +4 -0
- package/lib/MenuPopover/MenuPopover.d.ts.map +1 -0
- package/lib/MenuPopover/MenuPopover.js +44 -0
- package/lib/MenuPopover/MenuPopover.js.map +1 -0
- package/lib/MenuPopover/MenuPopover.types.d.ts +10 -0
- package/lib/MenuPopover/MenuPopover.types.d.ts.map +1 -0
- package/lib/MenuPopover/MenuPopover.types.js +2 -0
- package/lib/MenuPopover/MenuPopover.types.js.map +1 -0
- package/lib/MenuPopover/MenuPopoverTokens.d.ts +3 -0
- package/lib/MenuPopover/MenuPopoverTokens.d.ts.map +1 -0
- package/lib/MenuPopover/MenuPopoverTokens.js +4 -0
- package/lib/MenuPopover/MenuPopoverTokens.js.map +1 -0
- package/lib/MenuPopover/index.d.ts +5 -0
- package/lib/MenuPopover/index.d.ts.map +1 -0
- package/lib/MenuPopover/index.js +4 -0
- package/lib/MenuPopover/index.js.map +1 -0
- package/lib/MenuPopover/useMenuPopover.d.ts +3 -0
- package/lib/MenuPopover/useMenuPopover.d.ts.map +1 -0
- package/lib/MenuPopover/useMenuPopover.js +92 -0
- package/lib/MenuPopover/useMenuPopover.js.map +1 -0
- package/lib/MenuTrigger/MenuTrigger.d.ts +5 -0
- package/lib/MenuTrigger/MenuTrigger.d.ts.map +1 -0
- package/lib/MenuTrigger/MenuTrigger.js +20 -0
- package/lib/MenuTrigger/MenuTrigger.js.map +1 -0
- package/lib/MenuTrigger/MenuTrigger.types.d.ts +28 -0
- package/lib/MenuTrigger/MenuTrigger.types.d.ts.map +1 -0
- package/lib/MenuTrigger/MenuTrigger.types.js +2 -0
- package/lib/MenuTrigger/MenuTrigger.types.js.map +1 -0
- package/lib/MenuTrigger/index.d.ts +5 -0
- package/lib/MenuTrigger/index.d.ts.map +1 -0
- package/lib/MenuTrigger/index.js +4 -0
- package/lib/MenuTrigger/index.js.map +1 -0
- package/lib/MenuTrigger/useMenuTrigger.d.ts +3 -0
- package/lib/MenuTrigger/useMenuTrigger.d.ts.map +1 -0
- package/lib/MenuTrigger/useMenuTrigger.js +79 -0
- package/lib/MenuTrigger/useMenuTrigger.js.map +1 -0
- package/lib/MenuTrigger/useMergeRefs.d.ts +20 -0
- package/lib/MenuTrigger/useMergeRefs.d.ts.map +1 -0
- package/lib/MenuTrigger/useMergeRefs.js +36 -0
- package/lib/MenuTrigger/useMergeRefs.js.map +1 -0
- package/lib/__tests__/Menu.test.d.ts +2 -0
- package/lib/__tests__/Menu.test.d.ts.map +1 -0
- package/lib/__tests__/Menu.test.js +145 -0
- package/lib/__tests__/Menu.test.js.map +1 -0
- package/lib/consts.d.ts +2 -0
- package/lib/consts.d.ts.map +1 -0
- package/lib/consts.js +6 -0
- package/lib/consts.js.map +1 -0
- package/lib/context/index.d.ts +4 -0
- package/lib/context/index.d.ts.map +1 -0
- package/lib/context/index.js +4 -0
- package/lib/context/index.js.map +1 -0
- package/lib/context/menuContext.d.ts +16 -0
- package/lib/context/menuContext.d.ts.map +1 -0
- package/lib/context/menuContext.js +20 -0
- package/lib/context/menuContext.js.map +1 -0
- package/lib/context/menuListContext.d.ts +14 -0
- package/lib/context/menuListContext.d.ts.map +1 -0
- package/lib/context/menuListContext.js +15 -0
- package/lib/context/menuListContext.js.map +1 -0
- package/lib/context/menuTriggerContext.d.ts +9 -0
- package/lib/context/menuTriggerContext.d.ts.map +1 -0
- package/lib/context/menuTriggerContext.js +9 -0
- package/lib/context/menuTriggerContext.js.map +1 -0
- package/lib/index.d.ts +10 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +10 -0
- package/lib/index.js.map +1 -0
- package/lib-commonjs/MenuItem/MenuItem.types.d.ts +12 -0
- package/lib-commonjs/MenuItem/MenuItem.types.d.ts.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.types.d.ts +6 -0
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.types.d.ts.map +1 -1
- package/lib-commonjs/MenuList/MenuList.types.d.ts +3 -0
- package/lib-commonjs/MenuList/MenuList.types.d.ts.map +1 -1
- package/package.json +9 -9
- package/src/MenuItem/MenuItem.types.ts +14 -0
- package/src/MenuItemCheckbox/MenuItemCheckbox.types.ts +8 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|