katoikia-app/mobile-ui/components/Profile.js

147 lines
4.2 KiB
JavaScript
Raw Permalink Normal View History

2022-08-22 23:51:55 +00:00
import React, { useContext, useState } from "react";
2022-08-23 01:31:42 +00:00
import { API } from "../environment/api";
2022-08-22 06:51:05 +00:00
2022-08-17 16:36:33 +00:00
import {
2022-08-22 20:31:47 +00:00
Box, Button,
Center, FormControl, Heading, ScrollView, VStack
} from "native-base";
2022-08-17 16:36:33 +00:00
2022-08-22 20:31:47 +00:00
import { StyleSheet, TextInput } from "react-native";
import { UserContext } from "../context/UserContext";
2022-08-22 20:09:33 +00:00
2022-08-22 20:31:47 +00:00
export default function Profile({ navigation }) {
2022-08-22 20:09:33 +00:00
2022-08-23 01:31:42 +00:00
const baseURL = `${API.BASE_URL}/user/updateUser/`
2022-08-22 23:51:55 +00:00
//const userData = JSON.parse(JSON.stringify(route.params));
2022-08-22 20:09:33 +00:00
const [name, setName] = useState();
const [apellido, setApellido] =useState();
const [email, setEmail] = useState();
const [password, setPassword] = useState();
2022-08-23 01:31:42 +00:00
const userData = useContext(UserContext)
2022-08-22 20:38:18 +00:00
const id = userData.user._id;
2022-08-22 06:09:51 +00:00
2022-08-22 06:51:05 +00:00
console.log(userData.user);
2022-08-22 20:09:33 +00:00
const updateInfo = async() => {
2022-08-22 20:38:18 +00:00
const data = {
"_id": "6301df20dac7dcf76dcecade",
"dni": "1234567890",
"name": name,
"last_name": apellido,
"email": email,
"phone": 12121212,
"password": "827ccb0eea8a706c4c34a16891f84e7b",
"user_type": "3",
"status": "1",
"date_entry": "2022-08-21T07:30:09.929Z",
"community_id": null,
}
2022-08-22 20:09:33 +00:00
try {
2022-08-23 01:31:42 +00:00
await fetch(baseURL+`${id}`, {
2022-08-22 20:38:18 +00:00
2022-08-22 20:09:33 +00:00
cache: 'no-cache',
method: 'PUT',
2022-08-22 20:38:18 +00:00
body: JSON.stringify(data),
2022-08-22 20:09:33 +00:00
headers: {
'Content-Type': 'application/json'
}
})
.then(response => {
2022-08-22 20:38:18 +00:00
2022-08-23 01:31:42 +00:00
console.log(baseURL+`${id}`);
2022-08-22 20:09:33 +00:00
if (response.status != 201){
console.log('ocurrio un error ');
}else{
return response.json();
}
})
} catch (error) {
console.log("ERROR: " + error);
}
}
2022-08-17 16:36:33 +00:00
return (
2022-08-17 21:08:38 +00:00
<Center>
2022-08-22 06:51:05 +00:00
<ScrollView width='100%' h='550' ml='36' _contentContainerStyle={{
px: "20px",
mb: "4",
minW: "72"
}}>
2022-08-17 21:08:38 +00:00
<Box safeArea p="2" w="90%" maxW="290" py="8">
<Heading size="lg" color="coolGray.800" _dark={{
color: "warmGray.50"
}} fontWeight="semibold">
2022-08-22 06:51:05 +00:00
Bienvenido {userData.user.name}
2022-08-17 21:08:38 +00:00
</Heading>
<Heading mt="1" color="coolGray.600" _dark={{
color: "warmGray.200"
}} fontWeight="medium" size="xs">
2022-08-17 22:47:48 +00:00
Modifique sus datos
2022-08-17 21:08:38 +00:00
</Heading>
<VStack space={3} mt="5">
2022-08-22 06:51:05 +00:00
<FormControl>
<FormControl.Label>DNI</FormControl.Label>
2022-08-22 20:09:33 +00:00
<TextInput type="text" defaultValue={userData.user.dni} editable={false} />
</FormControl>
<FormControl>
<FormControl.Label>Teléfono</FormControl.Label>
<TextInput type="text" defaultValue={userData.user.phone} editable={false} />
2022-08-22 06:51:05 +00:00
</FormControl>
2022-08-17 21:08:38 +00:00
<FormControl>
<FormControl.Label>Nombre</FormControl.Label>
2022-08-22 20:09:33 +00:00
<TextInput style={styles.input} type="text" defaultValue={userData.user.name} onChangeText={(value) => setName(value) }/>
2022-08-17 21:08:38 +00:00
</FormControl>
<FormControl>
2022-08-22 06:51:05 +00:00
<FormControl.Label>Apellido</FormControl.Label>
2022-08-22 20:09:33 +00:00
<TextInput style={styles.input} type="text"defaultValue={userData.user.last_name} onChangeText={(value) => setApellido(value) } />
2022-08-17 21:08:38 +00:00
</FormControl>
<FormControl>
2022-08-22 06:51:05 +00:00
<FormControl.Label>Correo electrónico</FormControl.Label>
2022-08-22 20:09:33 +00:00
<TextInput style={styles.input} type="text" defaultValue={userData.user.email} onChangeText={(value) => setEmail(value) }/>
2022-08-17 21:08:38 +00:00
</FormControl>
<FormControl>
<FormControl.Label>Contraseña actual</FormControl.Label>
2022-08-22 20:09:33 +00:00
<TextInput style={styles.input} type="password" defaultValue="" onChangeText={(value) => setPassword(value) }/>
2022-08-17 21:08:38 +00:00
</FormControl>
2022-08-22 20:09:33 +00:00
<Button mt="2" backgroundColor="orange.300" onPress={() => updateInfo()}>
2022-08-17 21:08:38 +00:00
Actualizar
</Button>
2022-08-17 22:47:48 +00:00
<Button mt="6" colorScheme="error" onPress={() => navigation.navigate('Inicio')}>
2022-08-17 21:08:38 +00:00
Cerrar sesión
</Button>
</VStack>
</Box>
2022-08-22 06:51:05 +00:00
</ScrollView>
2022-08-22 20:31:47 +00:00
</Center>
)
2022-08-22 06:51:05 +00:00
}
const styles = StyleSheet.create({
input: {
height: 10,
2022-08-22 20:31:47 +00:00
margin: 3,
2022-08-22 06:51:05 +00:00
borderWidth: 0.5,
padding: 5,
flex: 1,
paddingTop: 9,
paddingRight: 19,
paddingBottom: 20,
paddingLeft: 0,
2022-08-22 20:31:47 +00:00
marginTop: 6,
marginBottom: 6,
2022-08-22 06:51:05 +00:00
borderRadius: 4
}
2022-08-22 20:31:47 +00:00
})
2022-08-22 06:51:05 +00:00