mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-06 07:21:16 +08:00
# Conflicts: # addons/actions/package.json # addons/backgrounds/package.json # addons/controls/package.json # addons/cssresources/package.json # addons/design-assets/package.json # addons/essentials/package.json # addons/events/package.json # addons/google-analytics/package.json # addons/jest/package.json # addons/queryparams/package.json # addons/storysource/package.json # addons/toolbars/package.json # addons/viewport/package.json # app/ember/package.json # app/marko/package.json # app/riot/package.json # app/svelte/package.json # dev-kits/addon-decorator/package.json # dev-kits/addon-parameter/package.json # dev-kits/addon-roundtrip/package.json # lib/addons/package.json # lib/channel-postmessage/package.json # lib/channel-websocket/package.json # lib/codemod/package.json # lib/theming/package.json # scripts/run-e2e-config.ts
Storybook Channel
Storybook Channel is similar to an EventEmitter. Channels are used with Storybook implementations to send/receive events between the Storybook Manager and the Storybook Renderer.
class Channel {
addListener(type, listener) {}
addPeerListener(type, listener) {} // ignore events from itself
emit(type, ...args) {}
eventNames() {}
listenerCount(type) {}
listeners(type) {}
on(type, listener) {}
once(type, listener) {}
prependListener(type, listener) {}
prependOnceListener(type, listener) {}
removeAllListeners(type) {}
removeListener(type, listener) {}
}
The channel takes a Transport object as a parameter which will be used to send/receive messages. The transport object should implement this interface.
class Transport {
send(event) {}
setHandler(handler) {}
}
Currently, channels are baked into storybook implementations and therefore this module is not designed to be used directly by addon developers. When developing addons, use the getChannel
method exported by @storybook/addons
module. For this to work, Storybook implementations should use the setChannel
method before loading addons.
import addons from '@storybook/addons';
const channel = addons.getChannel();
For more information visit: storybook.js.org