Merge branch '238-loading-screen-for-data-import' into 'master'

Add loading screen for data import

Closes #238

See merge request bloodyhealth/drip!206
This commit is contained in:
Julia Friesel
2019-05-06 06:44:54 +00:00
4 changed files with 92 additions and 39 deletions
+18
View File
@@ -0,0 +1,18 @@
import React from 'react'
import { View } from 'react-native'
import AppText from './app-text'
import { shared } from '../i18n/en/labels'
const AppLoadingView = () => {
return (
<View flex={1}>
<View style={{flex:1, justifyContent: 'center'}}>
<AppText style={{alignSelf: 'center'}}>{shared.loading}</AppText>
</View>
</View>
)
}
export default AppLoadingView
+2 -5
View File
@@ -10,6 +10,7 @@ import { cycleDayColor } from '../../styles'
import { scaleObservable } from '../../local-storage' import { scaleObservable } from '../../local-storage'
import config from '../../config' import config from '../../config'
import AppText from '../app-text' import AppText from '../app-text'
import AppLoadingView from '../app-loading'
import { shared as labels } from '../../i18n/en/labels' import { shared as labels } from '../../i18n/en/labels'
import DripIcon from '../../assets/drip-icons' import DripIcon from '../../assets/drip-icons'
import DripHomeIcon from '../../assets/drip-home-icons' import DripHomeIcon from '../../assets/drip-home-icons'
@@ -133,11 +134,7 @@ export default class CycleChart extends Component {
onLayout={this.onLayout} onLayout={this.onLayout}
style={{ flexDirection: 'row', flex: 1 }} style={{ flexDirection: 'row', flex: 1 }}
> >
{!this.state.chartLoaded && {!this.state.chartLoaded && <AppLoadingView />}
<View style={{width: '100%', justifyContent: 'center', alignItems: 'center'}}>
<AppText>{labels.loading}</AppText>
</View>
}
{this.state.chartHeight && this.state.chartLoaded && {this.state.chartHeight && this.state.chartLoaded &&
<View> <View>
@@ -6,23 +6,23 @@ import { shared as sharedLabels } from '../../../i18n/en/labels'
import labels from '../../../i18n/en/settings' import labels from '../../../i18n/en/settings'
import alertError from '../shared/alert-error' import alertError from '../shared/alert-error'
export default function openImportDialogAndImport() { export function openImportDialog(onImportData) {
Alert.alert( Alert.alert(
labels.import.title, labels.import.title,
labels.import.message, labels.import.message,
[{ [{
text: labels.import.replaceOption, text: labels.import.replaceOption,
onPress: () => getFileContentAndImport({ deleteExisting: false }) onPress: () => onImportData(false)
}, { }, {
text: labels.import.deleteOption, text: labels.import.deleteOption,
onPress: () => getFileContentAndImport({ deleteExisting: true }) onPress: () => onImportData(true)
}, { }, {
text: sharedLabels.cancel, style: 'cancel', onPress: () => { } text: sharedLabels.cancel, style: 'cancel', onPress: () => { }
}] }]
) )
} }
async function getFileContentAndImport({ deleteExisting }) { export async function getFileContent() {
let fileInfo let fileInfo
try { try {
fileInfo = await new Promise((resolve, reject) => { fileInfo = await new Promise((resolve, reject) => {
@@ -45,8 +45,13 @@ async function getFileContentAndImport({ deleteExisting }) {
return importError(labels.import.errors.couldNotOpenFile) return importError(labels.import.errors.couldNotOpenFile)
} }
return fileContent
}
export async function importData(shouldDeleteExistingData, fileContent) {
try { try {
await importCsv(fileContent, deleteExisting) await importCsv(fileContent, shouldDeleteExistingData)
Alert.alert(sharedLabels.successTitle, labels.import.success.message) Alert.alert(sharedLabels.successTitle, labels.import.success.message)
} catch(err) { } catch(err) {
importError(err.message) importError(err.message)
+40 -7
View File
@@ -1,16 +1,45 @@
import React from 'react' import React, { Component } from 'react'
import { ScrollView } from 'react-native' import { ScrollView, View } from 'react-native'
import AppText from '../../app-text' import AppText from '../../app-text'
import FramedSegment from '../../framed-segment' import FramedSegment from '../../framed-segment'
import AppLoadingView from '../../app-loading'
import SettingsButton from '../shared/settings-button' import SettingsButton from '../shared/settings-button'
import openImportDialogAndImport from './import-dialog' import { openImportDialog, getFileContent, importData } from './import-dialog'
import openShareDialogAndExport from './export-dialog' import openShareDialogAndExport from './export-dialog'
import DeleteData from './delete-data' import DeleteData from './delete-data'
import labels from '../../../i18n/en/settings' import labels from '../../../i18n/en/settings'
const DataManagement = () => { export default class DataManagement extends Component {
constructor(props) {
super(props)
this.state = { isLoading: false }
}
startLoading = () => {
this.setState({ isLoading: true })
}
endLoading = () => {
this.setState({ isLoading: false })
}
startImportFlow = async (shouldDeleteExistingData) => {
this.startLoading()
const fileContent = await getFileContent()
if (fileContent) {
await importData(shouldDeleteExistingData, fileContent)
}
this.endLoading()
}
render() {
return ( return (
<View flex={1}>
{this.state.isLoading && <AppLoadingView />}
{!this.state.isLoading &&
<ScrollView> <ScrollView>
<View>
<FramedSegment title={labels.export.button}> <FramedSegment title={labels.export.button}>
<AppText>{labels.export.segmentExplainer}</AppText> <AppText>{labels.export.segmentExplainer}</AppText>
<SettingsButton onPress={openShareDialogAndExport}> <SettingsButton onPress={openShareDialogAndExport}>
@@ -19,7 +48,9 @@ const DataManagement = () => {
</FramedSegment> </FramedSegment>
<FramedSegment title={labels.import.button}> <FramedSegment title={labels.import.button}>
<AppText>{labels.import.segmentExplainer}</AppText> <AppText>{labels.import.segmentExplainer}</AppText>
<SettingsButton onPress={openImportDialogAndImport}> <SettingsButton
onPress= {() => openImportDialog(this.startImportFlow)}
>
{labels.import.button} {labels.import.button}
</SettingsButton> </SettingsButton>
</FramedSegment> </FramedSegment>
@@ -30,8 +61,10 @@ const DataManagement = () => {
<AppText>{labels.deleteSegment.explainer}</AppText> <AppText>{labels.deleteSegment.explainer}</AppText>
<DeleteData /> <DeleteData />
</FramedSegment> </FramedSegment>
</View>
</ScrollView> </ScrollView>
}
</View>
) )
} }
}
export default DataManagement