Skip to content
No description, website, or topics provided.
JavaScript CSS HTML
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
api
public
src
.gitignore
README.md
database.json
package-lock.json
package.json

README.md

ReactShell

The Information Dashboard

ReactShell 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.

Technologies Used

Development Languages and Libraries

Development Tools

______

Instructions for Installing Mission Control

You will need to have command line tools installed for your computer to use terminal commands.

  • Mac users - Open your terminal and type

    git --version
  • Linux/Windows users, please vist the Git page and follow the instructions for setup

You will now need to configure your git account. In the terminal window, type

git config –global user.name “You Name”
git config –global user.email “Your Email”

Create a new directory to store the files in. Type this into your terminal window.

mkdir reactShell
cd reactShell
git clone git@github.com:nss-mission-control/reactshell.git

If you do not have Node.js installed on your machine, visit the Node.js Download Page and follow the included instructions. To ensure that it is installed correctly, in your terminal window, type

echo $PATH
  • Ensure that the result has the following in the $PATH

    /usr/local/bin

    or

    /usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin

You will need to go into the lib folder in your directory and install and build npm modules and also your json-server. In your terminal, type

cd reactShell/src/lib
npm init
npm i
sudo npm install -g json-server

Now create a new directory inside the nutshell directory to store your JSON data. Type

cd ../..
mkdir api
touch api/database.json

In order to create and edit the require JSON file, you will need a text editor. For this project, we used VS Code. Visit VS Code to install a copy.

Once you have a text editor installed, open the database.json file and paste the following test data.

