Dashboard and Reporting UI for Fiscalismia. Fiscalismia is a Web Service for visualizing, analyzing, aggregating, importing and exporting personal finance data. Data can consist of variable and fixed costs, income, sales and investments. Advanced capabilities are available for dynamically updating supermarket grocery deals via web automation scraping data from supermarket websites.
fiscalismia-frontend is a REACT service rendered with Material UI, utilizes axios to communicate with a Node.js REST API in the backend. JWT tokens are used for authentication. The REACT elements are designed with full CRUD operations in mind, to seed, manipulate and analyze the data within the backend's cloud hosted production db. The frontend is built in a continuous integration pipeline, tested, scanned for vulnerabilities and published as a docker image to a public docker registry for later deployment in your environment of choice.
- Github Actions: CI/CD Pipeline for automating type checking, eslint analysis, integration testing, vulnerability scanning, building, publishing and deploying.
- Docker: Frontend, Backend and Dev-Database run within docker containers, orchestrated for fullstack development with one docker compose command.
- TypeScript: Statically typed JS with high strictness level and compile target ESNext. Mid-project Migration from plain JavaScript (ECMAScript 2016).
- React: A JavaScript library for building user interfaces, maintained by Facebook.
- Material UI: A popular React UI framework developed by Google, providing a set of pre-designed components for a consistent and visually appealing interface.
- JWT Auth: JSON Web Token authentication is used for securing and verifying the authenticity of API requests.
- Snyk: Static Code security analysis, dependency security analysis, monitoring and notifications on detected security issues.
- Vite: A fast & efficient build tool with Hot Module Replacement (HMR) allowing modules to be updated in real-time during development without requiring a full page refresh.
- Axios: A promise-based HTTP client for making requests to the backend API and handling asynchronous operations.
- Chart.js: A simple yet flexible JavaScript charting library for adding interactive charts and graphs to the application.
- Jest and React Testing Library: Used for unit testing to ensure the reliability of individual components.
- Playwright: Employed for post-deployment integration testing, specifically Smoketesting, ensuring that the server isn't crashing and burning.
- ESLint and Prettier: Linter and Formatter for ensuring code quality and enforcing coding standards.
-
Triggers:
- The pipeline runs on every push and pull request to the
main
branch.
- The pipeline runs on every push and pull request to the
-
Job:
test
:- Steps:
- Set up Node.js (v20.12.2), install dependencies and Snyk.
- Run type checks and ESLint analysis.
- Perform Snyk dependency security analysis.
- Perform Snyk Static Code security analysis.
- Publish type check, ESLint, and Snyk reports as artifacts.
- TODO: Playwright Integration Test covering basic UI interactions.
- Steps:
-
Job:
build
:- Steps:
- Build Frontend Docker image.
- Publish Docker image to GHCR (TODO: Switch to AWS ECR)
- Steps:
-
Job:
deploy
:- Steps:
- TODO: Deploy on Hetzner Self Managed Kubernetes via ArgoCD (K3s)
- Steps:
Dependencies
-
Node.js: Ensure that Node.js is installed on your local machine, with a minimum version of 20.12.2 You can download Node.js via Node Version Switcher here or directly from the source here.
-
Docker & Docker Compose Ensure that Docker is installed in your local development environment. Get Docker here and Docker Compose here.
-
Clone the Repository:
git clone https://github.com/your-username/fiscalismia-frontend.git
-
The Backend and Database must be running: See https://github.com/hangrybear666/fiscalismia-backend
Installation
-
Navigate to Project Folder:
cd fiscalismia-frontend
-
Install Dependencies:
npm install
-
Create Environment file
Create an
.env
file in the root directory with the following contentsFRONTEND_PORT=3001 SNYK_TOKEN=
-
Github Secrets:
Set up Github Secrets in your Repository Settings, for the pipeline to run successfully. These can and should be the same as in your
.env
file.SNYK_TOKEN
-
Option 1: Docker Compose
To run the entire stack in development mode, change directory to
fiscalismia-backend
docker compose build docker compose up
-
Option 2: Locally:
Run only the frontend locally.
npm run dev
-
Option 3: Docker:
Run only the frontend container (Linux Syntax)
docker build --pull --no-cache --rm -f "Dockerfile" -t fiscalismia-frontend:latest "." docker run -v $PWD/src:/fiscalismia-frontend/src --env-file .env --net fiscalismia-network --rm -it -p 3001:3001 --name fiscalismia-frontend fiscalismia-frontend:latest
Run only the frontend container (Windows Syntax)
docker build --pull --no-cache --rm -f "Dockerfile" -t fiscalismia-frontend:latest "." docker run -v %cd%\src:/fiscalismia-frontend/src --env-file .env --rm -it -p 3001:3001 --name fiscalismia-frontend fiscalismia-frontend:latest
Once the frontend, database and backend are up and running, the website will be ready at http://localhost:3001
The tests are executed in each github-actions workflow execution but can be run manually.
All tests generate report files in the reports/
subdirectory.
-
Static Code Analysis
Eslint is used to ensure a consistent codebase adhering to certain coding standards configured in
.eslintrc.js
. Typecheck runs the Typescript Compiler which is configured with high strictness intsconfig.json
.npm run typeCheck npm run eslintAnalysis
-
Playwright Web Automation Integration Tests
todo
-
Snyk Security Analysis
SNYK_TOKEN
has to be set in.env
file. Get one for free by creating a snyk account hereVulnerability scanning of both the codebase and installed dependencies.
Once per workspace
# with snyk cli installed snyk auth SNYK_TOKEN # without snyk cli installed npx snyk auth SNYK_TOKEN
On demand
npm run snykCodeAnalysis npm run snykDependencyAnalysis
This project is licensed under the MIT License.