@fluentui-react-native/menu 1.14.22 → 1.14.24
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 +65 -0
- package/CHANGELOG.md +17 -1
- package/eslint.config.js +3 -0
- package/lib/Menu/Menu.js +5 -5
- package/lib/Menu/Menu.js.map +1 -1
- package/lib/Menu/Menu.types.js +1 -1
- package/lib/Menu/Menu.types.js.map +1 -1
- package/lib/Menu/renderMenu.android.js +5 -5
- package/lib/Menu/renderMenu.android.js.map +1 -1
- package/lib/Menu/renderMenu.js +3 -3
- package/lib/Menu/renderMenu.js.map +1 -1
- package/lib/Menu/useMenu.android.js +86 -61
- package/lib/Menu/useMenu.android.js.map +1 -1
- package/lib/Menu/useMenu.js +39 -29
- package/lib/Menu/useMenu.js.map +1 -1
- package/lib/Menu/useMenuContextValue.js +4 -5
- package/lib/Menu/useMenuContextValue.js.map +1 -1
- package/lib/MenuCallout/MenuCallout.android.js +7 -8
- package/lib/MenuCallout/MenuCallout.android.js.map +1 -1
- package/lib/MenuCallout/MenuCallout.js +4 -5
- package/lib/MenuCallout/MenuCallout.js.map +1 -1
- package/lib/MenuCallout/MenuCallout.types.js +1 -1
- package/lib/MenuCallout/MenuCallout.types.js.map +1 -1
- package/lib/MenuDivider/MenuDivider.js +11 -7
- package/lib/MenuDivider/MenuDivider.js.map +1 -1
- package/lib/MenuDivider/MenuDivider.styling.js +12 -5
- package/lib/MenuDivider/MenuDivider.styling.js.map +1 -1
- package/lib/MenuDivider/MenuDivider.types.js +2 -2
- package/lib/MenuDivider/MenuDivider.types.js.map +1 -1
- package/lib/MenuDivider/MenuDividerTokens.android.js +2 -2
- package/lib/MenuDivider/MenuDividerTokens.android.js.map +1 -1
- package/lib/MenuDivider/MenuDividerTokens.js +2 -2
- package/lib/MenuDivider/MenuDividerTokens.js.map +1 -1
- package/lib/MenuDivider/MenuDividerTokens.macos.js +2 -2
- package/lib/MenuDivider/MenuDividerTokens.macos.js.map +1 -1
- package/lib/MenuDivider/MenuDividerTokens.win32.js +2 -2
- package/lib/MenuDivider/MenuDividerTokens.win32.js.map +1 -1
- package/lib/MenuGroup/MenuGroup.js +25 -30
- package/lib/MenuGroup/MenuGroup.js.map +1 -1
- package/lib/MenuGroup/MenuGroup.types.js +1 -1
- package/lib/MenuGroup/MenuGroup.types.js.map +1 -1
- package/lib/MenuGroupHeader/MenuGroupHeader.js +12 -8
- package/lib/MenuGroupHeader/MenuGroupHeader.js.map +1 -1
- package/lib/MenuGroupHeader/MenuGroupHeader.styling.js +6 -4
- package/lib/MenuGroupHeader/MenuGroupHeader.styling.js.map +1 -1
- package/lib/MenuGroupHeader/MenuGroupHeader.types.js +1 -1
- package/lib/MenuGroupHeader/MenuGroupHeader.types.js.map +1 -1
- package/lib/MenuGroupHeader/MenuGroupHeaderTokens.js +2 -2
- package/lib/MenuGroupHeader/MenuGroupHeaderTokens.js.map +1 -1
- package/lib/MenuGroupHeader/MenuGroupHeaderTokens.macos.js +2 -2
- package/lib/MenuGroupHeader/MenuGroupHeaderTokens.macos.js.map +1 -1
- package/lib/MenuItem/MenuItem.js +31 -21
- package/lib/MenuItem/MenuItem.js.map +1 -1
- package/lib/MenuItem/MenuItem.styling.js +27 -18
- package/lib/MenuItem/MenuItem.styling.js.map +1 -1
- package/lib/MenuItem/MenuItem.types.js +1 -1
- package/lib/MenuItem/MenuItem.types.js.map +1 -1
- package/lib/MenuItem/MenuItemTokens.android.js +2 -2
- package/lib/MenuItem/MenuItemTokens.android.js.map +1 -1
- package/lib/MenuItem/MenuItemTokens.js +2 -2
- package/lib/MenuItem/MenuItemTokens.js.map +1 -1
- package/lib/MenuItem/MenuItemTokens.macos.js +2 -2
- package/lib/MenuItem/MenuItemTokens.macos.js.map +1 -1
- package/lib/MenuItem/MenuItemTokens.win32.js +2 -2
- package/lib/MenuItem/MenuItemTokens.win32.js.map +1 -1
- package/lib/MenuItem/useMenuItem.js +57 -41
- package/lib/MenuItem/useMenuItem.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckbox.js +34 -16
- package/lib/MenuItemCheckbox/MenuItemCheckbox.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.js +54 -27
- package/lib/MenuItemCheckbox/MenuItemCheckbox.styling.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckbox.types.js +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckbox.types.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.android.js +2 -2
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.android.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.js +2 -2
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js +2 -2
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js.map +1 -1
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js +2 -2
- package/lib/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js.map +1 -1
- package/lib/MenuItemCheckbox/useMenuItemCheckbox.js +60 -40
- package/lib/MenuItemCheckbox/useMenuItemCheckbox.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadio.js +23 -16
- package/lib/MenuItemRadio/MenuItemRadio.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadio.styling.android.js +29 -18
- package/lib/MenuItemRadio/MenuItemRadio.styling.android.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadio.styling.js +33 -18
- package/lib/MenuItemRadio/MenuItemRadio.styling.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadio.types.js +1 -1
- package/lib/MenuItemRadio/MenuItemRadio.types.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadioTokens.android.js +2 -2
- package/lib/MenuItemRadio/MenuItemRadioTokens.android.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadioTokens.js +2 -2
- package/lib/MenuItemRadio/MenuItemRadioTokens.js.map +1 -1
- package/lib/MenuItemRadio/MenuItemRadioTokens.macos.js +2 -2
- package/lib/MenuItemRadio/MenuItemRadioTokens.macos.js.map +1 -1
- package/lib/MenuItemRadio/useMenuItemRadio.js +11 -11
- package/lib/MenuItemRadio/useMenuItemRadio.js.map +1 -1
- package/lib/MenuList/MenuList.js +46 -39
- package/lib/MenuList/MenuList.js.map +1 -1
- package/lib/MenuList/MenuList.styling.js +10 -6
- package/lib/MenuList/MenuList.styling.js.map +1 -1
- package/lib/MenuList/MenuList.types.js +1 -1
- package/lib/MenuList/MenuList.types.js.map +1 -1
- package/lib/MenuList/MenuListTokens.android.js +2 -2
- package/lib/MenuList/MenuListTokens.android.js.map +1 -1
- package/lib/MenuList/MenuListTokens.js +2 -2
- package/lib/MenuList/MenuListTokens.js.map +1 -1
- package/lib/MenuList/MenuListTokens.macos.js +2 -2
- package/lib/MenuList/MenuListTokens.macos.js.map +1 -1
- package/lib/MenuList/MenuListTokens.win32.js +2 -2
- package/lib/MenuList/MenuListTokens.win32.js.map +1 -1
- package/lib/MenuList/useMenuList.js +63 -69
- package/lib/MenuList/useMenuList.js.map +1 -1
- package/lib/MenuList/useMenuListContextValue.js +2 -3
- package/lib/MenuList/useMenuListContextValue.js.map +1 -1
- package/lib/MenuPopover/MenuPopover.d.ts +1 -1
- package/lib/MenuPopover/MenuPopover.js +29 -27
- package/lib/MenuPopover/MenuPopover.js.map +1 -1
- package/lib/MenuPopover/MenuPopover.types.js +1 -1
- package/lib/MenuPopover/MenuPopover.types.js.map +1 -1
- package/lib/MenuPopover/MenuPopoverTokens.android.js +2 -2
- package/lib/MenuPopover/MenuPopoverTokens.android.js.map +1 -1
- package/lib/MenuPopover/MenuPopoverTokens.d.ts +1 -1
- package/lib/MenuPopover/MenuPopoverTokens.js +1 -1
- package/lib/MenuPopover/MenuPopoverTokens.js.map +1 -1
- package/lib/MenuPopover/MenuPopoverTokens.macos.d.ts +1 -1
- package/lib/MenuPopover/MenuPopoverTokens.macos.js +2 -2
- package/lib/MenuPopover/MenuPopoverTokens.macos.js.map +1 -1
- package/lib/MenuPopover/useMenuPopover.js +33 -35
- package/lib/MenuPopover/useMenuPopover.js.map +1 -1
- package/lib/MenuTrigger/MenuTrigger.js +6 -4
- package/lib/MenuTrigger/MenuTrigger.js.map +1 -1
- package/lib/MenuTrigger/MenuTrigger.types.js +1 -1
- package/lib/MenuTrigger/MenuTrigger.types.js.map +1 -1
- package/lib/MenuTrigger/useMenuTrigger.js +29 -30
- package/lib/MenuTrigger/useMenuTrigger.js.map +1 -1
- package/lib/MenuTrigger/useMergeRefs.js +6 -10
- package/lib/MenuTrigger/useMergeRefs.js.map +1 -1
- package/lib/__tests__/Menu.test.js +21 -21
- package/lib/__tests__/Menu.test.js.map +1 -1
- package/lib/consts.js +1 -1
- package/lib/consts.js.map +1 -1
- package/lib/context/menuContext.js +5 -5
- package/lib/context/menuContext.js.map +1 -1
- package/lib/context/menuListContext.js +9 -9
- package/lib/context/menuListContext.js.map +1 -1
- package/lib/context/menuTriggerContext.js +3 -3
- package/lib/context/menuTriggerContext.js.map +1 -1
- package/lib-commonjs/Menu/Menu.js +12 -12
- package/lib-commonjs/Menu/Menu.js.map +1 -1
- package/lib-commonjs/Menu/renderMenu.android.js +9 -9
- package/lib-commonjs/Menu/renderMenu.android.js.map +1 -1
- package/lib-commonjs/Menu/renderMenu.js +6 -6
- package/lib-commonjs/Menu/renderMenu.js.map +1 -1
- package/lib-commonjs/Menu/useMenu.android.js +91 -65
- package/lib-commonjs/Menu/useMenu.android.js.map +1 -1
- package/lib-commonjs/Menu/useMenu.js +44 -33
- package/lib-commonjs/Menu/useMenu.js.map +1 -1
- package/lib-commonjs/Menu/useMenuContextValue.js +6 -6
- package/lib-commonjs/Menu/useMenuContextValue.js.map +1 -1
- package/lib-commonjs/MenuCallout/MenuCallout.android.js +14 -14
- package/lib-commonjs/MenuCallout/MenuCallout.android.js.map +1 -1
- package/lib-commonjs/MenuCallout/MenuCallout.js +10 -10
- package/lib-commonjs/MenuCallout/MenuCallout.js.map +1 -1
- package/lib-commonjs/MenuDivider/MenuDivider.js +15 -11
- package/lib-commonjs/MenuDivider/MenuDivider.js.map +1 -1
- package/lib-commonjs/MenuDivider/MenuDivider.styling.js +15 -8
- package/lib-commonjs/MenuDivider/MenuDivider.styling.js.map +1 -1
- package/lib-commonjs/MenuDivider/MenuDividerTokens.android.js +3 -3
- package/lib-commonjs/MenuDivider/MenuDividerTokens.android.js.map +1 -1
- package/lib-commonjs/MenuDivider/MenuDividerTokens.js +3 -3
- package/lib-commonjs/MenuDivider/MenuDividerTokens.js.map +1 -1
- package/lib-commonjs/MenuDivider/MenuDividerTokens.macos.js +3 -3
- package/lib-commonjs/MenuDivider/MenuDividerTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuDivider/MenuDividerTokens.win32.js +3 -3
- package/lib-commonjs/MenuDivider/MenuDividerTokens.win32.js.map +1 -1
- package/lib-commonjs/MenuGroup/MenuGroup.js +30 -34
- package/lib-commonjs/MenuGroup/MenuGroup.js.map +1 -1
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeader.js +16 -12
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeader.js.map +1 -1
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeader.styling.js +9 -7
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeader.styling.js.map +1 -1
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeaderTokens.js +3 -3
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeaderTokens.js.map +1 -1
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeaderTokens.macos.js +3 -3
- package/lib-commonjs/MenuGroupHeader/MenuGroupHeaderTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuItem/MenuItem.js +37 -27
- package/lib-commonjs/MenuItem/MenuItem.js.map +1 -1
- package/lib-commonjs/MenuItem/MenuItem.styling.js +30 -21
- package/lib-commonjs/MenuItem/MenuItem.styling.js.map +1 -1
- package/lib-commonjs/MenuItem/MenuItemTokens.android.js +3 -3
- package/lib-commonjs/MenuItem/MenuItemTokens.android.js.map +1 -1
- package/lib-commonjs/MenuItem/MenuItemTokens.js +3 -3
- package/lib-commonjs/MenuItem/MenuItemTokens.js.map +1 -1
- package/lib-commonjs/MenuItem/MenuItemTokens.macos.js +3 -3
- package/lib-commonjs/MenuItem/MenuItemTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuItem/MenuItemTokens.win32.js +3 -3
- package/lib-commonjs/MenuItem/MenuItemTokens.win32.js.map +1 -1
- package/lib-commonjs/MenuItem/useMenuItem.js +65 -48
- package/lib-commonjs/MenuItem/useMenuItem.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.js +43 -25
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.styling.js +57 -30
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckbox.styling.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.android.js +3 -3
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.android.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.js +3 -3
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js +3 -3
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js +3 -3
- package/lib-commonjs/MenuItemCheckbox/MenuItemCheckboxTokens.win32.js.map +1 -1
- package/lib-commonjs/MenuItemCheckbox/useMenuItemCheckbox.js +69 -48
- package/lib-commonjs/MenuItemCheckbox/useMenuItemCheckbox.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/MenuItemRadio.js +32 -25
- package/lib-commonjs/MenuItemRadio/MenuItemRadio.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/MenuItemRadio.styling.android.js +32 -21
- package/lib-commonjs/MenuItemRadio/MenuItemRadio.styling.android.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/MenuItemRadio.styling.js +36 -21
- package/lib-commonjs/MenuItemRadio/MenuItemRadio.styling.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/MenuItemRadioTokens.android.js +3 -3
- package/lib-commonjs/MenuItemRadio/MenuItemRadioTokens.android.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/MenuItemRadioTokens.js +3 -3
- package/lib-commonjs/MenuItemRadio/MenuItemRadioTokens.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/MenuItemRadioTokens.macos.js +3 -3
- package/lib-commonjs/MenuItemRadio/MenuItemRadioTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuItemRadio/useMenuItemRadio.js +16 -16
- package/lib-commonjs/MenuItemRadio/useMenuItemRadio.js.map +1 -1
- package/lib-commonjs/MenuList/MenuList.js +56 -48
- package/lib-commonjs/MenuList/MenuList.js.map +1 -1
- package/lib-commonjs/MenuList/MenuList.styling.js +13 -9
- package/lib-commonjs/MenuList/MenuList.styling.js.map +1 -1
- package/lib-commonjs/MenuList/MenuListTokens.android.js +3 -3
- package/lib-commonjs/MenuList/MenuListTokens.android.js.map +1 -1
- package/lib-commonjs/MenuList/MenuListTokens.js +3 -3
- package/lib-commonjs/MenuList/MenuListTokens.js.map +1 -1
- package/lib-commonjs/MenuList/MenuListTokens.macos.js +3 -3
- package/lib-commonjs/MenuList/MenuListTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuList/MenuListTokens.win32.js +3 -3
- package/lib-commonjs/MenuList/MenuListTokens.win32.js.map +1 -1
- package/lib-commonjs/MenuList/useMenuList.js +68 -73
- package/lib-commonjs/MenuList/useMenuList.js.map +1 -1
- package/lib-commonjs/MenuList/useMenuListContextValue.js +2 -3
- package/lib-commonjs/MenuList/useMenuListContextValue.js.map +1 -1
- package/lib-commonjs/MenuPopover/MenuPopover.d.ts +1 -1
- package/lib-commonjs/MenuPopover/MenuPopover.js +38 -35
- package/lib-commonjs/MenuPopover/MenuPopover.js.map +1 -1
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.android.js +6 -6
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.android.js.map +1 -1
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.d.ts +1 -1
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.js +3 -3
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.js.map +1 -1
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.macos.d.ts +1 -1
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.macos.js +5 -5
- package/lib-commonjs/MenuPopover/MenuPopoverTokens.macos.js.map +1 -1
- package/lib-commonjs/MenuPopover/useMenuPopover.js +37 -39
- package/lib-commonjs/MenuPopover/useMenuPopover.js.map +1 -1
- package/lib-commonjs/MenuTrigger/MenuTrigger.js +11 -8
- package/lib-commonjs/MenuTrigger/MenuTrigger.js.map +1 -1
- package/lib-commonjs/MenuTrigger/useMenuTrigger.js +35 -35
- package/lib-commonjs/MenuTrigger/useMenuTrigger.js.map +1 -1
- package/lib-commonjs/MenuTrigger/useMergeRefs.js +8 -11
- package/lib-commonjs/MenuTrigger/useMergeRefs.js.map +1 -1
- package/lib-commonjs/__tests__/Menu.test.js +35 -35
- package/lib-commonjs/__tests__/Menu.test.js.map +1 -1
- package/lib-commonjs/consts.js +1 -1
- package/lib-commonjs/consts.js.map +1 -1
- package/lib-commonjs/context/menuContext.js +5 -5
- package/lib-commonjs/context/menuContext.js.map +1 -1
- package/lib-commonjs/context/menuListContext.js +9 -9
- package/lib-commonjs/context/menuListContext.js.map +1 -1
- package/lib-commonjs/context/menuTriggerContext.js +3 -3
- package/lib-commonjs/context/menuTriggerContext.js.map +1 -1
- package/package.json +45 -26
- package/.eslintrc.js +0 -3
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { __assign } from "tslib";
|
|
2
1
|
import React from 'react';
|
|
3
|
-
export
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
return
|
|
2
|
+
export const useMenuContextValue = (state) => {
|
|
3
|
+
const [triggerHoverOutTimer, setTriggerHoverOutTimer] = React.useState();
|
|
4
|
+
const [popoverHoverOutTimer, setPopoverHoverOutTimer] = React.useState();
|
|
5
|
+
return { ...state, popoverHoverOutTimer, triggerHoverOutTimer, setPopoverHoverOutTimer, setTriggerHoverOutTimer };
|
|
7
6
|
};
|
|
8
7
|
//# sourceMappingURL=useMenuContextValue.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useMenuContextValue.js","sourceRoot":"","sources":["../../src/Menu/useMenuContextValue.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useMenuContextValue.js","sourceRoot":"","sources":["../../src/Menu/useMenuContextValue.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAK1B,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,KAAgB,EAAoB,EAAE;IACxE,MAAM,CAAC,oBAAoB,EAAE,uBAAuB,CAAC,GAAG,KAAK,CAAC,QAAQ,EAA8B,CAAC;IACrG,MAAM,CAAC,oBAAoB,EAAE,uBAAuB,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAkB,CAAC;IACzF,OAAO,EAAE,GAAG,KAAK,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,CAAC;AACpH,CAAC,CAAC"}
|
|
@@ -1,17 +1,16 @@
|
|
|
1
|
-
import { __assign } from "tslib";
|
|
2
1
|
import React from 'react';
|
|
3
2
|
import { Animated, Modal, TouchableWithoutFeedback, View, StyleSheet, ScrollView } from 'react-native';
|
|
4
3
|
import { stagedComponent } from '@fluentui-react-native/framework';
|
|
5
4
|
import { mergeProps } from '@fluentui-react-native/framework';
|
|
6
5
|
import { menuCalloutName } from './MenuCallout.types';
|
|
7
6
|
import { useMenuContext } from '../context';
|
|
8
|
-
|
|
9
|
-
export
|
|
10
|
-
|
|
11
|
-
return
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
return (React.createElement(Modal,
|
|
7
|
+
const AnimatedScrollView = Animated.createAnimatedComponent(ScrollView);
|
|
8
|
+
export const MenuCallout = stagedComponent((props) => {
|
|
9
|
+
const context = useMenuContext();
|
|
10
|
+
return (_rest, children) => {
|
|
11
|
+
const mergedProps = mergeProps(props, _rest);
|
|
12
|
+
const tokens = props.tokens;
|
|
13
|
+
return (React.createElement(Modal, { ...mergedProps, visible: context.open, onRequestClose: context.onRequestClose, supportedOrientations: ['portrait', 'portrait-upside-down', 'landscape', 'landscape-left', 'landscape-right'], transparent: true },
|
|
15
14
|
React.createElement(TouchableWithoutFeedback, { onPress: context.onRequestClose, accessible: false },
|
|
16
15
|
React.createElement(View, { style: [StyleSheet.absoluteFill] },
|
|
17
16
|
React.createElement(Animated.View, { onLayout: context.onMenuLayout, style: [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuCallout.android.js","sourceRoot":"","sources":["../../src/MenuCallout/MenuCallout.android.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuCallout.android.js","sourceRoot":"","sources":["../../src/MenuCallout/MenuCallout.android.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,wBAAwB,EAAE,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAEvG,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAG9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE5C,MAAM,kBAAkB,GAAG,QAAQ,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;AAExE,MAAM,CAAC,MAAM,WAAW,GAAG,eAAe,CAAC,CAAC,KAAuB,EAAE,EAAE;IACrE,MAAM,OAAO,GAAG,cAAc,EAAE,CAAC;IAEjC,OAAO,CAAC,KAAuB,EAAE,QAAyB,EAAE,EAAE;QAC5D,MAAM,WAAW,GAAG,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC7C,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAE5B,OAAO,CACL,oBAAC,KAAK,OACA,WAAW,EACf,OAAO,EAAE,OAAO,CAAC,IAAI,EACrB,cAAc,EAAE,OAAO,CAAC,cAAc,EACtC,qBAAqB,EAAE,CAAC,UAAU,EAAE,sBAAsB,EAAE,WAAW,EAAE,gBAAgB,EAAE,iBAAiB,CAAC,EAC7G,WAAW;YAEX,oBAAC,wBAAwB,IAAC,OAAO,EAAE,OAAO,CAAC,cAAc,EAAE,UAAU,EAAE,KAAK;gBAC1E,oBAAC,IAAI,IAAC,KAAK,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC;oBACpC,oBAAC,QAAQ,CAAC,IAAI,IACZ,QAAQ,EAAE,OAAO,CAAC,YAAY,EAC9B,KAAK,EAAE;4BACL,OAAO,CAAC,wBAAwB;4BAChC;gCACE,SAAS,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS;gCAC3E,QAAQ,EAAE,MAAM,CAAC,QAAQ;gCACzB,QAAQ,EAAE,UAAU;gCACpB,YAAY,EAAE,MAAM,CAAC,YAAY;gCACjC,SAAS,EAAE,MAAM,CAAC,SAAS;gCAC3B,QAAQ,EAAE,QAAQ;6BACnB;yBACF,IAEA,OAAO,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,SAAS;wBAC3D,OAAO,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAChE,oBAAC,kBAAkB,IAAC,KAAK,EAAE,CAAC,OAAO,CAAC,gBAAgB,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAG,QAAQ,CAAsB,CAC3G,CAAC,CAAC,CAAC,CACF,oBAAC,QAAQ,CAAC,IAAI,IAAC,KAAK,EAAE,CAAC,OAAO,CAAC,gBAAgB,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAG,QAAQ,CAAiB,CACjG,CACa,CACX,CACkB,CACrB,CACT,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,WAAW,CAAC,WAAW,GAAG,eAAe,CAAC;AAE1C,eAAe,WAAW,CAAC"}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import { __assign } from "tslib";
|
|
2
1
|
import React from 'react';
|
|
3
2
|
import { Callout } from '@fluentui-react-native/callout';
|
|
4
3
|
import { stagedComponent } from '@fluentui-react-native/framework';
|
|
5
4
|
import { mergeProps } from '@fluentui-react-native/framework';
|
|
6
5
|
import { menuCalloutName } from './MenuCallout.types';
|
|
7
|
-
export
|
|
8
|
-
return
|
|
9
|
-
|
|
10
|
-
return React.createElement(Callout,
|
|
6
|
+
export const MenuCallout = stagedComponent((props) => {
|
|
7
|
+
return (_rest, children) => {
|
|
8
|
+
const mergedProps = mergeProps(props, _rest);
|
|
9
|
+
return React.createElement(Callout, { ...mergedProps }, children);
|
|
11
10
|
};
|
|
12
11
|
});
|
|
13
12
|
MenuCallout.displayName = menuCalloutName;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuCallout.js","sourceRoot":"","sources":["../../src/MenuCallout/MenuCallout.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuCallout.js","sourceRoot":"","sources":["../../src/MenuCallout/MenuCallout.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAG9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,MAAM,CAAC,MAAM,WAAW,GAAG,eAAe,CAAC,CAAC,KAAuB,EAAE,EAAE;IACrE,OAAO,CAAC,KAAuB,EAAE,QAAyB,EAAE,EAAE;QAC5D,MAAM,WAAW,GAAG,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE7C,OAAO,oBAAC,OAAO,OAAK,WAAW,IAAG,QAAQ,CAAW,CAAC;IACxD,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,WAAW,CAAC,WAAW,GAAG,eAAe,CAAC;AAE1C,eAAe,WAAW,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export const menuCalloutName = 'MenuCallout';
|
|
2
2
|
//# sourceMappingURL=MenuCallout.types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuCallout.types.js","sourceRoot":"","sources":["../../src/MenuCallout/MenuCallout.types.ts"],"names":[],"mappings":"AAIA,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuCallout.types.js","sourceRoot":"","sources":["../../src/MenuCallout/MenuCallout.types.ts"],"names":[],"mappings":"AAIA,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAAC"}
|
|
@@ -1,16 +1,20 @@
|
|
|
1
|
-
import { __assign } from "tslib";
|
|
2
1
|
/** @jsxRuntime classic */
|
|
3
2
|
/** @jsx withSlots */
|
|
4
3
|
import { View } from 'react-native';
|
|
5
4
|
import { compose, withSlots } from '@fluentui-react-native/framework';
|
|
6
5
|
import { stylingSettings } from './MenuDivider.styling';
|
|
7
6
|
import { menuDividerName } from './MenuDivider.types';
|
|
8
|
-
export
|
|
7
|
+
export const MenuDivider = compose({
|
|
8
|
+
displayName: menuDividerName,
|
|
9
|
+
...stylingSettings,
|
|
10
|
+
slots: {
|
|
9
11
|
root: View,
|
|
10
|
-
},
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
12
|
+
},
|
|
13
|
+
useRender: (userProps, useSlots) => {
|
|
14
|
+
const Slots = useSlots(userProps);
|
|
15
|
+
return (final) => {
|
|
16
|
+
return withSlots(Slots.root, { ...final });
|
|
14
17
|
};
|
|
15
|
-
}
|
|
18
|
+
},
|
|
19
|
+
});
|
|
16
20
|
//# sourceMappingURL=MenuDivider.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDivider.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDivider.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuDivider.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDivider.tsx"],"names":[],"mappings":"AAAA,0BAA0B;AAC1B,qBAAqB;AACrB,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAGpC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAEtE,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,MAAM,CAAC,MAAM,WAAW,GAAG,OAAO,CAAkB;IAClD,WAAW,EAAE,eAAe;IAC5B,GAAG,eAAe;IAClB,KAAK,EAAE;QACL,IAAI,EAAE,IAAI;KACX;IACD,SAAS,EAAE,CAAC,SAA2B,EAAE,QAAmC,EAAE,EAAE;QAC9E,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;QAElC,OAAO,CAAC,KAAuB,EAAE,EAAE;YACjC,OAAO,UAAC,KAAK,CAAC,IAAI,OAAK,KAAK,GAAI,CAAC;QACnC,CAAC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1,15 +1,22 @@
|
|
|
1
|
-
import { __assign } from "tslib";
|
|
2
1
|
import { Platform } from 'react-native';
|
|
3
2
|
import { buildProps } from '@fluentui-react-native/framework';
|
|
4
3
|
import { menuDividerName } from './MenuDivider.types';
|
|
5
4
|
import { defaultMenuDividerTokens } from './MenuDividerTokens';
|
|
6
|
-
export
|
|
5
|
+
export const stylingSettings = {
|
|
7
6
|
tokens: [defaultMenuDividerTokens, menuDividerName],
|
|
8
7
|
tokensThatAreAlsoProps: ['insetSize'],
|
|
9
8
|
slotProps: {
|
|
10
|
-
root: buildProps(
|
|
11
|
-
style:
|
|
12
|
-
|
|
9
|
+
root: buildProps((tokens) => ({
|
|
10
|
+
style: {
|
|
11
|
+
height: tokens.height,
|
|
12
|
+
width: tokens.width,
|
|
13
|
+
backgroundColor: tokens.backgroundColor,
|
|
14
|
+
margin: tokens.margin,
|
|
15
|
+
marginVertical: tokens.marginVertical,
|
|
16
|
+
display: 'flex',
|
|
17
|
+
...(Platform.OS === 'android' && { marginStart: tokens.insetSize }),
|
|
18
|
+
},
|
|
19
|
+
}), ['backgroundColor', 'height', 'margin', 'marginVertical', 'width']),
|
|
13
20
|
},
|
|
14
21
|
};
|
|
15
22
|
//# sourceMappingURL=MenuDivider.styling.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDivider.styling.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDivider.styling.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuDivider.styling.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDivider.styling.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAGxC,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAG9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AAE/D,MAAM,CAAC,MAAM,eAAe,GAAiF;IAC3G,MAAM,EAAE,CAAC,wBAAwB,EAAE,eAAe,CAAC;IACnD,sBAAsB,EAAE,CAAC,WAAW,CAAC;IACrC,SAAS,EAAE;QACT,IAAI,EAAE,UAAU,CACd,CAAC,MAAyB,EAAE,EAAE,CAAC,CAAC;YAC9B,KAAK,EAAE;gBACL,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,KAAK,EAAE,MAAM,CAAC,KAAK;gBACnB,eAAe,EAAE,MAAM,CAAC,eAAe;gBACvC,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,cAAc,EAAE,MAAM,CAAC,cAAc;gBACrC,OAAO,EAAE,MAAM;gBACf,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC;aACpE;SACF,CAAC,EACF,CAAC,iBAAiB,EAAE,QAAQ,EAAE,QAAQ,EAAE,gBAAgB,EAAE,OAAO,CAAC,CACnE;KACF;CACF,CAAC"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
1
|
+
export const menuDividerName = 'MenuDivider';
|
|
2
|
+
export const MenuDividerInsetSizes = [0, 16, 56, 68, 72, 108];
|
|
3
3
|
//# sourceMappingURL=MenuDivider.types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDivider.types.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDivider.types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuDivider.types.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDivider.types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAAC;AAE7C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAU,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { globalTokens } from '@fluentui-react-native/theme-tokens';
|
|
2
|
-
export
|
|
2
|
+
export const defaultMenuDividerTokens = (t) => ({
|
|
3
3
|
backgroundColor: t.colors.neutralStroke2,
|
|
4
4
|
height: globalTokens.stroke.width10,
|
|
5
5
|
insetSize: 0,
|
|
6
|
-
});
|
|
6
|
+
});
|
|
7
7
|
//# sourceMappingURL=MenuDividerTokens.android.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDividerTokens.android.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.android.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuDividerTokens.android.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.android.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,MAAM,wBAAwB,GAA4C,CAAC,CAAQ,EAAqB,EAAE,CAAC,CAAC;IACjH,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc;IACxC,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,OAAO;IACnC,SAAS,EAAE,CAAC;CACb,CAAC,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { globalTokens } from '@fluentui-react-native/theme-tokens';
|
|
2
|
-
export
|
|
2
|
+
export const defaultMenuDividerTokens = (t) => ({
|
|
3
3
|
backgroundColor: t.colors.neutralStroke2,
|
|
4
4
|
height: globalTokens.stroke.width10,
|
|
5
5
|
marginVertical: globalTokens.size40,
|
|
6
|
-
});
|
|
6
|
+
});
|
|
7
7
|
//# sourceMappingURL=MenuDividerTokens.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDividerTokens.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuDividerTokens.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,MAAM,wBAAwB,GAA4C,CAAC,CAAQ,EAAqB,EAAE,CAAC,CAAC;IACjH,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc;IACxC,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,OAAO;IACnC,cAAc,EAAE,YAAY,CAAC,MAAM;CACpC,CAAC,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { globalTokens } from '@fluentui-react-native/theme-tokens';
|
|
2
|
-
export
|
|
2
|
+
export const defaultMenuDividerTokens = (t) => ({
|
|
3
3
|
backgroundColor: t.colors.neutralStroke2,
|
|
4
4
|
height: globalTokens.stroke.width10,
|
|
5
5
|
margin: globalTokens.size40,
|
|
6
|
-
});
|
|
6
|
+
});
|
|
7
7
|
//# sourceMappingURL=MenuDividerTokens.macos.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDividerTokens.macos.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.macos.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuDividerTokens.macos.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.macos.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,MAAM,wBAAwB,GAA4C,CAAC,CAAQ,EAAqB,EAAE,CAAC,CAAC;IACjH,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc;IACxC,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,OAAO;IACnC,MAAM,EAAE,YAAY,CAAC,MAAM;CAC5B,CAAC,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { globalTokens } from '@fluentui-react-native/theme-tokens';
|
|
2
|
-
export
|
|
2
|
+
export const defaultMenuDividerTokens = (t) => ({
|
|
3
3
|
backgroundColor: t.colors.neutralStroke1,
|
|
4
4
|
height: globalTokens.stroke.width10,
|
|
5
5
|
margin: globalTokens.size20,
|
|
6
|
-
});
|
|
6
|
+
});
|
|
7
7
|
//# sourceMappingURL=MenuDividerTokens.win32.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuDividerTokens.win32.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.win32.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuDividerTokens.win32.js","sourceRoot":"","sources":["../../src/MenuDivider/MenuDividerTokens.win32.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,MAAM,wBAAwB,GAA4C,CAAC,CAAQ,EAAqB,EAAE,CAAC,CAAC;IACjH,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc;IACxC,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,OAAO;IACnC,MAAM,EAAE,YAAY,CAAC,MAAM;CAC5B,CAAC,CAAC"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { __assign, __rest } from "tslib";
|
|
2
1
|
/** @jsxRuntime classic */
|
|
3
2
|
/** @jsx withSlots */
|
|
4
3
|
import React from 'react';
|
|
@@ -7,59 +6,55 @@ import { FocusZone } from '@fluentui-react-native/focus-zone';
|
|
|
7
6
|
import { compose, mergeProps, withSlots } from '@fluentui-react-native/framework';
|
|
8
7
|
import { menuGroupName } from './MenuGroup.types';
|
|
9
8
|
// Intentionally not enabled on macOS to match system context menus
|
|
10
|
-
|
|
11
|
-
export
|
|
9
|
+
const hasFocusZone = ['win32'].includes(Platform.OS);
|
|
10
|
+
export const MenuGroup = compose({
|
|
12
11
|
displayName: menuGroupName,
|
|
13
12
|
slots: {
|
|
14
13
|
root: View,
|
|
15
14
|
contentWrapper: hasFocusZone ? FocusZone : React.Fragment,
|
|
16
15
|
},
|
|
17
|
-
useRender:
|
|
18
|
-
|
|
19
|
-
return
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
var childrenWithSet = React.Children.toArray(children).map(function (child) {
|
|
24
|
-
var _a, _b;
|
|
16
|
+
useRender: (userProps, useSlots) => {
|
|
17
|
+
const Slots = useSlots(userProps);
|
|
18
|
+
return (final, children) => {
|
|
19
|
+
const { ...mergedProps } = mergeProps(userProps, final);
|
|
20
|
+
let itemPosition = 0;
|
|
21
|
+
const childrenWithSet = React.Children.toArray(children).map((child) => {
|
|
25
22
|
if (React.isValidElement(child)) {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
child.type.displayName !== 'MenuDivider';
|
|
30
|
-
}).length;
|
|
23
|
+
const itemCount = React.Children.toArray(children).filter((child) => React.isValidElement(child) &&
|
|
24
|
+
child.type.displayName !== 'MenuGroupHeader' &&
|
|
25
|
+
child.type.displayName !== 'MenuDivider').length;
|
|
31
26
|
if (child.type.displayName !== 'MenuGroupHeader' && child.type.displayName !== 'MenuDivider') {
|
|
32
27
|
itemPosition++;
|
|
33
28
|
}
|
|
34
29
|
return React.cloneElement(child, {
|
|
35
|
-
accessibilityPositionInSet:
|
|
36
|
-
accessibilitySetSize:
|
|
30
|
+
accessibilityPositionInSet: child.props.accessibilityPositionInSet ?? itemPosition,
|
|
31
|
+
accessibilitySetSize: child.props.accessibilitySetSize ?? itemCount, //win32
|
|
37
32
|
});
|
|
38
33
|
}
|
|
39
34
|
return child;
|
|
40
35
|
});
|
|
41
36
|
// Check if this MenuGroup has a MenuGroupHeader. If so, use the MenuGroupHeader
|
|
42
37
|
// as the accessibilityLabel for the MenuGroup.
|
|
43
|
-
|
|
38
|
+
const menuGroupHeader = React.Children.toArray(children).find((child) => React.isValidElement(child) && child.type.displayName === 'MenuGroupHeader');
|
|
44
39
|
// On win32, in order for assistive technology to read a group, it must have a name which is why
|
|
45
40
|
// we use a string with a space as the default accessibilityLabel for MenuGroup.
|
|
46
41
|
// If an empty string was used, the group context would not be read.
|
|
47
|
-
|
|
42
|
+
let menuGroupA11yLabel = ' ';
|
|
48
43
|
if (menuGroupHeader && typeof menuGroupHeader.props.children === 'string') {
|
|
49
44
|
menuGroupA11yLabel = menuGroupHeader.props.children;
|
|
50
45
|
}
|
|
51
|
-
return (withSlots(Slots.root,
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
46
|
+
return (withSlots(Slots.root, { ...mergedProps, ...(Platform.OS == 'win32' && {
|
|
47
|
+
accessible: true,
|
|
48
|
+
accessibilityRole: 'group',
|
|
49
|
+
accessibilityLabel: mergedProps.accessibilityLabel ?? menuGroupA11yLabel,
|
|
50
|
+
}) },
|
|
56
51
|
withSlots(Slots.contentWrapper
|
|
57
52
|
// avoid error that fires when props are passed into React.fragment
|
|
58
|
-
,
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
53
|
+
, { ...(hasFocusZone && {
|
|
54
|
+
focusZoneDirection: 'vertical',
|
|
55
|
+
enableFocusRing: false,
|
|
56
|
+
navigateAtEnd: 'NavigateContinue',
|
|
57
|
+
}) }, childrenWithSet)));
|
|
63
58
|
};
|
|
64
59
|
},
|
|
65
60
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroup.js","sourceRoot":"","sources":["../../src/MenuGroup/MenuGroup.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuGroup.js","sourceRoot":"","sources":["../../src/MenuGroup/MenuGroup.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export const menuGroupName = 'MenuGroup';
|
|
2
2
|
//# sourceMappingURL=MenuGroup.types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroup.types.js","sourceRoot":"","sources":["../../src/MenuGroup/MenuGroup.types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuGroup.types.js","sourceRoot":"","sources":["../../src/MenuGroup/MenuGroup.types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,aAAa,GAAG,WAAW,CAAC"}
|
|
@@ -1,15 +1,19 @@
|
|
|
1
|
-
import { __assign, __rest } from "tslib";
|
|
2
1
|
import { compose, mergeProps, withSlots } from '@fluentui-react-native/framework';
|
|
3
2
|
import { TextV1 as Text } from '@fluentui-react-native/text';
|
|
4
3
|
import { stylingSettings } from './MenuGroupHeader.styling';
|
|
5
4
|
import { menuGroupHeaderName } from './MenuGroupHeader.types';
|
|
6
|
-
export
|
|
5
|
+
export const MenuGroupHeader = compose({
|
|
6
|
+
displayName: menuGroupHeaderName,
|
|
7
|
+
...stylingSettings,
|
|
8
|
+
slots: {
|
|
7
9
|
root: Text,
|
|
8
|
-
},
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
},
|
|
11
|
+
useRender: (userProps, useSlots) => {
|
|
12
|
+
const Slots = useSlots(userProps);
|
|
13
|
+
return (final, children) => {
|
|
14
|
+
const { ...mergedProps } = mergeProps(userProps, final);
|
|
15
|
+
return (withSlots(Slots.root, { accessible: userProps.accessible, ...mergedProps }, children));
|
|
13
16
|
};
|
|
14
|
-
}
|
|
17
|
+
},
|
|
18
|
+
});
|
|
15
19
|
//# sourceMappingURL=MenuGroupHeader.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroupHeader.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeader.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuGroupHeader.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeader.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAElF,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,6BAA6B,CAAC;AAE7D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAE5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,MAAM,CAAC,MAAM,eAAe,GAAG,OAAO,CAAsB;IAC1D,WAAW,EAAE,mBAAmB;IAChC,GAAG,eAAe;IAClB,KAAK,EAAE;QACL,IAAI,EAAE,IAAI;KACX;IACD,SAAS,EAAE,CAAC,SAA+B,EAAE,QAAuC,EAAE,EAAE;QACtF,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;QAElC,OAAO,CAAC,KAA2B,EAAE,QAAyB,EAAE,EAAE;YAChE,MAAM,EAAE,GAAG,WAAW,EAAE,GAAG,UAAU,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YAExD,OAAO,CACL,UAAC,KAAK,CAAC,IAAI,IAAC,UAAU,EAAE,SAAS,CAAC,UAAU,KAAM,WAAW,IAC1D,QAAQ,CACE,CACd,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1,15 +1,17 @@
|
|
|
1
|
-
import { __assign } from "tslib";
|
|
2
1
|
import { fontStyles } from '@fluentui-react-native/framework';
|
|
3
2
|
import { buildProps } from '@fluentui-react-native/framework';
|
|
4
3
|
import { menuGroupHeaderName } from './MenuGroupHeader.types';
|
|
5
4
|
import { defaultMenuGroupHeaderTokens } from './MenuGroupHeaderTokens';
|
|
6
|
-
export
|
|
5
|
+
export const stylingSettings = {
|
|
7
6
|
tokens: [defaultMenuGroupHeaderTokens, menuGroupHeaderName],
|
|
8
7
|
slotProps: {
|
|
9
|
-
root: buildProps(
|
|
8
|
+
root: buildProps((tokens, theme) => {
|
|
10
9
|
return {
|
|
11
10
|
color: tokens.color,
|
|
12
|
-
style:
|
|
11
|
+
style: {
|
|
12
|
+
marginStart: tokens.gap,
|
|
13
|
+
...fontStyles.from(tokens, theme),
|
|
14
|
+
},
|
|
13
15
|
};
|
|
14
16
|
}, ['color']),
|
|
15
17
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroupHeader.styling.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeader.styling.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MenuGroupHeader.styling.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeader.styling.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAE9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,4BAA4B,EAAE,MAAM,yBAAyB,CAAC;AAEvE,MAAM,CAAC,MAAM,eAAe,GAA6F;IACvH,MAAM,EAAE,CAAC,4BAA4B,EAAE,mBAAmB,CAAC;IAC3D,SAAS,EAAE;QACT,IAAI,EAAE,UAAU,CACd,CAAC,MAA6B,EAAE,KAAY,EAAE,EAAE;YAC9C,OAAO;gBACL,KAAK,EAAE,MAAM,CAAC,KAAK;gBACnB,KAAK,EAAE;oBACL,WAAW,EAAE,MAAM,CAAC,GAAG;oBACvB,GAAG,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC;iBAClC;aACF,CAAC;QACJ,CAAC,EACD,CAAC,OAAO,CAAC,CACV;KACF;CACF,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export const menuGroupHeaderName = 'MenuGroupHeader';
|
|
2
2
|
//# sourceMappingURL=MenuGroupHeader.types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroupHeader.types.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeader.types.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuGroupHeader.types.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeader.types.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,mBAAmB,GAAG,iBAAiB,CAAC"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { globalTokens } from '@fluentui-react-native/theme-tokens';
|
|
2
|
-
export
|
|
2
|
+
export const defaultMenuGroupHeaderTokens = (t) => ({
|
|
3
3
|
color: t.colors.neutralForeground2,
|
|
4
4
|
fontFamily: t.typography.families.primary,
|
|
5
5
|
fontSize: globalTokens.font.size300,
|
|
6
6
|
fontWeight: globalTokens.font.weight.regular,
|
|
7
7
|
gap: globalTokens.size40,
|
|
8
8
|
padding: globalTokens.size60,
|
|
9
|
-
});
|
|
9
|
+
});
|
|
10
10
|
//# sourceMappingURL=MenuGroupHeaderTokens.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroupHeaderTokens.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeaderTokens.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuGroupHeaderTokens.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeaderTokens.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,MAAM,4BAA4B,GAAgD,CAAC,CAAC,EAAyB,EAAE,CAAC,CAAC;IACtH,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,OAAO,EAAE,YAAY,CAAC,MAAM;CAC7B,CAAC,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { globalTokens } from '@fluentui-react-native/theme-tokens';
|
|
2
|
-
export
|
|
2
|
+
export const defaultMenuGroupHeaderTokens = (t) => ({
|
|
3
3
|
color: t.colors.disabledText,
|
|
4
4
|
fontFamily: t.typography.families.primary,
|
|
5
5
|
fontSize: 13,
|
|
@@ -7,5 +7,5 @@ export var defaultMenuGroupHeaderTokens = function (t) { return ({
|
|
|
7
7
|
gap: globalTokens.size40,
|
|
8
8
|
paddingHorizontal: 5,
|
|
9
9
|
paddingVertical: 3,
|
|
10
|
-
});
|
|
10
|
+
});
|
|
11
11
|
//# sourceMappingURL=MenuGroupHeaderTokens.macos.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuGroupHeaderTokens.macos.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeaderTokens.macos.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"MenuGroupHeaderTokens.macos.js","sourceRoot":"","sources":["../../src/MenuGroupHeader/MenuGroupHeaderTokens.macos.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAKnE,MAAM,CAAC,MAAM,4BAA4B,GAAgD,CAAC,CAAC,EAAyB,EAAE,CAAC,CAAC;IACtH,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,YAAY;IAC5B,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO;IACzC,QAAQ,EAAE,EAAE;IACZ,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAA0B;IAC/D,GAAG,EAAE,YAAY,CAAC,MAAM;IACxB,iBAAiB,EAAE,CAAC;IACpB,eAAe,EAAE,CAAC;CACnB,CAAC,CAAC"}
|
package/lib/MenuItem/MenuItem.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { __assign, __rest } from "tslib";
|
|
2
1
|
import { I18nManager, Image, Pressable, View } from 'react-native';
|
|
3
2
|
import { compose, memoize, mergeProps, withSlots } from '@fluentui-react-native/framework';
|
|
4
3
|
import { IconV1 as Icon } from '@fluentui-react-native/icon';
|
|
@@ -7,7 +6,10 @@ import { SvgXml } from 'react-native-svg';
|
|
|
7
6
|
import { stylingSettings } from './MenuItem.styling';
|
|
8
7
|
import { menuItemName } from './MenuItem.types';
|
|
9
8
|
import { useMenuItem } from './useMenuItem';
|
|
10
|
-
export
|
|
9
|
+
export const MenuItem = compose({
|
|
10
|
+
displayName: menuItemName,
|
|
11
|
+
...stylingSettings,
|
|
12
|
+
slots: {
|
|
11
13
|
root: Pressable,
|
|
12
14
|
checkmark: View,
|
|
13
15
|
content: Text,
|
|
@@ -15,27 +17,35 @@ export var MenuItem = compose(__assign(__assign({ displayName: menuItemName }, s
|
|
|
15
17
|
imgIcon: Image,
|
|
16
18
|
fontOrSvgIcon: Icon,
|
|
17
19
|
submenuIndicator: SvgXml,
|
|
18
|
-
},
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
20
|
+
},
|
|
21
|
+
useRender: (userProps, useSlots) => {
|
|
22
|
+
const menuItem = useMenuItem(userProps);
|
|
23
|
+
const Slots = useSlots(userProps, (layer) => menuItem.state[layer] || userProps[layer]);
|
|
24
|
+
return (final, children) => {
|
|
25
|
+
const { accessibilityLabel, icon, tooltip, ...mergedProps } = mergeProps(menuItem.props, final);
|
|
26
|
+
const chevronXml = I18nManager.isRTL
|
|
27
|
+
? `
|
|
28
|
+
<svg>
|
|
29
|
+
<path fill='currentColor' d="M10.2603 3.20041C10.5639 3.48226 10.5814 3.95681 10.2996 4.26034L6.77348 8L10.2996 11.7397C10.5814 12.0432 10.5639 12.5177 10.2603 12.7996C9.9568 13.0815 9.48226 13.0639 9.2004 12.7603L5.2004 8.51034C4.9332 8.22258 4.9332 7.77743 5.2004 7.48966L9.20041 3.23966C9.48226 2.93613 9.95681 2.91856 10.2603 3.20041Z"/>
|
|
30
|
+
</svg>`
|
|
31
|
+
: `
|
|
32
|
+
<svg>
|
|
33
|
+
<path fill='currentColor' d="M5.73966 3.20041C5.43613 3.48226 5.41856 3.95681 5.70041 4.26034L9.22652 8L5.70041 11.7397C5.41856 12.0432 5.43613 12.5177 5.73967 12.7996C6.0432 13.0815 6.51775 13.0639 6.7996 12.7603L10.7996 8.51034C11.0668 8.22258 11.0668 7.77743 10.7996 7.48966L6.7996 3.23966C6.51775 2.93613 6.0432 2.91856 5.73966 3.20041Z"/>
|
|
34
|
+
</svg>`;
|
|
26
35
|
// We only automatically support the one child string.
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
return (withSlots(Slots.root,
|
|
36
|
+
const label = getAccessibilityLabel(accessibilityLabel, children[0]);
|
|
37
|
+
const tooltipResult = getTooltip(tooltip, menuItem.state.hasTooltips, children[0]);
|
|
38
|
+
return (withSlots(Slots.root, { ...mergedProps, accessibilityLabel: label },
|
|
30
39
|
menuItem.state.hasCheckmarks && withSlots(Slots.checkmark, { accessible: false }),
|
|
31
40
|
(icon || menuItem.state.hasIcons) && (withSlots(Slots.iconPlaceholder, { accessible: false },
|
|
32
|
-
icon && icon.source && withSlots(Slots.imgIcon,
|
|
33
|
-
icon && (icon.svgSource || icon.fontSource) && withSlots(Slots.fontOrSvgIcon,
|
|
34
|
-
children && (withSlots(Slots.content,
|
|
41
|
+
icon && icon.source && withSlots(Slots.imgIcon, { accessible: false, ...icon }),
|
|
42
|
+
icon && (icon.svgSource || icon.fontSource) && withSlots(Slots.fontOrSvgIcon, { accessible: false, ...icon }))),
|
|
43
|
+
children && (withSlots(Slots.content, { accessible: false, tooltip: tooltipResult, ...(tooltipResult && { alwaysShowToolTip: true }) }, children)),
|
|
35
44
|
menuItem.state.hasSubmenu && withSlots(Slots.submenuIndicator, { accessible: false, xml: chevronXml })));
|
|
36
45
|
};
|
|
37
|
-
}
|
|
38
|
-
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
const getAccessibilityLabelWorker = (accessibilityLabel, child) => {
|
|
39
49
|
if (accessibilityLabel !== undefined) {
|
|
40
50
|
return accessibilityLabel;
|
|
41
51
|
}
|
|
@@ -44,8 +54,8 @@ var getAccessibilityLabelWorker = function (accessibilityLabel, child) {
|
|
|
44
54
|
}
|
|
45
55
|
return undefined;
|
|
46
56
|
};
|
|
47
|
-
export
|
|
48
|
-
|
|
57
|
+
export const getAccessibilityLabel = memoize(getAccessibilityLabelWorker);
|
|
58
|
+
const getTooltipWorker = (tooltip, hasTooltips, child) => {
|
|
49
59
|
if (tooltip !== undefined) {
|
|
50
60
|
return tooltip;
|
|
51
61
|
}
|
|
@@ -54,5 +64,5 @@ var getTooltipWorker = function (tooltip, hasTooltips, child) {
|
|
|
54
64
|
}
|
|
55
65
|
return undefined;
|
|
56
66
|
};
|
|
57
|
-
export
|
|
67
|
+
export const getTooltip = memoize(getTooltipWorker);
|
|
58
68
|
//# sourceMappingURL=MenuItem.js.map
|