Skip to content

Contributing

Thanks for your interest in contributing to Wagmi! Please take a moment to review this document before submitting a pull request.

Overview

This guide is intended to help you get started with contributing. By following these steps, you will understand the development process and workflow. If you want to contribute, but aren't sure where to start, you can create a new discussion.

WARNING

Please ask first before starting work on any significant new features. This includes things like adding new hooks, actions, connectors, etc.

It's never a fun experience to have your pull request declined after investing time and effort into a new feature. To avoid this from happening, we request that contributors first create a feature request to discuss any API changes or significant new ideas.

1. Cloning the repository

To start contributing to the project, clone it to your local machine using git:

bash
git clone https://github.com/wevm/wagmi.git
git clone https://github.com/wevm/wagmi.git

Or the GitHub CLI:

bash
gh repo clone wevm/wagmi
gh repo clone wevm/wagmi

2. Installing Node.js and pnpm

Wagmi uses pnpm workspaces to manage multiple projects. You need to install Node.js v18 or higher and pnpm@8.10.5.

You can run the following commands in your terminal to check your local Node.js and pnpm versions:

bash
node -v
pnpm -v
node -v
pnpm -v

If the versions are not correct or you don't have Node.js or pnpm installed, download and follow their setup instructions:

3. Installing dependencies

Once in the project's root directory, run the following command to install the project's dependencies:

bash
pnpm install
pnpm install

After the install completes, pnpm links packages across the project for development and git hooks are set up.

4. Adding the env variables

The dev playgrounds and test suite require enironment variables to be set. Copy over the following environment variables to .env, and fill them out.

bash
VITE_MAINNET_FORK_BLOCK_NUMBER=18677381
VITE_MAINNET_FORK_URL=https://cloudflare-eth.com

VITE_OPTIMISM_FORK_BLOCK_NUMBER=107317577
VITE_OPTIMISM_FORK_URL=https://mainnet.optimism.io

VITE_WC_PROJECT_ID=3fbb6bba6f1de962d911bb5b5c9dba88
VITE_MAINNET_FORK_BLOCK_NUMBER=18677381
VITE_MAINNET_FORK_URL=https://cloudflare-eth.com

VITE_OPTIMISM_FORK_BLOCK_NUMBER=107317577
VITE_OPTIMISM_FORK_URL=https://mainnet.optimism.io

VITE_WC_PROJECT_ID=3fbb6bba6f1de962d911bb5b5c9dba88

*_BLOCK_NUMBER environment variables should remain set to the values above (the test suite depends on them), but you can change the others if you want. For example, you might want to change *_FORK_URL to a paid RPC provider for better performance.

5. Running the dev playgrounds

To start the local development playgrounds, run one of the following commands. These commands run playground apps, located at ./playgrounds, that are set up for trying out code while making changes.

bash
pnpm dev           # `wagmi` playground
pnpm dev:core      # `@wagmi/core` playground
pnpm dev:react     # `wagmi` playground (same as `pnpm dev`)
pnpm dev:ssr-react # `wagmi` playground with SSR
pnpm dev           # `wagmi` playground
pnpm dev:core      # `@wagmi/core` playground
pnpm dev:react     # `wagmi` playground (same as `pnpm dev`)
pnpm dev:ssr-react # `wagmi` playground with SSR

Once a playground dev server is running, you can make changes to any of the package source files (e.g. packages/react) and it will automatically update the playground.

6. Running the test suite

Wagmi uses Vitest to run tests and anvil.js to execute tests against locally running chain forks. First, install Anvil via Foundryup.

bash
curl -L https://foundry.paradigm.xyz | bash
foundryup
curl -L https://foundry.paradigm.xyz | bash
foundryup

Next, make sure you have set up your env variables. Now you are ready to run the tests! You have the following options for running tests:

  • pnpm test [package?] — runs tests in watch mode
  • pnpm test:cov — runs tests and reports coverage
  • pnpm test:ui — runs tests in the Vitest UI

When adding new features or fixing bugs, it's important to add test cases to cover the new or updated behavior. If snapshot tests fail, you can run the test:update command to update the snapshots.

7. Writing documentation

Documentation is crucial to helping developers of all experience levels use Wagmi. Wagmi uses VitePress for the documentation site (located at ./docs). To start the site in dev mode, run:

bash
pnpm docs:dev
pnpm docs:dev

Try to keep documentation brief and use plain language so folks of all experience levels can understand. If you think something is unclear or could be explained better, you are welcome to open a pull request.

8. Submitting a pull request

When you're ready to submit a pull request, you can follow these naming conventions:

  • Pull request titles use the Imperative Mood (e.g., Add something, Fix something).
  • Changesets use past tense verbs (e.g., Added something, Fixed something).

When you submit a pull request, GitHub will automatically lint, build, and test your changes. If you see an ❌, it's most likely a bug in your code. Please, inspect the logs through the GitHub UI to find the cause.

Please make sure that "Allow edits from maintainers" is enabled so the core team can make updates to your pull request if necessary.

9. Versioning

When adding new features or fixing bugs, we'll need to bump the package versions. We use Changesets to do this.

TIP

Only changes to the codebase that affect the public API or existing behavior (e.g. bugs) need changesets.

Each changeset defines which packages should be published and whether the change should be a major/minor/patch release, as well as providing release notes that will be added to the changelog upon release.

To create a new changeset, run pnpm changeset. This will run the Changesets CLI, prompting you for details about the change. You’ll be able to edit the file after it’s created — don’t worry about getting everything perfect up front.

Even though you can technically use any markdown formatting you like, headings should be avoided since each changeset will ultimately be nested within a bullet list. Instead, bold text should be used as section headings.

If your PR is making changes to an area that already has a changeset (e.g. there’s an existing changeset covering theme API changes but you’re making further changes to the same API), you should update the existing changeset in your PR rather than creating a new one.

Releasing to npm

The first time a PR with a changeset is merged after a release, a new PR will automatically be created called chore: version packages. Any subsequent PRs with changesets will automatically update this existing version packages PR. Merging this PR triggers the release process by publishing to npm and cleaning up the changeset files.

Creating a snapshot release

If a PR has changesets, you can create a snapshot release by manually dispatching the Canary workflow. This publishes a tagged version to npm with the PR branch name and timestamp.

10. Updating dependencies

Use Taze by running:

bash
pnpm deps    # prints outdated deps
pnpm deps -w # updates deps (best done with clean working tree)
pnpm deps    # prints outdated deps
pnpm deps -w # updates deps (best done with clean working tree)

Socket checks pull requests for vulnerabilities when new dependencies and versions are added, but you should also be vigilant! When updating dependencies, you should check release notes and source code as well as lock versions when possible.

Released under the MIT License.