forked from storybookjs/storybook
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwithOutline.ts
More file actions
35 lines (26 loc) · 1019 Bytes
/
withOutline.ts
File metadata and controls
35 lines (26 loc) · 1019 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import type { DecoratorFunction } from 'storybook/internal/types';
import { useEffect, useMemo } from 'storybook/preview-api';
import { PARAM_KEY } from './constants';
import { addOutlineStyles, clearStyles } from './helpers';
import outlineCSS from './outlineCSS';
export const withOutline: DecoratorFunction = (StoryFn, context) => {
const globals = context.globals || {};
const isActive = [true, 'true'].includes(globals[PARAM_KEY]);
const isInDocs = context.viewMode === 'docs';
const outlineStyles = useMemo(() => {
const selector = isInDocs ? `[data-story-block="true"]` : '.sb-show-main';
return outlineCSS(selector);
}, [context]);
useEffect(() => {
const selectorId = isInDocs ? `addon-outline-docs-${context.id}` : `addon-outline`;
if (!isActive) {
clearStyles(selectorId);
} else {
addOutlineStyles(selectorId, outlineStyles);
}
return () => {
clearStyles(selectorId);
};
}, [isActive, outlineStyles, context]);
return StoryFn();
};