English | 日本語
When it comes to open source, there are different ways you can contribute, all of which are valuable. Here are some guidelines that should help you as you prepare your contribution.
The following steps will get you up and running to contribute to Yamada UI:
-
Fork the repository.
-
Clone your fork locally.
git clone https://github.com/<your_github_username>/yamada-ui.git
cd yamada-ui
- Setup all the dependencies and packages by running
pnpm install
. This command will install dependencies.
To improve our development process, we have set up tools and systems. Yamada UI uses a monorepo structure and treats each component as an independent package.
- PNPM to manage packages and dependencies
- Tsup to bundle packages
- Storybook for rapid UI component development and testing
- Testing Library for testing components and hooks
- Changeset for changes documentation, changelog generation, and release management.
- Next.js Framework for documentation sites.
pnpm install
: bootstraps the entire project, symlinks all dependencies for cross-component development.pnpm storybook
: starts storybook server and loads stories.pnpm build
: run build for all component packages.pnpm test
: run test for all component packages.pnpm gen:component
: create a component package from a template using Plop.- Please enter package and component names in kebab case
- If the provider is true, it sets up a provider that provides styles used in
children
.
pnpm gen:hook
: create a hook package from a template using Plop.- Please enter package and custom hook names in kebab case
pnpm gen:tokens
: generate theme tokens.
To ensure the extension works correctly, please add the following settings to .vscode/settings.json
.
{
...
"eslint.options": {
"flags": ["unstable_ts_config"]
},
"eslint.workingDirectories": [
"docs",
"examples/create-react-app",
"examples/hono",
"examples/next/app",
"examples/next/pages",
"examples/remix",
"examples/vite"
],
...
}
Please conform to the issue template and provide a clear path to reproduction.
Please provide thoughtful comments and some sample API code. Proposals that don't line up with our roadmap or don't have a thoughtful explanation will be closed.
Before you create a Pull Request, please check whether your commits comply with the commit conventions used in this repository.
When you create a commit we kindly ask you to follow the convention
type(scope or module): message
in your commit message while using one of
the following types:
feat / feature
: all changes that introduce completely new code or new featuresfix
: changes that fix a bug (ideally you will additionally reference an issue if present)refactor
: any code related change that is not a fix nor a featuredocs
: changing existing or creating new documentation (i.e. README, docs for usage of a lib or cli usage)build
: all changes regarding the build of the software, changes to dependencies or the addition of new dependenciestest
: all changes regarding tests (adding new tests or changing existing ones)ci
: all changes regarding the configuration of continuous integration (i.e. github actions, ci system)chore
: all changes to the repository that do not fit into any of the above categories
Tip
If you are interested in the detailed specification you can visit Conventional Commits or check out the Angular Commit Message Guidelines.
-
Fork and clone the repository.
-
Create a new branch out of the
main
branch. We follow the convention[type/scope]
. For examplefix/accordion-hook
ordocs/menu-typo
.type
can be eitherdocs
,fix
,feat
,build
, or any other conventional commit type.scope
is just a short id that describes the scope of work. -
After making changes, please add test code for those changes. Run
pnpm test
orpnpm test <package-name>
to ensure all tests pass. please check Tips for Test for further guidance. -
Run
pnpm changeset
to create a detailed description of your changes. This will be used to generate a changelog when we publish an update. Learn more about Changeset. -
Also, if you provide
jsx
snippets to the changeset, please turn off the live preview by doing the following at the beginning of the snippet:```jsx live=false
If you made minor changes like CI config, prettier, etc, you can run
pnpm changeset add --empty
to generate an empty changeset file to document your changes.
-
Next, commit your changes following the commit convention.
Confirming changes
: Run thepnpm storybook
command to launch Storybook. The source for Storybook is in./stories
.Creating a new component
: When you run the pnpmgen:component
command, a component is created from a template and dependencies are installed.Adding functionality to an existing component
: After adding, please add a story for the target component so that the functionality can be understood.Creating a new hook
: When you run thepnpm gen:hook
command, a hook is created from a template and dependencies are installed.Adding functionality to an existing hook
: After adding, please add a story for the target hook so that the functionality can be understood.
-
Once you have completed all of the above tasks, please push your changes. After pushing, a URL for the pull request will be generated. Follow the template and submit your request accordingly. Additionally, check the Checks within the pull request and ensure that the Quality check has successfully completed. If there are any issues, this pull request will not be merged.
By contributing code to the Yamada UI
GitHub repository, you agree that your contributed code will be licensed under the MIT license.