Skip to content

A full-stack social media application where users can post and share their coding projects, adding friends, and joining the discussion in threaded comments on project posts.

Notifications You must be signed in to change notification settings

cnohilly/codeflow

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CodeFlow

License

Description

CodeFlow is a social media application where users can post and share their coding projects with others. By logging in or signing up the user will be able to use the project form to submit their project with a title, description, tags, repository link and deployed application link. Other users can then view those projects and like it, comment on it and also reply to other comments made on the project.

Along with this the user will have access to their own personal profile page where they can add a biography and custom profile picture and view their posted projects. The user also has the option to friend other users which allows them to view their friends profiles and projects.

Check out the deployed application using the links below!

Table of Contents

Installation

To install this application on your local machine:

  • Clone the application's repository and place it into a local directory on your computer.
  • Ensure that your computer has node.js installed.
  • Open a command-line interface (VS Code, Git Bash, etc.) and navigate to the root directory.
  • In the command-line, download the application's dependencies by typing:
    npm install
  • To seed the database, type the following command:
    npm run seed
  • Start the application by typing the following command. Your default web browser will then open the application in a new tab.
    npm run develop

Usage

  • To start the server, type the following command:
npm run develop
  • This will open a local host tab in your browser with the application.
  • Sign up as a new user or log in as an existing user in the upper right of the navigation bar to begin posting projects or liking and adding comments to existing projects.
  • On the homepage, the most recent projects posted will be shown. By clicking on them you will be taken to the individual project page which will show all comments and replies.
  • In the navigation bar on the top of the page is a search bar allowing you to search for projects. Select either title or tag from the dropdown and input your title or tag the search field. A search results page will display projects matching the user input.
  • You can like a comment by clicking on the heart below the comment text.
  • You can also leave a comment by filling out the comment form field and clicking on the comment button. The page will automaticaly update with the new comments appearing below the form.
  • Clicking on the profile link in the navigation bar will take you to your profile and allow them to add a profile picture, update their biography, view their previous project posts or add friends.
  • To log out of your account, click on the logout button on the upper right of the navigation bar.

Screenshots

The following images demonstrate the application's appearance and functionality.

Homepage

alt='homepage'

Project Forms

alt='projectform

User Profile Page

alt='profilepage'

Technologies Used

  • GraphQL
  • JWT-Decode
  • React
  • React-Dom
  • React-Router-Dom
  • Sass
  • Apollo/Client
  • Yaireo/tagify
  • JsonWebToken
  • Mongoose
  • Express
  • Apollo-Server-Express
  • Nodemon
  • Bcrypt
  • Concurrently
  • Animate.css
  • GoogleFonts

Credits

Special thanks to these developers for making this project possible:

Links

License

This application is covered under the MIT License.

About

A full-stack social media application where users can post and share their coding projects, adding friends, and joining the discussion in threaded comments on project posts.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published