Newer
Older
import React, { Component } from 'react'
import {
View,
Button,
import Share from 'react-native-share'
import getDataAsCsvDataUri from '../lib/export-to-csv'
import { DocumentPicker, DocumentPickerUtil } from 'react-native-document-picker'
import rnfs from 'react-native-fs'
import { importCsv } from '../db'
export default class Settings extends Component {
render() {
return (
<ScrollView>
<View style={styles.homeButtons}>
<View style={styles.homeButton}>
<Button
let data
try {
data = getDataAsCsvDataUri()
if (!data) {
}
} catch (err) {
console.error(err)
type: 'text/csv',
showAppsToView: true
})
} catch (err) {
onPress={ getFileContentAndImport }
title="Import data">
</Button>
</View>
</View>
</ScrollView>
)
}
async function getFileContentAndImport() {
let fileInfo
try {
fileInfo = await new Promise((resolve, reject) => {
DocumentPicker.show({
filetype: [DocumentPickerUtil.allFiles()],
}, (err, res) => {
if (err) return reject(err)
resolve(res)
})
})
} catch (err) {
return Alert.alert('There was a problem opening the file picker')
}
let fileContent
try {
fileContent = await rnfs.readFile(fileInfo.uri, 'utf8')
} catch (err) {
console.log(err)
return Alert.alert('Could not open file')
importCsv(fileContent, false)