'use strict'; import React, { AppRegistry, Dimensions, Image, StyleSheet, Text, TouchableOpacity, View, } from "react-native"; import Button from "react-native-button"; import CodePush from "react-native-code-push"; let CodePushDemoApp = React.createClass({ async sync() { let self = this; try { return await CodePush.sync( { updateDialog: true, installMode: CodePush.InstallMode.ON_NEXT_RESUME }, (syncStatus) => { switch(syncStatus) { case CodePush.SyncStatus.CHECKING_FOR_UPDATE: self.setState({ syncMessage: "Checking for update." }); break; case CodePush.SyncStatus.DOWNLOADING_PACKAGE: self.setState({ syncMessage: "Downloading package." }); break; case CodePush.SyncStatus.AWAITING_USER_ACTION: self.setState({ syncMessage: "Awaiting user action." }); break; case CodePush.SyncStatus.INSTALLING_UPDATE: self.setState({ syncMessage: "Installing update." }); break; case CodePush.SyncStatus.UP_TO_DATE: self.setState({ syncMessage: "App up to date.", progress: false }); break; case CodePush.SyncStatus.UPDATE_IGNORED: self.setState({ syncMessage: "Update cancelled by user.", progress: false }); break; case CodePush.SyncStatus.UPDATE_INSTALLED: self.setState({ syncMessage: "Update installed and will be run when the app next resumes.", progress: false }); break; case CodePush.SyncStatus.UNKNOWN_ERROR: self.setState({ syncMessage: "An unknown error occurred.", progress: false }); break; } }, (progress) => { self.setState({ progress: progress }); } ); } catch (error) { CodePush.log(error); } }, componentDidMount() { CodePush.notifyApplicationReady(); }, getInitialState() { return { }; }, render() { let syncView, syncButton, progressView; if (this.state.syncMessage) { syncView = ( {this.state.syncMessage} ); } else { syncButton = ( ); } if (this.state.progress) { progressView = ( {this.state.progress.receivedBytes} of {this.state.progress.totalBytes} bytes received ); } return ( Welcome to CodePush! {syncButton} {syncView} {progressView} ); } }); let styles = StyleSheet.create({ image: { marginTop: 50, width: Dimensions.get('window').width - 100, height: 365 * (Dimensions.get('window').width - 100) / 651, }, container: { flex: 1, alignItems: 'center', backgroundColor: '#F5FCFF', paddingTop: 50 }, welcome: { fontSize: 20, textAlign: 'center', margin: 10 }, messages: { textAlign: 'center', }, }); AppRegistry.registerComponent('CodePushDemoApp', () => CodePushDemoApp);