Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/practical-works/mevn-chat
💬 Realtime chat web app example made with the MEVN stack (MongoDB, ExpressJS, VueJS, and NodeJS).
https://github.com/practical-works/mevn-chat
chat chat-app chat-application express expressjs javascript messenger mevn mevn-stack mongo mongodb mongoose node nodejs realtime realtime-messaging socket socket-io vue vuejs
Last synced: 4 days ago
JSON representation
💬 Realtime chat web app example made with the MEVN stack (MongoDB, ExpressJS, VueJS, and NodeJS).
- Host: GitHub
- URL: https://github.com/practical-works/mevn-chat
- Owner: practical-works
- License: mit
- Created: 2021-09-18T04:11:36.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-09-28T03:14:28.000Z (over 3 years ago)
- Last Synced: 2024-12-24T13:47:48.783Z (about 2 months ago)
- Topics: chat, chat-app, chat-application, express, expressjs, javascript, messenger, mevn, mevn-stack, mongo, mongodb, mongoose, node, nodejs, realtime, realtime-messaging, socket, socket-io, vue, vuejs
- Language: JavaScript
- Homepage: https://amb-mevn-chat.herokuapp.com
- Size: 328 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 💬 MEVN Chat
[data:image/s3,"s3://crabby-images/f1a56/f1a56343fcf3997eb2376a9776b67f85e2320fec" alt="Web"](https://github.com/topics/web)
[data:image/s3,"s3://crabby-images/098d2/098d26fdc4507a6a990337a8c770526c792ef413" alt="JavaScript"](https://github.com/topics/javascript)
[data:image/s3,"s3://crabby-images/c8cda/c8cda04db4bc034c5d72f48981dc23467ba4908b" alt="VueJS"](https://github.com/topics/vue)
[data:image/s3,"s3://crabby-images/1f91e/1f91ec7deaf2182a8dae6e95193f75a74487f77e" alt="BulmaCSS"](https://github.com/topics/bulma)
[data:image/s3,"s3://crabby-images/4d734/4d734bfa09507fff3a84c9f0996169c329cb0e97" alt="SocketIO"](https://github.com/topics/socket.io)[data:image/s3,"s3://crabby-images/e6c04/e6c04eb3501ecc7c7405fa9eed79f5b9643b7bfc" alt="NodeJS"](https://github.com/topics/node)
[data:image/s3,"s3://crabby-images/d8558/d8558a4e92e2c94eb21ec36415de84da373f2e32" alt="ExpressJS"](https://github.com/topics/express)
[data:image/s3,"s3://crabby-images/27dd4/27dd4bbd5dc6f65790a5f2140e617eb3e91319f3" alt="MongoDB"](https://github.com/topics/mongo)
[data:image/s3,"s3://crabby-images/44178/44178822f1d98ff5de1371a087ef7ca3ff74d248" alt="Mongoose"](https://github.com/topics/mongoose)Realtime chat web application example made with the **MEVN** stack (**MongoDB**, **ExpressJS**, **VueJS**, and **NodeJS**).
[**🌐 View Live Demo**](https://amb-mevn-chat.herokuapp.com/)
data:image/s3,"s3://crabby-images/3312d/3312d078e6bfa5bbdc5741145c5c32b310c64153" alt="Screenshot"
## 🏁 Getting started
1. [Clone](https://docs.github.com/en/repositories/creating-and-managing-repositories/cloning-a-repository) the repository:
```bash
cd somewhere
git clone https://github.com/practical-works/mevn-chat.git
cd mevn-chat
```
2. Install the dependencies:```bash
npm i
```3. Install [Nodemon](https://github.com/remy/nodemon/) globally:
```bash
npm i -g nodemon`
```4. Run development **database**:
```bash
npm run db
```5. Run development **server**:
```bash
npm run server
```## ✈️ Deployment
1. Create and run a live **MongoDB** database using a service like [**MongoDB Atlas**](https://www.mongodb.com/cloud/atlas) and get the **connection string**.
The MongoDB **connection string** (URL) usually looks something like this:
> mongodb+srv://**username**:**password**@**host-address**/**database-name**?retryWrites=true&w=majority
where **username**, **password**, **host-address**, and **database-name** are placeholders for the values provided by the service and specific to the user.2. Push the repository to a **node server** using a service like [**Heroku**](https://heroku.com).
3. In the remote node server:
a. Set the environment variable `CONNECTION_STRING` to the obtained mongoDB **connection string**:
```bash
CONNECTION_STRING=mongodb+srv://...etc
```b. Install the dependencies:
```bash
npm i
```c. Start the server for production:
```bash
npm start
```## 🚀 Development
### 🏭 Environment
- Runtime: [**NodeJS**](https://github.com/nodejs)
- Package Manager: [**NPM**](https://github.com/npm)
- Editor: [**Sublime Text**](https://www.sublimetext.com)### 🌑 Backend
- ⚛️ Core:
- Main: [**NodeJS**](https://github.com/nodejs/node) / [**ExpressJS**](https://github.com/expressjs/express)
- 💽 Database:
- Main: [**MongoDB**](https://www.mongodb.com/)
- Object Modeling: [**Mongoose**](https://github.com/Automattic/mongoose)
- 🔧 Utils:
- Realtime Communication (Server Side): [**Socket.IO**](https://github.com/socketio/socket.io)
- Console Logging: [**Morgan**](https://github.com/expressjs/morgan)
- Console Coloration: [**Colors.JS**](https://github.com/Marak/colors.js)### 🌕 Frontend
- ⚛️ Core:
- Main: [**VueJS**](https://github.com/vuejs/vue)
- 🎨 UI:
- Main: [**Bulma**](https://github.com/jgthms/bulma)
- 🔧 Utils:
- Realtime Communication (Client Side): [**Socket.IO**](https://github.com/socketio/socket.io)
- Date Formatting: [**MomentJS**](https://github.com/moment/moment)## 📄 License
Licensed under [MIT](./LICENSE).