Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/miles-till/easy-mern-stack
An easy to use full-stack MERN project - without bloat
https://github.com/miles-till/easy-mern-stack
expressjs mern mern-stack mongodb mongoosejs monorepo nodejs reactjs
Last synced: 3 months ago
JSON representation
An easy to use full-stack MERN project - without bloat
- Host: GitHub
- URL: https://github.com/miles-till/easy-mern-stack
- Owner: miles-till
- License: mit
- Created: 2019-03-11T06:18:47.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-09T15:22:30.000Z (about 2 years ago)
- Last Synced: 2024-09-28T20:41:14.021Z (4 months ago)
- Topics: expressjs, mern, mern-stack, mongodb, mongoosejs, monorepo, nodejs, reactjs
- Language: JavaScript
- Homepage:
- Size: 1.23 MB
- Stars: 10
- Watchers: 1
- Forks: 4
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Easy MERN Stack
![MERN](media/mern.png "MERN")
An easy to use full-stack MERN project: [MongoDB](https://www.mongodb.com/), [Express](https://expressjs.com/), [React](https://reactjs.org/), [Node.js](https://nodejs.org/en/)
Client React app scaffolded with [create-react-app](https://github.com/facebook/create-react-app)
Monorepo project components (client, server, shared) integrated with [Yarn workspaces](https://yarnpkg.com/lang/en/docs/workspaces/)
## Contents
- [Quick Start](#quick-start)
- [Configure](#configure)
- [Run](#run)
- [Deploy](#deploy)
- [Yarn Scripts (package.json)](#yarn-scripts-packagejson)
- [Project Structure](#project-structure)
- [Client](#client)
- [Server](#server)
- [Development Tools](#development-tools)
- [License](#license)## Quick Start
### Configure
1. Install [Node.js](https://nodejs.org/en/)
2. Install [Yarn](https://yarnpkg.com/en/)
3. Install [nodemon](https://github.com/remy/nodemon) package globally:
```
yarn global add nodemon
```4. Install server and client packages:
```
yarn install
```5. Install [MongoDB](https://www.mongodb.com/download-center/community)
### Run
1. Ensure [MongoDB](https://www.mongodb.com/) is running on `mongodb://localhost:27017` (or change the `const mongoUrl` line in `server/src/index.js` to point to your MongoDB server)
2. In the project root directory, start the server and client:
```
yarn start
```_Note: In development the client app will be served by create-react-app (webpack dev server) and the proxy entry in the client app's `package.json` will pass any api requests to the node server._
### Deploy
1. Build project:
```
yarn build
```2. Deploy `build` directory
3. Start node server:
```
node main.js
```4. Navigate your browser to http://localhost:5000
## Yarn Scripts (package.json)
I have included some helper scripts as part of the `package.json` to reduce the need to `cd` in and out of the client and server directories:
| Script | Result |
| --- | --- |
| `yarn run client` | starts the client app |
| `yarn run server` | starts the server |
| `yarn start` | starts the server and client app concurrently |
| `yarn client-build` | builds the client app |
| `yarn server-build` | builds the server app |
| `yarn build` | builds the server and client app, then copies both to the root build directory for deployment |
| `yarn client-add ` | adds a package to the client app |
| `yarn server-add ` | adds a package to the server |
| `yarn shared-add ` | adds a package to the shared module |
| `yarn client-remove ` | removes a package from the client app |
| `yarn server-remove ` | removes a package from the server |
| `yarn shared-remove ` | removes a package from the shared module |## Project Structure
```
+-- .vscode # vs code configuration
|
+-- build/ # project builds to here
+-- packages/ # yarn workspaces
| +-- app/ # react client app
| | +-- build/ # client builds to here
| | +-- public/ # static resources
| | +-- src/ # client source
| | | +-- apis/ # apis for models to communicate with server
| | | +-- components/ # react components
| | |
| | +-- .env # allows absolute paths for imports
| | +-- jsconfig.json # vscode config for js project
| | +-- package.json # yarn package config
| | +-- README.md # create-react-app generated readme
| | +-- yarn.lock # yarn package lock file
| |
| +-- server/ # node web server + api
| | +-- build/ # server builds to here
| | +-- src/ # server source
| | | +-- apis/ # registers api endpoints
| | | +-- models/ # mongoose data models
| | | +-- index.js # server config
| | |
| | +-- package.json # server yarn package config
| |
| +-- shared/ # shared project modules
| +-- api-endpoints/ # describes api endpoints (urls)
|
+-- tools/ # project build tools
+-- LICENSE # MIT license
+-- package.json # project yarn package config
+-- README.md # this readme file
+-- yarn.lock # yarn package lock file
```## Client
* [React](https://reactjs.org/)
* Web client
* [Axios](https://github.com/axios/axios)
* AJAX requests## Server
* [Node.js](https://nodejs.org/en/)
* Server platform
* [Express](https://expressjs.com/)
* Web server
* [MongoDB](https://www.mongodb.com/)
* Database server
* [Mongoose](https://mongoosejs.com/)
* Server-side data models## Development Tools
* [Yarn](https://yarnpkg.com/en/)
* Package manager and script runner
* [Nodemon](https://github.com/remy/nodemon)
* Monitors and restarts node server when source changes
* [Concurrently](https://github.com/kimmobrunfeldt/concurrently)
* Runs multiple commands concurrently
* [Monopack](https://github.com/flegall/monopack)
* Server-side build tool## License
This project is licensed under the [MIT open source license](/LICENSE).