React Node JS Berry full-stack
Full-Stack
starter generated by React App Generator top of Berry Dashboard design.
The backend logic is provided by a simple, easy-to-extend
NodeJS API Server that manages the Authentication flow (login, registration, logout) using JSON Web Tokens
(JWT).
The React Design is crafted by CodedThemes on top of MUI
Library.
- 👉 React Node JS Berry -
Product Page
- 👉 React Node JS Berry -
LIVE Demo
M-UI
based design- Modern aesthetics UI design - Designed by CodedThemes
- React, Redux, Redux-persist
Tests
(compatibility matrix)
NodeJS | NPM | YARN |
---|---|---|
v14.0.0 |
✅ | ✅ |
v16.0.0 |
✅ | ✅ |
v18.0.0 |
❌ | ❌ |
- Stack:
NodeJS
/Express
/ SQLite TypeScript
, Joy for validation- DB Layer:
TypeORM
,SQLite
persistence - Auth: Passport /
passport-jwt
strategy - API Definition - the unified API structure implemented by this server
Tests
(compatibility matrix)
NodeJS | NPM | YARN |
---|---|---|
v18.0.0 |
❌ | ✅ |
v17.0.0 |
❌ | ✅ |
v16.13.0 |
❌ | ✅ |
v16.0.0 |
❌ | ❌ |
Being a full-stack product, the backend and the frontend should be compiled and started separately. Before starting to compile the product, make sure you have the following tools installed in the environment:
- NodeJS - version
14.x
or higher - GIT - used to clone tjhe sources from Github
- Python3 - used in many tools
Step 1 - Once the project is downloaded, change the directory to
react-ui
.
$ cd react-ui
Step 2 - Install dependencies via NPM or yarn
$ npm i
// OR
$ yarn
Step 3 - Start in development mode
$ npm run start
// OR
$ yarn start
At this point, the app is available in the browser localhost:3000
(the default address).
Step 1 - Change the directory to
api-server-nodejs
$ cd api-server-nodejs
Step 2 - Install dependencies via NPM or yarn
$ npm i
// OR
$ yarn
Step 3 - Run the SQLite migration via TypeORM
$ npm run typeorm migration:run
// OR
$ yarn typeorm migration:run
Step 4 - Start the API server (development mode)
$ npm run dev
// OR
$ yarn dev
The API server will start using the PORT
specified in .env
file (default 5000).
< ROOT / src >
|
|-- config/
| |-- config.ts # Configuration
| |-- passport.ts # Define Passport Strategy
|
|-- migration/
| |-- some_migration.ts # database migrations
|
|-- models/
| |-- activeSession.ts # Sessions Model (Typeorm)
| |-- user.ts # User Model (Typeorm)
|
|-- routes/
| |-- users.ts # Define Users API Routes
|
|
|-- index.js # API Entry Point
|-- .env # Specify the ENV variables
|
|-- ************************************************************************
The SQLite Path is set in .env
, as SQLITE_PATH
Generate migration:
$ yarn typeorm migration:generate -n your_migration_name
run migration:
$ yarn typeorm migration:run
React Berry Dashboard PRO Version
For more components, pages and priority on support, feel free to take a look at this amazing starter:
Berry Dashboard is a premium React Design now available for download as a full-stack app. Made of hundred of elements, designed blocks, and fully coded pages, Berry Dashboard PRO is ready to help you create stunning websites and web apps.
- 👉 React Berry Dashboard PRO - Product Page
- ✅
Enhanced UI
- more pages and components - ✅
Priority
on support
- ✅
React Node JS Berry - Full-Stack Seed project generated by App Generator.