# @git.zone/cli A CLI toolbelt to streamline local development cycles by using various gitzone utilities. ## Install To install the `@git.zone/cli` tool, you need to have Node.js and npm installed on your machine. Once you have those set up, you can install the CLI tool globally using the following command: ```shell npm install -g @git.zone/cli ``` This will add the `gitzone` or `gzone` command to your PATH, allowing you to use the tool from any directory. ## Usage The `gitzone` CLI is designed to streamline various aspects of the local development cycle, including project setup, maintenance, and deployment. Below, we'll go through several scenarios that demonstrate the capabilities of `gitzone`. ### Getting Started To start using `gitzone`, you need to initialize a new project or use it with an existing one. This section will guide you through the initial setup and provide examples of the core commands. #### Initialize a New Project `gitzone` can create several types of projects, including standard npm modules, websites using LitElement, and custom web components. To create a new project, you can use the following command: ```shell gitzone template [templatename] ``` Replace `[templatename]` with one of the following: - `npm`: A standard npm module with TypeScript support, testing, and CI/CD setup. - `website`: A LitElement-based website with e2e testing, bundling, and service worker support. - `element`: A LitElement standard setup for creating web components. Example of starting a new npm project: 1. Open your terminal and navigate to the directory where you want to create your project. 2. Execute the following command: ```shell gitzone template npm ``` 3. Follow the interactive prompts to set up your project. You will be asked to provide information such as the project name, description, GitHub repository, etc. #### Committing Changes To standardize commit messages and increment versions based on change types (fix, feat, breaking change): ```shell gitzone commit ``` This command will prompt you with a series of questions to help construct a standardized commit message and create a new commit. #### Deprecating a Package To deprecate an old package in favor of a new one: ```shell gitzone deprecate ``` This command will prompt you for the old and new package names and will automatically deprecate the old package on npm. #### Opening CI/CD Settings Quickly open the CI/CD settings page of your project repository: ```shell gitzone open ci ``` ### Example Commands #### Project Setup and Initialization Let's go through how to scaffold a new web component project: 1. Navigate to your desired directory. 2. Run the following command: ```shell gitzone template element ``` 3. Follow the prompts to set up your web component project. #### Managing Project Lifecycle Commands to manage your project's lifecycle: - **Commit Changes:** ```shell gitzone commit ``` - **Deprecate a Package:** ```shell gitzone deprecate ``` - **Format Project Files:** ```shell gitzone format ``` - **Regenerate Readme:** ```shell gitzone readme ``` - **Update Local Repositories:** ```shell gitzone update ``` #### Advanced Scenarios ##### Formatting To ensure consistent formatting using Prettier: ```shell gitzone format ``` ##### Building the Project To build your project as defined in your `package.json`: ```shell npm run build ``` ##### Git and Version Control Check the current project version: ```shell gitzone -v ``` To synchronize local repositories with remotes: ```shell gitzone update ``` ##### Metadata and Configuration To initialize or update metadata: ```shell gitzone meta init ``` ### Continuous Integration and Delivery (CI/CD) #### Running Tests To execute tests defined in your `package.json`: ```shell npm test ``` #### Building Documentation Generate documentation: ```shell npm run buildDocs ``` ### Troubleshooting and Debugging #### Detailed Logs Enable detailed logging for troubleshooting: ```shell gitzone --loglevel=debug ``` #### Cleaning Up To clean up project artifacts: ```shell gitzone clean ``` ### Summary The `gitzone` CLI tool provides a comprehensive suite of commands that streamline project setup, lifecycle management, and deployment, which are indispensable for modern development workflows. By familiarizing yourself with the different commands, you can maximize your productivity and focus on what really matters—writing code. Whether you are starting a new project, maintaining an existing one, or deploying your work, `gitzone` is your toolbelt for efficient development cycles. ## License and Legal Information This repository contains open-source code that is licensed under the MIT License. A copy of the MIT License can be found in the [license](license) file within this repository. **Please note:** The MIT License does not grant permission to use the trade names, trademarks, service marks, or product names of the project, except as required for reasonable and customary use in describing the origin of the work and reproducing the content of the NOTICE file. ### Trademarks This project is owned and maintained by Task Venture Capital GmbH. The names and logos associated with Task Venture Capital GmbH and any related products or services are trademarks of Task Venture Capital GmbH and are not included within the scope of the MIT license granted herein. Use of these trademarks must comply with Task Venture Capital GmbH's Trademark Guidelines, and any usage must be approved in writing by Task Venture Capital GmbH. ### Company Information Task Venture Capital GmbH Registered at District court Bremen HRB 35230 HB, Germany For any legal inquiries or if you require further information, please contact us via email at hello@task.vc. By using this repository, you acknowledge that you have read this section, agree to comply with its terms, and understand that the licensing of the code does not imply endorsement by Task Venture Capital GmbH of any derivative works.