Skip to content

keirankozlowski/Labs8-MusicMaker

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MusicMaker

Music Master Maker is a hybrid full-stack web and iOS learning management app for music education. Teachers can use the web app to assign music sheet assignments, track and grade recorded sessions, and provide feedback to students. Students can use the iOS app to record their practices and receive feedback on their sessions.

Students signs up by using their portable Apple device to scan a QR code provided in the teacher's home screen.

The app is free for students and has a monthly fee for teachers.

Table of Contents

  1. Live Versions
  2. Feature List
  3. Local Setup
  4. Endpoints
  5. Meet the Team

Live Versions

Teacher Web App

Feature List

Teacher Web App Features

  1. Sign up - can use email/password or Google OAuth.
  2. Sign in - can use email/password or Google OAuth.
  3. Reset Password - sends an email to the attached email address to reset.
  4. Sign out - remove auth token to sign out.
  5. Student View - shows all students as individual cards; clicking an individual card will bring up the individual student's information and any assignments they have been assigned.
  6. Create Assignment View - create a new assignment template with a few text fields and a PDF for sheet music.
  7. Assignment View - shows all assignment templates as individual cards; clicking an individual card will bring up the individual assignment attributes and any students that have been assigned to it and to assign additional students to it.
  8. Grading View - shows all assignments submitted by students for grading as individual cards; clicking an individual card will bring up the assignment information and allow feedback to be recorded.
  9. Billing View - allow payment through the Stripe API. This will enable other pages which have been route-protected.
  10. Settings View - see and edit user account info.

Local Setup

Teacher Local Web App

  1. Clone repo.
  2. Install environment and packages by typing yarn install within both the /server/functions/ and /client/ directories.
  3. Type yarn start in each directory to spin up the servers.
  4. Edit code as needed.

Endpoints

Teachers Web App Endpoints

GET
  1. /test:
  • test endpoint to check that server is up.
  1. /teacher/:idTeacher/students
  • retrieves a teacher's list of students.
  • fetches student name, instrument, proficiency level, and email.
  1. /teacher/:idTeacher/student/:idStudent
  • retrieves an individual student assigned to the teacher
  • fetches student name, instrument, proficiency level, and email.
  1. /teacher/:idTeacher/student/:idStudent/assignments
  • fetches list of assignments the student has been assigned.
  1. /teacher/:idTeacher/assignment/:idAssignment/students
  • fetches list of students assigned to the assignment
  1. /teacher/:idTeacher/assignment/:idAssignment/student/:idStudent
  • fetches a completed or uncompleted assignment from a student
  1. /teacher/:idTeacher/assignments
  • fetches a list of all ungraded assignments for a teacher
  1. /teacher/:idTeacher/assignment/:idAssignment
  • fetches an individual ungraded assignment
  1. /teacher/:idTeacher/settings
  • retrieves a teacher's account settings
  • fetches email, name (first, last, prefix), and QR code
POST
  1. /teacher/:idTeacher/assignment/:idAssignment/assignToStudent
  • posts an assignment from a teacher to a student, which allows the student access to complete it.
  1. /teacher/:idTeacher/createAssignment
  • posts a new assignment template to a teacher's list of assignments. This assignment can then be assigned to student(s)
  1. /uploadPDF
  • uploads a PDF to the Firestore database
  • should be used in conjunction with the create assignment endpoint.
  1. /addNewTeacher
  • adds a teacher's initial settings including name, email, and generates a QR code
  1. /teacher/:idTeacher/charge
  • uses the Stripe API to post a payment to a specific teacher account
  • a paid account allows full access to all features
PUT
  1. /teacher/:idTeacher/assignment/:idAssignment/student/:idStudent
  • edits an assignment when a teacher grades it.
  • should post feedback and grade
  1. /teacher/:idTeacher/settingsEdit
  • edits teacher account settings
DELETE
  1. /teacher/:idTeacher/assignment/:idAssignment
  • deletes an assignment template

Meet the Team

Jeanette Fernandez Linh Bouniol Evan Carlstrom Keiran Kozlowski Vuk Rado
Github Github Github Github Github
LinkedIn LinkedIn LinkedIn LinkedIn LinkedIn

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Swift 68.9%
  • JavaScript 28.2%
  • HTML 2.8%
  • Ruby 0.1%