import React,{ Component } from 'react'; import { Dimensions, StyleSheet, Text, TouchableOpacity, View, } from 'react-native'; import CodePush from "react-native-code-push"; class CodePushPa extends Component { constructor(props) { super(props); this.state = { restartAllowed: true, title:'' }; } codePushStatusDidChange(syncStatus) { switch(syncStatus) { case CodePush.SyncStatus.CHECKING_FOR_UPDATE: this.setState({ syncMessage: "Checking for update." }); break; case CodePush.SyncStatus.DOWNLOADING_PACKAGE: this.setState({ syncMessage: "Downloading package." }); break; case CodePush.SyncStatus.AWAITING_USER_ACTION: this.setState({ syncMessage: "Awaiting user action." }); break; case CodePush.SyncStatus.INSTALLING_UPDATE: this.setState({ syncMessage: "Installing update." }); break; case CodePush.SyncStatus.UP_TO_DATE: this.setState({ syncMessage: "App up to date.", progress: false }); break; case CodePush.SyncStatus.UPDATE_IGNORED: this.setState({ syncMessage: "Update cancelled by user.", progress: false }); break; case CodePush.SyncStatus.UPDATE_INSTALLED: this.setState({ syncMessage: "Update installed and will be applied on restart.", progress: false }); break; case CodePush.SyncStatus.UNKNOWN_ERROR: this.setState({ syncMessage: "An unknown error occurred.", progress: false }); break; } } codePushDownloadDidProgress(progress) { this.setState({ progress }); } toggleAllowRestart() { this.state.restartAllowed ? CodePush.disallowRestart() : CodePush.allowRestart(); this.setState({ restartAllowed: !this.state.restartAllowed }); } getUpdateMetadata() { CodePush.getUpdateMetadata(CodePush.UpdateState.RUNNING) .then((metadata) => { this.setState({ syncMessage: metadata ? JSON.stringify(metadata) : "Running binary version", progress: false }); }, (error) => { this.setState({ syncMessage: "Error: " + error, progress: false }); }); } /** Update is downloaded silently, and applied on restart (recommended) */ sync() { CodePush.sync( {}, this.codePushStatusDidChange.bind(this), this.codePushDownloadDidProgress.bind(this) ); } /** Update pops a confirmation dialog, and then immediately reboots the app */ syncImmediate() { CodePush.sync( { installMode: CodePush.InstallMode.IMMEDIATE, updateDialog: true }, this.codePushStatusDidChange.bind(this), this.codePushDownloadDidProgress.bind(this) ); } render() { let progressView; if (this.state.progress) { progressView = ( {this.state.progress.receivedBytes} of {this.state.progress.totalBytes} bytes received ); } return ( Welcome to CodePush! Press for background sync Press for dialog-driven sync {progressView} Restart { this.state.restartAllowed ? "allowed" : "forbidden"} Press for Update Metadata {this.state.syncMessage || ""} ); } } const styles = StyleSheet.create({ container: { flex:1, flexDirection:'column', backgroundColor:'white', }, image: { margin: 30, width: Dimensions.get("window").width - 100, height: 365 * (Dimensions.get("window").width - 100) / 651, }, messages: { marginTop: 30, margin: 10, textAlign: "center", }, restartToggleButton: { color: "blue", textAlign: "center", fontSize: 17, margin: 10 }, syncButton: { color: "green", textAlign: "center", fontSize: 17, margin: 10, }, welcome: { fontSize: 20, textAlign: "center", margin: 20 }, }); /** * Configured with a MANUAL check frequency for easy testing. For production apps, it is recommended to configure a * different check frequency, such as ON_APP_START, for a 'hands-off' approach where CodePush.sync() does not * need to be explicitly called. All options of CodePush.sync() are also available in this decorator. */ let codePushOptions = { checkFrequency: CodePush.CheckFrequency.MANUAL }; const CodePushPage = CodePush(codePushOptions)(CodePushPa); export default CodePushPage;