import React, { useState } from 'react'; import { SafeAreaView, StyleSheet, ScrollView, View, Text, StatusBar, Modal, TouchableHighlight, Image, FlatList, Linking, } from 'react-native'; import { Header, LearnMoreLinks, Colors, DebugInstructions, ReloadInstructions, } from 'react-native/Libraries/NewAppScreen'; import styles from './styles/morestyles' import liststyles from './styles/liststyles' import { url } from './resources/fetchInfo.json' import LinearGradient from 'react-native-linear-gradient'; import StudentWeek from './StudentWeek'; import { TouchableOpacity } from 'react-native-gesture-handler'; import { NavigationContainer } from '@react-navigation/native' import { createStackNavigator } from '@react-navigation/stack' import Announcements from './Announcements' import AsyncStorage from '@react-native-community/async-storage' const getCurrentDate=()=>{ var date = new Date().getDate(); var month = new Date().getMonth() + 1; var year = new Date().getFullYear(); return year + ',' + month + ',' + date; } const getWeekDate=()=>{ var date = new Date().getDate()-8; var month = new Date().getMonth()+1; var year = new Date().getFullYear(); return year + ',' + month + ',' + date; } const STORAGE_KEY = "teacherAnnouncements" const Stack = createStackNavigator() const Announcement = ({item}) => { const date = new Date const dateStr = `${date.getMonth()+1}/${date.getDate()}/${date.getFullYear()}` const dateInfo = dateStr===item.item.date&&item.item.time!==undefined?item.item.time:item.item.date; return ( {item.item.message} {dateInfo!==undefined?{dateInfo}:<>} ) } export const TeacherList = ({route}) => { return ( } keyExtractor={item=>JSON.stringify(item)} /> ) } export const whatsNew = ({route}) => { const item = route.params return ( Today } keyExtractor={item=>JSON.stringify(item)} horizontal /> Future } keyExtractor={item=>JSON.stringify(item)} horizontal /> Past Week } keyExtractor={item=>JSON.stringify(item)} horizontal /> ) } const Today = ({item}) => { const newIconURI = item.item.icon !== undefined?`data:image/png;charset=utf-8;base64,${item.item.icon}`:'' const today = new Date(getCurrentDate()) const itemDate = new Date(item.item.date) if (itemDate.getTime() == today.getTime()) { return ( setVisible(!visible)} activeOpacity={0.8}> {item.item.name} {item.item.date} ) } else { return ( null ) } } const Future = ({item}) => { const newIconURI = item.item.icon !== undefined?`data:image/png;charset=utf-8;base64,${item.item.icon}`:'' const today = new Date(getCurrentDate()) const itemDate = new Date(item.item.date) if (itemDate.getTime() > today.getTime()) { return ( setVisible(!visible)} activeOpacity={0.8}> {item.item.name} {item.item.date} ) } else { return ( null ) } } const PastWeek = ({item}) => { const newIconURI = item.item.icon !== undefined?`data:image/png;charset=utf-8;base64,${item.item.icon}`:'' const today = new Date(getCurrentDate()) const week = new Date(getWeekDate()) const itemDate = new Date(item.item.date) if (itemDate.getTime() >= week.getTime() && today.getTime()>itemDate.getTime()) { return ( setVisible(!visible)} activeOpacity={0.8}> {item.item.name} {item.item.date} ) } else { return ( null ) } } const AnnouncementToday = ({item}) => { const date = new Date const dateStr = `${date.getMonth()+1}/${date.getDate()}/${date.getFullYear()}` const dateInfo = dateStr===item.item.date&&item.item.time!==undefined?item.item.time:''; const itemDate = new Date(item.item.date) const today = new Date(getCurrentDate()) const teacher = item.item.teacher !==""?item.item.teacher:"No Teacher" if (itemDate.getTime()===today.getTime()) { return ( {item.item.message} {teacher}{'\t'}{dateInfo} ) } else { return ( null ) } } const New = ({item}) => { const calendarIconURI = item.item.icon !== undefined?`data:image/png;charset=utf-8;base64,${item.item.icon}`:'' const today = new Date(getCurrentDate()) const week = new Date(getWeekDate()) const itemDate = new Date(item.item.date) if (itemDate.getTime() >= today.getTime()) { return ( setVisible(!visible)} activeOpacity={0.8}> {item.item.name} {item.item.date} ) } else if (itemDate.getTime() >= week.getTime()){ return ( setVisible(!visible)} activeOpacity={0.8}> {item.item.name} {item.item.date} ) } else { return ( null ) } } function Home1() { const [modalVisible, setModalVisible] = useState(true); return ( {setModalVisible(false);}}> {url} ) } const background = () function HomeStack() { return ( background }} /> ({ title:"What's New", headerTitleStyle:styles.headerTitle, headerBackground: ()=>background })} /> ({ title:"Announcements", headerTitleStyle:styles.headerTitle, headerBackground: ()=>background })} /> ({ headerTitleStyle:[styles.headerTitle,{alignSelf:'center',fontSize:Math.min(24,24*23/route.params.name.length)}], title:route.params.name, headerRight:()=>(<>), headerBackground: ()=>background })} /> ) } function HomeScreen (props) { const iconURI = props.studentData.icon !== undefined?`data:image/png;charset=utf-8;base64,${props.studentData.icon}`:``; return( What's New? props.navigation.navigate('new', {data:props.data})}> View All } keyExtractor={item=>JSON.stringify(item)} horizontal /> Student of the Week {props.studentData.name} Grade {props.studentData.year} Hobbies: {props.studentData.hobbies} Achievements: {props.studentData.achievements} Messages: {props.studentData.messages} Announcements props.navigation.navigate(Announcements)}> View All } keyExtractor={item=>JSON.stringify(item)} /> Linking.openURL(props.challengeData.link)}> Linking.openURL(props.pollData.link)}> ) } class Home extends React.Component { constructor(props) { super(props) this.state = { studentData: [], annData:[], data:[], pollData:[], challengeData:[], teacherNames: [], favoriteNames: [], isLoading:true } } addFavorite = (name) => { const favoriteNames = this.state.favoriteNames.slice().map(({name})=>name) const index = favoriteNames.indexOf(name) if (index < 0) { favoriteNames.push(name) } else { favoriteNames.splice(index,1) } favoriteNames.sort() this.setState({favoriteNames:favoriteNames.map(name=>({name:name}))}) AsyncStorage.setItem(STORAGE_KEY,JSON.stringify(favoriteNames)).catch(console.log).done() } componentDidMount() { fetch(`${url}/api/en/challenge`,{ headers: { 'Cache-Control': 'no-cache' }} ).then((response) => { return response.text(); }).then((json) => { this.setState({challengeData: JSON.parse(json),isLoading:false}); }).catch((error) => console.error(error)) fetch(`${url}/api/en/student`,{ headers: { 'Cache-Control': 'no-cache' }} ).then((response) => { return response.text();list }).then((json) => { this.setState({studentData: JSON.parse(json),isLoading:false}); }).catch((error) => console.error(error)) this.getData() this.props.navigation.addListener( 'focus', () => { this.getData() } ); this.getData1() AsyncStorage.getItem(STORAGE_KEY) .then(value=>value==null?[]:JSON.parse(value).map(x=>({name:x}))) .then(names=>this.setState({favoriteNames:names})) .catch(console.log) .done() } getData() { fetch(`${url}/api/en/new`,{ headers: { 'Cache-Control': 'no-cache' } }) .then((response) => { return response.text(); }) .then((json) => { const data = JSON.parse(json).data data.sort((a,b)=>new Date(b.date).getTime()-new Date(a.date).getTime()) this.setState({data: data}); }) .catch((error) => console.error(error)) } getData1() { fetch(`${url}/api/en/announcements`,{ headers: { 'Cache-Control': 'no-cache' } } ) .then((response) => { return response.text() }) .then((txt) => { const data = JSON.parse(txt).data; const teacherNames = [...new Set(data.filter(x=>x.teacher!=null&&x.teacher.trim()!=='').map(x=>x.teacher))]; teacherNames.sort() this.setState({annData: data, teacherNames: teacherNames.map(x=>({name:x})),isLoading:false}); }) .catch((error) => console.error(error)) } render() { return ( ) } } export default HomeStack;