const React = require('react'); const { Text, Modal, View, StyleSheet, Button } = require('react-native'); const { themeStyle } = require('./global-style.js'); const { _ } = require('@joplin/lib/locale'); class ModalDialog extends React.Component { constructor() { super(); this.styles_ = {}; } styles() { const themeId = this.props.themeId; const theme = themeStyle(themeId); if (this.styles_[themeId]) return this.styles_[themeId]; this.styles_ = {}; const styles = { modalWrapper: { flex: 1, justifyContent: 'center', }, modalContentWrapper: { flex: 1, flexDirection: 'column', backgroundColor: theme.backgroundColor, borderWidth: 1, borderColor: theme.dividerColor, margin: 20, padding: 10, borderRadius: 5, }, modalContentWrapper2: { flex: 1, }, title: { ...theme.normalText, borderBottomWidth: 1, borderBottomColor: theme.dividerColor, paddingBottom: 10, fontWeight: 'bold' }, buttonRow: { flexDirection: 'row', borderTopWidth: 1, borderTopColor: theme.dividerColor, paddingTop: 10, }, }; this.styles_[themeId] = StyleSheet.create(styles); return this.styles_[themeId]; } render() { const ContentComponent = this.props.ContentComponent; const buttonBarEnabled = this.props.buttonBarEnabled !== false; return ( {}}> {this.props.title} {ContentComponent} ); } } module.exports = ModalDialog;