Welcome to the Tamagui contributing guide. We appreciate your interest in contributing to Tamagui. In our effort to make Tamagui open and inclusive to all we have written a code of conduct, please endeavour to read through it.
- Set up your development environment
- Issue and Pull Request Guidelines
- UI Kit Contributions
- Documentation Contributions
Since Tamagui is a monorepo it's quite easy to contribute to which ever part you're interested in, just go to the particular directory and you're set. To set up your development environment you'll first need clone the Tamagui repo:
git clone https://github.com/tamagui/tamagui
This might take some time depending on your internet speed. Once it's done run the following command to install the dependencies:
yarn install
And then build the app:
yarn build
You may see some errors due to encryption, as the studio has encrypted contents. This is fine and won't affect contributions to Tamagui.
That's it! You should be good to go. As you are developing you'll also want to have a yarn watch
running somewhere ongoing to ensure packages JS and types are rebuilt as you iterate.
Do not open issues for general support questions, that is what our discord is for. Please do not open pull requests that do not address pre-existing issues, unless spoken about and approved in our discord. These rules are to uphold order and code quality, and most of all separate the wheat from the chaff.
When opening issues please make sure that they adhere to these guidelines:
-
Bug reports:
- Make sure that your bug is reproducible and not a one off thing.
- Make sure that your bug is Tamagui specific and not an integration with other libraries that we might not support yet. (Seek help in discord for these).
- Use the Reproducible Bug Report template for all bug reports.
For now this is the only Github issue we support, for any other kinds of issues or general questions please join our discord and feel free to ask for help in the help-casual
channel or open a help discussion in the help board
.
If your issue does not adhere to these guidelines, in order to save everyone's time we will close it on sight.
Please make sure that your pull request adheres to these strict guidelines.
Your pull request should:
- address a pre-existing issue, unless reviewed and approved in the discord.
- have a detailed explanation of what it addresses and how you went about the solution.
- make use of any one of the pull request templates depending on whether you're contributing to the documentation or the UI kit.
- address a single issue. Do not fix multiple issues in a single PR unless they are connected or closely related.
Endeavour to adhere to these rules and make use of the proper templates, lest your pull requests be closed without review.
Contributions to the UI Kit otherwise known as code level contributions should come in the form of pull requests or issues. Pull requests can be done by forking the repo, creating a branch for that specific change and making changes locally. For issues, make sure that you follow the guidelines mentioned previously in the Issues section.
Note: While developing, you'll want to watch the build watching in a dedicated terminal.
yarn watch:build
Note: you may see some errors around "studio" as you run build - this is fine, we encrypt some of the non-open-source projects in the repo. The errors shouldn't block anything.
This kind of issue type should be used whenever you would like to report any kind of unexpected behavior, such as components not rendering correctly, unresponsive components, incompatibilities with supported libraries etc. Things like general questions, how tos or feature requests are not eligible to be reported as bugs and will be closed on sight.
When making pull requests addressing bug issues please make sure that they meet the following criteria:
- The bug should not be reproducible anymore.
- The solution adheres to the code style and quality of the repo.
- The solution does not break or change the behavior of any other part of Tamagui.
- The solution is up to date with the current release of Tamagui.
- The solution should have tests and should not break any pre-existing tests. (reference the testing section below)
If your pull request ticks all these boxes then congratulations your PR is ready for review, and you're well on your way to being a Tamagui contributor.
It's easiest to use the sandbox project to test and develop things for web:
yarn sandbox
This runs a client-side only vite build of Tamagui, with a complete configuration already set up.
To test on native, kitchen-sink
is equally well set up.
You'll need to create a development build to run this.
# Android
yarn kitchen-sink:build:android
# iOS
yarn kitchen-sink:build:ios
After the build has been completed, run the below command to start the Expo app:
yarn kitchen-sink
Once you've made changes, you can add tests. All compiler and CSS generation tests live in packages/static-tests
, other tests live in apps/kitchen-sink/tests
or in other -tests
packages.
Before submitting a PR, please check everything works across every combination of environments.
To do so, run the site first in development to test if it works entirely at runtime:
# Make sure you have run `yarn watch:build` before you execute this command.
yarn site
You use pages/test.tsx
as an easy way to load things. If it looks good, try running again with the compiler on:
yarn site:extract
Finally, if that looks good, build to production and test that:
yarn site:prod
This flow ensures it works with Vite, Webpack, Metro, Next.js with SSR, and with the compiler both on and off.
Contributions to the documentation can come in many formats such as issues, pull requests, discord discussions or blog posts. However, the primary ways of contributing being issues and pull requests. If you would like to contribute directly to the Tamagui documentation please make sure to read the writing guide before doing anything.
If you're not quite up to contributing to documentation or code, don't worry you can always contribute in other ways. You can contribute by:
- answering questions other community members might have;
- helping other community members debug their code;
- sharing your progress in learning Tamagui;
- sharing some of your awesome projects built using Tamagui; or
- advocating for Tamagui by writing blog posts and making tutorials.
We're open and welcoming of all kinds of contributions. Take that first step by joining our discord, and get to know more about the Tamagui community.