This is the React component library and design system for Traefik Labs.
Built with React, Typescript, Stitches and Radix UI Primitives.
You can find the Storybook with an example for every component in this library here.
npm install @traefiklabs/faency@next
Then you need to wire up the FaencyProvider which will hold the context with the Theme configuration and everything global that the components will need to work well.
The provider accepts one parameter besides the
children
, which is theprimaryColor
, that will be used to build the colors used on the Theme. This color can be one of the colors exported by theStitches
config, just by adding$
as a prefix, or can be any string that represents a CSS color.
import { FaencyProvider } from '@traefiklabs/faency';
const App = () => <FaencyProvider primaryColor="$blue8">{/* your app */}</FaencyProvider>;
Then you are ready to import components and use them on your project:
import { Flex, styled } from '@traefiklabs/faency';
const Container = styled(Flex, {
padding: '$3',
bg: '$black', // alias for backgroundColor
mx: '$2', // alias for margin left and right
});
const MyComponent = () => <Container>{children}</Container>;
- Make sure you have Node 12+, or if you prefer, you can work in a Docker container:
docker run -it -v $(pwd):/usr/local/src/ -w /usr/local/src/ -p 3000:3000 node:latest bash
- Install the project dependencies
npm install
- Run the Storybook
npm run storybook
At this point, Storybook should automatically open up in your browser and you can start coding, it has hot reload so it will automatically re-render whenever a change is detected on the code.
We use Stories to demonstrate how components can behave and which variants they can take, so it's expected that every component has a Story. Check out how to create stories in the Storybook Docs.
Pull requests are always welcome, but if you have a big change that you would like to work on, it's recommended to open an issue, so we can discuss it beforehand.
A good PR is small, focuses on a single feature or improvement, and clearly communicates the problem it solves.
Try not to include more than one issue in a single PR. It's much easier for us to review multiple small pull requests than one that is large and unwieldy.
Note we follow conventional commits.
Please follow the provided PR template.
We use semantic-release/semantic-release to automagically release any commit on the master
branch.
Recommended conventional commit types:
["build", "chore", "ci", "docs", "feat", "fix", "revert", "test"]
build
/chore
: Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm)ci
: Changes to CI configuration files and scripts (examples: CircleCi, SauceLabs)docs
: Documentation (comments) only changesfeat
: A new featurefix
: A bug fixrevert
: Reverts a previous committest
: Adding missing tests or correcting existing tests
Breaking change syntax:
<type>!: <description>
Matching between commit type and release
[
{ breaking: true, release: 'major' },
// types impacting release version
{ revert: true, release: 'patch' },
{ type: 'feat', release: 'minor' },
{ type: 'fix', release: 'patch' },
{ type: 'perf', release: 'patch' },
];
See semantic-release/commit-analyzer for more information.