mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-04 13:31:19 +08:00
updates decorators docs
This commit is contained in:
parent
aeb14830a7
commit
fc9cd60e59
@ -0,0 +1,5 @@
|
||||
```ts
|
||||
// src/polyfills.ts
|
||||
|
||||
import '@angular/localize/init';
|
||||
```
|
@ -0,0 +1,21 @@
|
||||
```js
|
||||
// .storybook/preview.js
|
||||
|
||||
import { setCompodocJson } from '@storybook/addon-docs/angular';
|
||||
import docJson from '../documentation.json';
|
||||
|
||||
import '../src/polyfills';
|
||||
|
||||
setCompodocJson(docJson);
|
||||
|
||||
export const parameters = {
|
||||
actions: { argTypesRegex: '^on[A-Z].*' },
|
||||
controls: {
|
||||
matchers: {
|
||||
color: /(background|color)$/i,
|
||||
date: /Date$/,
|
||||
},
|
||||
},
|
||||
docs: { inlineStories: true },
|
||||
};
|
||||
```
|
@ -38,9 +38,9 @@ Some components require a “harness” to render in a useful way. For instance,
|
||||
|
||||
## “Context” for mocking
|
||||
|
||||
Framework-specific libraries (e.g., [Styled Components](https://styled-components.com/), [Fortawesome](https://github.com/FortAwesome/vue-fontawesome) for Vue) may require additional configuration to render correctly in Storybook.
|
||||
Framework-specific libraries (e.g., [Styled Components](https://styled-components.com/), [Fortawesome](https://github.com/FortAwesome/vue-fontawesome) for Vue, Angular's [localize](https://angular.io/api/localize)) may require additional configuration to render correctly in Storybook.
|
||||
|
||||
For example, if you're working with Styled Components and your components use a theme, add a single global decorator to [`.storybook/preview.js`](../configure/overview.md#configure-story-rendering) to provide it. Or with Vue, extend Storybook's application and register your library:
|
||||
For example, if you're working with React's Styled Components and your components use themes, add a single global decorator to [`.storybook/preview.js`](../configure/overview.md#configure-story-rendering) to enable them. With Vue, extend Storybook's application and register your library. Or with Angular, add the package into your `polyfills.ts` and import it:
|
||||
|
||||
<!-- prettier-ignore-start -->
|
||||
|
||||
@ -54,12 +54,14 @@ For example, if you're working with Styled Components and your components use a
|
||||
'vue/storybook-preview-with-hoc-component-decorator.3-component.js.mdx',
|
||||
'vue/storybook-preview-with-mixin-decorator.2-mixin.js.mdx',
|
||||
'vue/storybook-preview-with-mixin-decorator.3-mixin.js.mdx',
|
||||
'angular/add-localize-package-to-polyfills.ts.mdx',
|
||||
'angular/storybook-preview-with-angular-polyfills.js.mdx',
|
||||
]}
|
||||
/>
|
||||
|
||||
<!-- prettier-ignore-end -->
|
||||
|
||||
In the example above, the values provided are hardcoded. Still, you may want to vary them, either on a per-story basis (i.e., if the values you're providing are relevant to a specific story) or in a user-controlled way (e.g., provide a theme switcher or a different set of icons).
|
||||
In the example above, the values provided are hardcoded. Still, you may want to vary them, either per-story basis (i.e., if the values you're adding are relevant to a specific story) or in a user-controlled way (e.g., provide a theme switcher or a different set of icons).
|
||||
|
||||
The second argument to a decorator function is the **story context** which in particular contains the keys:
|
||||
|
||||
@ -71,12 +73,12 @@ The second argument to a decorator function is the **story context** which in pa
|
||||
- `viewMode`- Storybook's current active window (e.g., canvas, docs).
|
||||
|
||||
<div class="aside">
|
||||
💡 This pattern can also be applied to your own stories. Some of Storybook's supported frameworks already use it (e.g., vue 2).
|
||||
💡 <strong>Note:</strong> This pattern can also be applied to your own stories. Some of Storybook's supported frameworks already use it (e.g., vue 2).
|
||||
</div>
|
||||
|
||||
### Using decorators to provide data
|
||||
|
||||
If your components are “connected” and require side-loaded data to render, you can use decorators to provide that data in a mocked way without having to refactor your components to take that data as an arg. There are several techniques to achieve this. Depending on exactly how you are loading that data -- read more in the [building pages in Storybook](./build-pages-with-storybook.md) section.
|
||||
If your components are “connected” and require side-loaded data to render, you can use decorators to provide that data in a mocked way without having to refactor your components to take that data as an arg. There are several techniques to achieve this. Depending on exactly how you are loading that data -- read more in the [building pages in Storybook](../workflows/build-pages-with-storybook.md) section.
|
||||
|
||||
## Story decorators
|
||||
|
||||
@ -87,9 +89,7 @@ To define a decorator for a single story, use the `decorators` key on a named ex
|
||||
<CodeSnippets
|
||||
paths={[
|
||||
'react/button-story-decorator.js.mdx',
|
||||
'react/button-story-decorator.ts.mdx',
|
||||
'react/button-story-decorator.story-function.js.mdx',
|
||||
'react/button-story-decorator.story-function-ts.ts.mdx',
|
||||
'react/button-story-decorator.mdx.mdx',
|
||||
'vue/button-story-decorator.js.mdx',
|
||||
'vue/button-story-decorator.mdx.mdx',
|
||||
@ -156,4 +156,4 @@ All decorators relevant to a story will run in the following order once the stor
|
||||
|
||||
- Global decorators, in the order they are defined
|
||||
- Component decorators, in the order they are defined
|
||||
- Story decorators, in the order they are defined.
|
||||
- Story decorators, in the order they are defined.
|
Loading…
x
Reference in New Issue
Block a user