Files
mobile-darmasaba/components/modalFloat.tsx
2025-07-28 10:15:27 +08:00

42 lines
1.5 KiB
TypeScript

import Styles from '@/constants/Styles';
import { Pressable, View } from 'react-native';
import Text from './Text';
import Modal from 'react-native-modal';
type Props = {
isVisible: boolean
setVisible: (value: boolean) => void
title?: string
children: React.ReactNode
onSubmit: () => void
disableSubmit?: boolean
}
export default function ModalFloat({ isVisible, setVisible, title, children, onSubmit, disableSubmit }: Props) {
return (
<Modal
animationIn={"fadeIn"}
animationOut={"fadeOut"}
isVisible={isVisible}
hideModalContentWhileAnimating={true}
onBackdropPress={() => { setVisible(false) }}
>
<View style={[Styles.modalFloatContent]}>
<View style={[Styles.titleContainerModalFloat]}>
<Text style={Styles.textDefaultSemiBold}>{title}</Text>
</View>
<View style={[Styles.mb10]}>
{children}
</View>
<View style={[Styles.rowItemsCenter, { justifyContent: 'flex-end' }]}>
<Pressable style={[Styles.ph15, Styles.pv05, Styles.round10, Styles.mr10]} onPress={() => { setVisible(false) }}>
<Text style={[Styles.textDefault]}>Batal</Text>
</Pressable>
<Pressable style={[Styles.ph15, Styles.pv05, Styles.round10]} onPress={onSubmit} disabled={disableSubmit}>
<Text style={[Styles.textDefault, disableSubmit && Styles.cGray]}>Simpan</Text>
</Pressable>
</View>
</View>
</Modal>
)
}