Skip to content

SF-WDI-LABS/tunely

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Tune.ly lab

Full CRUD app with MongoDB, Mongoose, and Express.

Objectives

This lab is all about practicing the skills you've been developing over the past few weeks. After completing this lab, developers will be able to...

  • work in a code base that they did not start from scratch
  • discuss code and approaches to other developers
  • create a JSON CRUD API on /api routes in an Express server
  • serve static content on non-/api routes in an Express server
  • make AJAX requests with jQuery
  • render JSON data with template strings
  • create the client/server/database connections required for a full stack application

Prerequisites

Before starting this lab, developers should have some familiarity with...

  • html data- attributes
  • jQuery, AJAX
    • $('asdf').on('click', '.add-song', handleAdd)
    • $.get or $.ajax
    • $.post or $.ajax
    • $(document).ready(function(){});
    • Advanced CSS selectors could be helpful. Example: $('[data-album-id=a7397f6f2e]')
  • Express server, static assets
  • RESTful route design
  • serving JSON with /api routes
  • Bootstrap grid system, forms, buttons
  • CRUD with mongoose for MongoDB
    • find, findOne, new, save, remove
    • mongoose embedded data associations

New Tools and Patterns

Overview

This lab begins with a basic front-end to display a list of music albums. As we progress through, we'll:

  • serve the album data from our server's /api/ routes
  • get the data from the server using AJAX and display it on the page with jQuery
  • retrieve the data from the database
  • add functionality to create a new album
  • add functionality to remove/delete an album
  • add the ability to edit/update an album
  • support storing song information (mongoose embedded)

Project Planning and Approach

Planning

When working on large projects, it's important to do a good amount of planning and whiteboarding before you start coding.

  • Diligent planning will save you from costly mistakes and help you to refine the user experience before you've spent hours on the project.
  • The planning techniques and habits you develop here will be essential throughout your career as a web developer.
  • Every successful company invests time in planning and design, and you should too!

Typically when you work on a project, you'll start with a basic idea and do your initial development on paper or whiteboard. A number of software packages can will help you build wireframes, too. Remember, though, a wireframe should include simple diagrams of your site's layout and flow, not full mockups.

In the wireframe below, you can see we're building a site that displays a list of musical albums. It also has a jumbotron to introduce users to the page. This is only our starting point; you'll be responsible for evolving it as we work through the lab.

Outside-In

We're going to use "outside-in development" practices. This means that we'll start by designing our UI (the outside) with hard-coded data on the client side. Then we'll move "inside" by connecting our UI to a server serving hard-coded data from the server files. Next, we'll retrieve that data from a database.

We will also be breaking our work into short sprints with specific design goals. Each sprint is organized in an outside-in manner.

Getting Started

  1. Fork and clone this repository, and cd into your local copy.
  2. Add your partner as a collaborator on your fork of the repo.
  3. Read the rest of this readme, then continue to Sprint 0.

Workflow

You'll complete this lab in rotating pairs! This is a challenging project, so remember the teamwork strategies you've built up recently.

One person will drive, and the other will navigate. The driver should fork and clone this repo, and is the one with their hands on the computer; the navigator is directing the driver in where to write code and what code to write. At intervals, you should switch roles: the driver should become the navigator, and the navigator should become the driver.

Later in the day, we will switch partners, so you get the experience of pair programming with more than one person. After switching, discuss your recent work. Start back from the point where you last both felt comfortable.

Sprints

Sprint 0

Sprint 0: set up express server and back-end file structure

Module A: Create and Read with Mongo and embedded model relationships.

Sprint 1

Sprint 1: serve & display hard-coded data on the page, then connect to a database

Sprint 2

Sprint 2: add a form and support creation of new data

Sprint 3

Sprint 3: add mongo embedded song data

Module B: Update and Delete with Mongo and embedded model relationships.

Sprint 4

Sprint 4: delete albums

Sprint 5

Sprint 5: edit and update album info

Sprint 6

Sprint 6: update song info & delete songs

Using Tune.ly Solutions

There is a solution branch in this repository for each sprint. For the most part, we expect you'll reference these solutions online as needed. Follow the instructions below if you ever need to start working from the solutions of a previous sprint:

  1. First, git add and commit any current changes.

  2. Check out the desired solutions branch to start from:

git checkout sprint-4

  1. Create a new branch from the solution branch for your work:

git checkout -b my-sprint-4

Packages

No packages published

Languages

  • HTML 77.6%
  • JavaScript 17.4%
  • CSS 5.0%