Thanks for your interest in contributing to the Ionic Framework! :tada:
Please see our Contributor Code of Conduct for information on our rules of conduct.
If you have a question about using the framework, please ask on the Ionic Forum or in the Ionic Worldwide Slack group.
It is required that you clearly describe the steps necessary to reproduce the issue you are running into. Although we would love to help our users as much as possible, diagnosing issues without clear reproduction steps is extremely time-consuming and simply not sustainable.
The issue list of this repository is exclusively for bug reports and feature requests. Non-conforming issues will be closed immediately.
Issues with no clear steps to reproduce will not be triaged. If an issue is labeled with "needs reply" and receives no further replies from the author of the issue for more than 5 days, it will be closed.
If you think you have found a bug, or have a new feature idea, please start by making sure it hasn't already been reported. You can search through existing issues to see if there is a similar one reported. Include closed issues as it may have been closed with a solution.
Next, create a new issue that thoroughly explains the problem. Please fill out the populated issue form before submitting the issue.
We appreciate you taking the time to contribute! Before submitting a pull request, we ask that you please create an issue that explains the bug or feature request and let us know that you plan on creating a pull request for it. If an issue already exists, please comment on that issue letting us know you would like to submit a pull request for it. This helps us to keep track of the pull request and make sure there isn't duplicated effort.
Looking for an issue to fix? Make sure to look through our issues with the help wanted label!
npm install
(make sure you have node and npm installed first)test/
directory under the component directory, if possible. If the test does not exist and it is possible to show the change, please create a new test in a directory called basic/
.*.spec.ts
file located in the test/
folder, update it to include a karma test for your change, if needed. If this file doesn't exist, please notify us.gulp test
to make sure all tests are working, regardless if a test was added.gulp lint.ts
and fix any linter errors.gem install scss_lint
gulp lint.sass
and fix any linter errors.gulp e2e
button
with the component you are modifying and basic
with the test folder): gulp e2e.watch --f=button/basic
http://localhost:8080/dist/e2e
. From here, navigate to the component you are changing.*.ts
) file, prior to the Class definition. For example, Badge
looks similar to this: /**
* @name Badge
* @module ionic
* @description
* Badges are simple components in Ionic containing numbers or text.
*
* @see {@link /docs/v2/components/#badges Badges Component Docs}
* @demo /docs/v2/demos/badge/
**/
where @name
is the Class name, @description
is the description displayed on the documentation page, @see
links to any related pages, and @demo
links to the API demo located in the demos
folder.
ionic-site
repo as a sibling to the ionic
repo and then run it: https://github.com/ionic-team/ionic-site#local-buildgulp docs
in the ionic
repo every time you make a change and the site will update.ionic-site
repo: https://github.com/ionic-team/ionic-site/issuesdemos/
folder.*.ts
) file (under src/components
) by adding a link to it in the documentation using @demo
, for example: /**
* @name Badge
*
* ...
*
* @demo /docs/v2/demos/src/badge/
**/
gulp watch.demos
to watch for changes to the demohttp://localhost:8000/dist/demos/
and then to your component's demo to view it.ionic-site
repo: https://github.com/ionic-team/ionic-site/issuesWe have very precise rules over how our git commit messages should be formatted. This leads to readable messages that are easy to follow when looking through the project history. We also use the git commit messages to generate our changelog. (Ok you got us, it's basically Angular's commit message format).
type(scope): subject
Must be one of the following:
The scope can be anything specifying place of the commit change. For example action-sheet
, button
, menu
, nav
, etc. If you make multiple commits for the same component, please keep the naming of this component consistent. For example, if you make a change to navigation and the first commit is fix(nav)
, you should continue to use nav
for any more commits related to navigation.
The subject contains succinct description of the change:
.
at the endBy contributing your code to the ionic-team/ionic GitHub Repository, you agree to license your contribution under the MIT license.