diff --git a/app/Announcements.js b/app/Announcements.js index a3f8bdd..45c5e2c 100644 --- a/app/Announcements.js +++ b/app/Announcements.js @@ -40,14 +40,22 @@ const getCurrentDate=()=>{ const Announcement = ({item}) => { const todayDate = getCurrentDate() const itemDate = new Date(item.item.date) - const dateInfo = todayDate.getTime()===itemDate.getTime()&&item.item.time!==undefined?item.item.time:(item.item.date+", " + item.item.time) + + 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?{dateInfo}:<>} + {dateInfo!==undefined?Posted {dateInfo}:<>} ) @@ -84,7 +92,7 @@ export const TeacherList = ({route}) => { var futureBoolean = true for (var i = 0; i < route.params.data.length; i++) { - const itemDate = new Date(route.params.data[i].date) + 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]) } @@ -173,8 +181,8 @@ class Announcements extends React.Component { return response.text() }) .then((txt) => { - const data = JSON.parse(txt).data; - console.log(data) + 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({data: data, teacherNames: teacherNames.map(x=>({name:x})),isLoading:false}); @@ -185,7 +193,6 @@ class Announcements extends React.Component { render() { return ( - x.teacher==null||x.teacher.trim()==='')} name="No Teacher" navigation={this.props.navigation} /> this.state.favoriteNames.map(({name})=>name).indexOf(x.name) < 0))} renderItem={({item})=>= 0?'red':'lightgrey'} item={item} data={this.state.data.filter(x=>x.teacher===item.name)} name={item.name} navigation={this.props.navigation} icon={true} addFavorite={this.addFavorite}/>} diff --git a/app/Calendar.js b/app/Calendar.js index 88a876c..10384ad 100644 --- a/app/Calendar.js +++ b/app/Calendar.js @@ -174,7 +174,7 @@ class Calendar extends React.Component { } getData() { - fetch(`http://127.0.0.1:8080/api/en/events`,{ + fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/events`,{ headers: { 'Cache-Control': 'no-cache' } }) diff --git a/app/ChallengeWeek.js b/app/ChallengeWeek.js index 01a1099..70b4e73 100644 --- a/app/ChallengeWeek.js +++ b/app/ChallengeWeek.js @@ -28,7 +28,8 @@ class ChallengeWeek extends React.Component { super(props) this.state = { isLoading: true, - flip: true + flip: true, + data:[] } } @@ -40,74 +41,31 @@ class ChallengeWeek extends React.Component { ).then((response) => { return response.text(); }).then((json) => { - this.setState({data: JSON.parse(json),isLoading:false}); + const data = JSON.parse(json) + data.sort((a,b)=>a.id-b.id) + this.setState({data: data,isLoading:false}); }).catch((error) => console.error(error)) - - /*this.animatedValue=new Animated.Value(0); - this.value=0; - this.animatedValue.addListener(({value}) => { - this.value=value; - }) - this.frontInterpolate = this.animatedValue.interpolate({ - inputRange:[0,180], - outputRange:['0deg', '180deg'], - }) - this.backInterpolate = this.animatedValue.interpolate({ - inputRange:[0,180], - outputRange: ['180deg','360deg'] - })*/ } - - /*flipCard() { - if (this.value >= 90) { - Animated.spring(this.animatedValue, { - toValue:0, - friction:8, - tension: 10 - }).start(); - } - else { - Animated.spring(this.animatedValue, { - toValue:180, - friction: 8, - tension: 10 - }).start(); - } - this.setState({flip:!this.state.flip}) - }*/ render() { - {/*const frontAnimatedStyle = { - transform: [ - {rotateY:this.frontInterpolate} - ] - } - const backAnimatedStyle = { - transform: [ - {rotateY:this.backInterpolate} - ] - } - var styling={} - var styling2={} - if (this.state.flip) { - styling=({height: '100%', width: '100%', backgroundColor: 'white', borderRadius: 20, textAlign: 'center', display: 'flex', alignContent: 'center', padding: '5%', paddingTop: '15%', borderColor: 'red', borderWidth: 1}) - styling2=({display:'none'}) - } - else { - styling=({display:'none'}) - styling2=({height: '100%', width: '100%', backgroundColor: 'white', borderRadius: 20, textAlign: 'center', display: 'flex', alignContent: 'center', padding: '5%', paddingTop: '15%', borderColor: 'red', borderWidth: 1}) - }*/} - if (this.state.isLoading) { return } else { - return ( - - {this.state.data.title} - {this.state.data.text} - Linking.openURL(this.state.data.link)}>{I18n.t("challenge.link")} - - ) + if (this.state.data[this.state.data.length-1]==undefined) { + return ( + + No challenge + + ) + } else { + return ( + + {this.state.data[this.state.data.length-1].title} + {this.state.data[this.state.data.length-1].text} + Linking.openURL(this.state.data[this.state.data.length-1].link)}>{I18n.t("challenge.link")} + + ) + } } } } diff --git a/app/Clubs.js b/app/Clubs.js index ad4fb8d..1846421 100644 --- a/app/Clubs.js +++ b/app/Clubs.js @@ -148,8 +148,12 @@ class Clubs extends React.Component { return response.text(); }) .then((json) => { - this.setState({data: JSON.parse(json).clubs,dataSearch:JSON.parse(json).clubs }); + const data = JSON.parse(json) + data.sort((a,b)=>a.id-b.id) + this.setState({data: data,dataSearch:data }); + console.log(this.state.data) }) + .catch((error) => console.error(error)) } diff --git a/app/Home.js b/app/Home.js index de94f60..c833dbc 100644 --- a/app/Home.js +++ b/app/Home.js @@ -54,14 +54,22 @@ const getCurrentDate=()=>{ const Announcement = ({item}) => { const todayDate = getCurrentDate() const itemDate = new Date(item.item.date) - const dateInfo = todayDate.getTime()===itemDate.getTime()&&item.item.time!==undefined?item.item.time:(item.item.date+", " + item.item.time) + + 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?{dateInfo}:<>} + {dateInfo!==undefined?Posted {dateInfo}:<>} ) @@ -98,7 +106,7 @@ export const TeacherList = ({route}) => { var futureBoolean = true for (var i = 0; i < route.params.data.length; i++) { - const itemDate = new Date(route.params.data[i].date) + 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]) } @@ -116,11 +124,11 @@ export const TeacherList = ({route}) => { var noAnn = (todayBoolean||pastBoolean||futureBoolean) return ( - + {todayBoolean?:<>} {pastBoolean?:<>} {futureBoolean?:<>} - {!noAnn?{I18n.t('home.noAnnouncements')}:<>} + {!noAnn?{I18n.t('announcements.noAnnouncements')}:<>} ) } @@ -188,7 +196,7 @@ export const whatsNew = ({route}) => { export const NewItem = ({route}) => { const item = route.params.data - const iconURI = item.icon !== undefined?`data:image/png;charset=utf-8;base64,${item.icon}`:'' + const iconURI = item.image !== undefined?`data:image/png;charset=utf-8;base64,${item.image}`:'' return ( @@ -204,13 +212,21 @@ export const NewItem = ({route}) => { } const AnnouncementToday = ({item}) => { - const teacher = item.item.teacher !==""?item.item.teacher:"No Teacher" + 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} - {item.item.time} + {time} {teacher} @@ -364,7 +380,9 @@ function HomeStack() { } function HomeScreen (props) { - const iconURI = props.studentData.icon !== undefined?`data:image/png;charset=utf-8;base64,${props.studentData.icon}`:``; + console.log(props.studentData) + 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 = [] @@ -450,10 +468,10 @@ function HomeScreen (props) { - {props.studentData.name}, Grade {props.studentData.year} + {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.name} + {I18n.t('home.moreOn')} {props.studentData[props.studentData.length-1].name} @@ -467,7 +485,7 @@ class Home extends React.Component { constructor(props) { super(props) this.state = { - studentData: [], + studentData:[], annData:[], data:[], lunchData:[], @@ -489,25 +507,30 @@ class Home extends React.Component { 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();list + return response.text(); }).then((json) => { - this.setState({studentData: JSON.parse(json),isLoading:false}); - }).catch((error) => console.error(error)) + 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]+`/lunchEvents`,{ + fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/lunch_events`,{ headers: { 'Cache-Control': 'no-cache' }} ).then((response) => { return response.text(); }).then((json) => { - this.setState({lunchData: JSON.parse(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() @@ -535,8 +558,8 @@ class Home extends React.Component { return response.text(); }) .then((json) => { - console.log(json) const data = JSON.parse(json).data + 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}); }) @@ -552,20 +575,27 @@ class Home extends React.Component { return response.text() }) .then((txt) => { - const data = JSON.parse(txt).data; + 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; \ No newline at end of file diff --git a/app/Languages/en.js b/app/Languages/en.js index f438a16..766ac36 100644 --- a/app/Languages/en.js +++ b/app/Languages/en.js @@ -54,7 +54,8 @@ export default { }, lunch: { information: "Information", - location: "Location" + location: "Location", + time: "Time of Event" }, ssl: { information: "Information", diff --git a/app/Languages/es.js b/app/Languages/es.js index 6eca954..100e751 100644 --- a/app/Languages/es.js +++ b/app/Languages/es.js @@ -54,7 +54,8 @@ export default { }, lunch: { information: "ESInformation", - location: "ESLocation" + location: "ESLocation", + time:"ES TIME OF EVENT" }, ssl: { information: "ESInformation", diff --git a/app/LunchEvents.js b/app/LunchEvents.js index 2180bd3..5ceaf61 100644 --- a/app/LunchEvents.js +++ b/app/LunchEvents.js @@ -55,6 +55,14 @@ const Stack = createStackNavigator(); function LunchEvent (props) { const item = props.item const [expand, setExpand] = useState(false); + + var time_array = 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( setExpand(!expand)}> @@ -65,7 +73,15 @@ function LunchEvent (props) { {expand?:} - {expand?{I18n.t('lunch.information')}{item.text}{'\n'}{I18n.t('lunch.location')}{item.loc}:<>} + {expand? + + {I18n.t('lunch.information')} + {item.text} + {'\n'}{I18n.t('lunch.location')} + {item.location} + {'\n'}{I18n.t('lunch.time')} + {time} + :<>} ) @@ -81,7 +97,7 @@ class LunchEvents extends React.Component { } componentDidMount() { - fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/lunchEvents`,{ + fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/lunch_events`,{ headers: { 'Cache-Control': 'no-cache' } @@ -91,7 +107,9 @@ class LunchEvents extends React.Component { return response.text(); }) .then((json) => { - this.setState({data: JSON.parse(json)}); + const data = JSON.parse(json) + data.sort((a,b)=>a.id-b.id) + this.setState({data: data}); }) .catch((error) => console.error(error)) } diff --git a/app/Poll.js b/app/Poll.js index 9f41bf1..0b6a72a 100644 --- a/app/Poll.js +++ b/app/Poll.js @@ -80,21 +80,54 @@ import { DebugInstructions, ReloadInstructions, } from 'react-native/Libraries/NewAppScreen'; +import { url } from './resources/fetchInfo.json' import {WebView} from 'react-native-webview'; +import I18n from 'i18n-js'; + class Poll extends React.Component { + constructor(props) { + super(props) + this.state = { + data:[] + } + } + componentDidMount() { + fetch(`${url}/api/`+String(I18n.locale).split('-')[0]+`/polls`,{ + 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({data: data}); + }).catch((error) => console.error(error)) + } + render() { - return ( - - - ) + if (this.state.isLoading) { + return + } else { + if (this.state.data.length==0) { + return ( + + No Poll + + ) + } else { + return ( + + ) + } + } } } diff --git a/app/SSLOps.js b/app/SSLOps.js index b53cedd..5b3370d 100644 --- a/app/SSLOps.js +++ b/app/SSLOps.js @@ -102,6 +102,8 @@ class SSLOps extends React.Component { return response.text(); }) .then((json) => { + const data = JSON.parse(json) + data.sort((a,b)=>a.id-b.id) this.setState({data: JSON.parse(json)}); }) .catch((error) => console.error(error)) diff --git a/app/Staff.js b/app/Staff.js index 509c3d0..ca629ff 100644 --- a/app/Staff.js +++ b/app/Staff.js @@ -179,8 +179,10 @@ class Staffs extends React.Component { return response.text(); }) .then((json) => { - this.setState({data: JSON.parse(json).data}); - this.setState({dataSearch:JSON.parse(json).data}); + const data = JSON.parse(json) + data.sort((a,b)=>a.id-b.id) + this.setState({data: data}); + this.setState({dataSearch: data}); }) .catch((error) => console.error(error)) } @@ -197,7 +199,9 @@ class Staffs extends React.Component { } render() { const { data , dataSearch,search} = this.state; - + if (this.state.isLoading) { + return + } else { return ( - ); + );} } } diff --git a/app/StudentWeek.js b/app/StudentWeek.js index fa477f8..255327d 100644 --- a/app/StudentWeek.js +++ b/app/StudentWeek.js @@ -57,8 +57,9 @@ class StudentWeek extends React.Component { ).then((response) => { return response.text(); }).then((json) => { - - this.setState({data: JSON.parse(json),isLoading:false}); + const data = JSON.parse(json) + data.sort((a,b)=>a.id-b.id) + this.setState({data: data,isLoading:false}); console.log(this.state.data) }).catch((error) => console.error(error)) } @@ -67,17 +68,18 @@ class StudentWeek extends React.Component { if (this.state.isLoading) { return } else { - const iconURI = this.state.data.icon !== undefined?`data:image/png;charset=utf-8;base64,${this.state.data.icon}`:''; - const hobbyText = ({this.state.data.hobbies}) - const achievementText = ({this.state.data.achievements}) - const messageText = ({this.state.data.messages}) + console.log(this.state.data[this.state.data.length-1].image) + const iconURI = this.state.data[this.state.data.length-1].image !== undefined?`data:image/png;charset=utf-8;base64,${this.state.data[this.state.data.length-1].image}`:''; + const hobbyText = ({this.state.data[this.state.data.length-1].hobbies}) + const achievementText = ({this.state.data[this.state.data.length-1].achievements}) + const messageText = ({this.state.data[this.state.data.length-1].messages}) return ( - {this.state.data.name} - {I18n.t('student.Grade')} {this.state.data.year} + {this.state.data[this.state.data.length-1].name} + {I18n.t('student.Grade')} {this.state.data[this.state.data.length-1].grade} diff --git a/app/resources/fetchInfo.json b/app/resources/fetchInfo.json index 0bad083..7cad022 100644 --- a/app/resources/fetchInfo.json +++ b/app/resources/fetchInfo.json @@ -1 +1 @@ -{"url":"https://blazerappcms.ml/"} \ No newline at end of file +{"url":"http://127.0.0.1:8080"} \ No newline at end of file diff --git a/cms/migrations/setup/down.sql b/cms/migrations/setup/down.sql index 42892ff..1c76ddf 100644 --- a/cms/migrations/setup/down.sql +++ b/cms/migrations/setup/down.sql @@ -1,11 +1,13 @@ DROP TABLE auth_val; +DROP TABLE student; DROP TABLE events; DROP TABLE teachers; DROP TABLE announcements; DROP TABLE clubs; DROP TABLE lunch_events; -DROP TABLE ssl_opps; +DROP TABLE ssl_ops; DROP TABLE polls; DROP TABLE new; DROP TABLE important; +DROP TABLE challenge; \ No newline at end of file diff --git a/cms/migrations/setup/up.sql b/cms/migrations/setup/up.sql index c52e53d..3c690a1 100644 --- a/cms/migrations/setup/up.sql +++ b/cms/migrations/setup/up.sql @@ -21,7 +21,10 @@ CREATE TABLE teachers ( id SERIAL PRIMARY KEY, lang VARCHAR, name VARCHAR NOT NULL, - emails VARCHAR NOT NULL + email VARCHAR NOT NULL, + phone VARCHAR NOT NULL, + position VARCHAR NOT NULL, + image VARCHAR ); CREATE TABLE announcements ( @@ -51,14 +54,14 @@ CREATE TABLE lunch_events ( time TIME ); -CREATE TABLE ssl_opps ( +CREATE TABLE ssl_ops ( id SERIAL PRIMARY KEY, lang VARCHAR, title VARCHAR NOT NULL, text VARCHAR NOT NULL, location VARCHAR NOT NULL, teacher VARCHAR NOT NULL, - time TIME + date DATE ); CREATE TABLE polls ( @@ -75,9 +78,30 @@ CREATE TABLE new ( new_date DATE ); +CREATE TABLE challenge ( + id SERIAL PRIMARY KEY, + lang VARCHAR, + title VARCHAR NOT NULL, + text VARCHAR NOT NULL, + link VARCHAR NOT NULL +); + +CREATE TABLE student ( + id SERIAL PRIMARY KEY, + lang VARCHAR, + name VARCHAR NOT NULL, + image VARCHAR, + grade VARCHAR NOT NULL, + messages VARCHAR NOT NULL, + hobbies VARCHAR NOT NULL, + achievements VARCHAR NOT NULL +); + CREATE TABLE important ( id SERIAL PRIMARY KEY, lang VARCHAR, image VARCHAR, text VARCHAR NOT NULL -) +); + + diff --git a/cms/src/data/mod.rs b/cms/src/data/mod.rs index 8d7e77d..7ed6253 100644 --- a/cms/src/data/mod.rs +++ b/cms/src/data/mod.rs @@ -144,6 +144,17 @@ pub mod defs { } +api_route! { + student { + name: (Text, String, String), + image: (Text, String, Image), + grade: (Text, String, String), + messages: (Text, String, String), + hobbies: (Text, String, String), + achievements: (Text, String, String), + } +} + api_route! { events { title: (Text, String, String), @@ -158,7 +169,10 @@ api_route! { api_route! { teachers { name: (Text, String, String), - emails: (Text, String, String), + email: (Text, String, String), + phone: (Text, String, String) + position: (Text, String, String), + image: (Text, String, Image) } } @@ -171,15 +185,6 @@ api_route! { } } -api_route! { - student { - name: (Text, String, String), - meeting: (Text, String, String), - link: (Text, String, String), - sponsor: (Text, String, String), - } -} - api_route! { clubs { name: (Text, String, String), @@ -228,9 +233,18 @@ api_route! { } } +api_route! { + challenge { + title: (Text, String, String), + text: (Text, String, String), + link: (Text, String, String), + } +} + api_route! { important { image: (Text, String, Image), text: (Text, String, String), } } + diff --git a/cms/src/main.rs b/cms/src/main.rs index b16642d..16c36bb 100644 --- a/cms/src/main.rs +++ b/cms/src/main.rs @@ -76,6 +76,7 @@ fn rocket(port: u16, address: String, env: Environment, pg: PgConnection, sa: Se routes![home, home_not_logged_in, login, auth::callback, auth::oauth, static_files], ) .mount("/api", routes![ + data::student::api, data::events::api, data::teachers::api, data::announcements::api, @@ -85,15 +86,16 @@ fn rocket(port: u16, address: String, env: Environment, pg: PgConnection, sa: Se data::calendar::api, data::polls::api, data::new::api, - data::important::api + data::important::api, + data::challenge::api, ]) .mount( "/ui", routes![ - data::events::eui, data::teachers::eui, data::announcements::eui, data::clubs::eui, data::lunch_events::eui, data::ssl_ops::eui, data::calendar::eui, data::polls::eui, data::new::eui, data::important::eui, - data::events::upd, data::teachers::upd, data::announcements::upd, data::clubs::upd, data::lunch_events::upd, data::ssl_ops::upd, data::calendar::upd, data::polls::upd, data::new::upd, data::important::upd, - data::events::del, data::teachers::del, data::announcements::del, data::clubs::del, data::lunch_events::del, data::ssl_ops::del, data::calendar::del, data::polls::del, data::new::del, data::important::del, - data::events::add, data::teachers::add, data::announcements::add, data::clubs::add, data::lunch_events::add, data::ssl_ops::add, data::calendar::add, data::polls::add, data::new::add, data::important::add, + data::student::eui, data::events::eui, data::teachers::eui, data::announcements::eui, data::clubs::eui, data::lunch_events::eui, data::ssl_ops::eui, data::calendar::eui, data::polls::eui, data::new::eui, data::challenge::eui, data::important::eui, + data::student::upd, data::events::upd, data::teachers::upd, data::announcements::upd, data::clubs::upd, data::lunch_events::upd, data::ssl_ops::upd, data::calendar::upd, data::polls::upd, data::new::upd, data::challenge::upd, data::important::upd, + data::student::del, data::events::del, data::teachers::del, data::announcements::del, data::clubs::del, data::lunch_events::del, data::ssl_ops::del, data::calendar::del, data::polls::del, data::new::del, data::challenge::del, data::important::del, + data::student::add, data::events::add, data::teachers::add, data::announcements::add, data::clubs::add, data::lunch_events::add, data::ssl_ops::add, data::calendar::add, data::polls::add, data::new::add, data::challenge::add, data::important::add, ], ) } diff --git a/cms/templates/announcements.html.hbs b/cms/templates/announcements.html.hbs index cea3483..411ba88 100644 --- a/cms/templates/announcements.html.hbs +++ b/cms/templates/announcements.html.hbs @@ -45,15 +45,15 @@
-

Add Event

+

Add Announcement

-

Lang

- -
-
- +
@@ -77,7 +77,7 @@
-

Date

+

Date of Submission

@@ -98,11 +98,11 @@
-

Update Event

- +

Update Announcement

+
-

ID of event to update

+

ID of announcement to update

@@ -111,11 +111,11 @@
-

Lang

- -
-
- +
@@ -139,7 +139,7 @@
-

Date

+

Date of Submission

@@ -154,15 +154,6 @@
- -
-
-

Teacher/Organizer Email

-
-
- -
-
diff --git a/cms/templates/challenge.html.hbs b/cms/templates/challenge.html.hbs new file mode 100644 index 0000000..d918bbf --- /dev/null +++ b/cms/templates/challenge.html.hbs @@ -0,0 +1,148 @@ +{{! vim: set ft=html: }} + + + + + + + + + + +
+

+ Admin Panel +

+
+ +
+ +
+

Challenge of the Week

+ +
+ {{#each ctx}} +
+ ID: {{id}} | LANG: {{lang}} +

{{title}}

+

{{text}}

+

{{link}}

+
+
+ +
+ +
+
+ {{/each}} +
+
+ + +
+

COTW Actions

+ +
+ +
+

Add Announcement

+
+
+
+ +
+
+ +
+
+

Title

+
+
+ +
+
+ +
+
+

Information

+
+
+ +
+
+ +
+
+

Link to Challenge

+
+
+ +
+
+ + +
+
+ +
+

Update Challenge

+
+
+
+

ID of challenge to update

+
+
+ +
+
+ +
+
+ +
+
+ +
+
+

Title

+
+
+ +
+
+ +
+
+

Information

+
+
+ +
+
+ +
+
+

Link to Challenge

+
+
+ +
+
+ + +
+
+ +
+
+
+ + \ No newline at end of file diff --git a/cms/templates/clubs.html.hbs b/cms/templates/clubs.html.hbs index 4b9d80f..51b03ff 100644 --- a/cms/templates/clubs.html.hbs +++ b/cms/templates/clubs.html.hbs @@ -50,11 +50,11 @@
-

Lang

- -
-
- +
@@ -69,7 +69,7 @@
-

Meeting

+

Meeting Date and Time

@@ -78,7 +78,7 @@
-

Link

+

Meeting Location

@@ -100,7 +100,7 @@

Update Club

- +

ID of club to update

@@ -112,11 +112,11 @@
-

Lang

- -
-
- +
@@ -131,7 +131,7 @@
-

Meeting

+

Meeting Date and Time

@@ -140,7 +140,7 @@
-

Link

+

Meeting Location

diff --git a/cms/templates/events.html.hbs b/cms/templates/events.html.hbs index 94c0826..6a75197 100644 --- a/cms/templates/events.html.hbs +++ b/cms/templates/events.html.hbs @@ -50,11 +50,11 @@
-

Lang

- -
-
- +
@@ -130,11 +130,11 @@
-

Lang

- -
-
- +
diff --git a/cms/templates/home.html.hbs b/cms/templates/home.html.hbs index 07e0d80..525abdb 100644 --- a/cms/templates/home.html.hbs +++ b/cms/templates/home.html.hbs @@ -6,5 +6,11 @@ Events New + Announcements + Clubs + Lunch Events + Polls + SSL Opportunities + Polls diff --git a/cms/templates/important.html.hbs b/cms/templates/important.html.hbs new file mode 100644 index 0000000..2d7d780 --- /dev/null +++ b/cms/templates/important.html.hbs @@ -0,0 +1,167 @@ +{{! vim: set ft=html: }} + + + + + + + + + + +
+

+ Admin Panel +

+
+ +
+ +
+

Important

+ +
+ {{#each ctx}} +
+ ID: {{id}} | LANG: {{lang}} +

{{name}}

+

{{meeting}}

+

{{link}}

+

Sponsor: {{sponsor}}

+ +
+ +
+ + +
+ {{/each}} +
+
+ + +
+

Clubs Actions

+ +
+ +
+

Add Club

+
+
+
+

Lang

+ +
+
+ +
+
+ +
+
+

Name

+
+
+ +
+
+ +
+
+

Meeting

+
+
+ +
+
+ +
+
+

Link

+
+
+ +
+
+ +
+
+

Sponsor

+
+
+ +
+
+ + +
+
+ +
+

Update Club

+
+
+
+

ID of club to update

+
+
+ +
+
+ +
+
+

Lang

+ +
+
+ +
+
+ +
+
+

Name

+
+
+ +
+
+ +
+
+

Meeting

+
+
+ +
+
+ +
+
+

Link

+
+
+ +
+
+ +
+
+

Sponsor

+
+
+ +
+
+ + +
+
+ +
+
+
+ + \ No newline at end of file diff --git a/cms/templates/lunch_events.html.hbs b/cms/templates/lunch_events.html.hbs new file mode 100644 index 0000000..ec6d70f --- /dev/null +++ b/cms/templates/lunch_events.html.hbs @@ -0,0 +1,167 @@ +{{! vim: set ft=html: }} + + + + + + + + + + +
+

+ Admin Panel +

+
+ +
+ +
+

Lunch Events

+ +
+ {{#each ctx}} +
+ ID: {{id}} | LANG: {{lang}} +

{{title}}

+

{{text}}

+

{{location}}

+

{{time}}

+
+
+ +
+ +
+
+ {{/each}} +
+
+ + +
+

Lunch Events Actions

+ +
+ +
+

Add Lunch Event

+
+
+
+ +
+
+ +
+
+

Title

+
+
+ +
+
+ +
+
+

Information

+
+
+ +
+
+ +
+
+

Location

+
+
+ +
+
+ +
+
+

Time of event

+
+
+ +
+
+ + +
+
+ +
+

Update Lunch Event

+
+
+
+

ID of lunch event to update

+
+
+ +
+
+ +
+
+ +
+
+ +
+
+

Title

+
+
+ +
+
+ +
+
+

Information

+
+
+ +
+
+ +
+
+

Location

+
+
+ +
+
+ +
+
+

Time of event

+
+
+ +
+
+ + +
+
+ +
+
+
+ + \ No newline at end of file diff --git a/cms/templates/polls.html.hbs b/cms/templates/polls.html.hbs index 094f223..885905e 100644 --- a/cms/templates/polls.html.hbs +++ b/cms/templates/polls.html.hbs @@ -24,10 +24,7 @@ {{#each ctx}}
ID: {{id}} | LANG: {{lang}} -

{{url}}

-

{{meeting}}

-

{{link}}

-

Sponsor: {{sponsor}}

+

Poll: {{url}}

@@ -46,51 +43,24 @@
-

Add Club

+

Add Poll

-

Lang

- -
-
- +
-

Name

+

URL of poll

- -
-
- -
-
-

Meeting

-
-
- -
-
- -
-
-

Link

-
-
- -
-
- -
-
-

Sponsor

-
-
- +
@@ -99,11 +69,11 @@
-

Update Club

- +

Update Poll

+
-

ID of club to update

+

ID of Poll to update

@@ -112,49 +82,22 @@
-

Lang

- -
-
- +
-

Name

+

URL of poll

- -
-
- -
-
-

Meeting

-
-
- -
-
- -
-
-

Link

-
-
- -
-
- -
-
-

Sponsor

-
-
- -
+
+
diff --git a/cms/templates/ssl_ops.html.hbs b/cms/templates/ssl_ops.html.hbs new file mode 100644 index 0000000..ebd1eb0 --- /dev/null +++ b/cms/templates/ssl_ops.html.hbs @@ -0,0 +1,185 @@ +{{! vim: set ft=html: }} + + + + + + + + + + +
+

+ Admin Panel +

+
+ +
+ +
+

SSL Opportunities

+ +
+ {{#each ctx}} +
+ ID: {{id}} | LANG: {{lang}} +

{{name}}

+

{{meeting}}

+

{{link}}

+

Sponsor: {{sponsor}}

+
+
+ +
+ +
+
+ {{/each}} +
+
+ + +
+

SSL Opps Actions

+ +
+ +
+

Add SSL Op

+
+
+
+ +
+
+ +
+
+

Title

+
+
+ +
+
+ +
+
+

Information

+
+
+ +
+
+ +
+
+

Location

+
+
+ +
+
+ +
+
+

Organizer

+
+
+ +
+
+ +
+
+

Date of Event

+
+
+ +
+
+ + +
+
+ +
+

Update SSL Opps

+
+
+
+

ID of club to update

+
+
+ +
+
+ +
+
+ +
+
+ +
+
+

Title

+
+
+ +
+
+ +
+
+

Information

+
+
+ +
+
+ +
+
+

Location

+
+
+ +
+
+ +
+
+

Organizer

+
+
+ +
+
+ +
+
+

Date of Event

+
+
+ +
+
+ + +
+
+ +
+
+
+ + \ No newline at end of file diff --git a/cms/templates/student.html.hbs b/cms/templates/student.html.hbs new file mode 100644 index 0000000..ed379b5 --- /dev/null +++ b/cms/templates/student.html.hbs @@ -0,0 +1,204 @@ +{{! vim: set ft=html: }} + + + + + + + + + + +
+

+ Admin Panel +

+
+ +
+ +
+

Student of the Week

+ +
+ {{#each ctx}} +
+ ID: {{id}} | LANG: {{lang}} +

{{name}} | Grade {{grade}}

+

{{image}}

+

Message: {{messages}}

+

Hobbies: {{hobbies}}

+

Achievements: {{achievements}}

+
+
+ +
+ +
+
+ {{/each}} +
+
+ + +
+

SOTW Actions

+ +
+ +
+

Add SOTW

+
+
+
+ +
+
+ +
+
+

Student Name

+
+
+ +
+
+ +
+
+

Student Picture

+
+
+ +
+
+ +
+
+

Grade

+
+
+ +
+
+ +
+
+

Message

+
+
+ +
+
+ +
+
+

Hobbies

+
+
+ +
+
+ +
+
+

Achievements

+
+
+ +
+
+ + +
+
+ +
+

Update SOTW

+
+
+
+

ID of SOTW to update

+
+
+ +
+
+ +
+
+ +
+
+ +
+
+

Student Name

+
+
+ +
+
+ +
+
+

Student Picture

+
+
+ +
+
+ +
+
+

Grade

+
+
+ +
+
+ +
+
+

Message

+
+
+ +
+
+ +
+
+

Hobbies

+
+
+ +
+
+ +
+
+

Achievements

+
+
+ +
+
+ + +
+
+ +
+
+
+ + \ No newline at end of file diff --git a/cms/templates/teachers.html.hbs b/cms/templates/teachers.html.hbs new file mode 100644 index 0000000..3a3a6b1 --- /dev/null +++ b/cms/templates/teachers.html.hbs @@ -0,0 +1,185 @@ +{{! vim: set ft=html: }} + + + + + + + + + + +
+

+ Admin Panel +

+
+ +
+ +
+

Staff

+ +
+ {{#each ctx}} +
+ ID: {{id}} | LANG: {{lang}} +

{{name}}

+

{{meeting}}

+

{{link}}

+

Sponsor: {{sponsor}}

+
+
+ +
+ +
+
+ {{/each}} +
+
+ + +
+

Staff Actions

+ +
+ +
+

Add Staff

+
+
+
+ +
+
+ +
+
+

Name

+
+
+ +
+
+ +
+
+

Email

+
+
+ +
+
+ +
+
+

Phone

+
+
+ +
+
+ +
+
+

Position

+
+
+ +
+
+ +
+
+

Staff Picture

+
+
+ +
+
+ + +
+
+ +
+

Update Staff

+
+
+
+

ID of staff to update

+
+
+ +
+
+ +
+
+ +
+
+ +
+
+

Name

+
+
+ +
+
+ +
+
+

Email

+
+
+ +
+
+ +
+
+

Phone

+
+
+ +
+
+ +
+
+

Position

+
+
+ +
+
+ +
+
+

Staff Picture

+
+
+ +
+
+ + +
+
+ +
+
+
+ + \ No newline at end of file