In this activity, you'll create a new React-based rendition of the New York Times Article Search application. This assignment requires you to create React components, work with helper/util functions, and utilize the React mounting lifecycle to query and display articles based on user searches. You'll also use Node, Express and MongoDB so that users can save articles to read later.
- Please submit both the deployed Heroku link to your homework AND the link to the Github Repository!
-
Check out this mockup image. This explains how your site's components should function.
-
Create a MongoDB database called
nytreact
. -
Using mongoose, then create an Article schema and model
-
At a minimum, articles should have each of the following fields:
-
title
(Title of the stored article from nytimes.com) -
date
(publish date and time of the article) -
url
(URL of the article on nytimes.com) -
Creating
documents
in yourarticles
collection similar to{ title: 'Ali Sells Jersey House And Moves to Chicago', date: '1974-07-18T00:00:00Z', url: 'http://query.nytimes.com/gst/abstract.html?res=9A0DE5D8173FEF34BC4052DFB166838F669EDE' }
-
-
Create a Node/Express/MongoDB/ReactJS app called
nytreact
. This will be a recreation of the NYT Articles Search exercise application we built back in Unit 6. Running this application will:-
Create a Bootstrap layout similar to that displayed in HW_Assignment.png. This should be a SPA (Single Page Application) that uses
react-router-dom
to navigate, hide and show your React components without changing the route within Express.- If you want to try out another CSS framework, feel free to use an alternative to Bootstrap.
-
You'll need several Express routes for your app:
-
/api/articles
(get) - your components will use this to query MongoDB for all saved articles -
/api/articles
(post) - your components will use this to save an article to the database -
/api/articles
(delete) - your components will use this to delete a saved article in the database -
*
(get) - will load your single HTML page (with ReactJS) inclient/build/index.html
. Make sure you put this after all other GET routes
-
-
The layout should include at least two React Components for each page
Home
andSaved
.-
Home - contains all of the JSX to be rendered on the homepage. This component may contain other smaller components or JSX that renders plain HTML elements. This component should be able to query the NYT API for articles. It displays the results from the API search in a rendered list that displays the article title, publication date, and allows the user to visit an article's url or save the article to the MongoDB.
-
Saved - Renders articles that are saved in the MongoDB and allows the user to visit the article's url or delete it from the MongoDB. This page may be made up of multiple smaller components or JSX that renders plain HTML elements.
-
-
- Deploy your application to Heroku once complete. Feel free to use the Mern Example as a starting point. You must use Create React App and current versions of React and React-Router-Dom for this assignment.
-
Use React routing and socket.io to create a notification or a component that triggers whenever a user saves an article. Your message should include the title of the saved article.
-
Say you have multiple browsers open, each one visiting your site. If you save an article in one browser, then all of your browsers should notify you that a new article was saved.
-
- Please submit both the deployed Heroku link to your homework AND the link to the Github Repository!
Attempt to complete homework assignment as described in instructions. If unable to complete certain portions, please pseudocode these portions to describe what remains to be completed. Hosting on Heroku and adding a README.md are required for this homework. In addition, add this homework to your portfolio, more information can be found below.
Add a README.md
to your repository describing the project. Here are some resources for creating your README.md
. Here are some resources to help you along the way:
After completing the homework please add the piece to your portfolio. Make sure to add a link to your updated portfolio in the comments section of your homework so the TAs can easily ensure you completed this step when they are grading the assignment. To receive an 'A' on any assignment, you must link to it from your portfolio.
Now that we have a backend to our applications, we use Heroku for hosting. Please note that while Heroku is free, it will request credit card information if you have more than 5 applications at a time or are adding a database.
Please see Heroku’s Account Verification Information for more details.
If you have any questions about this project or the material we have covered, please post them in the community channels in slack so that your fellow developers can help you! If you're still having trouble, you can come to office hours for assistance from your instructor and TAs.
Good Luck!