Read this entire document before writing a line of code.
- Overview: What is this project?
- Planning & Deliverables: What will we be turning in?
- Technical Requirements: What technologies will we be using?
- Further Exploration: What if we want to do more?
- Deadlines: When is it due?
- Submission: How do we turn in the project?
- Project Groups: Who are my group members and assigned instructor?
- Presentation Guidelines: What should we cover during our presentation?
- Project Feedback: How will we get feedback from instructors?
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.
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.
- 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)
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!
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.
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!
-
Wednesday, November 2 Morning - Project planning deliverables due! Before beginning work on your project, your idea, project scope, and other planning deliverables must be approved by an instructor.
-
Wednesday, November 9 Afternoon - Completed project deliverables due and presentations!
- As you make code changes, frequently commit and push to GitHub.
- 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
- Kenny
- Lily
- Lynette
- Ryan
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?
See the feedback doc for details.