react-native-1app
Version:
293 lines (272 loc) • 8.97 kB
JavaScript
;
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=``