mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-07 07:11:29 +08:00
In 6.5 the `framework` config option was one of `react`, `angular`, etc. and included Webpack settings. In the 7.0, we’ve updated it so that these are now called `renderers`, and are builder-independent. Now, frameworks contain specific builder information, such as `cra` or `nextjs` (for specific app environments) or `react-webpack5` / `react-vite` (for custom apps). This fixes the `sb init` CLI command to use renderer-specific templates. I also call out some follow-up work to fix automigrations & telemetry
37 lines
1.1 KiB
TypeScript
37 lines
1.1 KiB
TypeScript
import { moduleMetadata, StoryFn, Meta } from '@storybook/angular';
|
|
import { within, userEvent } from '@storybook/testing-library';
|
|
import { CommonModule } from '@angular/common';
|
|
|
|
import Button from './button.component';
|
|
import Header from './header.component';
|
|
import Page from './page.component';
|
|
|
|
export default {
|
|
title: 'Example/Page',
|
|
component: Page,
|
|
parameters: {
|
|
// More on StoryFn layout: https://storybook.js.org/docs/angular/configure/story-layout
|
|
layout: 'fullscreen',
|
|
},
|
|
decorators: [
|
|
moduleMetadata({
|
|
declarations: [Button, Header],
|
|
imports: [CommonModule],
|
|
}),
|
|
],
|
|
} as Meta;
|
|
|
|
const Template: StoryFn<Page> = (args: Page) => ({
|
|
props: args,
|
|
});
|
|
|
|
export const LoggedOut = Template.bind({});
|
|
|
|
// More on interaction testing: https://storybook.js.org/docs/angular/writing-tests/interaction-testing
|
|
export const LoggedIn = Template.bind({});
|
|
LoggedIn.play = async ({ canvasElement }) => {
|
|
const canvas = within(canvasElement);
|
|
const loginButton = await canvas.getByRole('button', { name: /Log in/i });
|
|
await userEvent.click(loginButton);
|
|
};
|