Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imranr98/frontload
Angular based Web App to be used as a template or starting off point for frontend projects. This is designed to work with https://github.com/ImranR98/Backdraft; see that project for more details.
https://github.com/imranr98/frontload
angular authentication bootstrap bootstrap5 client frontend i18n internationalization webapp
Last synced: 3 months ago
JSON representation
Angular based Web App to be used as a template or starting off point for frontend projects. This is designed to work with https://github.com/ImranR98/Backdraft; see that project for more details.
- Host: GitHub
- URL: https://github.com/imranr98/frontload
- Owner: ImranR98
- License: mit
- Created: 2021-09-07T14:22:09.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-04-14T03:52:25.000Z (almost 2 years ago)
- Last Synced: 2023-10-20T20:20:45.313Z (over 1 year ago)
- Topics: angular, authentication, bootstrap, bootstrap5, client, frontend, i18n, internationalization, webapp
- Language: TypeScript
- Homepage:
- Size: 1.11 MB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ๐งบ Frontload
Angular based Web App to be used as a template or starting off point for frontend projects.
[data:image/s3,"s3://crabby-images/87a3b/87a3b13a0bff7acaa6b9b8b6f436753ad3b84e07" alt="Security Rating"](https://sonarcloud.io/summary/new_code?id=ImranR98_Frontload) [data:image/s3,"s3://crabby-images/f7c10/f7c100cdbddf0977f851b10e8f171b842ecfd5d5" alt="Maintainability Rating"](https://sonarcloud.io/summary/new_code?id=ImranR98_Frontload) [data:image/s3,"s3://crabby-images/f1039/f1039de11af154f4ca83dac88bd32dfb21c6b65c" alt="Reliability Rating"](https://sonarcloud.io/summary/new_code?id=ImranR98_Frontload) [data:image/s3,"s3://crabby-images/26d36/26d36a2f9e880e5981e4226f4b2d78fd40be2d64" alt="Vulnerabilities"](https://sonarcloud.io/summary/new_code?id=ImranR98_Frontload) [data:image/s3,"s3://crabby-images/9723d/9723df180f0fe8a89d66e3dc91b4a23b29d27242" alt="Bugs"](https://sonarcloud.io/summary/new_code?id=ImranR98_Frontload)
***This is designed to work with [Backdraft](https://github.com/ImranR98/Backdraft); see that project for more details.***
## Features
- Frontend to all Backdraft endpoints/features.
- Angular Material UI.
- Dark mode (automatic; follows system).
- Internationalization.## Setup/Usage
1. Use `npm i` to install required dependencies.
2. Build the project for production or run it in a development environment using the scripts defined in `package.json`.## Project Structure
### Components and Pages
The `components` directory contains all Angular components, except the page components (accessed via routes).The `pages` directory contains all page components.
### Models and Services
The `services` directory contains all Angular services, such as those used to make API requests. These should be broken into spearate services based on their function.The `models` directory contains any TypeScript models (and in some cases, custom classes) used in the app.
### Everything Else
The remaining files in `/src` include:
- The `app-http.interceptor.ts` contains the HTTP interceptor used to insert the JWT token (if any) into each request, and to intercept 401 errors when the token needs to be refreshed.
- The `locale` directory contains language translation files for internationalization. For more info on this, read the official [Angular internationalization docs](https://angular.io/guide/i18n-overview).## Typical Flow for Implementing New Features
Implementing new functionality in the application usually involves:
- Checking the API spec for relevant endpoints and models.
- Creating a service (or adding to an existing one) with functions to make the relevant requests (along with any related state management).
- Creating or modifying the relevant components and pages to make use of the new functions.
- Adding new routes if needed.## Notes
1. Note that the boilerplate code files for unit tests exist (`.spec.ts` files) as they are automatically generated by Angular. However, automated testing has not been implemented.## Screenshots
Login Page:
data:image/s3,"s3://crabby-images/aa3a4/aa3a43d923b3015bb24687f67a83082c630797e9" alt="Login Page"
Internationalization (Swahili example - incomplete):
data:image/s3,"s3://crabby-images/82a6b/82a6be14d5357cc72abd7d6d3f8fe7f231635482" alt="Internationalization (Swahili example - incomplete)"
Account Page:
data:image/s3,"s3://crabby-images/6132f/6132f9c310222b4e47242b1f16fa14a5e2e4803f" alt="Account Page"
Login Revocation:
data:image/s3,"s3://crabby-images/04569/045699aac8171324447a9a56352c75d10d5195fa" alt="Login Revocation"
Email Verification Code for Signup or Password Reset:
data:image/s3,"s3://crabby-images/0a49c/0a49cc1fe6eaaee9d5dc84b54bfe567fe4e76c77" alt="Email Verification Code for Signup or Password Reset"
Dark Mode:
data:image/s3,"s3://crabby-images/dfbe0/dfbe044b41359c5a7c0278222821676a6ff60273" alt="Dark Mode"
Responsive UI (Mobile View):
data:image/s3,"s3://crabby-images/5d90f/5d90f2565197c2e84cf7cf56dbc455fb27669cfd" alt="Responsive UI (Mobile View)"