A library of shared React components.
Node (16.14.x)
yarn install
cd packages/<package-name> && yarn build
Set environment variables in ./packages/storybook/.env
. Note: the TRANSLATE_URL
environment variable is required to build/start Storybook.
Running storybook
yarn storybook
Building the static site
yarn build-storybook
package.json
{
"name": "my-awesome-project",
"dependencies": {
"@performant-software/semantic-components": "^1.0.0"
}
}
MyComponent.js
import { ListTable } from '@performant-software/semantic-components';
const MyComponent = (props) => (
<ListTable
columns={[]}
/>
);
Sometimes it may be necessary to test your consuming application prior to creating a release. For example, you just added a new component and want to test it out in the application to make sure everything looks and works as expected.
For this we can use NPM's "beta" tags. This will allow the compiled code to be added as a dependency from NPM, but will not map to the "latest" release for production.
Let's say the current version number is "0.5.15". You can update the version in react-components.json
to "0.5.16-beta.0" and publish the package(s) to NPM via:
yarn publish-beta
Then, in your consuming application, update your dependencies as follows:
{
"dependencies": {
"@performant-software/semantic-components": "0.5.16-beta.0",
"@performant-software/shared-components": "0.5.16-beta.0"
}
}
After all testing has passed, create your release of 0.5.16
. See publishing below.
Each of the versions of the individual packages will be kept in sync. The following steps should be taken when publishing a new version of these packages.
- Commit your changes and create a PR into the
master
branch. Wait until your PR is merged to proceed. - Create a release in GitHub. Be sure to note any breaking changes, new features, and bug fixes
- Update the version in
react-components.json
. See Semantic Versioning Guide below to determine the new version. - From the project root, run
yarn publish-production
. - In GitHub update the "next release" label to "<your_release_number>". This will allow us to go back and see exactly which PRs were included in each release.
- Create a new "next release" label in GitHub.
- Major:
1.2.3 -> 2.0.0
Many breaking changes, new UI library, new package - Minor:
1.2.3 -> 1.3.0
API changes, many new components, large bug fixes - Patch:
1.2.3 -> 1.2.4
Bug fixes, new components