Files
react-native/packages/rn-tester/js/examples/PopupMenuAndroid/PopupMenuAndroidExample.js
Tim Yung 1977dd6596 RN: Sort Pragmas in Headers (#51554)
Summary:
Pull Request resolved: https://github.com/facebook/react-native/pull/51554

Sorts pragma directives file headers in React Native.

Changelog:
[Internal]

Reviewed By: SamChou19815

Differential Revision: D75264593

fbshipit-source-id: 9e4b253dd0fc94dc2fc469d7114b93a8aae305f4
2025-05-22 21:18:53 -07:00

73 lines
1.8 KiB
JavaScript

/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @flow
* @format
*/
'use strict';
import type {PopupMenuAndroidInstance} from '@react-native/popup-menu-android';
import type {Node} from 'react';
import PopupMenuAndroid from '@react-native/popup-menu-android';
import * as React from 'react';
import {useRef, useState} from 'react';
import {Button, StyleSheet, Text, View} from 'react-native';
type Fruit = 'Apple' | 'Pear' | 'Banana' | 'Orange' | 'Kiwi';
const PopupMenu = () => {
const popupRef = useRef<?PopupMenuAndroidInstance>();
const [fruit, setFruit] = useState<?Fruit>();
const fruits: Array<Fruit> = ['Apple', 'Pear', 'Banana', 'Orange', 'Kiwi'];
const items = fruits.map(item => ({
label: item,
onPress: () => {
setFruit(item);
},
}));
return (
<View style={styles.container}>
{fruit ? <Text>Selected {fruit}</Text> : null}
<PopupMenuAndroid
instanceRef={popupRef}
menuItems={items.map(({label}) => label)}
onSelectionChange={selection => items[selection].onPress()}
onDismiss={() => console.warn('Popup was dismissed!')}>
<Button
title="Show PopupMenu!"
onPress={() => {
popupRef.current?.show();
}}
/>
</PopupMenuAndroid>
</View>
);
};
const styles = StyleSheet.create({
container: {
flex: 1,
alignItems: 'center',
justifyContent: 'center',
padding: 16,
},
});
exports.title = 'PopupMenuAndroid';
// TODO(T175446328): Publish oss documentation for PopupMenuAndroid
exports.description = 'PopupMenuAndroid Example';
exports.examples = [
{
title: 'PopupMenu Example',
render(): Node {
return <PopupMenu />;
},
},
];