##LEARNING REACT

State, Props, and Forms in React

In this project, you will work with using state, props, and forms to create an application that shares the song you are listening to or suggesting to other users.

To help you with the AJAX request functionality, there are some functions to copy and paste included in the tinylasagna.js file in the starter_files.

tinylasagna.js: this file contains functions that will need to be pasted into the corresponding components to help the functionality of your application.

###Objectives
You will need to create a new React application using create-react-app. You will need to create styles and components folders and place the appropriate files in each, being sure to link the other files correctly to each other. Your project will need to have the following components: App.js NavBar.js PlayListForm.js PlayList.js PlayListItem.js

###You can use Bootstrap 4 for easy styling of this project.

Bootstrap 4 Link

Simply add the tag to your index.html file in your public directory. If using Bootstrap, be sure to add a class="container" to your

tag in your index.html. Adding the various class names will help automatically style many of your features.

###This project is about managing state, props, lifecycles, and forms. The following should be true of your application:

  1. Your PlayListcomponent should pass down the state in the form of props to your PlayListItem component which will render the actual play list entries. (Hint: PlayListItem should be imported in PlayList)

  2. You App.js component should only have import statements for your NavBar, PlayList, and PlayListForm.

  3. The state for your PlayListForm component should have userName, songArtist, songTitle, and songNotes in order to function properly with the fetch functions from the tinylasgna.js file that you will copy into the component. Follow the directions in that file.

  4. The state for your PlayList should just have one key value pair, songs, in order to properly function with the fetch function from the tinylasagna.js file that you will copy into the PlayListComponent (follow the directions in that file).

  5. The styling is up to you, but please make this a polished product!

HINTS Handling input changes example:

ReactMusicApp