Files
notesnook/apps/mobile/src/components/ExportDialog/index.js

202 lines
4.9 KiB
JavaScript
Raw Normal View History

2020-09-07 12:33:35 +05:00
import React, {useEffect, useState} from 'react';
import {
Modal,
StyleSheet,
Text,
TouchableOpacity,
View,
Platform,
} from 'react-native';
import Icon from 'react-native-vector-icons/MaterialCommunityIcons';
import {opacity, ph, pv, SIZE, WEIGHT} from '../../common/common';
import {useTracked} from '../../provider';
import {DDS, getElevation, db} from '../../utils/utils';
import {Loading} from '../Loading';
const {
eSubscribeEvent,
eUnSubscribeEvent,
} = require('../../services/eventManager');
const {
eOpenExportDialog,
eCloseExportDialog,
} = require('../../services/events');
2020-09-09 11:10:35 +05:00
import {Button} from '../Button/index';
2020-09-09 22:09:57 +05:00
import Seperator from '../Seperator';
2020-09-07 12:33:35 +05:00
const ExportDialog = () => {
const [state, dispatch] = useTracked();
const {colors, tags, premiumUser} = state;
2020-09-10 10:19:36 +05:00
const [visible, setVisible] = useState(false);
2020-09-07 12:33:35 +05:00
const [notes, setNotes] = useState([]);
const [exporting, setExporting] = useState(false);
const [complete, setComplete] = useState(false);
useEffect(() => {
eSubscribeEvent(eOpenExportDialog, open);
eSubscribeEvent(eCloseExportDialog, close);
return () => {
eUnSubscribeEvent(eOpenExportDialog, open);
eUnSubscribeEvent(eCloseExportDialog, close);
};
}, []);
const open = (data) => {
setVisible(true);
setNotes(data);
};
const close = (data) => {
setComplete(false);
setExporting(false);
setNotes([]);
setVisible(false);
setNotes(data);
};
const actions = [
{
title: 'PDF',
func: () => {},
icon: 'file-pdf-box',
},
{
title: 'Markdown',
func: () => {},
icon: 'language-markdown',
},
{
title: 'Plain Text',
func: () => {},
icon: 'card-text',
},
{
title: 'HTML',
func: () => {},
icon: 'language-html5',
},
];
return (
<Modal
visible={visible}
transparent={true}
animated
animationType="fade"
onRequestClose={close}>
<View style={styles.wrapper}>
<TouchableOpacity onPress={close} style={styles.overlay} />
<View
style={[
{
width: DDS.isTab ? '40%' : '80%',
backgroundColor: colors.bg,
},
styles.container,
]}>
<View style={styles.headingContainer}>
<Icon name="export" color={colors.accent} size={SIZE.lg} />
<Text style={[{color: colors.accent}, styles.heading]}>
Export
{notes.length === 0 || notes.length === 1
? ''
: ' ' + notes.length}{' '}
Note
</Text>
</View>
2020-09-09 22:09:57 +05:00
<Text style={[{color: colors.pri,fontSize:SIZE.xs + 1,alignSelf:'center'}]}>
Export your note in any of the following formats.
</Text>
<Seperator half />
2020-09-07 12:33:35 +05:00
{exporting ? (
<Loading
done={complete}
doneText={`Note exported successfully! You can find exported notes in ${
Platform.OS === 'ios'
? 'Files Manager/Notesnook'
: 'Phone Storage/Notesnook/Exported/'
}.`}
onDone={close}
tagline="Exporting notes..."
/>
) : (
<View style={styles.buttonContainer}>
{actions.map((item) => (
2020-09-09 22:09:57 +05:00
<>
<Seperator half />
<Button
width="100%"
title={item.title}
icon={item.icon}
activeOpacity={opacity}
onPress={() => {
setExporting(true);
setTimeout(() => {
setComplete(true);
}, 1000);
}}
/>
</>
2020-09-07 12:33:35 +05:00
))}
</View>
)}
</View>
</View>
</Modal>
);
};
const styles = StyleSheet.create({
wrapper: {
width: '100%',
height: '100%',
backgroundColor: 'rgba(0,0,0,0.3)',
justifyContent: 'center',
alignItems: 'center',
},
container: {
...getElevation(5),
maxHeight: 350,
borderRadius: 5,
paddingHorizontal: ph,
paddingVertical: pv,
},
headingContainer: {
flexDirection: 'row',
justifyContent: 'center',
alignItems: 'center',
},
buttonContainer: {
justifyContent: 'space-between',
alignItems: 'center',
},
heading: {
fontFamily: WEIGHT.bold,
marginLeft: 5,
fontSize: SIZE.md,
},
button: {
paddingVertical: pv,
paddingHorizontal: ph,
marginTop: 10,
borderRadius: 5,
width: '100%',
justifyContent: 'center',
alignItems: 'center',
borderWidth: 1,
flexDirection: 'row',
},
buttonText: {
fontFamily: WEIGHT.medium,
color: 'white',
fontSize: SIZE.sm,
marginLeft: 5,
},
overlay: {
width: '100%',
height: '100%',
position: 'absolute',
},
});
export default ExportDialog;