1 | import { ReactNode } from 'react';
|
2 | import { Channel } from '@storybook/channels';
|
3 | import { ThemeVars } from '@storybook/theming';
|
4 | import { API, State, ModuleFn, Root, Group, Story } from '../index';
|
5 | import { StoryMapper, Refs } from './refs';
|
6 | import { UIOptions } from './layout';
|
7 | interface SidebarOptions {
|
8 | showRoots?: boolean;
|
9 | collapsedRoots?: string[];
|
10 | renderLabel?: (item: Root | Group | Story) => ReactNode;
|
11 | }
|
12 | declare type IframeRenderer = (storyId: string, viewMode: State['viewMode'], id: string, baseUrl: string, scale: number, queryParams: Record<string, any>) => ReactNode;
|
13 | export interface Provider {
|
14 | channel?: Channel;
|
15 | serverChannel?: Channel;
|
16 | renderPreview?: IframeRenderer;
|
17 | handleAPI(api: API): void;
|
18 | getConfig(): {
|
19 | sidebar?: SidebarOptions;
|
20 | theme?: ThemeVars;
|
21 | refs?: Refs;
|
22 | StoryMapper?: StoryMapper;
|
23 | [k: string]: any;
|
24 | } & Partial<UIOptions>;
|
25 | [key: string]: any;
|
26 | }
|
27 | export interface SubAPI {
|
28 | renderPreview?: Provider['renderPreview'];
|
29 | }
|
30 | export declare const init: ModuleFn;
|
31 | export {};
|