mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-03 05:04:51 +08:00
149 lines
3.9 KiB
Markdown
149 lines
3.9 KiB
Markdown
# Storybook Centered Decorator
|
|
|
|
[](https://circleci.com/gh/storybooks/storybook)
|
|
[](https://www.codefactor.io/repository/github/storybooks/storybook)
|
|
[](https://snyk.io/test/github/storybooks/storybook/8f36abfd6697e58cd76df3526b52e4b9dc894847)
|
|
[](https://bettercodehub.com/results/storybooks/storybook) [](https://codecov.io/gh/storybooks/storybook)
|
|
[](https://now-examples-slackin-rrirkqohko.now.sh/)
|
|
[](#backers) [](#sponsors)
|
|
|
|
* * *
|
|
|
|
Storybook Centered Decorator can be used to center components inside the preview in [Storybook](https://storybook.js.org).
|
|
|
|
[Framework Support](https://github.com/storybooks/storybook/blob/master/ADDONS_SUPPORT.md)
|
|
|
|
### Usage
|
|
|
|
```sh
|
|
npm install @storybook/addon-centered --save-dev
|
|
```
|
|
|
|
#### As a decorator
|
|
|
|
You can set the decorator locally.
|
|
|
|
example for React:
|
|
|
|
```js
|
|
import { storiesOf } from '@storybook/react';
|
|
import centered from '@storybook/addon-centered';
|
|
|
|
import MyComponent from '../Component';
|
|
|
|
storiesOf('MyComponent', module)
|
|
.addDecorator(centered)
|
|
.add('without props', () => (<MyComponent />))
|
|
.add('with some props', () => (<MyComponent text="The Comp"/>));
|
|
```
|
|
|
|
example for Vue:
|
|
|
|
```js
|
|
import { storiesOf } from '@storybook/vue';
|
|
import centered from '@storybook/addon-centered';
|
|
|
|
import MyComponent from '../Component.vue';
|
|
storiesOf('MyComponent', module)
|
|
.addDecorator(centered)
|
|
.add('without props', () => ({
|
|
components: { MyComponent },
|
|
template: '<my-component />'
|
|
}))
|
|
.add('with some props', () => ({
|
|
components: { MyComponent },
|
|
template: '<my-component text="The Comp"/>'
|
|
}));
|
|
```
|
|
|
|
example for Mithril:
|
|
|
|
```js
|
|
import { storiesOf } from '@storybook/mithril';
|
|
import centered from '@storybook/addon-centered/mithril';
|
|
|
|
import MyComponent from '../Component';
|
|
|
|
storiesOf('MyComponent', module)
|
|
.addDecorator(centered)
|
|
.add('without props', () => ({
|
|
view: () => <MyComponent />
|
|
}))
|
|
.add('with some props', () => ({
|
|
view: () => <MyComponent text="The Comp"/>
|
|
}));
|
|
```
|
|
|
|
Also, you can also add this decorator globally
|
|
|
|
example for React:
|
|
|
|
```js
|
|
import { configure, addDecorator } from '@storybook/react';
|
|
import centered from '@storybook/addon-centered';
|
|
|
|
addDecorator(centered);
|
|
|
|
configure(function () {
|
|
//...
|
|
}, module);
|
|
```
|
|
|
|
example for Vue:
|
|
|
|
```js
|
|
import { configure, addDecorator } from '@storybook/vue';
|
|
import centered from '@storybook/addon-centered';
|
|
|
|
addDecorator(centered);
|
|
|
|
configure(function () {
|
|
//...
|
|
}, module);
|
|
```
|
|
|
|
example for Mithril:
|
|
|
|
```js
|
|
import { configure, addDecorator } from '@storybook/mithril';
|
|
import centered from '@storybook/addon-centered/mithril';
|
|
|
|
addDecorator(centered);
|
|
|
|
configure(function () {
|
|
//...
|
|
}, module);
|
|
```
|
|
|
|
#### As an extension
|
|
|
|
##### 1 - Configure the extension
|
|
|
|
```js
|
|
import { configure, setAddon } from '@storybook/react';
|
|
import centered from '@storybook/addon-centered';
|
|
|
|
setAddon({
|
|
addCentered(storyName, storyFn) {
|
|
this.add(storyName, (context) => (
|
|
centered.call(context, storyFn)
|
|
));
|
|
},
|
|
});
|
|
|
|
configure(function () {
|
|
//...
|
|
}, module);
|
|
```
|
|
|
|
##### 2 - Use it in your story
|
|
|
|
```js
|
|
import { storiesOf } from '@storybook/react';
|
|
|
|
import Component from '../Component';
|
|
|
|
storiesOf('Component', module)
|
|
.addCentered('without props', () => (<Component />))
|
|
```
|