storybook/code/builders/builder-webpack5/templates/virtualModuleModernEntry.js
Norbert de Langen 38bb600f5b merge next
2025-02-12 15:55:41 +01:00

45 lines
1.4 KiB
JavaScript

import { createBrowserChannel } from 'storybook/internal/channels';
import { isPreview } from 'storybook/internal/csf';
import { PreviewWeb, addons, composeConfigs } from 'storybook/internal/preview-api';
import { global } from '@storybook/global';
import { importFn } from '{{storiesFilename}}';
const getProjectAnnotations = () => {
const previewAnnotations = ['{{previewAnnotations_requires}}'];
// the last one in this array is the user preview
const userPreview = previewAnnotations[previewAnnotations.length - 1]?.default;
if (isPreview(userPreview)) {
return userPreview.composed;
}
return composeConfigs(previewAnnotations);
};
const channel = createBrowserChannel({ page: 'preview' });
addons.setChannel(channel);
if (global.CONFIG_TYPE === 'DEVELOPMENT') {
window.__STORYBOOK_SERVER_CHANNEL__ = channel;
}
const preview = new PreviewWeb(importFn, getProjectAnnotations);
window.__STORYBOOK_PREVIEW__ = preview;
window.__STORYBOOK_STORY_STORE__ = preview.storyStore;
window.__STORYBOOK_ADDONS_CHANNEL__ = channel;
if (import.meta.webpackHot) {
import.meta.webpackHot.accept('{{storiesFilename}}', () => {
// importFn has changed so we need to patch the new one in
preview.onStoriesChanged({ importFn });
});
import.meta.webpackHot.accept(['{{previewAnnotations}}'], () => {
// getProjectAnnotations has changed so we need to patch the new one in
preview.onGetProjectAnnotationsChanged({ getProjectAnnotations });
});
}