- Clone this repository
cd
into the directory it creates- Make a
database.json
file in theapi
directory cd
into thesrc
directory- Run
hs -o .
to verify everything works
Nutshell is a new product offering that you have been tasked with building. It's a dashboard for people to use to organize their daily tasks, events, news article, friends, and chat messages.
You will be utilizing all of the skills and concepts that you've learned up to this point in the course.
- Functions
- Databases/API (JSON Server Documentation)
- Github
- Objects
- CSS/Flexbox
- Array methods
- Handling user events
- Factory functions
- Implementing CRUD operations
- Modular code with Webpack
- Relational data
To start you off, here's an example of what the resources in your API should look like once it's populated with some data from your application.
{ "id": 1, "username": "Steve", "email": "[email protected]" }
{ "id": 1, "userId": 1, "message": "What's up?" }
{
"id": 1,
"userId": 2,
"url": "https://www.quantamagazine.org/newfound-wormhole-allows-information-to-escape-black-holes-20171023/",
"title": "Wormholes Allow Information to Escape Black Holes",
"synopsis": "Check out this recent discovery about workholes"
}
{ "id": 1, "userId": 1, "loggedInUserId": 3 }
{ "id": 1, "userId": 3, "task": "Take out garbage" }
- All teammates must be using Webpack to compile their code.
- Each module should have a comment at the top with the following info: author(s) and purpose of module
- The README for your project should include instructions on how another person can download and run the application
- An ERD showing the database relationships. A screenshot/image should be included on your README.
Be very clear that what you will be implemting is not real authentication. It is a simulation of it using very simplistic tools.
You will be using session storage to keep track of which user has logged into Nutshell. When the user fills out the registration form, you will POST their username and password to the users
collection in your API. You will then immediately take the id
of the object in the response and save it to session storage.
sessionStorage.setItem("activeUser", user.id)
If you want to add a Logout feature, all you need to do it remove the session storage item.
sessionStorage.removeItem("activeUser")
To help you along, here is a visualization of a few features, as envisioned by one of your predecessors.
- Use acceptable conventions
- Logo positioned at top left
- Navigation across the top or down the left side
- Visual hierarchy
- Most important information is the most prominent
- Break pages up into defined sections
- Logically related content should be related visually
- That which is clickable should be obviously clickable.
- Eliminate distractions
- Use only two typefaces
- Limit color pallet (3 colors with black and white)
- Use a grid
- Support scanning (users don't read)
- Use plenty of headings
- Short paragraphs
- Bulleted lists
- Strive for consistency.