Firstly, it's important to understand that contributing to an open-source project is not just about submitting code to fix bugs or add features. There are many ways to contribute to an open-source project, including but not limited to:
- Raising requirements: Submitting detailed requirements based on your business needs when the open-source project cannot meet them.
- Documentation: Submitting PRs to fix small issues in the documentation or submitting issues to report problems and suggest improvements.
- Discussion: Initiating discussions on your ideas, needs, and suggestions.
- Answering questions: Helping to reply to and handle issues and discussions based on your own experience.
- Bugfix: If you encounter problems during use and can locate the problem code and are willing to try to accept the challenge, you can submit a PR to solve the problem.
- Feature submission: Based on discussions in issues and discussions, submit a PR after implementation for the benefit of all open-source users.
- Ecosystem operation: Adding ecosystem content to an open-source project through your abilities, such as blogs, case studies, solutions, and extensions.
If you have any questions, feel free to submit an issue (https://github.com/antvis/g-device-api/issues) or directly modify and submit a PR (https://github.com/antvis/g-device-api/pulls). The following mainly introduces the operational guidelines for several types of open-source contributions.
When learning the project code or solving bugs and submitting features for the project, debugging and running the code is necessary. Here is how to start and debug the project.
- Clone the project and install dependencies:
git clone git@github.com:antvis/g-device-api.git
cd g-device-api
npm install
- Start a local debugging case:
We use Vite to build the preview environment. Going through npm run dev
can open the preview page.
npm run dev
In order to ensure the long-term code quality and stability of the project, a PR needs to meet the following requirements at least:
- Commit Message format
- Automation testing requirements
- Pull Request guidelines
Follow the angular format for commit messages. This makes the commit history more clear and enables the generation of changelogs. The format should be as follows:
type(scope): your commit message subject
type
: The type of the commit, including the following categories:
- feat: a new feature
- fix: a bug fix
- docs: changes to documentation
- style: code style changes that do not affect the logic
- refactor: code refactoring that does not affect the existing features
- perf: performance improvements
- test: adding or modifying tests
- chore: changes to tools or utilities (including but not limited to documentation, code generation, etc.)
- deps: dependency upgrades (2) scope The scope of the modified files. (3) subject The specific content of the modification. Example
- fix(compile): couple of unit tests for IE9
scope
: the scope of the commit.
subject
: the subject of the commit.
This project has two parts of automated testing:
- Unit tests: tests for data modules or functions, located in
__tests__/unit/
. - Integration tests: tests the rendering results of the entire visualization chart by comparing screenshots, located in
__tests__/integration/
.
For all changes, unit tests or integration tests should be submitted to cover the modified parts. Additionally, run npm run test
locally to ensure the CI runs successfully.
It can automatically create GitHub Releases and automatically associate the release to the corresponding issue.
- Create
release
branch fromnext
- Checkout dev branch from
release
, run changeset and commit
pnpm run changeset
git add ./
git commit -a -m "chore: commit changeset"
- Merge dev branch into
release
branch, CI version process will create aVersion Package
PR - Merge
release
intonext
branch
In addition, all API deprecations need to be deprecate
prompted on the current stable version and guaranteed to be compatible on the current stable version until a new version is released.
Since no one can guarantee how long it will be until they remember, please provide the following information when submitting a Pull Request for convenient historical reference:
- Requirement (usually associated with an issue or comment)
- Reason for the upgrade (different from the issue, briefly describe why it needs to be addressed)
- Framework testing points (can be associated with test files, no need for detailed description, just key points)
- Concerns (for users, optional, usually for incompatible updates, additional prompts are required)
For any other questions, please submit a discussion for help. We look forward to your contribution.