Group-Based Social Network Web App
Single-page application for group-based social networking similar to Reddit, built with React and JavaScript
Per course policy, access to code is only granted upon request.
Highlights
- Created Ginger, a group-based social network application using the MERN web development technology stack.
- Built backend using Express and MongoDB, exposing REST APIs for object creation, modification, and deletion.
- Deployed WebSockets for push notifications and infinite scroll, enabling live post feeds on client side.
data:image/s3,"s3://crabby-images/0e4c9/0e4c91e85564e62b9bf5279b721a40962859c64a" alt="group main page"
Group main page
Features
User Operations
- Sign Up. Users can sign up for an account by providing a username, email, and password.
- Log In. Users can log in to their account using their username and password.
- Log Out. Users can log out of their account.
- Edit Profile. Users can edit their profile information, including their username, email, and password.
- Deactivate Account. Users can deactivate their account, which will hide their profile and posts from other users.
data:image/s3,"s3://crabby-images/21115/21115c322055af25d5017ed5ea0f5b265a9c5814" alt="Signup page"
data:image/s3,"s3://crabby-images/489fc/489fca7bc7b9eaccf6ba46a632cc379068c803cf" alt="Profile page"
data:image/s3,"s3://crabby-images/0fca1/0fca1696725ccb9b2e64ed757943718d51fe05b9" alt="Profile update page"
Left: Signup page; Middle: Profile page; Right: Profile update page.
Group Operations
- Create Group. Users can create a new group by providing a name, icon, labels. Groups can either be public or private.
- Invite Users. Group owners can invite other users to join their group.
- Manage Group. Group admins can add new admins and remove members from the group.
data:image/s3,"s3://crabby-images/1786f/1786f1724d3ee6abc5a758821dc771efb2cbcbb4" alt="Group creation page"
data:image/s3,"s3://crabby-images/5fab3/5fab308bb3e880dd5651eed297cd40bc3d009f14" alt="Invite users to group"
data:image/s3,"s3://crabby-images/bf137/bf137478d8df8c8987ca25ed276e6309c509cb54" alt="Manage Group admins"
Left: Group creation page; Middle: Invite users to group; Right: Manage Group admins.
Post Operations
- Create Post. Users can create a new post in a group by providing a title, content, and optional media files, including images, videos, and audio.
- Delete Post. Users can delete their own posts.
- Flag or Hide Post. Users can flag or hide posts that violate community guidelines. Admins of the group will be notified and can take action.
- Comment on Post. Users can comment on posts to share their thoughts and opinions.
- Mentions. Users can mention other users in their posts and comments using the
@
symbol. The user mentioned will receive a notification.
data:image/s3,"s3://crabby-images/a6f7b/a6f7b02f68b52e8803b19f3601ab47f8163237b0" alt="Post creation page"
data:image/s3,"s3://crabby-images/b1e82/b1e82d3b76a66bd3dfaaeb8a2fcaabf0d4962231" alt="Post presentation page with comments"
Left: Post creation page; Right: Post presentation page with comments.
Other Features
- Infinite Scroll. Posts are loaded dynamically as the user scrolls down the page.
- Push Notifications. Users receive real-time notifications for new posts, comments, and mentions. This is made possible using WebSockets.
- Suggestions. Users will receive suggestions for groups to join based on the labels they are already in.
data:image/s3,"s3://crabby-images/386f9/386f957f0ab2e03e3723a1b256b94a3da1bf0f87" alt="Notification of flags"
data:image/s3,"s3://crabby-images/55138/55138153ca521e0c4a005617b0d0ad0aa9810331" alt="Notification of mentions"
Left: Notification of flags; Right: Notification of mentions.
Technologies
This project uses the MERN stack: MongoDB, Express, React, and Node.js.
- Frontend. The frontend is built with React using JavaScript. Material-UI is used for UI elements.
- Backend. The backend is built with Node.js and Express. MongoDB is used as the database. Multimedia files can be stored in either GridFS or AWS S3.