Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/GabrielToth/Angular-V17-Template

The Angular-V17-Template is a template designed for Angular 17 that emphasizes clean code practices and test-friendly development.
https://github.com/GabrielToth/Angular-V17-Template

angular frontend jest template test-automation

Last synced: about 2 months ago
JSON representation

The Angular-V17-Template is a template designed for Angular 17 that emphasizes clean code practices and test-friendly development.

Awesome Lists containing this project

README

        

# Angular V17 Template · ![GitHub License](https://img.shields.io/github/license/GabrielToth/Angular-V17-Template?color=blue) ![Static Badge](https://img.shields.io/badge/-18.10.0-g?style=&logo=node.js&logoColor=white) ![Static Badge](https://img.shields.io/badge/PRs-welcome-g)

The Angular V17 Template is an advanced and comprehensive tool for efficiently bootstrapping Angular projects. Built for the latest version of Angular, this template offers a well-organized directory structure, ready for scalable development. Additionally, it features an integrated system to handle error pages and site maintenance states, providing a robust development experience and easing the creation of modern web applications. With clear requirements and simple installation, the Angular V17 Template is the ideal choice for developers seeking a solid and flexible foundation for their Angular projects.

## Prerequisites

- Node Package Manager 18.10.0 or later installed in your system.
- Look at the [get npm guide](https://www.npmjs.com/get-npm?utm_source=house&utm_medium=homepage&utm_campaign=free%20orgs&utm_term=Install%20npm) for more info.
- Basic knowledge in [Angular](https://angular.io/).

## Step 1 - Install the Angular CLI

You are first going to need to install the Angular CLI (Command Line Interface) tool. The CLI helps you to start new Angular project as well as assist you during development. In your CMD (terminal) type:

```
npm install -g @angular/cli
```

## Step 2 - Clone the template

### If you are using GitHub Desktop:

1. On GitHub Desktop, click on "File" and then "Clone Repository."
2. Paste the URL of the repository you copied earlier into the "Repository URL" box.
3. Choose the local directory where you want to clone the repository.
4. Click the "Clone" button to initiate the cloning process.

### If you are using only Git Bash:

1. Open Git Bash in the directory where you want to clone the repository.
2. Enter the command `git clone` followed by the URL you copied:
```
git clone https://github.com/GabrielToth/Angular-V17-Template
```
3. Use the `cd` command to enter the directory of the cloned repository:
```
cd Angular-V17-Template
```

## Step 3 - Install all packages

Install all packages and dependences from package.json:

```
npm i
```

## Step 4 - Change project name

In Visual Studio Code open Search Tool, search for:

```
put-your-project-name
```

On replace type the name of your project.

## Folder Structure

The project follows a specific folder structure to ensure organization and clarity. Please adhere to the following guidelines:

- **`/src`**: Contains the source code of the project.

- **`/app`**: Main application code.

- **`/core`** : This folder often contains core functionalities that are not directly related to a specific feature or page. It's a good place to put services, guards, interceptors, and other pieces of code that are critical to the application but not tied to a particular feature.

- **`/auth`** : This folder contain authentication-related code, such as services or guards responsible for handling user authentication and authorization.
- **`/guards`** : Guards are used to control access to certain routes in your application. They can be placed here to keep the code organized.
- **`/interceptors`** : Interceptors can be used to modify HTTP requests or responses globally. Placing them in this folder helps maintain a clean structure.
- **`/layout`** : This might be used for components or services related to the overall layout of your application, such as a navigation bar or footer.
- **`/models`** : This folder can contain data models used throughout the application. Defining models in one place makes it easier to manage and maintain consistency.
- **`/services`** : Services that are shared across multiple features or components can be placed here. These could include data services, utility services, etc.

* **`/features`** : This folder is typically used for organizing pages or features of your application. Each feature might have its own subfolder containing components, services, and other files specific to that feature.
* **`/shared`** : This folder is for components, services, or other pieces of code that are shared across multiple features. It helps to avoid duplication and ensures consistency in the application."

- **`/components`**: This directory contains reusable UI components utilized across various features of the application. Organizing components here promotes reusability, maintains consistency in design patterns, and facilitates easier maintenance and development.
- **`/styles`**: Housing global and component-specific stylesheets, this directory centralizes the styling resources for the application. Global stylesheets define overarching design principles, while component-specific stylesheets tailor the appearance of individual components, fostering a cohesive and visually appealing user interface.

- **`/assets`**: Resources like images, fonts and databases.

- **`/data`**: Houses data-related files or mockups used in the project.

- **`db.json`**: JSON file serving as the database for the json-server mock API. This file contains mock data used for simulating API responses during development.

- **`/images`**: Stores image files used within the application. These include icons, graphics, and other visual elements.
- **`/fonts`**: Holds font files utilized for typography and styling purposes in the application.

- **`/stories`**: Storybook for automatic components documentation. Try: `ng storybook`

- **`/docs`**: Documentation files.
- **`/tests`**: Unit, integration, e2e and other tests.

## Project Organization

To maintain consistency and ease collaboration, the project follows the GitFlow branching model. The main branches are:

- **`main`**: Represents the production-ready code. Only merge into this branch after thorough testing.
- **`develop`**: The main branch for ongoing development. Feature branches branch off from here, and completed features are merged back.
- **`feature/branch-name`**: Feature branches for new features or enhancements. Always branch off from `develop`.
- **`bugfix/branch-name`**: Bugfix branches for resolving issues. Always branch off from `develop`.
- **`hotfix/branch-name`**: Hotfix branches for critical fixes in the production code. Branch off from `main`.

## Commit and Push Guidelines

To maintain a clean and well-documented version history, follow these guidelines:

1. **Feature Development:**

- Create a new branch for each feature or enhancement.
- Use clear and concise commit messages, adhering to the [Conventional Commits standard](https://www.conventionalcommits.org/en/v1.0.0/) (e.g., 'feat:', 'fix:', 'docs:', etc.).
- Regularly push changes to the remote repository.

2. **Bug Fixes:**

- Create a new branch for each bug fix.
- Include a reference to the issue being addressed in your commit message.
- Use clear and concise commit messages, following the Conventional Commits standard.
- Push changes promptly.

3. **Code Review:**

- Before merging into `develop` or `main`, ensure that your code has been reviewed.
- Address feedback and retest.
- Ensure commit messages follow the Conventional Commits standard.

4. **GitFlow Model:**

- Strictly adhere to the GitFlow branching model.
- Respect the roles and responsibilities defined by GitFlow.
- Use Conventional Commits standard for commit messages.

By adhering to these guidelines, we can maintain a well-organized and collaborative development environment. If you have any questions or encounter issues, please refer to this documentation or reach out to the project team.

## Issues with Husky?

If you are experiencing difficulties while committing or pushing your solution, we recommend checking Issue #5 or the issues in the Husky repository for a more detailed understanding of reported problems.

**Issue #5**: [Link to Issue #5](https://github.com/GabrielToth/Angular-V17-Template/issues/5)

Husky plays a crucial role in code quality control, and issues related to it can impact the development workflow. Make sure to review discussions in the issues to find solutions or relevant information about any specific problem you might be facing.

Remember, transparent and collaborative communication is key to overcoming challenges and continuously improving the development environment. We are here to help ensure a positive experience with the Angular V17 Template.

---

Feel free to tailor this draft to fit the specifics of your project and documentation style.