import * as React from 'react'; import { StyleSheet, View } from 'react-native'; import type { ThemeProp } from 'src/types'; import { useInternalTheme } from '../../core/theming'; import Icon, { IconSource } from '../Icon'; export type Props = { /** * Custom color for action icon. */ color?: string; /** * Name of the icon to show. */ icon: IconSource; /** * Optional icon size. */ size?: number; /** * @optional */ theme?: ThemeProp; }; /** * @supported Available in v5.x with theme version 3 * A component to show an icon in a Dialog. * *
* *
* * ## Usage * ```js * import * as React from 'react'; * import { StyleSheet } from 'react-native'; * import { Dialog, Portal, Text } from 'react-native-paper'; * * const MyComponent = () => { * const [visible, setVisible] = React.useState(false); * * const hideDialog = () => setVisible(false); * * return ( * * * * This is a title * * This is simple dialog * * * * ); * }; * * const styles = StyleSheet.create({ * title: { * textAlign: 'center', * }, * }) * * export default MyComponent; * ``` */ const DialogIcon = ({ size = 24, color, icon, theme: themeOverrides, }: Props) => { const theme = useInternalTheme(themeOverrides); if (!theme.isV3) { return null; } //@ts-ignore const iconColor = color || theme.colors.secondary; return ( ); }; DialogIcon.displayName = 'Dialog.Icon'; const styles = StyleSheet.create({ wrapper: { alignItems: 'center', justifyContent: 'center', paddingTop: 24, }, }); export default DialogIcon; // @component-docs ignore-next-line export { DialogIcon };