Fakebooker is an extensive open-source project that is essentially a clone of the real Facebook. Now Fakebooker is not one of those little pet projects that just prove the concept, the Fakebooker UI is almost identical to the real Facebook Beta which makes it even more unique. The idea of this project is to try to implement Facebook's design patterns using the MERN stack. It is made for educational purposes only and nothing else!
- Javascript library for building User Interfaces:
React
- Client for handling GraphQL queries + caching + local state management:
ApolloClient
- CSS-in-JS library for handling Fakebooker's styles:
styled-components
- Performant, flexible and extensible forms with easy-to-use validation:
react-hook-form
- Notifications are built on top of:
react-toastify
- Popups are made using:
reactjs-popup
- Handling time properly:
momentjs
- Skeletons for loading components:
react-content-loader
- Loading spinners for smaller actions:
react-loader-spinner
Backend link
- The NoSQL database for modern applications:
mongodb
- Elegant MongoDB object modeling for node.js:
mongoose
- GraphQLServer:
apollo-server
- Authentication built on top of tokens:
jwt
- Image Upload:
cloudinary
- Easily faking data:
faker
- Testing framework:
jest
- Integration testing package:
apollo-server-testing
Most of the backend code is test covered except some resolvers and the subscription ones
I've tried my best to clone the real Facebook Beta even with the same colors provided in theme.js
- You can
login
orregister
easily, and if something goes wrong there are cool validations to help you get on ( every input is validated on the app )
- You can create a post in which you can also use
markdown
and upload an image if you want to just like Facebook - You can like or comment on a post and if the post is not yours the person who created it will receive an instant realtime notification about your particular action (
apollo subscriptions
) - You can delete a post (
if it's yours all comments and likes associated to it will get deleted
) - You can unlike or delete your comment (
the notifications related to your like or comment will get deleted
) - You can delete anyone's comment as long as you are the post creator
- On every post or comment if you hover on the post's / comment's creator you can go to his profile page
- You can make friends: send friend requests to other users and they can respond to your request (
a friend notification is fired through subscriptions once again
) - You can open up a chat with that particular user
- You can change your avatarImage (
cloudinary
) - You can change your coverImage (
cloudinary
) - You can view your Timeline, About, Friends and Photos pages (
refer to ProfilePage
)
- You can search for users with filter on.
- You can chat with people (
again through subscriptions
) and the ProfilePage corresponds with that user's data - You can see all your conversations (
chat button on Navbar
) - You can see all your notifications (
notification button on Navbar
) - When you click on a notification it redirects you to the SinglePostPage if it's a post type or user if it's a friend request type
- Loading states and skeletons for every single component/page on the app
- Navbar
- Consists of the single post that the notification is pointing to
- The newsfeed contains all posts from the app, which again you can interact with them
- Contacts: Your friends (
if you click on a friend, a chat tab is going to be opened for a quick chat with him
) - Navbar
- Navbar
- ProfileHeader
You've read most of the features, go to fakebooker.com and then check in real time the features that I'm explaining
- Consists of all your information: About, Photos, Friends and your posts
- Consists of all your personal information such as:
- Workplace
- School
- Homeplace
- Birthday
- Gender
- Consists of all your friends (
each friend has a button to remove him from your friends' list
)
- Consists of all your posts that contain images
- Copy the
.env.example
file into.env.local
and fill in the actual values (you need to have a cloudinary account
)
npm install && npm start
Contribution is accepted and I encourage you to do so as long as you follow my Github worklfow
Check out Projects
tab in both frontend and backend repos and if you don't find that issue that you are having, better create one and I will make sure everything is alright!