2020-11-17 09:43:38 +01:00
|
|
|
import React from 'react';
|
2024-05-20 11:54:13 +02:00
|
|
|
import { Platform, StyleSheet, useWindowDimensions, View } from 'react-native';
|
2020-11-17 09:43:38 +01:00
|
|
|
import Modal from 'react-native-modal';
|
2024-05-20 11:54:13 +02:00
|
|
|
|
2023-11-15 09:40:22 +01:00
|
|
|
import { BlueSpacing10 } from '../BlueComponents';
|
2021-05-18 04:17:00 +02:00
|
|
|
import loc from '../loc';
|
2023-11-15 09:40:22 +01:00
|
|
|
import Button from './Button';
|
2024-05-20 11:54:13 +02:00
|
|
|
import { useTheme } from './themes';
|
2020-11-17 09:43:38 +01:00
|
|
|
|
|
|
|
const styles = StyleSheet.create({
|
|
|
|
root: {
|
|
|
|
justifyContent: 'flex-end',
|
|
|
|
margin: 0,
|
|
|
|
},
|
2021-05-18 04:17:00 +02:00
|
|
|
hasDoneButton: {
|
|
|
|
padding: 16,
|
|
|
|
paddingBottom: 24,
|
|
|
|
},
|
2020-11-17 09:43:38 +01:00
|
|
|
});
|
|
|
|
|
2024-02-10 05:35:24 +01:00
|
|
|
interface BottomModalProps {
|
|
|
|
children?: React.ReactNode;
|
|
|
|
onBackButtonPress?: () => void;
|
|
|
|
onBackdropPress?: () => void;
|
|
|
|
onClose: () => void;
|
|
|
|
windowHeight?: number;
|
|
|
|
windowWidth?: number;
|
|
|
|
doneButton?: boolean;
|
|
|
|
avoidKeyboard?: boolean;
|
|
|
|
allowBackdropPress?: boolean;
|
|
|
|
isVisible: boolean;
|
2024-03-11 23:38:39 +01:00
|
|
|
coverScreen?: boolean;
|
2024-02-10 05:35:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
const BottomModal: React.FC<BottomModalProps> = ({
|
|
|
|
onBackButtonPress,
|
|
|
|
onBackdropPress,
|
2021-09-30 13:33:50 +02:00
|
|
|
onClose,
|
2024-02-10 05:35:24 +01:00
|
|
|
windowHeight,
|
|
|
|
windowWidth,
|
|
|
|
doneButton,
|
|
|
|
isVisible,
|
2021-09-09 13:00:11 +02:00
|
|
|
avoidKeyboard = false,
|
|
|
|
allowBackdropPress = true,
|
2024-03-11 23:38:39 +01:00
|
|
|
coverScreen = true,
|
2021-09-09 13:00:11 +02:00
|
|
|
...props
|
|
|
|
}) => {
|
2024-02-10 05:35:24 +01:00
|
|
|
const { height: valueWindowHeight, width: valueWindowWidth } = useWindowDimensions();
|
2020-11-17 09:43:38 +01:00
|
|
|
const handleBackButtonPress = onBackButtonPress ?? onClose;
|
2021-09-09 13:00:11 +02:00
|
|
|
const handleBackdropPress = allowBackdropPress ? onBackdropPress ?? onClose : undefined;
|
2021-05-18 04:17:00 +02:00
|
|
|
const { colors } = useTheme();
|
|
|
|
const stylesHook = StyleSheet.create({
|
|
|
|
hasDoneButton: {
|
|
|
|
backgroundColor: colors.elevated,
|
|
|
|
},
|
|
|
|
});
|
2024-02-10 05:35:24 +01:00
|
|
|
|
2020-11-17 09:43:38 +01:00
|
|
|
return (
|
|
|
|
<Modal
|
|
|
|
style={styles.root}
|
|
|
|
deviceHeight={windowHeight ?? valueWindowHeight}
|
|
|
|
deviceWidth={windowWidth ?? valueWindowWidth}
|
|
|
|
onBackButtonPress={handleBackButtonPress}
|
|
|
|
onBackdropPress={handleBackdropPress}
|
2024-02-10 05:35:24 +01:00
|
|
|
isVisible={isVisible}
|
2024-03-11 23:38:39 +01:00
|
|
|
coverScreen={coverScreen}
|
2020-11-17 09:43:38 +01:00
|
|
|
{...props}
|
2021-03-16 03:07:52 +01:00
|
|
|
accessibilityViewIsModal
|
2021-09-09 13:00:11 +02:00
|
|
|
avoidKeyboard={avoidKeyboard}
|
2021-05-18 04:17:00 +02:00
|
|
|
useNativeDriverForBackdrop={Platform.OS === 'android'}
|
|
|
|
>
|
|
|
|
{props.children}
|
|
|
|
{doneButton && (
|
|
|
|
<View style={[styles.hasDoneButton, stylesHook.hasDoneButton]}>
|
2024-03-01 12:45:05 +01:00
|
|
|
<Button title={loc.send.input_done} onPress={onClose} testID="ModalDoneButton" />
|
2021-11-16 17:40:01 +01:00
|
|
|
<BlueSpacing10 />
|
2021-05-18 04:17:00 +02:00
|
|
|
</View>
|
|
|
|
)}
|
|
|
|
</Modal>
|
2020-11-17 09:43:38 +01:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default BottomModal;
|