Skip to content

sf-wdi-gaia/project-03

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 

Repository files navigation

Project 3 - Rails Group Project

Read this entire document before writing a line of code.

Contents


Overview

What is this project?

For the second project, you will use your knowledge of front-end and back-end web development to produce a polished web application that can be used by friends, family, or the wider online community -- and that will benefit your portfolio.

The objective of this project is to:

  • Work with a group in a shared GitHub repository.
  • Plan and implement a larger scale project as part of a development team.
  • Integrate topics learned and experience gained in the course so far.
  • Showcase your abilities to potential employers, friends, family, and community members.

You will be working in groups of 4 for this project.


Planning & Deliverables

What will we be turning in?

Project Planning Deliverables

You must review the following with your instructional team BEFORE you start to code.

  • Scope: What are you planning to build? What do you reasonably think you can implement in the time period?
  • User Stories: Who is your user? What features will your app have? Set up your project and user stories in Trello or in some other organized format.
  • Wireframes: Sketch out what your core pages will look like and how they will work. Consider making a paper prototype to demonstrate and/or test key user interactions.
  • Data Models: Draw out the models and any associations for your project in an entity relationship diagram (ERD).
  • Milestones: Outline the milestones/sprints for your group.
  • Delegating Tasks: What will each group member work on? Leverage everyone's strengths, and spend the majority of coding time pair programming.

Completed Project Deliverables

  • Link to Heroku hosted project, with all core technical requirements and three flexible technical requirements complete.
  • Link to source code on GitHub.
  • A README.md file with the following:
    • Description: Short paragraph (2-3 sentences) "elevator pitch" describing what your project does
    • Wireframes and user stories
    • Link to Heroku hosted project
    • Technologies (languages, external libraries, APIs)
    • Wish List / Future Development
    • Contributors (with links to their GitHub profiles)

Technical Requirements

What technologies will we be using?

Core Technical Requirements

Your app should have all of the following:

  • Rails: Use Rails as the core framework for Ruby.
  • PostgreSQL: Use PostgreSQL for your database in development and production.
  • Data Models Include at least two data models with associations.
  • Data Validation: Your application should validate incoming data before entering it into the database.
  • Error Handling: Forms in your application should also validate data, handle incorrect inputs, and provide user feedback on the client side.
  • Testing: Write unit tests for every model method.
  • Views: Use partials to follow DRY (Don’t Repeat Yourself) development in your views.
  • Home & About Pages: Create a landing page (homepage) that clearly explains your app's value proposition and guides the user through the "get started" funnel. Create an about page that includes photos and brief bios of your team members.
  • User Experience: Ensure a pleasing and logical user experience. Use a framework like Bootstrap to enhance and ease your CSS styling.
  • Responsive Design: Make sure your app looks great on a phone or tablet.
  • Heroku: Deploy your app to Heroku. Ensure no app secrets are exposed. Do not commit secret keys to GitHub!

Flexible Technical Requirements

Your app should have 3 out of the 5 following options:

  • User Login Make sure you have authentication and authorization.
  • AJAX Use AJAX to communicate with the server without reloading the page when appropriate.
  • External APIs Use HTTParty or a third-party API back-end gem to integrate third-party data into your app.
  • Paperclip Upload files with Paperclip.
  • JavaScript & jQuery: Add dynamic client-side behavior with event-driven functionality.
  • User-Friendly URLs: Make pretty URLs that don't expose database IDs.

Further Exploration

What if we want to do more?

If you want to push yourself and learn something new, optionally consider doing any of the following ideas. Please talk to an instructor beforehand.

  • Charting: Visualize your data! Possibilities include D3, Morris.js, Highcharts, Chart.js, and Google Charts.
  • Job Scheduling: Set up a job-scheduler like Sidekiq, Delayed Job, or Resque to queue actions that don't need to run immediately.
  • Emails: Use ActionMailer to send emails to your users.
  • Text Messaging: Use Twilio to send texts to your users (note: not free).
  • Payment: Use Stripe to allow your users to purchase from or donate to your site.
  • Material Design: Research the material design paradigm and apply it to ground your app's UI in the physical realm.
  • CSS Animations: Use jQuery or animate.css to include animations on your site.
  • Accessibility: Research web accessibility (e.g. for blind users), and apply accessibility principles to your app.
  • Sessions: Use sessions to store data for site visitors (who aren't necessarily logged in).
  • Search: Build a form that allows users to search your data, based on attributes. Consider looking into Elasticsearch to speed up queries.
  • Whatever else you can think of!

Deadlines

When is it due?

Submission

How do we turn in the project?
  • As you make code changes, frequently commit and push to GitHub.

Project Groups

Who are my group members?

Group 1 - Online shop for various items.

  • Alivia
  • Brendan
  • Chris
  • Sherri

Group 2 - Fitness app to keep track of what you lifted, workouts completed, times, etc. Can localize with various gyms and clients are associated to gyms.

  • Natalia
  • Toby
  • Teddy
  • Bill

Group 3 - Band builder application to find band members.

  • Kenny
  • Lily
  • Lynette
  • Ryan

Presentation Guidelines

What should we cover during our presentation?

Each group will present their project on Wednesday, November 9 starting at 1:30 PM. Please follow these guidelines:

  • Your presentation should include the motivation for building this project and a demo of the core functionality.
  • Maximum 15 minutes.
  • Minimum 5 slides. Slides should include:
    • Wireframes
    • User stories
    • ERDs
    • Walk through the development of one feature from ideation to execution. At minimum, this should include wireframes, code samples, and the final result.
  • ALL group members must speak during the presentation. Each group member should answer the following:
    • What parts of the project did you work on?
    • What was the most challenging aspect? Was there anything that was surprisingly easy to implement?
    • What did you learn?

Project Feedback

How will we get feedback from instructors?

See the feedback doc for details.

About

Ruby On Rails Group Project

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published