Important
Please leave a β if you like this project.
A Real-Time web-based MERN Chat App by Vaibhaw Mishra. { Development in Progress }
Live At: Netlify | TwinkConnect
- Real-time one-to-one chat
- reCAPTCHA support
- Robust authentication system with dynamic flow
- OTP based verification and password reset functionality
- 3 Social logins methods (Google, GitHub & LinkedIn)
- Disposable email check
- Highly responsive UI
- Dark/Light theme support
- 6 different color presets
- Custom movable sidebar for theme settings
- Profile section with image cropper & drag-n-drop support
- Search friends with infinite scrolling
- Emoji support
- Real-time online status
- Real-time typing... message
- Dynamic friends contact menu
Backend:
- Added security options (Rate Limit, XSS Protection, Sanitization, URL Encoding & more)
- Dynamic server & routes error handling
- Dedicted folder structure
- JWT Middlewares for both APIs & Socket based requests
- Cloudinary file upload system with auto folder structuring
- Access & Refresh token with cookies support
- Structured DB with pre save & validations
- And much more
Frontend:
- Custom axios setup for easier API calling
- Custom error interceptors for axios error handlings
- Redux toolkit with persist
- Custom hooks
- Auto refresh tokens & auto token verification
- Google Ananlytics support
- Dynamic routing with lazy loading
- Custom loader
- Customized theme with dedicated folder structuring
- React Hook Form with Yup form validations
- Custom utils folder
- And much more
From root directory, move to the backend using command
$ cd backend/
Install dependencies for server
$ npm install
Setup .env using .env copy
file
$ located in backend/
Start the backend using nodemon
$ npm start
From root directory, move to the frontend using command
$ cd frontend/
Install dependencies for frontend
$ npm install -f
Setup .env using .env copy
file
$ located in frontend/
Runs frontend on localhost(React App)
$ npm start
Creates an optimized production build
$ npm run build
Main Structure
βββbackend/
β βββ ...
βββfrontend/
β βββ ...
βββ .gitignore
βββ LICENSE
βββ Readme.md
Backend
βββ backend/
β βββ src/
β β βββ controllers/
β β β βββ authController.js
β β β βββ conversationController.js
β β β βββ friendsController.js
β β β βββ messageController.js
β β β βββ socialController.js
β β β βββ userController.js
β β βββ middlewares/
β β β βββ authMiddleware.js
β β β βββ socketMiddleware.js
β β βββ models/
β β β βββ conversationModel.js
β β β βββ friendRequestModel.js
β β β βββ index.js
β β β βββ messageModel.js
β β β βββ userModel.js
β β βββ routes/
β β β βββ authRouter.js
β β β βββ conversationRouter.js
β β β βββ friendsRouter.js
β β β βββ index.js
β β β βββ messageRouter.js
β β β βββ userRouter.js
β β βββ services/
β β β βββ authService.js
β β β βββ conversationService.js
β β β βββ fileUploadService.js
β β β βββ friendsService.js
β β β βββ mailer.js
β β β βββ messageService.js
β β β βββ socialAuthService.js
β β β βββ tokenService.js
β β β βββ userService.js
β β βββ Templates/
β β β βββ Mail/
β β β β βββ otp.js
β β β β βββ reset.js
β β βββ utils/
β β β βββ checkDispose.js
β β β βββ filterObj.js
β β β βββ generatePassword.js
β β β βββ tokenGenerator.js
β βββ .env copy
β βββ app.js
β βββ package-lock.json
β βββ package.json
β βββ server.js
β βββ socket.js
β βββ vercel.json
Frontend
βββ frontend/
β βββ public/
β β βββ favicon.ico
β β βββ index.html
β β βββ logo.ico
β β βββ manifest.json
β β βββ robots.txt
β β βββ sitemap.xml
β β βββ _redirects
β βββ src/
β β βββ assets/
β β β βββ backgrounds/
β β β β βββ catDoodle.png
β β β β βββ catDoodle2.png
β β β β βββ catDoodle3.png
β β β βββ icons/
β β β β βββ flags/
β β β β β βββ flag_am.svg
β β β β β βββ flag_en.png
β β β β β βββ flag_en.svg
β β β β β βββ flag_fr.png
β β β β β βββ flag_fr.svg
β β β β β βββ flag_hi.png
β β β β β βββ flag_hi.svg
β β β β β βββ flag_ja.svg
β β β β β βββ flag_vn.svg
β β β β βββ logo/
β β β β β βββ TwinkConnect-old.png
β β β β β βββ TwinkConnect.png
β β β β β βββ TwinkConnectSub.png
β β β β β βββ VaibhawMishra.ico
β β β βββ Illustration/
β β β β βββ Animations/
β β β β β βββ Cat404.json
β β β β β βββ CatAnimation1.json
β β β β β βββ CatAnimation2.json
β β β β β βββ CatAnimation3.json
β β β β β βββ CatAnimation4.json
β β β β β βββ CatAnimation5.json
β β β β β βββ ChillingVibes.json
β β β β β βββ HangingBuddy.json
β β β β β βββ NoResultsFound.json
β β β β β βββ SearchNotFound.json
β β β β βββ NoChat.js
β β βββ components/
β β β βββ animate/
β β β β βββ varients/
β β β β β βββ actions.js
β β β β β βββ background.js
β β β β β βββ bounce.js
β β β β β βββ container.js
β β β β β βββ fade.js
β β β β β βββ flip.js
β β β β β βββ index.js
β β β β β βββ path.js
β β β β β βββ rotate.js
β β β β β βββ scale.js
β β β β β βββ slide.js
β β β β β βββ transition.js
β β β β β βββ zoom.js
β β β β βββ DialogAnimate.js
β β β β βββ FabButtonAnimate.js
β β β β βββ features.js
β β β β βββ IconButtonAnimate.js
β β β β βββ index.js
β β β β βββ MotionContainer.js
β β β β βββ MotionLazyContainer.js
β β β β βββ MotionViewport.js
β β β β βββ TextAnimate.js
β β β βββ hook-form/
β β β β βββ FormProvider.js
β β β β βββ index.js
β β β β βββ RHFOtp.js
β β β β βββ RHFTextField.js
β β β β βββ RHFUpload.js
β β β βββ Image/
β β β β βββ getRatio.js
β β β β βββ Image.js
β β β β βββ index.js
β β β βββ PageComponents/
β β β β βββ ContactPage/
β β β β β βββ FriendsComponents/
β β β β β β βββ FriendsSubComps/
β β β β β β β βββ index.js
β β β β β β β βββ UserCard.js
β β β β β β β βββ UsersSearchResults.js
β β β β β β βββ FriendRequests.js
β β β β β β βββ index.js
β β β β β β βββ SearchUsers.js
β β β β β β βββ SentRequests.js
β β β β β βββ ContactList.js
β β β β β βββ FriendsMenu.js
β β β β β βββ index.js
β β β β βββ GeneralAppPage/
β β β β β βββ ChatElements/
β β β β β β βββ AllChatElement.js
β β β β β β βββ ChatSearchResults.js
β β β β β β βββ OnlineChatElement.js
β β β β β βββ ConversationElements/
β β β β β β βββ ConvoSubElements/
β β β β β β β βββ ChatInput.js
β β β β β β β βββ MessageContainer.js
β β β β β β βββ ConversationFooter.js
β β β β β β βββ ConversationHeader.js
β β β β β β βββ ConversationMain.js
β β β β β β βββ index.js
β β β β β βββ ChatsList.js
β β β β β βββ Conversation.js
β β β β β βββ index.js
β β β β βββ OnlineFriendsElement/
β β β β β βββ OnlineFriendsElement.js
β β β β βββ ProfilePage/
β β β β β βββ ProfilePage.js
β β β β βββ UserProfileDrawer/
β β β β β βββ UserDrawerComps/
β β β β β β βββ UDMainComps/
β β β β β β β βββ RemoveFriendDialog.js
β β β β β β βββ index.js
β β β β β β βββ UserDrawerHeader.js
β β β β β β βββ UserDrawerMain.js
β β β β β βββ UserProfileDrawer.js
β β β βββ Search/
β β β β βββ index.js
β β β β βββ Search.js
β β β β βββ SearchIconWrapper.js
β β β β βββ StyledInputBase.js
β β β βββ settings/
β β β β βββ drawer/
β β β β β βββ BoxMask.js
β β β β β βββ Developer.js
β β β β β βββ index.js
β β β β β βββ SettingColorPresets.js
β β β β β βββ SettingContrast.js
β β β β β βββ SettingDirection.js
β β β β β βββ SettingFullscreen.js
β β β β β βββ SettingLayout.js
β β β β β βββ SettingMode.js
β β β β β βββ SettingStretch.js
β β β β β βββ ToggleButton.js
β β β β βββ index.js
β β β β βββ ThemeColorPresets.js
β β β β βββ ThemeContrast.js
β β β β βββ ThemeLocalization.js
β β β β βββ ThemeRtlLayout.js
β β β βββ upload/
β β β β βββ preview/
β β β β β βββ AvatarCropper.js
β β β β β βββ AvatarPreview.js
β β β β β βββ cropImage.js
β β β β βββ index.js
β β β β βββ UploadAvatar.js
β β β βββ AntSwitch.js
β β β βββ Iconify.js
β β β βββ LoadingScreen.js
β β β βββ NoData.js
β β β βββ StyledBadge.js
β β β βββ ThemeSwitch.js
β β βββ contexts/
β β β βββ SettingsContext.js
β β βββ data/
β β β βββ index.js
β β βββ hooks/
β β β βββ useLocales.js
β β β βββ useLocalStorage.js
β β β βββ useResponsive.js
β β β βββ useSettings.js
β β βββ layouts/
β β β βββ auth/
β β β β βββ index.js
β β β βββ dashboard/
β β β β βββ index.js
β β β β βββ Sidebar.js
β β β βββ docs/
β β β β βββ index.js
β β βββ pages/
β β β βββ auth/
β β β β βββ ForgotPassword.js
β β β β βββ Login.js
β β β β βββ Register.js
β β β β βββ ResetPassword.js
β β β β βββ Verify.js
β β β β βββ WelcomePage.js
β β β βββ dashboard/
β β β β βββ Contact.js
β β β β βββ GeneralApp.js
β β β β βββ GroupChat.js
β β β β βββ Profile.js
β β β β βββ Settings.js
β β β βββ docs/
β β β β βββ TnC.js
β β β βββ 404.js
β β βββ redux/
β β β βββ slices/
β β β β βββ actions/
β β β β β βββ authActions.js
β β β β β βββ chatActions.js
β β β β β βββ contactActions.js
β β β β β βββ userActions.js
β β β β βββ authSlice.js
β β β β βββ chatSlice.js
β β β β βββ contactSlice.js
β β β β βββ index.js
β β β β βββ userSlice.js
β β β βββ rootReducer.js
β β β βββ store.js
β β βββ routes/
β β β βββ index.js
β β β βββ paths.js
β β βββ sections/
β β β βββ auth/
β β β β βββ AuthSocial.js
β β β β βββ ForgotPasswordForm.js
β β β β βββ LoginForm.js
β β β β βββ RegisterForm.js
β β β β βββ ResetPasswordForm.js
β β β β βββ VerifyForm.js
β β β βββ settings/
β β β β βββ ProfileForm.js
β β β β βββ Shortcuts.js
β β β β βββ ThemeDialog.js
β β βββ theme/
β β β βββ overrides/
β β β β βββ Accordion.js
β β β β βββ Alert.js
β β β β βββ Autocomplete.js
β β β β βββ Avatar.js
β β β β βββ Backdrop.js
β β β β βββ Badge.js
β β β β βββ Breadcrumbs.js
β β β β βββ Button.js
β β β β βββ ButtonGroup.js
β β β β βββ Card.js
β β β β βββ Checkbox.js
β β β β βββ Chip.js
β β β β βββ ControlLabel.js
β β β β βββ CssBaseline.js
β β β β βββ CustomIcons.js
β β β β βββ DataGrid.js
β β β β βββ Dialog.js
β β β β βββ Drawer.js
β β β β βββ Fab.js
β β β β βββ index.js
β β β β βββ Input.js
β β β β βββ Link.js
β β β β βββ List.js
β β β β βββ LoadingButton.js
β β β β βββ Menu.js
β β β β βββ Pagination.js
β β β β βββ Paper.js
β β β β βββ Popover.js
β β β β βββ Progress.js
β β β β βββ Radio.js
β β β β βββ Rating.js
β β β β βββ Select.js
β β β β βββ Skeleton.js
β β β β βββ Slider.js
β β β β βββ Stepper.js
β β β β βββ SvgIcon.js
β β β β βββ Switch.js
β β β β βββ Table.js
β β β β βββ Tabs.js
β β β β βββ Timeline.js
β β β β βββ ToggleButton.js
β β β β βββ Tooltip.js
β β β β βββ TreeView.js
β β β β βββ Typography.js
β β β βββ breakpoints.js
β β β βββ index.js
β β β βββ palette.js
β β β βββ shadows.js
β β β βββ typography.js
β β βββ utils/
β β β βββ axios.js
β β β βββ axiosInterceptors.js
β β β βββ createAvatar.js
β β β βββ cssStyles.js
β β β βββ flattenArray.js
β β β βββ formatNumber.js
β β β βββ formatTime.js
β β β βββ getColorName.js
β β β βββ getColorPresets.js
β β β βββ getFileData.js
β β β βββ getFontValue.js
β β β βββ getOtherUser.js
β β β βββ helmetHandler.js
β β β βββ jwt.js
β β β βββ scrollToBottom.js
β β β βββ socialLoginHelpers.js
β β β βββ socket.js
β β β βββ timeFormatter.js
β β β βββ truncateText.js
β β β βββ uuidv4.js
β β βββ App.js
β β βββ config.js
β β βββ index.css
β β βββ index.js
β βββ .env copy
β βββ package-lock.json
β βββ package.json
β βββ README.md