design
Frontend
The StudySync platform is designed to enhance students' learning experiences by providing a centralized dashboard for streamlined access to educational resources. With an emphasis on collaboration and efficiency, it facilitates AI-powered creation of flashcards and quizzes, fostering an interactive learning environment. Students can effortlessly share these resources with friends, enriching the collective study process. Additionally, StudySync allows users to schedule study sessions, ensuring consistent and focused learning engagements.
Dashboard Component & Mysets Component & Social Component & Profile Component
The image shows the react component that make the dashboard page, mysets page, social page and profile page. These components interact with the userRepository class to fetch the data from database.
Dashboard
Dashboard component uses the methods inside the userRepository to fetch the data from database and all the other database operation, it displays the upcoming events, friends, recent flashcards and recent quizzes.
Mysets
Mysets component uses the methods inside the userRepository to fetch the data from database and all the other database operation, it displays flashcards and quizzes and allow user to share them. ScheduleDialog will allow user to set the time to study.
Social
Social component uses the methods inside the userRepository to fetch the data from database and all the other database operation, it displays user's following and followers. This page also allow user to find users.
Profile
Profile component uses the methods inside the userRepository to fetch the data from database and all the other database operation, it displays user's information. User can edit its own information here or click on the flashcards to redirect to the flashcard component.
Flashcard Component
Here is the flashcard component. It uses the methods inside the flashcardRepo to fetch the data from database and all the other database operation. User can create a flashcard set here. And then click the flashcard button to redirect the flashcardUICom. This is the component where user can create and study their flashcards.
Quiz Component
Here is the Quiz component. It uses the methods inside the QuizRepository to fetch the data from database and all the other database operation. QuizList allows user to create multiple quizzes for one flashcard set. MainQuizPage allows user to actual take the quiz.
Events Component
Here is the Event component. It uses the methods inside the EventRepository to fetch the data from database and all the other database operation. User can edit upcoming events in the page. EventCard is the style of each event.
Leaderboard Component
Here is the leaderboard component. It uses the methods inside the QuizRepository to fetch the data from database and all the other database operation. User can see the score comparison here.
Notificatin Component
Here is the notification component. It uses the methods inside the NotificationRepository to fetch the data from database and all the other database operation. NotificationBadge styles the notification page. Users will receive notifications for various interactions such as following or unfollowing a user, sharing flashcards or quizzes, and reminders for upcoming events.
Backend
StudySync, an innovative learning platform, seamlessly integrates Firebase's robust features to deliver an engaging user experience. Its use of Firebase hosting ensures rapid content delivery and secure hosting, while Firebase Cloud Functions allow for efficient serverless back-end operations. This harmonious integration provides users with real-time access to study tools and a responsive platform that adapts to their interactive needs.
Beyond smooth operations, Firebase's advanced capabilities also include real-time database updates and secure user authentication, contributing to a cohesive ecosystem. StudySync users benefit from a dynamic platform where learning materials are instantly accessible, interactions are safeguarded, and updates are immediately reflected, all thanks to Firebase's comprehensive suite of tools that underpin the platform's performance and reliability.
Database
Database Model
StudySync will be using a Firebase NoSQL database to store all data.
For single properties on a user model such as email, password and name, we will just store it in the user the corresponding collection. For more complex properties such as notifications, followers and following, flashcards and events, we will store the ids of each corresponding field in the user collection and query the respective collection as needed. To be more specific, in the case of notifications, the actual data for notifications will be stored in the Notifications collections, anytime we need to query user notifications, we can do this easily by fetching all the notification ids for that user from the Users collection and then querying the Notifications collection using those ids. This same idea applies to fetching events for Notifications
Collections
The database will be made up of the following collections:
- Users: This collection stores everything related to a single user.
- Notifications: Stores all the metadata related to a notification
- Events: Store metadata for each event
- Upcoming Events: Store metadata for each event
- FlashCardSets: Representation of an entire stack of flashcards. Made up of flashcard items
- Quizzes: A quiz object generated based on a flash card.
Static Structures
Events and Upcoming Events collections will use these structures.
- Event_Type: An enum/object representing the type of event. Either a NewFollower, ShareQuiz, or ShareFlashcard event.
- Share Event: Underlying Model for ShareQuiz event and ShareFlashcard event
- New FollowerEvent: Represents a NewFollowerEvent
- Upcoming_Event_Type: An enum/object representing the type of event. Either study for QUIZ or study for FLASHCARD
Use case 1
A user forgets to review because of daily chores and uses StudySync to review before midterm is approaching.
- User login using StudySynce credential.
- After logging into the account, the user navigates to Study Tool tab to check his flashcard decks.
- Then he found the flashcard topic for his subject.
- After reviewing the flashcards, the user went back to Study Tool page and select "Quiz".
- Finally, the user completes the quiz and the correct answer is displayed.
- After submission, the quiz shows all the correct answer and quiz score will be saved to the leaderboard.
Use case 2
A user is about to take a naturalization test but doesn't have time to study for it due to work, so he needs to practice for the test using StudySyne.
- Users opens the website and logs in with their StudySync accounts.
- Then since there is nothing on StudySync that he needs to learn, the user needs to add some flashcards.
- He then adds the naturalization test questions he has studied and uploads them to StudySync.
- After completing the upload of the question bank he chose flashcard mode to study those terms and definitions.
- When the flashcard comes out there are three options, know, don't know, and not sure.
- Finally, the rating for those questions will be saved and can be used to generate questions for quiz.
Use case 3
A user was recommended a learning program by his classmates that said he could have a quiz competition.
- He navigates to StudySync website and sign up for a new StudySync account.
- Then he went to the friends list and chose to add a friend.
- After adding his friends he is able to receive a shared quiz from one of his friends.
- The user then has the ability to do the quiz that was shared by his friends.
Use case 4
A user wants to study the subject he wants but, he doesn't find the flash card for the subject he wants in StudySync.
- The user navigates to StudySync website and then logs in.
- After he didn't find any flashcard for the subject he wanted to study, he turned on the AI topic generation function.
- After pressing AI Assist button, the user is able to specify the description of his desired flashcards.
- Once the AI has finished the flashcard generating, the user is able to study the flashcard and is also able to rate them.
- After learning, the user is able to go "Quiz" mode and generate questions by using AI question generating feature.
- The user didn't like the questions generated by AI, so he/she decides to edit the questions as well as the answer choices and then save it.
Use case 5
A user wants to take a quiz created by themselves or a friend and compare it to his/her friends.
- User logs in to StudySync.
- User then navigate to the mySets section.
- At the mySets section, user has a wide range of quizzes either created by themselves or shared by friends.
- User selects a quiz and completes it.
- The system will then calculate and the display user's score on the leaderboard.
- User then navigates to the leaderboard page to compare scores with his/her friends.
Use case 6
Jack wants to add John as a friend on StudySync.
- Jack will have to log in to his own account.
- Then navigate to the socials section.
- Jack searches for John.
- Once the John's name popup, Jack recognizes his friends then selects follow.
- John receives the follow notification and follows the Jack back.
- John and Jack are now friends on StudySync as they have now follow each other.
Use case 7
A user has been studying for 6 hours and wants to take a break but also wants to save the quiz's progress.
- User is taking a quiz but then realizes he/she wants to take a quick coffee break.
- User clicks "Save&Exit" button in order for the quiz to be saved and quit.
- The system saves the user's progress.
- After the break, the user goes to the mySets section and pick the quiz to resume.
- User finishes the quiz and saves its data to the database.
Use case 8
A user finds out some flashcards need to be updated in order to improve accuracy.
- User logs in to StudySynce as usual.
- Then user goes to MySets to view owned/shared flashcards.
- User finds out which flashcard set need to be updated.
- User selects flashcard set and makes changes to the flashcard definition and details.
- User saves changes and then flashcards are updated and ready to be learned.