Skip to content

🦸🏼‍♀️ 🦹🏼‍♀️ Spybook is a clone of Facebook for the superhero community built using the MERN stack.

License

Notifications You must be signed in to change notification settings

laurenbrabbin/spybook

Repository files navigation

The Incredibles - Spybook

Our goal for this project was to build a clone of Facebook - 'Spybook', specifically for the superhero community. Our aim was to create a fun but professional looking social media website.

Description

Our user story:

  • Users can sign-up to the platform with their own display picture.
  • Users can log in and sign out of the platform.
  • Users can post their thoughts and share images with other spybook users.
  • Usres can comment on their own and other user's posts.
  • Users can like their own and other user's posts.

A significant part of this challenge was to familiarise ourselves with an existing codebase. We debugged the original codebase and implemented a number of new features, replicating some of Facebook's functionality, including posts, comments, likes and the ability to upload images.

Technologies

Spybook was written with JavaScript, CSS and JSX. Here's an overview of the technologies we used to build our application.

M is for MongoDB

MongoDB is a NoSQL database program that stores data in collections of JSON-like structures, rather than in tables. The application interracts with MongoDB using a tool called Mongoose.

E is for Express

Express is the Javascript equivalent of Sinatra. The structure of this application will feel quite different to what you're used to but the principles are the same.

R is for React

React is a hugely popular tool that is used to build engaging front ends. The basic principle is that the front end is split up into components, each of which could include some logic, template structure (HTML) and styling (CSS).

N is for Node

JavaScript was originally designed to run exclusively in browsers, such as Chrome. Node is a tool that allows you to run Javascript outside the browser and its invention made it possible to build full stack Javascript apps.

We also used...

  • Jest for unit testing on the back end
  • Cypress for end-to-end testing and component testing, on the front end
  • Mongoose to model objects in MongoDB.
  • Nodemon to reload the server automatically.
  • Firebase to store images in a remote database.
  • Heroku to deploy our application to the web.
  • Bcrypt to encrypt user passwords.

Future features for Spybook

  • Users can like other user's comments
  • Users can send private messages
  • Users can send and recieve friend requests
  • Users have their own profile pages
  • Users can upload and share videos
  • Users can create and join groups

Project setup

  1. Fork this repository

  2. Clone your fork to your local machine

  3. Install Node.js dependencies for both frontend and backend (API)

    ; cd api
    ; npm install
    ; cd ../frontend
    ; npm install
    
  4. Install MongoDB

    brew tap mongodb/brew
    brew install mongodb-community@5.0
    
  5. Start MongoDB

    brew services start mongodb-community@5.0
    

Running the application

  1. Start the server
    ; cd api
    ; JWT_SECRET=SUPER_SECRET npm start
    
  2. Start the front end

In a new terminal session...

; cd frontend
; npm start

You should now be able to open your browser and go to http://localhost:3000/ which directs you to the hompeage, where you can sign-up or log in.

(Add heroku link here)

The Incredibles team

This project was created by:

How to contribute ❤

Follow the Project Setup / Running the application steps above to build upon our exsiting project. Open source contributions can include translating to other languages, adding new features, and improving and expanding test functionality.

We welcome any and all contributions.

About

🦸🏼‍♀️ 🦹🏼‍♀️ Spybook is a clone of Facebook for the superhero community built using the MERN stack.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published