import React, { useState } from 'react'; import { SafeAreaView, StyleSheet, ScrollView, View, Text, StatusBar, Modal, TouchableHighlight, Image, FlatList, Dimensions, Linking, ImageBackground } from 'react-native'; import { useHeaderHeight } from '@react-navigation/stack'; 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 LunchEvents from './LunchEvents' import { TouchableOpacity } from 'react-native-gesture-handler'; import { NavigationContainer } from '@react-navigation/native' import { createStackNavigator } from '@react-navigation/stack' import Announcements from './Announcements' import I18n from './i18n.js' import AsyncStorage from '@react-native-async-storage/async-storage' const STORAGE_KEY = "teacherAnnouncements" const Stack = createStackNavigator() const windowWidth = Dimensions.get('window').width; const windowHeight = Dimensions.get('window').height; console.log(String(I18n.locale).split('-')[0]) const getCurrentDate=()=>{ var date = new Date().getDate(); var month = new Date().getMonth(); var year = new Date().getFullYear(); return new Date(year, month, date); } const Announcement = ({item}) => { const todayDate = getCurrentDate() const itemDate = new Date(item.item.date) var time_array = item.item.time.split(':') if (time_array[0]>12) { var time = String(parseInt(time_array[0])-12) + ':' + String(time_array[1]) + ' PM' } else { var time = String(time_array[0])+':'+String(time_array[1]) + ' AM' } const dateInfo = todayDate.getTime()===itemDate.getTime()&&item.item.time!==undefined?item.item.time:(item.item.date+", " + time) return ( {item.item.message} {dateInfo!==undefined?Posted {dateInfo}:<>} ) } function NewTeacherList(props) { return ( {I18n.t('dates.'+props.name)} } keyExtractor={item=>JSON.stringify(item)} /> ) } export const TeacherList = ({route}) => { const todayDate = getCurrentDate() const weekPastDate = new Date(); var pastDate = weekPastDate.getDate() - 7; weekPastDate.setDate(pastDate); const weekFutureDate = new Date(); var futureDate = weekFutureDate.getDate() + 7; weekFutureDate.setDate(futureDate); const today = [] const past = [] const future = [] var todayBoolean = true var pastBoolean = true var futureBoolean = true for (var i = 0; i < route.params.data.length; i++) { const itemDate = new Date(parseInt(String(route.params.data[i].date).split('-')[0]), parseInt(String(route.params.data[i].date).split('-')[1])-1, parseInt(String(route.params.data[i].date).split('-')[2])) if (itemDate.getTime() == todayDate.getTime()) { today.push(route.params.data[i]) } else if (itemDate.getTime() > todayDate.getTime() && itemDate.getTime() <= weekFutureDate.getTime()) { future.push(route.params.data[i]) } else if (itemDate >= weekPastDate && itemDate < todayDate) { //else if (itemDate.getTime() < todayDate.getTime()) { past.push(route.params.data[i]) } } if (today.length === 0) todayBoolean = false if (past.length === 0) pastBoolean = false if (future.length === 0) futureBoolean = false var noAnn = (todayBoolean||pastBoolean||futureBoolean) return ( {todayBoolean?:<>} {pastBoolean?:<>} {futureBoolean?:<>} {!noAnn?{I18n.t('announcements.noAnnouncements')}:<>} ) } function NewElement(props) { var name = props.name return ( {I18n.t('dates.'+props.name)} } keyExtractor={item=>JSON.stringify(item)} horizontal /> ) } export const whatsNew = ({route}) => { const todayDate = getCurrentDate() const weekPastDate = new Date(); var pastDate = weekPastDate.getDate() - 7; weekPastDate.setDate(pastDate); const weekFutureDate = new Date(); var futureDate = weekFutureDate.getDate() + 7; weekFutureDate.setDate(futureDate); const today = [] const past = [] const future = [] var todayBoolean = true var pastBoolean = true var futureBoolean = true for (var i = 0; i < route.params.data.length; i++) { const itemDate = new Date(parseInt(String(route.params.data[i].new_date).split('-')[0]), parseInt(String(route.params.data[i].new_date).split('-')[1])-1, parseInt(String(route.params.data[i].new_date).split('-')[2])) if (itemDate.getTime() == todayDate.getTime()) { today.push(route.params.data[i]) } else if (itemDate.getTime() > todayDate.getTime() && itemDate.getTime() <= weekFutureDate.getTime()) { future.push(route.params.data[i]) } else if (itemDate >= weekPastDate && itemDate < todayDate) { //else if (itemDate.getTime() < todayDate.getTime()) { past.push(route.params.data[i]) } } if (today.length === 0) todayBoolean = false if (past.length === 0) pastBoolean = false if (future.length === 0) futureBoolean = false const item = route.params return ( {todayBoolean?:<>} {pastBoolean?:<>} {futureBoolean?:<>} ) } export const NewItem = ({route}) => { const item = route.params.data return ( {item.new_date} {item.name} {item.text} ) } const AnnouncementToday = ({item}) => { const teacher = item.item.teacher var time_array = item.item.time.split(':') if (time_array[0]>12) { var time = String(parseInt(time_array[0])-12) + ':' + String(time_array[1]) + ' PM' } else { var time = String(time_array[0])+':'+String(time_array[1]) + ' AM' } return ( {item.item.message} {time} {teacher} ) } const New = (props) => { const item = props.item const iconURI = item.item.icon !== undefined?`data:image/png;charset=utf-8;base64,${item.item.icon}`:'' const textLength = item.item.name.length var text = item.item.name if (textLength >=17) { text = text.substring(0, 14)+"..." } return ( props.navigation.navigate('NewItem', {data:props.item.item})}> {item.item.new_date} {text} ) } function Home1() { const [modalVisible, setModalVisible] = useState(false); return ( {setModalVisible(false);}}> {url} ) } const background = () function HomeStack() { return ( background }} /> ({ title:I18n.t('home.whatsNew'), headerTitleStyle:styles.headerTitle, headerBackground: ()=>background, //headerLeft:null, headerBackTitleVisible:false, headerTintColor: 'black', headerTitleAlign: 'center' })} /> ({ title:I18n.t('home.Announcements'), headerTitleStyle:styles.headerTitle, headerBackground: ()=>background, //headerLeft:null, headerBackTitleVisible:false, headerTintColor: 'black', headerTitleAlign: 'center' })} /> ({ headerTitleStyle:[styles.headerTitle], title:route.params.name, headerRight:()=>(<>), headerBackground: ()=>background, //headerLeft:null, headerBackTitleVisible:false, headerTintColor: 'black', headerTitleAlign: 'center' })} /> background, headerTitleAlign: 'center', headerBackTitleVisible:false, headerTintColor: 'black' }} /> background, //headerLeft:null, headerBackTitleVisible:false, headerTintColor: 'black', headerTitleAlign: 'center' }} /> ({ headerTitleStyle:[styles.headerTitle], title:I18n.t('home.news'), headerRight:()=>(<>), headerBackground: ()=>background, //headerLeft: null, headerBackTitleVisible:false, headerTintColor: 'black', headerTitleAlign: 'center' })} /> ) } function HomeScreen (props) { var showStudent = true if (props.studentData.length==0) {showStudent = false} const iconURI = null //const iconURI = props.studentData.image !== undefined?`data:image/png;charset=utf-8;base64,${props.studentData.image}`:``; global.headerHeight = useHeaderHeight(); const todayDate = getCurrentDate() var todayAnn = [] var todayNew = [] var todayAnnBoolean = true var todayNewBoolean = true var showLunch = false for (var i = 0; i < props.annData.length; i++) { const itemDate = new Date(parseInt(String(props.annData[i].date).split('-')[0]), parseInt(String(props.annData[i].date).split('-')[1])-1, parseInt(String(props.annData[i].date).split('-')[2])) if (itemDate.getTime() == todayDate.getTime()) todayAnn.push(props.annData[i]) } for (var i = 0; i < props.data.length; i++) { const itemDate = new Date(parseInt(String(props.data[i].new_date).split('-')[0]), parseInt(String(props.data[i].new_date).split('-')[1])-1, parseInt(String(props.data[i].new_date).split('-')[2])) if (itemDate.getTime() == todayDate.getTime()) todayNew.push(props.data[i]) } if (todayAnn.length === 0) todayAnnBoolean = false if (todayNew.length ===0) todayNewBoolean = false todayAnn = todayAnn.slice(0, 4) var currentTime = new Date(); var time = currentTime.toLocaleTimeString().replace(/([\d]+:[\d]{2})(:[\d]{2})(.*)/, "$1$3").split(' ') var dayOfWeek = currentTime.getDay() var hourTime = parseInt(time[0].split(':')[0]) if (dayOfWeek!=0 && dayOfWeek!=6 && ((hourTime>=10 && time[1]=='AM') || (hourTime ==12 && parseInt(time[0].split(':')[1])<=30 && time[1]=='PM'))) { showLunch = true } if (time[1]!='PM' && time[1]!='AM' && dayOfWeek!=0 && dayOfWeek!=6 && hourTime>=10 && (hourTime <=12 && parseInt(time[0].split(':')[1])<=30)) { showLunch = true } return ( {showLunch? {I18n.t('home.shortcut')} {'\t'} props.navigation.navigate(LunchEvents)}> {I18n.t('home.seeLunch')} :<>} {I18n.t('home.whatsNew')} props.navigation.navigate('new', {data:props.data, navigation: props.navigation})}> {!todayNewBoolean?{I18n.t('home.noNews')}:} keyExtractor={item=>JSON.stringify(item)} horizontal />} {I18n.t('home.Announcements')} props.navigation.navigate(Announcements)}> {!todayAnnBoolean?{I18n.t('home.noAnnouncements')}:} keyExtractor={item=>JSON.stringify(item)} />} {showStudent? {I18n.t('home.SOTW')} {props.studentData[props.studentData.length-1].name}, Grade {props.studentData[props.studentData.length-1].grade} props.navigation.navigate(StudentWeek)}> {I18n.t('home.moreOn')} {props.studentData[props.studentData.length-1].name} : } ) } class Home extends React.Component { constructor(props) { super(props) this.state = { studentData:[], annData:[], data:[], lunchData:[], 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/`+String(I18n.locale).split('-')[0]+`/student`,{ headers: { 'Cache-Control': 'no-cache' }} ).then((response) => { return response.text(); }).then((json) => { const data = JSON.parse(json) data.sort((a,b)=>a.id-b.id) this.setState({studentData: data,isLoading:false}); }).catch((error) => console.error(error)) fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/lunch_events`,{ headers: { 'Cache-Control': 'no-cache' }} ).then((response) => { return response.text(); }).then((json) => { const data = JSON.parse(json) data.sort((a,b)=>a.id-b.id) this.setState({lunchData: data}); }).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/`+String(I18n.locale).split('-')[0]+`/new`,{ headers: { 'Cache-Control': 'no-cache' } }) .then((response) => { return response.text(); }) .then((json) => { const data = JSON.parse(json) data.sort((a,b)=>a.id-b.id) data.sort((a,b)=>new Date(b.date).getTime()-new Date(a.date).getTime()) this.setState({data: data}); console.log(this.state.data) }) .catch((error) => console.error(error)) } getData1() { fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/announcements`,{ headers: { 'Cache-Control': 'no-cache' }}) .then((response) => { return response.text() }) .then((txt) => { const data = JSON.parse(txt); data.sort((a,b)=>a.id-b.id) 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}); console.log(annData) }).catch((error) => console.error(error)) } render() { if (this.state.isLoading) { return } else { return ( )} } } export default HomeStack;