79 lines
2.1 KiB
JavaScript
79 lines
2.1 KiB
JavaScript
// @flow
|
|
|
|
import React from 'react';
|
|
import { TouchableOpacity } from 'react-native-gesture-handler';
|
|
import { Text, TouchableRipple } from 'react-native-paper';
|
|
|
|
import { Icon } from '../../../base/icons';
|
|
import BaseTheme from '../../../base/ui/components/BaseTheme';
|
|
import styles from '../../../conference/components/native/styles';
|
|
|
|
type Props = {
|
|
|
|
/**
|
|
* Is the button disabled?
|
|
*/
|
|
disabled?: boolean,
|
|
|
|
/**
|
|
* Label of the button.
|
|
*/
|
|
label?: string,
|
|
|
|
/**
|
|
* Callback to invoke when the {@code HeaderNavigationButton} is clicked/pressed.
|
|
*/
|
|
onPress?: Function,
|
|
|
|
/**
|
|
* The ImageSource to be rendered as image.
|
|
*/
|
|
src?: Object,
|
|
|
|
/**
|
|
* Header has two actions.
|
|
*/
|
|
twoActions?: boolean
|
|
}
|
|
|
|
const HeaderNavigationButton
|
|
= ({
|
|
disabled,
|
|
label,
|
|
onPress,
|
|
src,
|
|
twoActions
|
|
}: Props) =>
|
|
(
|
|
<>
|
|
{
|
|
src ? (
|
|
<TouchableOpacity
|
|
onPress = { onPress }
|
|
style = { styles.headerNavigationButton }>
|
|
<Icon
|
|
size = { 20 }
|
|
src = { src }
|
|
style = { styles.headerNavigationIcon } />
|
|
</TouchableOpacity>
|
|
) : (
|
|
<TouchableRipple
|
|
disabled = { disabled }
|
|
onPress = { onPress }
|
|
rippleColor = { BaseTheme.palette.screen01Header }>
|
|
<Text
|
|
style = {
|
|
twoActions
|
|
? styles.headerNavigationTextBold
|
|
: styles.headerNavigationText
|
|
}>
|
|
{ label }
|
|
</Text>
|
|
</TouchableRipple>
|
|
)}
|
|
</>
|
|
);
|
|
|
|
|
|
export default HeaderNavigationButton;
|