{
  "users": [
    {
      "id": 1,
      "firstName": "Kelly",
      "lastName": "Morin",
      "username": "kmorin06",
      "password": "1234NSS",
      "email": "kmorin06@gmail.com",
      "profilePic": "https://scontent-atl3-1.xx.fbcdn.net/v/t1.0-9/14100479_10157231480525062_191282433024935032_n.jpg?_nc_cat=102&_nc_ht=scontent-atl3-1.xx&oh=8ecc7dd157438c9c3d09c5c910ff4c61&oe=5C6FC0EA"
    },
    {
      "id": 2,
      "firstName": "Jase",
      "lastName": "Hackman",
      "username": "JaseTheGreat",
      "password": "MusicMan",
      "email": "jaseH@gmail.com",
      "profilePic": "https://avatars1.githubusercontent.com/u/42299515?s=400&v=4"
    },
    {
      "id": 3,
      "firstName": "Brendan",
      "lastName": " McCray",
      "username": "Brendan",
      "password": "CodeWhiz",
      "email": "brendanMc@gmail.com",
      "profilePic": "https://avatars0.githubusercontent.com/u/43763999?s=400&v=4"
    },
    {
      "id": 4,
      "firstName": "Brad",
      "lastName": "Davis",
      "username": "braddavistech",
      "password": "12345NSS",
      "email": "brad@braddavistech.com",
      "profilePic": "https://scontent-atl3-1.xx.fbcdn.net/v/t1.0-9/35884762_10211693141659337_7630947963367325696_n.jpg?_nc_cat=103&_nc_ht=scontent-atl3-1.xx&oh=ffc0c07db4711096066f9a4612ebff3c&oe=5C7CD0B2"
    },
    {
      "id": 5,
      "firstName": "Donald",
      "lastName": "Trump",
      "username": "Love My Hair",
      "password": "12345NSS",
      "email": "trump@trump.com",
      "profilePic": ""
    },
    {
      "id": 6,
      "firstName": "Mike",
      "lastName": "Tyson",
      "username": "Still Hungry",
      "password": "12345NSS",
      "email": "mike@littleMikey.com",
      "profilePic": "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTBN2BB7Jk3VpInKi7R-ylNVUSDThjy77ESQD6lCk1G5j83TQwB"
    },
    {
      "id": 7,
      "firstName": "June",
      "lastName": "Shannon",
      "username": "Not My Baby",
      "password": "12345NSS",
      "email": "not@hottonot.com",
      "profilePic": "https://66.media.tumblr.com/avatar_559f50fa0023_128.pnj"
    },
    {
      "id": 8,
      "firstName": "Bob",
      "lastName": "Ross",
      "username": "Happy Trees",
      "password": "12345NSS",
      "email": "trees@treesdoplease.com",
      "profilePic": ""
    }
  ],
  "messages": [
    {
      "id": 1,
      "messageContent": "Hi, first message.",
      "timeStamp": "2018-11-08T14:07:21.489Z",
      "userId": 1
    },
    {
      "id": 2,
      "messageContent": "I changed the message.",
      "timeStamp": "2018-11-09T12:10:34.489Z",
      "userId": 3
    },
    {
      "id": 3,
      "messageContent": "You get the idea.",
      "timeStamp": "2018-11-07T21:16:34.489Z",
      "userId": 2
    },
    {
      "messageContent": "This makes a better message",
      "timeStamp": "2018-11-10T09:16:34.489Z",
      "userId": 4,
      "id": 4
    }
  ],
   "articles": [
    {
      "articleName": "Tearful Elon Musk Warns About Dangers Of AI After Having Heart Broken By Beautiful Robotrix",
      "url": "https://www.theonion.com/tearful-elon-musk-warns-about-dangers-of-ai-after-havin-1822192554",
      "articleImage": "https://i.kinja-img.com/gawker-media/image/upload/s--CJvX7MgP--/c_scale,f_auto,fl_progressive,q_80,w_800/tizlx79ig3cluhdkvwuh.jpg",
      "dateSaved": "2018-11-14T21:18:52.339Z",
      "about": "It was named Mark Zuckerberg",
      "userId": 2,
      "id": 1
    },
    {
      "articleName": "Astronomers Confirm Moon Will Have Dozens Of New Phases In 2019",
      "url": "https://www.theonion.com/astronomers-confirm-moon-will-have-dozens-of-new-phases-1830339439",
      "articleImage": "https://i.kinja-img.com/gawker-media/image/upload/s---K0s5FLo--/c_scale,f_auto,fl_progressive,q_80,w_800/chmtxbc2yw9jzlv1bpxu.jpg",
      "dateSaved": "2018-11-09T21:18:52.339Z",
      "about": "Cheese phase activate",
      "userId": 3,
      "id": 2
    },
    {
      "articleName": "Astronomers Confirm Moon Will Have Dozens Of New Phases In 2019",
      "url": "https://www.trtworld.com/americas/five-things-you-need-to-know-about-trump-s-space-force-21667",
      "articleImage": "",
      "dateSaved": "2018-11-14T21:18:52.339Z",
      "about": "The sun is bright",
      "userId": 1,
      "id": 3
    },
    {
      "articleName": "Scammers impersonate Elon Musk on Twitter, hack Target in bitcoin fraud",
      "url": "https://www.usatoday.com/story/money/2018/11/13/twitter-bitcoin-scam-elon-musk-target/1986017002/",
      "articleImage": "https://www.gannett-cdn.com/-mm-/a890a0b221257bbeacdf114031d88c89afd4f7cf/c=32-0-548-387/local/-/media/2018/10/27/USATODAY/usatsports/bitcoin-gettyimages-880534636_large.jpg?width=534&height=401&fit=crop",
      "dateSaved": "2018-11-13T21:18:52.339Z",
      "about": "Bitcoin is at an all time HIGH! LOW! HIGH! LOW! HIGH!",
      "userId": 4,
      "id": 4
    }
   ],
     "events": [
    {
      "id": 2,
      "name": "Fancy Party",
      "timestamp": "2018-12-09T15:02:52.339",
      "location": "My House",
      "userId": 2
    },
    {
      "name": "Soccer Practice Today",
      "timestamp": "2018-12-02T22:11:52.339",
      "location": "The Field",
      "userId": 2,
      "id": 3
    },
    {
      "name": "Sleep",
      "timestamp": "2018-12-15T04:23:52.339",
      "location": "My Bed",
      "userId": 3,
      "id": 4
    },
    {
      "name": "First day of school",
      "timestamp": "2018-10-01T01:02:52.339",
      "location": "NSS",
      "userId": 2,
      "id": 9
    },
    {
      "name": "The Day I Was Born",
      "timestamp": "1989-05-15T12:12:52.339",
      "location": "Hospital",
      "userId": 2,
      "id": 10
    },
    {
      "name": "Coffee with Jim",
      "timestamp": "2018-12-12T08:45:00.000",
      "location": "Starbucks",
      "userId": 1,
      "id": 11
    },
    {
      "name": "Lunch with Jill",
      "timestamp": "2018-12-15T17:23:52.339",
      "location": "Pizza Hut",
      "userId": 3,
      "id": 12
    },
    {
      "name": "Jase's Party",
      "timestamp": "2018-12-20T22:10:52.339",
      "location": "The Moon",
      "userId": 2,
      "id": 13
    },
    {
      "name": "Brendan's House Warming",
      "timestamp": "2018-12-17T20:16:52.339",
      "location": "Nashville, TN",
      "userId": 4,
      "id": 14
    },
    {
      "name": "Dance Class",
      "timestamp": "2018-12-14T11:11:52.339",
      "location": "Roots",
      "userId": 4,
      "id": 15
    },
    {
      "name": "Spelling Bee",
      "timestamp": "2018-12-11T11:11:52.339",
      "location": "Highschool",
      "userId": 3,
      "id": 16
    },
    {
      "name": "Lunch with Mike",
      "timestamp": "2018-12-12T11:11:52.339",
      "location": "South",
      "userId": 2,
      "id": 17
    },
    {
      "name": "Start NSS",
      "timestamp": "2018-10-01T09:00:52.339",
      "location": "Nashville Software School",
      "userId": 4,
      "id": 19
    },
    {
      "name": "Presentation of Mission Control Test",
      "timestamp": "2018-12-04T09:00:52.339",
      "location": "Nashville Software School",
      "userId": 4,
      "id": 20
    },
    {
      "userId": 1,
      "name": "Test",
      "location": "NSS",
      "timestamp": "2018-12-07T08:30:00.000",
      "id": 21
    }
  ],
  "friends": [
    {
      "id": 3,
      "request_userId": 3,
      "userId": 2
    },
    {
      "request_userId": 1,
      "userId": 3,
      "id": 4
    },
    {
      "request_userId": 1,
      "userId": 2,
      "id": 5
    },
    {
      "request_userId": 2,
      "userId": 3,
      "id": 6
    },
    {
      "request_userId": 2,
      "userId": 1,
      "id": 7
    },
    {
      "request_userId": 2,
      "userId": 2,
      "id": 8
    }
  ],
  "columns": [
    {
      "name": "Upcoming",
      "id": 1,
      "columnTasks": [
        1
      ]
    },
    {
      "name": "InProgress",
      "id": 2,
      "columnTasks": [
        2
      ]
    },
    {
      "name": "Completed",
      "id": 3,
      "columnTasks": [
        3
      ]
    }
  ],
  "column_order": {
    "columnId": [
      1,
      2,
      3
    ]
  }
}

