-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 5026ac8
Showing
54 changed files
with
24,036 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
# See https://help.github.com/ignore-files/ for more about ignoring files. | ||
|
||
# dependencies | ||
node_modules/ | ||
|
||
# testing | ||
/coverage | ||
|
||
# production | ||
/build | ||
|
||
# misc | ||
.DS_Store | ||
.env.local | ||
.env.development.local | ||
.env.test.local | ||
.env.production.local | ||
.env | ||
|
||
npm-debug.log* | ||
yarn-debug.log* | ||
yarn-error.log* | ||
|
||
# webstorm files | ||
.idea/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
# Build a blog using Nest.js, TypeScript, React and MongoDB | ||
|
||
Application repo for a simple blog application built with Nest.js, TypeScript, React and MongoDB. | ||
|
||
## Getting Started | ||
This prototype is divided into two separate sections. Namely the Backend ( Built with Nest.js) and the frontend | ||
( Built with React ). | ||
|
||
Install TypeScript globally on your machine if you don't have it installed already: | ||
|
||
```bash | ||
npm install -g typescript | ||
``` | ||
|
||
### Clone the repository | ||
To easily set up the application, clone this repository which contains directory for both sections of the project ( i.e `blog-backend` and `blog-frontend`) | ||
|
||
```bash | ||
git clone https://github.com/yemiwebby/nest-react-project.git | ||
``` | ||
|
||
## Change directory into the newly cloned project | ||
```bash | ||
cd nest-react-project | ||
``` | ||
|
||
## Backend | ||
### Change directory into the backend | ||
```bash | ||
cd blog-backend | ||
``` | ||
|
||
### Install backend dependencies | ||
|
||
```bash | ||
npm install | ||
``` | ||
|
||
### Create .env file | ||
Once the installation process is complete, create a `.env` file: | ||
|
||
```bash | ||
touch .env | ||
``` | ||
|
||
Open the newly created file and add the following code: | ||
|
||
``` | ||
AUTH0_DOMAIN=YOUR_AUTH0_DOMAIN | ||
AUTH0_AUDIENCE=YOUR_AUTH0_AUDIENCE | ||
``` | ||
|
||
Ensure that you replace the `YOUR_AUTH0_DOMAIN` and `YOUR_AUTH0_AUDIENCE` placeholder with the appropriate credentials as obtained from your Auth0 dashboard. | ||
|
||
|
||
### MongoDB | ||
Ensure that you have mongoDB installed on your machine before running the application. I have this fully setup on my mac already. | ||
|
||
Start mongoDB: | ||
|
||
```bash | ||
sudo mongod | ||
``` | ||
|
||
### Run the application | ||
Open another terminal and still within the `blog-backend` project directory run the application with: | ||
|
||
```bash | ||
npm run start:dev | ||
``` | ||
|
||
This will start the backend application on port `5000`. This was modified to avoid confliction with the frontend application which by default will run on port `3000` | ||
|
||
|
||
## Frontend | ||
Open another terminal from the `nest-react-project` and navigate to the `blog-frontend` folder to setup the frontend | ||
|
||
### Frontend dependencies | ||
```bash | ||
cd blog-frontend | ||
npm install | ||
``` | ||
|
||
### Run the frontend app | ||
|
||
```bash | ||
npm start | ||
``` | ||
|
||
### Create .env file and include Auth0 App credentials | ||
|
||
Create a `.env` file as shown here: | ||
|
||
``` | ||
touch .env | ||
``` | ||
|
||
Open the file and paste the following code in it: | ||
|
||
``` | ||
REACT_APP_AUTH0_CLIENT_ID=YOUR_AUTH0_CLIENT_ID | ||
REACT_APP_AUTH0_DOMAIN=YOUR_AUTH0_DOMAIN | ||
REACT_APP_AUTH0_AUDIENCE=YOUR_AUTH0_AUDIENCE | ||
REACT_APP_AUTH0_REDIRECT_URI=http://localhost:3000/callback | ||
REACT_APP_BASEURL=http://localhost:3000/ | ||
``` | ||
|
||
Replace `YOUR_AUTH0_CLIENT_ID`, `YOUR_AUTH0_DOMAIN` and `YOUR_AUTH0_AUDIENCE` placeholder with your Auth0 credentials. | ||
|
||
### Test the application | ||
Finally open your browser and view the application on http://localhost:3000 | ||
|
||
## Prerequisites | ||
[Node.js](https://nodejs.org/en/), [Yarn package manager](https://yarnpkg.com/lang/en/docs/install/#mac-stable), [MongoDB](https://docs.mongodb.com/v3.2/installation/) and [TypeScript](https://www.typescriptlang.org/) | ||
|
||
|
||
## Built With | ||
[Nest.js]() | ||
[React.js]() | ||
[Auth0]() | ||
[TypeScript]() | ||
[MongoDB]() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
# compiled output | ||
/dist | ||
/node_modules | ||
|
||
# Logs | ||
logs | ||
*.log | ||
npm-debug.log* | ||
yarn-debug.log* | ||
yarn-error.log* | ||
lerna-debug.log* | ||
.env | ||
|
||
# OS | ||
.DS_Store | ||
|
||
# Tests | ||
/coverage | ||
/.nyc_output | ||
|
||
# IDEs and editors | ||
/.idea | ||
.project | ||
.classpath | ||
.c9/ | ||
*.launch | ||
.settings/ | ||
*.sublime-workspace | ||
|
||
# IDE - VSCode | ||
.vscode/* | ||
!.vscode/settings.json | ||
!.vscode/tasks.json | ||
!.vscode/launch.json | ||
!.vscode/extensions.json |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
{ | ||
"singleQuote": true, | ||
"trailingComma": "all" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
<p align="center"> | ||
<a href="http://nestjs.com/" target="blank"><img src="https://nestjs.com/img/logo_text.svg" width="320" alt="Nest Logo" /></a> | ||
</p> | ||
|
||
[travis-image]: https://api.travis-ci.org/nestjs/nest.svg?branch=master | ||
[travis-url]: https://travis-ci.org/nestjs/nest | ||
[linux-image]: https://img.shields.io/travis/nestjs/nest/master.svg?label=linux | ||
[linux-url]: https://travis-ci.org/nestjs/nest | ||
|
||
<p align="center">A progressive <a href="http://nodejs.org" target="blank">Node.js</a> framework for building efficient and scalable server-side applications, heavily inspired by <a href="https://angular.io" target="blank">Angular</a>.</p> | ||
<p align="center"> | ||
<a href="https://www.npmjs.com/~nestjscore"><img src="https://img.shields.io/npm/v/@nestjs/core.svg" alt="NPM Version" /></a> | ||
<a href="https://www.npmjs.com/~nestjscore"><img src="https://img.shields.io/npm/l/@nestjs/core.svg" alt="Package License" /></a> | ||
<a href="https://www.npmjs.com/~nestjscore"><img src="https://img.shields.io/npm/dm/@nestjs/core.svg" alt="NPM Downloads" /></a> | ||
<a href="https://travis-ci.org/nestjs/nest"><img src="https://api.travis-ci.org/nestjs/nest.svg?branch=master" alt="Travis" /></a> | ||
<a href="https://travis-ci.org/nestjs/nest"><img src="https://img.shields.io/travis/nestjs/nest/master.svg?label=linux" alt="Linux" /></a> | ||
<a href="https://coveralls.io/github/nestjs/nest?branch=master"><img src="https://coveralls.io/repos/github/nestjs/nest/badge.svg?branch=master#5" alt="Coverage" /></a> | ||
<a href="https://gitter.im/nestjs/nestjs?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=body_badge"><img src="https://badges.gitter.im/nestjs/nestjs.svg" alt="Gitter" /></a> | ||
<a href="https://opencollective.com/nest#backer"><img src="https://opencollective.com/nest/backers/badge.svg" alt="Backers on Open Collective" /></a> | ||
<a href="https://opencollective.com/nest#sponsor"><img src="https://opencollective.com/nest/sponsors/badge.svg" alt="Sponsors on Open Collective" /></a> | ||
<a href="https://paypal.me/kamilmysliwiec"><img src="https://img.shields.io/badge/Donate-PayPal-dc3d53.svg"/></a> | ||
<a href="https://twitter.com/nestframework"><img src="https://img.shields.io/twitter/follow/nestframework.svg?style=social&label=Follow"></a> | ||
</p> | ||
<!--[data:image/s3,"s3://crabby-images/ad24f/ad24f79c0029c1ca3e81af419cacc05e71c1f1d6" alt="Backers on Open Collective"](https://opencollective.com/nest#backer) | ||
[data:image/s3,"s3://crabby-images/6c390/6c390379835332e1d4597137c5df09dd43445ae1" alt="Sponsors on Open Collective"](https://opencollective.com/nest#sponsor)--> | ||
|
||
## Description | ||
|
||
[Nest](https://github.com/nestjs/nest) framework TypeScript starter repository. | ||
|
||
## Installation | ||
|
||
```bash | ||
$ npm install | ||
``` | ||
|
||
## Running the app | ||
|
||
```bash | ||
# development | ||
$ npm run start | ||
|
||
# watch mode | ||
$ npm run start:dev | ||
|
||
# production mode | ||
$ npm run start:prod | ||
``` | ||
|
||
## Test | ||
|
||
```bash | ||
# unit tests | ||
$ npm run test | ||
|
||
# e2e tests | ||
$ npm run test:e2e | ||
|
||
# test coverage | ||
$ npm run test:cov | ||
``` | ||
|
||
## Support | ||
|
||
Nest is an MIT-licensed open source project. It can grow thanks to the sponsors and support by the amazing backers. If you'd like to join them, please [read more here](https://docs.nestjs.com/support). | ||
|
||
## Stay in touch | ||
|
||
- Author - [Kamil Myśliwiec](https://kamilmysliwiec.com) | ||
- Website - [https://nestjs.com](https://nestjs.com/) | ||
- Twitter - [@nestframework](https://twitter.com/nestframework) | ||
|
||
## License | ||
|
||
Nest is [MIT licensed](LICENSE). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
{ | ||
"collection": "@nestjs/schematics", | ||
"sourceRoot": "src" | ||
} |
Oops, something went wrong.