We would love for you to contribute to KoliBriand help make it even better than it is today! As a contributor, we ask that you follow the following guidelines:
Help us keep KoliBri open and inclusive. Please read and follow our Code of Conduct.
Please do not create issue tickets for general support questions. We want to use the ticket system for tracking bug reports and feature requests.
Instead, we recommend first checking Stack Overflow to see whether someone else has already solved the question or problem. You can also create new questions with the tag “hummingbird”. To save your time and ours, we will close all general questions in the ticket system and redirect those asking to Stack Overflow.
If you would like to contact us, please send us an email to [email protected].
If you find an error in the source code, you can report it to our ticket system.
It would be even better if you suggested a solution to us as a pull request.
You can request new features by submitting an issue to our ticket system. If you would like to implement a new function, please note the following steps for further action:
- It is helpful to read the KoliBri architecture concept before implementing.
- For major innovations, please create a ticket with the description of the new function.
- For small innovations, you can offer and justify the implementation directly as a pull request.
We work according to the Git flow: https://medium.com/android-news/gitflow-with-github-c675aa4f606a
- For contributing, you need a GitHub account
- Fork our repository on GitHub
- Open your preferred command line interface
- Clone the forked repository to your local machine
- Navigate the project root directory
- Create a new branch for your changes
- Install PNPM on you local machine
- Install all packages with
pnpm i
- Build all packages within the mono repository
pnpm -r build
- Navigate to the desired package in our monorepo
- When you want to start the project navigate to
packages/components/
and runpnpm dev
- To watch for changes navigate to
samples/react/
and executepnpm start
.http://localhost:8080/
will open automatically
Refer to new component tutorial.
When changing the current working branch, it is important to reinstall all dependencies, as these may have changed. It is very important that all packages are built when working on dependents. This is because the packages always use the built state of the referenced packages in the mono repo. To avoid unexpected problems, it is therefore always advisable to build all packages once. This can be done with these steps:
- Reinstall all dependencies:
pnpm i
- Build all packages:
pnpm -r build
- You can then switch to the package to be processed and start it with
pnpm start
.
If it is also necessary to edit dependent packages such as @public-ui/components
, these must be rebuilt for each change. Such packages offer the dev
script for this purpose. This automatically rebuilds the package after each change.
By default, development is carried out in the development
branch for the following version. However, if it becomes necessary to provide an issue for an older major release, such as version 1.7.x, the code change must also be merged into the corresponding release branch. In this case, it would be the release/1.7
branch. It is important that the branch that was created from the develop
is not merged into the release branch, as otherwise the next patch version will receive all the changes from the current development status.
The simplest procedure is therefore to create a new branch from the release branch (e.g. release/1.7
) and transfer the individual commits of the feature branch from the develop
to the new branch using cherry-picking. This branch can then be merged into the release branch as normal with a new pull request.
The Continuous Integration (CI) pipeline incorporates automated visual regression testing using the React sample app across all available themes.
When introducing visual modifications to components, themes, or the React sample app, initial test failures are expected. To address this, the
update-snapshots.yml
action on GitHub should be executed, followed by a careful review of the changes.
The following methods can be used to update the snapshots.
-
GitHub website: Update the snapshots directly on the GitHub website by following these steps.
- Navigate to the
Actions
tab in thekolibri
repository. - Execute the
03 - Update Snapshots
action. - Select the desired branch in which you want to update the snapshots.
- The workflow checks out the branch, updates all snapshot files, and commits the changes to that branch.
- Navigate to the
-
Terminal Command: Use the GitHub CLI (gh) to run the
update-snapshots.yml
action from the local terminal. This method is recommended for updating snapshots on the current branch without navigating to the GitHub website. For terminal convenience, the GitHub CLI (gh) needs to be installed.- Run the following command within the project directory to update the snapshots in your checked-out branch:
gh workflow run update-snapshots.yml -r `git rev-parse --abbrev-ref HEAD`
- If your want to delete all snapshots before regenerating them add
-f purge_snapshots=true
to the command:gh workflow run update-snapshots.yml -r `git rev-parse --abbrev-ref HEAD` -f purge_snapshots=true
- You can also run the action on a different branch by specifying the another target branch with the
-r <branch_name>
flag. For example, to update snapshots on themain
branch:gh workflow run update-snapshots.yml -r main
- Run the following command within the project directory to update the snapshots in your checked-out branch:
These steps ensure that visual snapshots are updated systematically, maintaining the integrity of the testing process.