Skip to content

Lessons_lab. A mobile web app for teachers to manage personalised lessons progress

License

Notifications You must be signed in to change notification settings

canriquez/rails_capstone_lessons_lab

Repository files navigation

Lessons Lab

This web application is a mobile application targeting freelance teachers to admin, track, and manage lessons with their students.

. The front end is based on the original design idea by Gregoire Vella on Behance .

screenshot

Live App link

heroku live site

For the demo, use the following pre-loaded users. You could also create new users. For all users, the password is password

email name role
[email protected] Sussane teacher
[email protected] Carlos teacher
[email protected] Anna student
[email protected] Clara student
[email protected] Cecil student
[email protected] Caro student
[email protected] Matt student
[email protected] Laureano student
[email protected] Robert student

Customer Story

- The user logs in to the app, only by typing the email
    . Additional feature implemented: password is an additional feature (demo password: password)
    
3. The logged-in user is presented with a profile page that includes:
    a. Bookings ("all my transactions")
        - Inside bookings two taps hell to show  
    b. All Courses 
    d. Additional feature: All students '''not available in demo'''

4. When a logged-in user opens "My billable bookings" page:
    a. The total amount of booked minutes is displayed on top.
        i. Additional feature: All equivalent revenue also displayed.
    b. A list of all transactions created by a logged-in user is displayed (sorted by most recent)
    c. Each transaction displays:
        i.  Student name (name), 
        ii. minutes-amount and date, 
        iii. equivalent price per session. 
        iv.  Course's grouping icon (group).
    d. An action button "Add new booking" is displayed

5. When the logged-in user opens "My non-billable booking" page:
    a. A list of all created transactions  by an authenticated  teacher but not assigned to any course (group), or student (user). 
    b. The design of the page is similar to the "My billable bookings."

6. When a logged-in user opens the "All Courses " page:
    a. A list of all courses is displayed in alphabetical order.
        
    b. Each Course displays its icon, name, and record creation date.


7. When a logged-in user opens the "Course transactions" page:
    a. A list of all transactions that belong to that Course is displayed.
    b. The design of the page is similar to the "All my bookings."  Each booking displays the name of the author of the transaction.

8. When a logged-in user opens, "create a new course" or "Add new transaction" page:
    a. A form with all necessary fields is displayed.

9. Additional feature: For create a new course, the following vital data should be provided (among others)
        i. Course name.
        ii. Price per session.
        iii. Session length.
        
10. Additional feature: Signing up students to courses:
    a. Only a professor and course author can enroll students in courses.
    b. Enroll student button is available only on the "course index page"
    c. "add a new transaction" shows on the "course transaction page"
        i. A transaction can be created only for students currently enrolled  into the Course.
        
11. Next release features: Signup of students:
    a. Students will be created only by teachers. Fields will include.
        i. Name
        ii. Email
        iii. Role: student
    ```for simplification this feature is not implemented in the demo```

Technical design details

  • Below I include the fundamental ERD design and associations map to better understand the implemented solution.

ERD design

screenshot

Models Associations Map

screenshot

Environment set up requirements

To run this project, you need ruby installed in your environment Run the following command:

$ ruby -v

You should have a result similar to this: s

ruby 2.6.5p114 (2019-10-01 revision 67812) [x86_64-linux]

If you don't get that result, follow this link and install Ruby in your local environment.

Setup

  • Clone this repository in your local environment
  • Located on the root of repository execute

bundle install

This action will install all the required dependencies.

Built With

  • Ruby
  • Ruby on Rails
  • bootstrap
  • Devise
  • RSpec
  • Capybara
  • FactoryBot
  • Shoulda-Matchers

Authors

👤 Carlos Anriquez

🤝 Contributing

Contributions, issues, and feature requests are welcome!

Feel free to check the issues page.

Acknowledgments

  • My Family (Oh man, after 70 hs in 9 days, definitely has been fundamental support)
  • The great TSE team for a fast review, key challenges, and contributions: Addo, Simon, and Issac. Thanks, Guys!
  • @microverse / The Corgis

Show your support

Give a ⭐️ if you like this project!

📝 License

This project is MIT licensed.