Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adrice727/typescript-react-storybook
A Starter Kit for Building a Reusable React Component Library
https://github.com/adrice727/typescript-react-storybook
components postcss react starter-project storybook typescript
Last synced: 3 months ago
JSON representation
A Starter Kit for Building a Reusable React Component Library
- Host: GitHub
- URL: https://github.com/adrice727/typescript-react-storybook
- Owner: adrice727
- License: mit
- Created: 2018-05-11T22:16:42.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-05-18T23:55:31.000Z (over 6 years ago)
- Last Synced: 2024-10-07T01:04:34.436Z (4 months ago)
- Topics: components, postcss, react, starter-project, storybook, typescript
- Language: TypeScript
- Size: 184 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![logo](./assets/logo.png)
# TypeScript React Storybook
A starter kit for building a reusable component library with [TypeScript](http://www.typescriptlang.org/), [React](https://reactjs.org/), and [Storybook](https://storybook.js.org/).
## Quick Start
To get `Storybook` up and running with the provided example components:
```bash
$ yarn install
$ yarn storybook
```
Go to `localhost:6000` in your browser. You can start building your own components and stories.## CSS Configuration
The project is configured to use [`PostCSS`](https://github.com/postcss/postcss) and the following plugins:
- [PreCSS](https://github.com/jonathantneal/precss)
- [PostCSS Import](https://github.com/postcss/postcss-import)
- [Autoprefixer](https://github.com/postcss/autoprefixer)
- [PostCSS Mixins](https://github.com/postcss/postcss-mixins)You can update the plugins by editing `postcss.config.js`.
The project uses the [`BEM`](http://getbem.com/naming/) naming convention for CSS classes in order to avoid CSS namespace collisions. By default classes will use the package name defined in `package.json`:
![bem](./assets/bem.png)
You can customize the naming convention by editing the `localIdentName` field in `webpack.config.js` and `.storybook/webpack.config.js`:
```javascript
MiniCssExtractPlugin.loader,
{
loader: require.resolve('typings-for-css-modules-loader'),
options: {
. . .
localIdentName: `${packageName}_[name]__[local]`
}
},
```[Nunito](https://fonts.google.com/specimen/Nunito) and [Source Code Pro](https://fonts.google.com/specimen/Source+Code+Pro) fonts are used by the provided example components. You can customize the fonts included in the library by updating `src/styles/imports/font-face.css`
## Build
To build the library for publishing or local testing, simply run:
```bash
$ yarn build
```After building the library, you can test it in a local project by using [`yarn link`](https://yarnpkg.com/lang/en/docs/cli/link/), or publish it directly to `npm`.
All of the fonts, styles, and images will be included in the bundled build. Just import the stylesheet:
```javascript
// Inside your top-level component
import 'typescript-react-storybook/dist/style.css';
```
and then import and use the components as normal:```javascript
import { Button } from 'typescript-react-storybook';const myComponent = () =>
console.log('clicked'))} />
```