@storybook/angular
Version:
Storybook for Angular: Develop Angular components in isolation with hot reloading.
43 lines (42 loc) • 1.65 kB
TypeScript
import { Parameters as DefaultParameters, StoryContext as DefaultStoryContext, WebRenderer } from 'storybook/internal/types';
import { Provider } from '@angular/core';
import { ApplicationConfig } from '@angular/platform-browser';
export interface NgModuleMetadata {
/** List of components, directives, and pipes that belong to your component. */
declarations?: any[];
entryComponents?: any[];
/**
* List of modules that should be available to the root Storybook Component and all its children.
* If you want to register application providers or if you want to use the forRoot() pattern,
* please use the `applicationConfig` decorator in combination with the importProvidersFrom helper
* function from @angular/core instead.
*/
imports?: any[];
schemas?: any[];
/**
* List of providers that should be available on the root component and all its children. Use the
* `applicationConfig` decorator to register environemt and application-wide providers.
*/
providers?: Provider[];
}
export interface ICollection {
[p: string]: any;
}
export interface StoryFnAngularReturnType {
props?: ICollection;
moduleMetadata?: NgModuleMetadata;
applicationConfig?: ApplicationConfig;
template?: string;
styles?: string[];
userDefinedTemplate?: boolean;
}
export interface AngularRenderer extends WebRenderer {
component: any;
storyResult: StoryFnAngularReturnType;
}
export type Parameters = DefaultParameters & {
bootstrapModuleOptions?: unknown;
};
export type StoryContext = DefaultStoryContext<AngularRenderer> & {
parameters: Parameters;
};