Skip to content
Snippets Groups Projects
settings.js 2.41 KiB
Newer Older
import React, { Component } from 'react'
import {
  View,
  Button,
  ScrollView,
  Alert
} from 'react-native'
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 styles from '../styles/index'
Julia Friesel's avatar
Julia Friesel committed
import { settings as labels } from './labels'
import { importCsv } from '../db'

export default class Settings extends Component {
  render() {
    return (
      <ScrollView>
        <View style={styles.homeButtons}>
          <View style={styles.homeButton}>
            <Button
Julia Friesel's avatar
Julia Friesel committed
              onPress={async () => {
                let data
                try {
                  data = getDataAsCsvDataUri()
                  if (!data) {
Julia Friesel's avatar
Julia Friesel committed
                    return Alert.alert(labels.errors.noData)
                  }
                } catch (err) {
                  console.error(err)
Julia Friesel's avatar
Julia Friesel committed
                  return Alert.alert(labels.errors.couldNotConvert)
Julia Friesel's avatar
Julia Friesel committed
                try {
                  await Share.open({
Julia Friesel's avatar
Julia Friesel committed
                    title: labels.exportTitle,
Julia Friesel's avatar
Julia Friesel committed
                    url: data,
Julia Friesel's avatar
Julia Friesel committed
                    subject: labels.exportSubject,
Julia Friesel's avatar
Julia Friesel committed
                    type: 'text/csv',
                    showAppsToView: true
                  })
                } catch (err) {
                  console.error(err)
Julia Friesel's avatar
Julia Friesel committed
                  return Alert.alert(labels.errors.problemSharing)
Julia Friesel's avatar
Julia Friesel committed
                }
              }}
Julia Friesel's avatar
Julia Friesel committed
              title={labels.buttonLabel}>
          <View style={styles.homeButton}>
            <Button
              onPress={ getFileContentAndImport }
              title="Import data">
            </Button>
          </View>
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)
  } catch(err) {