๐ฌ Chatify ยท
A realtime chat app built with TypeScript, React, Node.js, and AWS. It allows users to log in easily using OAuth 2.0 (Google, GitHub, email/password). Users can connect with others and send text messages, emojis, stickers, media, files, and more. The chat offers many features found in popular messaging apps like WhatsApp.
- Fronted:
TypeScript
ยทReact
ยทVite
ยทTailwindCSS
ยทZustand
ยทAuth0
- Backend:
TypeScript
ยทNode.js
ยทExpress
ยทTurso
ยทSocket.io
ยทREST
ยทJWT Auth
- Infra:
AWS: EC2 - S3 - CloudFront
ยทCloudflare Pages
ยทPNPM Workspaces
ยทPM2
ยทGitHub Actions
- Linting and Formatting:
StandarJS
ยทEsLint
ยทPrettier
-
๐ Sign in/Sign up with Google, GitHub, or email/password
-
๐ฌ Initiate personalized chats with other users.
-
๐ฉ Messaging Options:
- ๐๏ธ Share any file type.
- ๐ท Exchange images.
- โ๏ธ Send and receive text messages.
- ๐ฅ Share videos.
- ๐ Express with fun stickers.
- ๐๏ธ Share animated GIFs.
- ๐ Add emojis to convey emotions.
-
๐ Automatically identify links and provide clickable anchor tags.
-
๐ Respond to messages to maintain clear and contextual conversations.
-
๐ฎ Stay updated with notifications for unseen messages.
-
๐ง Track message read status for improved communication clarity.
-
๐ React to messages with emojis to express feelings and responses.
-
๐ Access a wide array of emojis through an intuitive emoji picker.
-
๐ Send stickers using an intuitive sticker picker powered by Tenor.
-
๐ท Preview sent images and files directly within the chat interface.
-
๐ฌ Message Management:
- ๐๏ธ Delete messages with a note indicating removal.
- ๐ Filter chats and messages efficiently using the search bar.
- ๐งฎ Sort messages by file type, media, and more.
-
๐ฅ Chat Actions:
- ๐ Pin/Unpin
- ๐ Hide/Unhide
- ๐ Mute/Unmute
- ๐ต Mark Read/Unread
- ๐ Block/Unblock
- ๐งผ Clear
- โ Delete
To run the project in your local environment, follow these steps:
- Clone the repository to your local machine.
- Rename the files:
client/.env.example
to.env.local
and/server/.env.example
to.env.local
. - Fill in the values of the environment variables in the newly created
.env.local
files with your own data. - Ensure you have Node.js and pnpm installed on your machine.
- Navigate to the
server
directory of the project and install dependencies and run the server by runningnpm i && npm start
. - Open another terminal, navigate to the
client
directory, install the dependencies, and start the client by running:npm i && npm start
- You can access the app at: http://localhost:5173.
That's it! Your project should now be up and running locally.
Thank you for exploring this project! If you find the structure or features useful, feel free to use this code for your project. Contributions are welcome! If you have ideas, corrections, or improvements, please open an issue or send a pull request. Your collaboration is valued and appreciated! ๐
Chatify is MIT licensed. โค๏ธ