15
11
24
Cover image for I built a Dev.to clone from scratch! 🥳😄

I built a Dev.to clone from scratch! 🥳😄

Live Site

Backend API

Tech

  • UI: React
  • Routing: React Router
  • Real-time Notifications: Socket.io
  • Backend: Express
  • Database: MongoDB
  • ORM: Mongoose
  • Image hosting: Cloudinary

Features

  • Login / Signup
  • Google Oauth
  • Create / Remove / Update / Delete Post
  • Like / Unicorn / Bookmark Post
  • Reading List
  • Create / Add Tags to Post
  • Follow Tags
  • Find Posts by Tags
  • Comment / Replies
  • Like Comment
  • Edit / Delete Comment
  • View Profile
  • Edit Profile
  • Follow User
  • Search Posts
  • Real-time Notifications

How to setup locally

Clone

Clone the repo to your local machine using https://github.com/eknoorpreet/dev.to-clone

Setup

Install npm dependencies in both client and server subdirectories using npm install

$ cd server && npm install $ cd client && npm install

Set up a MongoDB database either locally or online via MongoDB Atlas

Create a Cloudinary account

Create a new project on Google Cloud Platform

Create a .env file in in both client and server subdirectories

Set up the following environment variables

In client/.env:

REACT_APP_BASE_URL=http://localhost:5000/api REACT_APP_SOCKET_IO_URL=http://localhost:5000 REACT_APP_GOOGLE_CLIENT_ID=<GOOGLE_CLIENT_ID>

In server/.env:

DB_USER= //user name for db DB_PASSWORD= //password for db DB_NAME= // name for db JWT_KEY= //random string //cloundiary will provide you with the following credentials CLOUDINARY_CLOUD_NAME= //cloud name CLOUDINARY_API_KEY= //API key CLOUDINARY_API_SECRET; //API secret //Google will provide you with the following credentials GOOGLE_API_KEY = //API key

Finally, run npm start in both client and server subdirectories

$ cd server && npm start $ cd client && npm start

Discussion (34 comments)

avatar
avatar
Eknoorpreet Singh
Apr 6, 2022
Hey guys, I tried to make it as close to the original as possible. Would appreciate any feedback 😄
avatar
Chris Meyers
Apr 6, 2022
Looks good!
avatar
Tai Nguyen Tien
Jun 12, 2022
kaka
avatar
AZIZBEK MATYAQUBOV
Oct 3, 2022
you need to make video for youtube
avatar
Anthony Fdez
Apr 6, 2022
damn this does look really good! Good shit
avatar
Test
Apr 7, 2022
Nice done! (by u/dance2die)
avatar
Test
Apr 7, 2022
3
avatar
Test
Apr 7, 2022
4
avatar
Eknoorpreet Singh
Apr 7, 2022
Thanks a lot! 😀
avatar
demo
Apr 8, 2022
amazing! it is really cool!
avatar
mayank k
Apr 8, 2022
This comment is from that app. Was wondering if you have also implemented the filtering engine like the main website
avatar
Gyana D valentino
Apr 8, 2022
welldone man
avatar
Test
Apr 8, 2022
ggg
avatar
Duplicate
Apr 13, 2022
Great job!!
avatar
Sriram Krishnamurthy
Apr 15, 2022
Dandy Dandy Dandy Bro ! Aawesome !
avatar
djo amairi
Apr 24, 2022
great work <3
avatar
Đào trung kiên
Apr 25, 2022
Hi
avatar
Võ Hoàng Huy
Sep 24, 2022
hi
avatar
Võ Hoàng Huy
Sep 24, 2022
hi
avatar
admin admin
Oct 20, 2022
hii
avatar
admin admin
Oct 20, 2022
hiii
avatar
DaniellSpeed
Apr 26, 2022
perfect
avatar
Do Hung
Apr 17, 2024
sssssss
avatar
Thống Trần Lê Quốc
Apr 27, 2022
just a test bro
avatar
thongtran
Apr 28, 2022
why the notificaiton socket not working
avatar
Thống Trần Lê Quốc
Apr 28, 2022
I dk
avatar
Thống Trần Lê Quốc
Apr 27, 2022
1
avatar
thongtran
Apr 28, 2022
hey
avatar
Winner
May 2, 2022
hi
avatar
Winner
May 3, 2022
great!!
avatar
Tom Tran
Jun 11, 2022
Amazing job bro
avatar
Tarsbblf
Aug 15, 2022
Jdfifjfjf
avatar
Xuân Tiền Tạ
Sep 27, 2022
good
avatar
Jeecooo
Sep 1, 2024
Looks good!
avatar

Eknoorpreet Singh

Typical bacon scholar. Subtly charming food junkie. Extreme social media guru. Coffee maven.

Skills/Languages

React, Node, GraphQL

Location

Vancouver, BC

Work

Freelance Software Engineer