import React, {useState, useEffect} from 'react'; import { FlatList, StatusBar, StyleSheet, Text, TouchableOpacity, TextInput, View, Button, ActivityIndicator, Alert, ScrollView, RefreshControl } from "react-native"; import axios from 'axios' import * as SecureStore from 'expo-secure-store'; import Modal from 'react-native-modal'; import {Picker} from '@react-native-community/picker'; const Item = ({ item, onPress, style }) => ( {`${item.code}: ${item.grade}`} ); // separates results, taken from https://stackoverflow.com/questions/60350768/how-to-make-search-bar-with-dropdown-list-in-react-native const renderSeparator = () => { return ( ); }; const CurrentCourses = () =>{ const [courses, setCourses] = useState(null) const [refreshing, setRefreshing] = useState(false) const [selectedId, setSelectedId] = useState(null); // course_id const [animating, setAnimating] = useState(false) const [modalVisible, setModalVisible] = useState(false) const [year, setYear] = useState(1) const [semester, setSemester] = useState(1) const [grade, setGrade] = useState('A') const toggle = ()=>{ setModalVisible(!modalVisible) setSelectedId(null) } const getCoursesBySemester = async()=>{ const token = await SecureStore.getItemAsync('token') let id = await SecureStore.getItemAsync('id') let user_id = parseInt(id) console.log(user_id) try { let response = await axios(`http://7f9219a069f7.ngrok.io/api/get_all_courses_by_semester?user_id=${user_id}&year=${year}&semestre=${semester}`, { method: 'GET', headers: { 'content-type': 'application/json', Authorization: `Token ${token}` } }) // console.log(response.data.list) setCourses(response.data.list) } catch(error){ console.log(error) } } const deleteOneCourse = async()=>{ const token = await SecureStore.getItemAsync('token') let id = await SecureStore.getItemAsync('id') let user_id = parseInt(id) try { let response = await axios(`http://7f9219a069f7.ngrok.io/api/delete_course`, { method: 'DELETE', headers: { 'content-type': 'application/json', Authorization: `Token ${token}` }, data:{ user_id: user_id, course_id: selectedId, year: year, semestre: semester } }) setAnimating(true) // after 3 seconds, the courses, the modal and the activity indicator will disappear setTimeout(()=>{ setAnimating(false) setModalVisible(false) setSelectedId(null) }, 3000) setTimeout(()=>{ Alert.alert(response.data.msg) }, 5000) getCoursesBySemester() // get current courses again } catch(error){ console.log(error) } } const updateGrade = async()=>{ const token = await SecureStore.getItemAsync('token') let id = await SecureStore.getItemAsync('id') let user_id = parseInt(id) console.log(semester) console.log(year) try { let response = await axios(`http://7f9219a069f7.ngrok.io/api/update_grade_and_gpa`, { method: 'PATCH', headers: { 'content-type': 'application/json', Authorization: `Token ${token}` }, data:{ user_id: user_id, course_id: selectedId, year: year, semestre: semester, grade: grade } }) setAnimating(true) // after 3 seconds, the courses, the modal and the activity indicator will disappear setTimeout(()=>{ setAnimating(false) setModalVisible(false) setSelectedId(null) }, 3000) setTimeout(()=>{ Alert.alert(response.data.msg) }, 5000) getCoursesBySemester() // get current courses again } catch(error){ console.log(error) } } const onRefresh = React.useCallback(async ()=>{ setRefreshing(true) getCoursesBySemester() setRefreshing(false) }, [refreshing]) useEffect(()=>{ getCoursesBySemester() },[year, semester]) const renderItem = ({ item }) => { const backgroundColor = item.course_id === selectedId ? "#e60505" : "#fafbfc"; return ( { setModalVisible(true) setSelectedId(item.course_id) setYear(item.year) setSemester(item.semestre) setGrade(item.grade) }} style={{ backgroundColor }} /> ); }; // if student does not have courses currently, return this if(courses === null || courses.length === 0){ return ( } > No tienes cursos ) } // console.log(grade) return ( item.course_id.toString()} extraData={selectedId} ItemSeparatorComponent={renderSeparator} refreshControl={} />