// import * as Expo from 'expo' import React from 'react' import { Text, View, AsyncStorage, Image, } from 'react-native' import Uppy from '@uppy/core' import Tus from '@uppy/tus' import UppyFilePicker from '@uppy/react-native' import FileList from './FileList' import PauseResumeButton from './PauseResumeButton' import ProgressBar from './ProgressBar' import SelectFiles from './SelectFilesButton' import getTusFileReader from './tusFileReader' export default class App extends React.Component { constructor () { super() this.state = { progress: 0, total: 0, file: null, uploadURL: null, isFilePickerVisible: false, isPaused: false, uploadStarted: false, uploadComplete: false, info: null, totalProgress: 0, } this.isReactNative = (typeof navigator !== 'undefined' && typeof navigator.product === 'string' && navigator.product.toLowerCase() === 'reactnative') this.showFilePicker = this.showFilePicker.bind(this) this.hideFilePicker = this.hideFilePicker.bind(this) this.togglePauseResume = this.togglePauseResume.bind(this) console.log('Is this React Native?', this.isReactNative) this.uppy = new Uppy({ autoProceed: true, debug: true }) this.uppy.use(Tus, { endpoint: 'https://tusd.tusdemo.net/files/', urlStorage: AsyncStorage, fileReader: getTusFileReader, chunkSize: 10 * 1024 * 1024, // keep the chunk size small to avoid memory exhaustion }) this.uppy.on('upload-progress', (file, progress) => { this.setState({ progress: progress.bytesUploaded, total: progress.bytesTotal, totalProgress: this.uppy.state.totalProgress, uploadStarted: true, }) }) this.uppy.on('upload-success', () => { // console.log(file.name, response) }) this.uppy.on('complete', (result) => { this.setState({ status: 'Upload complete ✅', uploadURL: result.successful[0] ? result.successful[0].uploadURL : null, uploadComplete: true, uploadStarted: false, }) console.log('Upload complete:', result) }) this.uppy.on('info-visible', () => { const { info } = this.uppy.getState() this.setState({ info, }) console.log('uppy-info:', info) }) this.uppy.on('info-hidden', () => { this.setState({ info: null, }) }) } showFilePicker () { this.setState({ isFilePickerVisible: true, uploadStarted: false, uploadComplete: false, }) } hideFilePicker () { this.setState({ isFilePickerVisible: false, }) } togglePauseResume () { if (this.state.isPaused) { this.uppy.resumeAll() this.setState({ isPaused: false, }) } else { this.uppy.pauseAll() this.setState({ isPaused: true, }) } } render () { return ( Uppy in React Native {this.state.info ? ( {this.state.info.message} ) : null} {/* {this.state.status ? 'Status: ' + this.state.status : null} {this.state.progress} of {this.state.total} */} ) } }