Banking app built in TypeScript, React, Redux and Node. There is also an option to use Strapi, but you would have to adjust the Front End to use it.
Demo user (automatically created when you start the app):
Login: [email protected]
Password: admin123
(Please note this app needs to be adjusted to use the new Strapi Back End. Also, the TypeScript implementation is in early stage and covers only Front End at the moment.)
- Login/register
- Accounts
- Transactions + new transaction
- Credit/debit cards + change PIN/limits
- Internal messages
- User profile incl. data change
- Help form
- Income change chart
- Currency stats
- Form validation, async routing
- Dummy data generator
Inspired by Daily UI 30 PSD files.
Moved to HTML5/CSS3 using Avocode (link to HTML/CSS repo).
Technologies:
WEB:
- TypeScript
- React
- Redux
- React Router
- Webpack
- Sass
- Bootstrap 4
- JWT tokens
- recharts
- react-dates
API:
- Node, Express, Strapi
- JWT tokens
- Database: MongoDB, Mongoose (old API), MySQL or MariaDB (new API on Strapi)
- Fixer.io for currency rates
- Install Node.js and MongoDB (MongoDB Compass may be useful as well, to work on the database)
- Create database called
react-bank-api
or use any other name, but then update it in theold-api/.env
config file - Install all dependencies both in
web
andold-api
folder by typingnpm install
inside each of them - Run API: type
npm run start-dev
inold-api
folder - Run web: type
npm start
inweb
folder
- Install Node.js and MariaDB
- Create database called
react-bank-api
or use any other name, but then update it in the.env
config file - Install all dependencies both in
web
and root folder by typingnpm install
inside each of them - Run API: type
npm run develop
in root folder or (recommended) useVisual Studio Code debugger
to run it - Run web: type
npm start
inweb
folder - Adjust Front End to use new Strapi endpoints
To create an optimized build in both cases, run npm run build
in web
folder
-
When you start the app, you should create yourself an example user, like
[email protected]
/admin123
You can also use dummy data generator by sendingPOST
request tohttp://localhost:1337/app/generate-dummy-data
It will create few users and for each one of them few accounts, cards, transactions, messages and stats for the income/expenses stats widget on Front End -
Go to Strapi admin panel
http://localhost:1337
and set proper roles for all the endpoints your app is using, like enable generating dummy data forPublic
role. Otherwise you will see "Forbidden" every time you try to connect to the API
I assume you will use Ubuntu 20.04 LTS as your system
- Install node
sudo apt install nodejs
and npmsudo apt install npm
- Install
pm2
package:npm i -g pm2
- Move all the Strapi files to /var/www/react-bank-api
- Run
NODE_ENV=production npm run build && pm2 start ecosystem.config.js --env production
This command will build Strapi admin panel inproduction
mode and then will use PM2's configecosystem.config.js
to start the app - Now your production Strapi should be ready to serve
Remember to set up the routes permissions on the server as well, otherwise most of the endpoints will return "Forbidden"
HAVE FUN! 💪