UNPKG

react-native-1app

Version:

293 lines (272 loc) 8.97 kB
'use strict'; import React from 'react'; import {Alert,StyleSheet,View,Text,TouchableOpacity,ActivityIndicator,ImageBackground,Modal,Dimensions,Image} from "react-native"; import GridView from "react-native-super-grid"; import ImageZoom from 'react-native-photo-view'; // import {ImageUpload} from 'react-native-1app' import ImageUpload from './ImageUpload' export default class FotosUpload extends React.Component { constructor(props) { super(props); this.state = { pos:0, open:false }; } setPos(pos){ let{value=[]}=this.props; if(pos < value.length) this.setState({pos}); } upLoad() { let {value=[],onChange}=this.props; ImageUpload.pegarFoto( base64 => { if(!base64) return; this.setState({ load: true }); ImageUpload.upLoad(base64,(link,error)=>{ this.setState({ load: false }); if(!value) value=[]; value.push({url_img:link}) onChange(value); },this.props) },this.props); } delete(index){ let{value,onChange}=this.props; Alert.alert( 'Apagar', 'Deseja apagar este item N:'+(index+1)+'?', [ {text: 'Sim', onPress: () => { value.splice(index, 1); this.setState({pos:(index-1)}); onChange(value) }}, {text: 'Não', onPress: () => console.log()} ] ) } render() { let{value,onChange,style,styleImage,itemDimension,disabled,...prop}=this.props; if(!value)value=[]; let{pos}=this.state; if(pos >= value.length) pos=0; return ( <View style={[styles.body,style]}> <GridView style={styles.gridview} itemDimension={itemDimension} spacing={5} items={[...value,{add:true}]} renderItem={(rowData, sectionID, rowID) => { if(disabled) return null; if(rowData.add) return( <TouchableOpacity style={[styles.bottonAdd,styleImage]} disabled={this.state.load} onPress={()=>{ this.upLoad(); }} > {!this.state.load&&[ <Text style={styles.iconAction}> {"+"} </Text>, <Text style={styles.text}> {"Adicionar foto"} </Text> ]|| <ActivityIndicator style={[ { backgroundColor:"rgba(0,0,0,0)"}]} /> } </TouchableOpacity> ) return ( <TouchableOpacity style={[styles.itemImagem,styleImage]} disabled={disabled} onPress={()=>{ this.setState({open:true}); }} > <Image source={{uri:rowData.url_img }} style={styles.itemImagem} onLoadStart={(e) => this.setState({["load"+sectionID]: true})} onLoadEnd={(e) => this.setState({["load"+sectionID]: false})} /> <Modal animationType={"slide"} transparent={true} visible={this.state.open} onRequestClose={() => { this.setState({open:false}) }} > {this.state.open?( <Zoom {...this.props} activity={this} source={{uri:rowData.url_img }} delete={()=>{this.delete(sectionID)}} /> ):(<View/>)} </Modal> {this.state["load"+sectionID]&& <View style={styles.bodyLoad}> <ActivityIndicator style={{height: 80}} size="large" /> </View> } </TouchableOpacity> ); }} /> </View> ); } } FotosUpload.defaultProps={ value:[], label:null, onChange:()=>console.log("not onChange"), style:{}, styleImage:{}, onResposta:(res,error)=>({result:res,error}), itemDimension:100, disabled:false }; class Zoom extends React.Component { constructor(props) { super(props); this.state = { }; } componentDidMount() { } render() { var source = this.props.source; if(!this.props.source){ source = {}; } console.log(source); var style = {}; style.width = Dimensions.get('window').width; style.height = Dimensions.get('window').height; return (//resizeMode = {this.props.resizeMode} <View style={ { "alignSelf": "stretch", "flex": 1, backgroundColor: "#000" } }> <ImageZoom resizeMode={ "contain" } source={source} minimumZoomScale={1} maximumZoomScale={3} androidScaleType="fitCenter" onLoad={() => console.log("Image loaded!")} style={style} /> <TouchableOpacity style={[styles.bottonAction,{left:5}]} underlayColor = 'rgba(220,220,220,1)' onPress = {()=>{ if(this.props.activity){ this.props.activity.setState({open:false}); } }} > <Image style={styles.imagenIcon} resizeMode = {"cover"} source={{uri: iconVoltor, scale: 1}} > </Image> </TouchableOpacity> <TouchableOpacity style={[styles.bottonAction,{right:5}]} underlayColor = 'rgba(220,220,220,1)' onPress = {()=>{ if(this.props.activity){ this.props.activity.setState({open:false}); this.props.delete() } }} > <Image style={styles.imagenIcon} resizeMode = {"cover"} source={{uri: iconDeletar, scale: 1}} > </Image> </TouchableOpacity> </View> ); } } var styles = StyleSheet.create( { "body": { justifyContent: "center", alignItems: "center", flexDirection:"column", minWidth:100, alignSelf:"stretch", flex: 1, }, bodyLoad:{ top: 0, left: 0, right: 0, bottom: 0, position: "absolute", justifyContent: "center", alignItems: "center" }, gridview: { alignSelf: "stretch", flex: 1 }, itemImagem: { alignSelf: "stretch", flex: 1, "backgroundColor": "rgba(250,250,250,1)", height:100, borderRadius:10 }, viewAdd: { justifyContent: "center", alignItems: "center", flexDirection:"column", alignSelf:"stretch", flex: 1, }, bottonAdd:{ justifyContent: "center", alignItems: "center", flexDirection:"column", alignSelf:"stretch", "backgroundColor": "rgba(250,250,250,1)", flex: 1, height:100, borderRadius:10 }, iconAction:{ "color": "rgba(66,66,66,1)", "fontSize": 35, fontWeight:"bold", marginBottom:5 }, imagenIcon:{ "width": 30, "height": 30, "marginLeft": 0, "marginTop": 0, tintColor:"rgba(255,255,255,1)" }, text:{ alignSelf: "stretch", textAlign: "center", fontSize: 11, fontWeight: "800", color: "rgba(66,66,66,1)", }, bottonAction:{ "position": "absolute", "borderRadius": 5, "flexDirection": "column", "alignItems": "center", "justifyContent": "center", "backgroundColor": "rgba(0,0,0,0.5)", "width": 50, "height": 50, "top": 20 } } ); let iconVoltor=` AAABIAAAASABGyWs+AAAACXZwQWcAAAAYAAAAGAB4TKWmAAAAUElEQVRIx2NgGAVDCvz//z/q////tbQ0/M9/CHCgpeENo4YPL8NJBujmMVHVdWT6on7 UkpFpiQOx+liIVcjIyLgMmsxVGBkZD9DEF6OAJgAAorj7ZBCISyAAAAAASUVORK5CYII=` let iconDeletar=``