Before submitting a pull request (PR), consider filing an issue to gain clarity and direction.
Fork the repo and clone your fork:
git clone <YOUR_FORK>
cd carbon-components-svelte
Set the original repository as the upstream:
git remote add upstream [email protected]:IBM/carbon-components-svelte.git
# verify that the upstream is added
git remote -v
Install the project dependencies:
# carbon-components-svelte/
yarn install
Component documentation is located in the docs
folder. The website is built using svite, routify, and MDsveX. You will need to create a symbolic project link in order to see live changes reflected when developing locally.
First, create a symbolic link at the root of the project folder:
# carbon-components-svelte/
yarn link
Go into the docs
folder:
cd docs
Link "carbon-components-svelte"
:
yarn link "carbon-components-svelte"
yarn install
If linked correctly, any change to a component in the src
folder should be reflected in the docs
site.
Create a topic branch from master
. Keep your PR focused and branch up-to-date with upstream master
.
git checkout -b new-feature
Preview changes to components from the src
folder in the documentation website located in docs/
.
In the docs
folder, run:
yarn dev
The site should be served at http://localhost:3000/
(or the next available port).
Each component should adopt the following structure:
src/Component
│
└───Component.svelte // main component
└───ComponentSkeleton.svelte // Skeleton component (if applicable)
└───index.js // export components
If adding or editing an exported component prop, be sure to annotate its value using JSDoc conventions.
/**
* Specify the size of the component
* @type {"sm" | "default" | "lg"}
*/
export let size = "default";
First, submit an issue.
If creating a new component, don't forget it from src/index.js
:
export { CopyButton } from "./CopyButton";
export { ComboBox } from "./ComboBox";
+ export { FixedComboBox } from "./FixedComboBox";
export {
ComposedModal,
ModalHeader,
ModalBody,
ModalFooter,
} from "./ComposedModal";
Run the following command to re-generate TypeScript definitions and documentation.
# carbon-components-svelte/
yarn build:docs
Before submitting a pull request, make sure your fork is up to date with the latest upstream changes.
git fetch upstream
git checkout master
git merge upstream/master
After you've pushed your changes to remote, submit your PR. Make sure you are comparing <YOUR_USER_ID>/feature
to origin/master
.
The following items only apply to project maintainers.
Locally, while on master
and the branch is clean, run yarn release
. This command will:
- Build library and docs
- Bump package.json version
- Add notes to Changelog
This command will not create a commit nor tag. Afterwards, perform the following manually:
# 1. Stage prepared files for a commit
git add .
# 2. Commit based on the current version, either manually or with jq
git commit -m "v$(jq -r '.version' package.json)"
# 3. Create a tag based on the current version, either manually or with `jq`:
git tag "v$(jq -r '.version' package.json)"
# 4. Push branch and tag, then publish
git push master [tag]
yarn publish
# 5. Generate release notes on GitHub, and comment on issues and pull requests