TTime/frontend
2024-02-13 15:28:32 +01:00
..
public Plain typescript+swc vite react template as frontend 2024-02-12 12:47:46 +01:00
src Further tuning the formatting and linting rules 2024-02-13 15:02:41 +01:00
.eslintrc.cjs Further tuning the formatting and linting rules 2024-02-13 15:02:41 +01:00
.gitignore Plain typescript+swc vite react template as frontend 2024-02-12 12:47:46 +01:00
.prettierrc Prettier for formatting and some stricter linting rules 2024-02-13 14:47:36 +01:00
index.html Plain typescript+swc vite react template as frontend 2024-02-12 12:47:46 +01:00
package-lock.json Further tuning the formatting and linting rules 2024-02-13 15:02:41 +01:00
package.json Further tuning the formatting and linting rules 2024-02-13 15:02:41 +01:00
README.md Build instructions for frontend 2024-02-13 15:28:32 +01:00
tsconfig.json Plain typescript+swc vite react template as frontend 2024-02-12 12:47:46 +01:00
tsconfig.node.json Plain typescript+swc vite react template as frontend 2024-02-12 12:47:46 +01:00
vite.config.ts Prettier for formatting and some stricter linting rules 2024-02-13 14:47:36 +01:00

The Frontend

This is a React + TypeScript + Vite project. It is a single-page application (SPA) that communicates with the backend via a REST API. Most of this looks very complex, but it's mostly just a lot of boilerplate due to the ugodly amount of abstraction that comes with TypeScript and React, and just modern web development in general.

Build Instructions

Our build tool, npm, is the only dependency required to build this project. It handles fetching the dependencies and placing them in the famously huge node_modules directory, also known as the heaviest object in the known universe. It also handles the build process, which is just a matter of running npm run build.

The build target results in a dist directory, which contains the static assets that can be served by a web server. This is the directory that will be served by the backend. Think of this like compiling a program, the .exe/elf/binary is the dist directory.

For development, you use npm run dev to start a development server. This server will automatically rebuild the project when you make changes to the source code, and it will also automatically reload the page in your browser. The issue is that the development server will run without the backend, so you will need to run the backend separately during development if you want any meaningful data to be displayed.