Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oieduardorabelo/2021-04-11-thunder-monorepo
https://github.com/oieduardorabelo/2021-04-11-thunder-monorepo
Last synced: 13 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/oieduardorabelo/2021-04-11-thunder-monorepo
- Owner: oieduardorabelo
- Created: 2021-04-11T06:10:35.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2021-04-21T22:44:13.000Z (almost 4 years ago)
- Last Synced: 2025-01-13T14:27:07.967Z (about 1 month ago)
- Language: TypeScript
- Size: 2.92 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## monorepo example with backend and frontend using npm 7.x
**frontend** overview:
- using [create-react-app](https://create-react-app.dev/) for a quick react application setup with [tailwindcss](https://tailwindcss.com/docs/guides/create-react-app) for application styling
- filter source of true is the url and they are synced with application state
- using [react suspense](https://reactjs.org/docs/concurrent-mode-suspense.html) and [react query](https://react-query.tanstack.com) for remote state/cache management
- full-rendering tests with [react testing library](https://testing-library.com/docs/react-testing-library/intro/), included react suspense and react query**backend** overview:
- traditional [express](https://www.npmjs.com/package/express) application
- using [nedb](https://github.com/louischatriot/nedb) for an in memory database
- api documented swagger with [swagger-ui-express](https://www.npmjs.com/package/swagger-ui-express)
- integratio tests with [supertest](https://www.npmjs.com/package/supertest)## how to run it?
the requirements are:
- node >= 12.x
- npm 7.xinstall the dependencies from the root folder:
```
$ npm install
```from here you will need two tabs open in your terminal,
go to `projects/backend` and:
```
$ cd projects/backend
$ npm start
```go to `projects/frontend` and:
```
$ cd projects/frontend
$ npm start
```## runnings tests
in each project folder, to run all tests a single time, you can use:
```
$ npm test
```for watch mode use:
```
$ npm run test:watch
```## screenshots
**frontend** screenshots:
data:image/s3,"s3://crabby-images/d70fb/d70fb87d554290f3e731823d93d92eea90be2493" alt=""
data:image/s3,"s3://crabby-images/a5977/a59777589a73fa2b9f8d64dc5c2931f33a66e48d" alt=""
data:image/s3,"s3://crabby-images/35e7d/35e7d77f86e19dff5caecd0df13e346bc37d5639" alt=""
data:image/s3,"s3://crabby-images/0e71a/0e71a77d087a2fb1a2ec9cf1d7e614a88bfb8d09" alt=""**backend** screenshots:
data:image/s3,"s3://crabby-images/2d3e0/2d3e0194db1abc5d15333e07bee3ce7956eff2c7" alt=""
data:image/s3,"s3://crabby-images/d7b57/d7b57be2eed23941c35dd1ef993a8cc80f9d5d00" alt=""
data:image/s3,"s3://crabby-images/a11de/a11deca06b9b1fd19f83756db2547335887e639e" alt=""