Skip to content

Latest commit

 

History

History
148 lines (103 loc) · 4.21 KB

CONTRIBUTING.md

File metadata and controls

148 lines (103 loc) · 4.21 KB

Contributing to Hashtegrity 🚀

Thank you for considering contributing to Hashtegrity! We welcome contributions from the community and are excited to see what you can bring to the table. Whether you're a seasoned developer or a beginner, your contributions are valuable.

Table of Contents

  1. Getting Started
  2. How to Contribute
  3. Style Guide
  4. Running Tests
  5. Documentation
  6. Changesets
  7. Submitting Changes

Getting Started 🛠️

Prerequisites

  • Node.js (>= 20.0.0)

    • Check if you have Node.js installed:
      node -v
    • If you don't have Node.js installed, follow the official guide to install it.
  • pnpm (>= 9.12.0)

    • Check if you have pnpm installed:
      pnpm -v
    • If you don't have pnpm installed, you can install it using npm:
      npm install -g pnpm
    • For more details, refer to the pnpm installation guide.

Setup

  1. Fork the repository: Click the "Fork" button at the top right of the repository page.

  2. Clone your fork:

    git clone https://github.com/ITZSHOAIB/hashtegrity.git
    cd hashtegrity
  3. Install dependencies:

    pnpm install
  4. Build the project:

    pnpm build

How to Contribute 🤝

Reporting Bugs 🐛

If you find a bug, please open an issue on GitHub with as much detail as possible. Include steps to reproduce the bug, your environment, and any relevant logs.

Suggesting Enhancements 💡

If you have an idea for an enhancement, please open an issue on GitHub. Describe the enhancement in detail and explain why it would be beneficial to the project.

Pull Requests 📦

  1. Create a branch:

    git checkout -b my-feature-branch
  2. Make your changes: Follow the Style Guide and ensure your code is well-documented.

  3. Commit your changes: With a descriptive commit message following the GitHub convention (e.g., feat:, docs:, fix:, etc.).

    git commit -m "feat: Add feature XYZ"
  4. Push to your branch:

    git push origin my-feature-branch
  5. Open a pull request: Go to the repository on GitHub and click "New pull request". Fill out the template and submit.

Style Guide 🎨

  • Follow the coding standards defined in our biome.json file.
  • Use pnpm lint to check for linting errors.
  • Format your code using pnpm format.

Running Tests 🧪

  1. Run unit tests:
    pnpm test

Documentation 📚

Documentation is located in the docs/ directory. To contribute to the documentation:

  1. Edit the relevant markdown files in the docs/ directory.
  2. Preview the documentation:
    pnpm docs:dev

Changesets 📦

We use Changesets to manage versioning and publishing. Here’s how you can create a changeset:

  1. Add a new changeset:

    pnpm changeset
  2. Follow the prompts to describe your changes. This will create a new file in the .changeset/ directory.

  3. Commit the changeset file:

    git add .changeset/*
    git commit -m "Add changeset for your changes"

When to Add a Changeset

Not every change requires a changeset. You should add a changeset if:

  • You want the package version to be bumped.
  • You want the changes to be published to the npm registry.

Changesets help us keep track of changes and generate changelogs automatically.

Submitting Changes 🚀

  1. Ensure your code follows the style guide.
  2. Ensure your changes are well-documented.
  3. Open a pull request and fill out the template.
  4. Inspect Your PR: If you see a red cross ❌ mark in your PR, it means our workflow has detected an issue. The workflow automatically builds and lints your changes. Please inspect your changes, fix any issues, and push the updates to your branch.

Thank you for contributing! Your efforts help make hashtegrity better for everyone. If you have any questions, feel free to ask in the issues or discussions section.

Happy Coding! 🎉