/*! For license information please see 262.bd39c4e7.js.LICENSE.txt */ (self.webpackChunk=self.webpackChunk||[]).push([["262"],{51362:function(e,n,t){"use strict";t.r(n);var i=t("80681");let o=["innerHTML"];n.default={setup:()=>({html:""}),render:()=>((0,i.wg)(),(0,i.iD)("div",{class:"van-doc-markdown-body",innerHTML:'

Contribution Guide

\n

Introduction

\n

Thank you for using Vant.

\n

Below are the guidelines for submitting feedback or code to Vant. Please take a few minutes to read the following before submitting an issue or PR to Vant.

\n

Issue Specification

\n\n

Participate in development

\n

Local development

\n

Before developing locally, please make sure that Node.js >= 18 is installed in your development environment.

\n

Follow the steps below to develop Vant components locally.

\n
# Clone repository\ngit clone git@github.com:vant-ui/vant.git\n\n# Enable pnpm package manager\ncorepack enable\n\n# Install dependencies\npnpm i\n\n# Start development\npnpm dev\n
\n

Different branches of the repository correspond to different Vant versions, please switch to the appropriate branch for development:

\n\n

Mirror repository

\n

If GitHub cloning is slow, you can also directly clone Vant\'s mirror repository directly on gitee:

\n
git clone git@gitee.com:vant-contrib/vant.git\n
\n

The mirror repository is only used to speed up local access, please do not submit issues and pull requests to the mirror repository.

\n

Directory Structure

\n

Vant uses monorepo for code management, and all subpackages are in the packages/vant directory:

\n
root\n\u2514\u2500 packages\n   \u251C\u2500 vant        # Component library\n   \u251C\u2500 vant-cli    # Scaffolding\n   \u251C\u2500 vant-icons  # Icon library\n   \u251C\u2500 vant-use    # Composition API\n   \u2514\u2500 ....        # Other npm packages\n
\n

Among them, the packages/vant directory is the core code of the component library:

\n
vant\n\u251C\u2500 docs             # Documentation\n\u251C\u2500 src              # Component source code\n\u251C\u2500 test             # Test utils\n\u2514\u2500 vant.config.mjs  # Document configuration\n
\n

The packages/vant/src directory contains the source code of each component, and each folder corresponds to a component:

\n
src\n\u2514\u2500 button\n   \u251C\u2500 demo             # Demo code\n   \u251C\u2500 test             # Unit test\n   \u251C\u2500 Component.tsx    # Component\n   \u251C\u2500 index.ts         # Component entry\n   \u251C\u2500 index.less       # Styles\n   \u251C\u2500 README.md        # English document\n   \u2514\u2500 README.zh-CN.md  # Chinese document\n
\n

Code Specification

\n

When writing code, please note:

\n\n

Submitting a Pull Request

\n

Reference Guide

\n

If this is your first time submitting a pull request on GitHub, you can learn from the following article:

\n\n

Pull Request Specification

\n

When submitting a Pull Request, please note:

\n\n

Pull Request Process

\n
    \n
  1. Fork the main repository. If you have already forked, please synchronize the latest code from the main repository.
  2. \n
  3. Create a new branch based on the main branch of the repository after the fork, such as feature/button_color.
  4. \n
  5. Develop on the new branch. When development is complete, submit a pull request to the main branch of the main repository.
  6. \n
  7. The pull request is merged into the main repository after the review is approved.
  8. \n
  9. Wait for Vant to release a new version, usually once a week.
  10. \n
\n

Pull Request Title Format

\n

The title of the Pull Request should be in the following format:

\n
type(ComponentName?)\uFF1Acommit message\n
\n

Example\uFF1A

\n\n

Allowed Types:

\n\n

Synchronize the latest code

\n

Before submitting a Pull Request, please synchronize the latest code of the main repository according to the following process:

\n
# Add the main repository to remote\ngit remote add upstream git@github.com:vant-ui/vant.git\n\n# Pull the latest code from the main repository\ngit fetch upstream\n\n# Switch to the main branch\ngit checkout main\n\n# Merge the code from the main repository\ngit merge upstream/main\n
\n
'},null,8,o))}}}]);