Coder Social home page Coder Social logo

react-router-movies's Introduction

Client Side Routing w/ React Router v. 4

Topics:

  • React Router
  • Using Link and NavLink to navigate to specific routes
  • Passing Route Parameters
  • Passing props to components rendered by the Router

Instructions

NOTE โš ๏ธ - You will NOT need to finish this project after React Router I. Start working on it now, then you can finish it up after the next module - React Router II.

  • Fork this repository, then clone your fork.

  • NOTE You have 2 servers that you will be running here so read these instructions carefully.

  • In the root of this directory: Run yarn install to download dependencies.

  • Run the server using yarn start or node server.js. (Don't worry too much about this process, you'll get used to doing this and it will be explained more in the future).

  • In a separate terminal cd into the client folder and run yarn install to download dependencies.

  • Still inside the client folder run yarn start to run the client application.

  • Once your application is up and running on the client, you should see a browser window that looks like this at localhost:3000 Movies Home

Part 1:

  • Wrap your app with the router.
  • Inside your App file add two routes.
    • one route for / that loads the MovieList component.
    • one route that will take an id parameter after/movies/ (ex: /movies/2, /movies/3 where the id is dynamic). This route should load the Movie component.

Part 2:

  • Make it so that the card in MovieList is a link, this should direct the user to the /movies/{id of movie here} URL, where :id is the id of the individual movie.
  • When a user clicks on a movie card they should be taken to /movies/{id of movie here} to see the details for the selected movie.
  • You will need to modify line 13 of Movie.js in order to accept the correct id for the movie selected.
  • Add functionality so the Home button on the SavedList component navigates back to home.
  • You should now be able to navigate back and forth between the individual movies and the home screen.

Stretch Goals.

If you have completed Parts 1 & 2 feel free to move on to these stretch goals.

Refactor so that our code is DRY.

You may notice that we are using essentially the same exact JSX code in the Movie component and the MovieDetails component in MovieList.js create a new component in MovieCard.js that returns this JSX code. Then remove the old code from Movie and MovieDetails and instead return the new MovieCard component.

Add Save Movie functionality.

You will notice there is a 'Saved Movies' component that we are not currently using. In this step you will add the functionality to save a movie. You will need to pass the addToSavedList function to the Movie component. Once you have done that you will need to add a click handler to the save button.

Turn your Saved Movie list into Links.

You will need to uncomment lines 25-28 in Movie.js to complete this. Your list of saved movies should be links to the movie itself. Study and understand what the saveMovie function is doing.

Turn your Saved Movie Links into NavLinks.

react-router-movies's People

Contributors

dustinmyers avatar luishrd avatar tetondan avatar dswhitely1 avatar ryan-hamblin avatar seanchen1991 avatar sunjieming avatar ladrillo avatar jasonsbarr avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.