import React, { Component } from 'react'
import {
View,
TouchableOpacity,
ScrollView,
Alert,
Text,
TextInput,
Keyboard
} from 'react-native'
import DateTimePicker from 'react-native-modal-datetime-picker-nevo'
import Slider from '@ptomasroos/react-native-multi-slider'
import Share from 'react-native-share'
import { DocumentPicker, DocumentPickerUtil } from 'react-native-document-picker'
import rnfs from 'react-native-fs'
import styles, { secondaryColor } from '../styles/index'
import config from '../config'
import { settings as settingsLabels, shared as sharedLabels } from './labels'
import getDataAsCsvDataUri from '../lib/import-export/export-to-csv'
import importCsv from '../lib/import-export/import-from-csv'
import { scaleObservable, saveTempScale } from '../local-storage'
export default class Settings extends Component {
constructor(props) {
super(props)
this.state = {}
}
render() {
return (
this.setState({ isTimePickerVisible: true })}
>
{settingsLabels.tempReminder.title}
{this.state.time ?
{settingsLabels.tempReminder.explainerChange}
:
{settingsLabels.tempReminder.explainer}
}
{this.state.time}
{
this.setState({
time: padWithZeros(`${jsDate.getHours()}:${jsDate.getMinutes()}`),
isTimePickerVisible: false
})
}}
onCancel={() => this.setState({ isTimePickerVisible: false })}
/>
{settingsLabels.tempScale.segmentTitle}
{settingsLabels.tempScale.segmentExplainer}
{settingsLabels.export.button}
{settingsLabels.export.segmentExplainer}
{settingsLabels.export.button}
{settingsLabels.import.button}
{settingsLabels.import.segmentExplainer}
{settingsLabels.import.button}
)
}
}
class TempSlider extends Component {
constructor(props) {
super(props)
this.state = Object.assign({}, scaleObservable.value)
}
onValuesChange = (values) => {
this.setState({
min: values[0],
max: values[1]
})
}
onValuesChangeFinish = (values) => {
this.setState({
min: values[0],
max: values[1]
})
try {
saveTempScale(this.state)
} catch(err) {
alertError(settingsLabels.tempScale.saveError)
}
}
render() {
return (
{`${settingsLabels.tempScale.min} ${this.state.min}`}
{`${settingsLabels.tempScale.max} ${this.state.max}`}
)
}
}
async function openShareDialogAndExport() {
let data
try {
data = getDataAsCsvDataUri()
if (!data) {
return alertError(settingsLabels.errors.noData)
}
} catch (err) {
console.error(err)
return alertError(settingsLabels.errors.couldNotConvert)
}
try {
await Share.open({
title: settingsLabels.export.title,
url: data,
subject: settingsLabels.export.subject,
type: 'text/csv',
showAppsToView: true
})
} catch (err) {
console.error(err)
return alertError(settingsLabels.export.errors.problemSharing)
}
}
function openImportDialogAndImport() {
Alert.alert(
settingsLabels.import.title,
settingsLabels.import.message,
[{
text: settingsLabels.import.replaceOption,
onPress: () => getFileContentAndImport({ deleteExisting: false })
}, {
text: settingsLabels.import.deleteOption,
onPress: () => getFileContentAndImport({ deleteExisting: true })
}, {
text: sharedLabels.cancel, style: 'cancel', onPress: () => { }
}]
)
}
async function getFileContentAndImport({ deleteExisting }) {
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) {
// because cancelling also triggers an error, we do nothing here
return
}
let fileContent
try {
fileContent = await rnfs.readFile(fileInfo.uri, 'utf8')
} catch (err) {
return importError(settingsLabels.import.errors.couldNotOpenFile)
}
try {
await importCsv(fileContent, deleteExisting)
Alert.alert(sharedLabels.successTitle, settingsLabels.import.success.message)
} catch(err) {
importError(err.message)
}
}
function alertError(msg) {
Alert.alert(sharedLabels.errorTitle, msg)
}
function importError(msg) {
const postFixed = `${msg}\n\n${settingsLabels.import.errors.postFix}`
alertError(postFixed)
}
function padWithZeros(time) {
const vals = time.split(':')
return vals.map(val => {
if (parseInt(val) < 10) {
val = `0${val}`
}
return val
}).join(':')
}