From your terminal window, type

cd reactShell/api
json-server -p 8088 database.json

From your terminal window, type Command T, then in the new tab type

cd reactShell
npm start

Now that the server is up and running, you can open an internet browser and access the application:

http://localhost:8080/

The database can be accessed by entering the following in the url bar.

http://localhost:8088/

Congratulations! You are now experiencing ReactShell!

Topics Covered Building Mission Control

We covered numerous topics in the execution of this project which include:

  1. Functions
  2. Stand-Up meetings
  3. ERD Diagrams
  4. React
  5. State-management
  6. Databases/API
  7. Github
  8. Objects
  9. CSS
  10. Handling user events
  11. Factory functions
  12. Data entry/editing
  13. Modular code with Browserify
  14. Relational data

Entity Relationship Diagrams

Professional Requirements

  1. All teams must manage their navigation through state
  2. The README for your project should include instructions on how another person can download and run the application

How to Handle Authentication

Session storage was used to store the current user at login and makeAPI calls in relation to the value stored. Only the userId is saved to sessonStorage.

sessionStorage.setItem("id", userId);

If you want to add a Logout feature, all you need to do it remove the session storage item.

sessionStorage.removeItem("id");

Visual Feature List

To help you along, here is a visualization of the features, and behaviors of the application to get you started.

You can’t perform that action at this time.