1 | "use strict";
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | exports.sourceDecorator = exports.skipSourceRender = void 0;
|
4 | const preview_api_1 = require("@storybook/preview-api");
|
5 | const docs_tools_1 = require("@storybook/docs-tools");
|
6 | const renderer_1 = require("../../renderer");
|
7 | const skipSourceRender = (context) => {
|
8 | const sourceParams = context?.parameters.docs?.source;
|
9 |
|
10 | if (sourceParams?.type === docs_tools_1.SourceType.DYNAMIC) {
|
11 | return false;
|
12 | }
|
13 |
|
14 |
|
15 | return sourceParams?.code || sourceParams?.type === docs_tools_1.SourceType.CODE;
|
16 | };
|
17 | exports.skipSourceRender = skipSourceRender;
|
18 |
|
19 |
|
20 |
|
21 |
|
22 |
|
23 | const sourceDecorator = (storyFn, context) => {
|
24 | const story = storyFn();
|
25 | if ((0, exports.skipSourceRender)(context)) {
|
26 | return story;
|
27 | }
|
28 | const channel = preview_api_1.addons.getChannel();
|
29 | const { props, template, userDefinedTemplate } = story;
|
30 | const { component, argTypes } = context;
|
31 | let toEmit;
|
32 | (0, preview_api_1.useEffect)(() => {
|
33 | if (toEmit) {
|
34 | const { id, unmappedArgs } = context;
|
35 | channel.emit(docs_tools_1.SNIPPET_RENDERED, { id, args: unmappedArgs, source: toEmit, format: 'angular' });
|
36 | }
|
37 | });
|
38 | if (component && !userDefinedTemplate) {
|
39 | const source = (0, renderer_1.computesTemplateSourceFromComponent)(component, props, argTypes);
|
40 |
|
41 |
|
42 | if (source || template) {
|
43 | toEmit = source || template;
|
44 | }
|
45 | }
|
46 | else if (template) {
|
47 | toEmit = template;
|
48 | }
|
49 | return story;
|
50 | };
|
51 | exports.sourceDecorator = sourceDecorator;
|