Player + Storybook Integration
Reference Assets
The reference asset set, complete with the storybook-plugin integration below is available here
Storybook Plugin
The @player-ui/storybook
package is a storybook addon + wrapper that provides easy-to-use mechanisms for integrating Player flows into storybook.
Installation
There are a few different parts required to integrate with storybook.
Start by installing @player-ui/storybook
:
npm i @player-ui/storybook
yarn add @player-ui/storybook
pnpm add @player-ui/storybook
Next, add @player-ui/storybook
to the addons
section in .storybook/main.js
module.exports = { addons: ["@player-ui/storybook"],};
In .storybook/preview.js
add the PlayerDecorator
:
import { PlayerDecorator } from "@player-ui/storybook";
export const decorators = [PlayerDecorator];
Lastly use the PlayerStory
component to render a flow:
import { PlayerStory } from "@player-ui/storybook";
export const MyStory = <PlayerStory flow={initialFlow} />;
The reactPlayerPlugins
story parameter allows you to add any custom plugins (like asset providers) to a story. This can also be set in the .storybook/preview.js
file as a global option:
import { ReferenceAssetsPlugin } from "@player-ui/reference-assets-plugin-react";
export const parameters = { reactPlayerPlugins: [new ReferenceAssetsPlugin()],};
Panels
Events
The events panel addon shows a timeline of events as the flow is processed. Here you will see logs, render/update metrics, data mutations, and more.
data:image/s3,"s3://crabby-images/4a690/4a690166ba8c73b815718f17e3d485860aacf47d" alt="Events Addon Panel"
Flow
The flow panel addon enables users to view and edit the JSON content in the running Player.
data:image/s3,"s3://crabby-images/f1b2f/f1b2f9a06d7f213e320142a3d0455dca6aa34ef9" alt="Flow Addon Panel"
Asset Docs
The asset docs panel will show the data-types for the configured Assets.
data:image/s3,"s3://crabby-images/29cac/29cac22a4817c41de8877d6ea26aee4a01d05eaf" alt="Docs Addon Panel"
In order to configure the panel to show specific asset documentation, first include the assetXLRSources
as a parameter in your preview.js
:
import RefXLR from "@player-ui/reference-assets-plugin/dist/xlr/manifest.js";
export const parameters = { assetXLRSources: [RefXLR],};
then use the assetDocs
parameter in each story to set the asset types to render:
const meta: Meta<typeof Action> = { title: "Reference Assets/Action", component: Action, parameters: { assetDocs: ["ActionAsset"], },};
Reset
The reset button in the toolbar will reset the running Player with the initial content. This is useful for clearing any data or validation state, or for resetting a completed flow.
data:image/s3,"s3://crabby-images/73fbf/73fbf8d5b89fbe82f4d6bbffee4d6160f0b1bafe" alt="Flow Reset Button"