mirror of
https://github.com/bitwarden/browser
synced 2025-01-13 10:54:07 +01:00
40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
|
import { setCompodocJson } from "@storybook/addon-docs/angular";
|
||
|
import { componentWrapperDecorator } from "@storybook/angular";
|
||
|
import type { Preview } from "@storybook/angular";
|
||
|
|
||
|
import docJson from "../documentation.json";
|
||
|
setCompodocJson(docJson);
|
||
|
|
||
|
const decorator = componentWrapperDecorator(
|
||
|
(story) => `
|
||
|
<ng-template #lightPreview>
|
||
|
<div class="theme_light tw-px-5 tw-py-10 tw-border-2 tw-border-solid tw-border-secondary-300 tw-bg-[#ffffff]">${story}</div>
|
||
|
</ng-template>
|
||
|
<ng-template #darkPreview>
|
||
|
<div class="theme_dark tw-mt-5 tw-px-5 tw-py-10 tw-bg-[#1f242e]">${story}</div>
|
||
|
</ng-template>
|
||
|
<ng-container *ngTemplateOutlet="lightPreview"></ng-container>
|
||
|
<ng-container *ngTemplateOutlet="darkPreview"></ng-container>`
|
||
|
);
|
||
|
|
||
|
const preview: Preview = {
|
||
|
decorators: [decorator],
|
||
|
parameters: {
|
||
|
actions: { argTypesRegex: "^on[A-Z].*" },
|
||
|
controls: {
|
||
|
matchers: {
|
||
|
color: /(background|color)$/i,
|
||
|
date: /Date$/,
|
||
|
},
|
||
|
},
|
||
|
options: {
|
||
|
storySort: {
|
||
|
order: ["Documentation", ["Introduction", "Colors", "Icons"], "Component Library"],
|
||
|
},
|
||
|
},
|
||
|
docs: { source: { type: "dynamic", excludeDecorators: true } },
|
||
|
},
|
||
|
};
|
||
|
|
||
|
export default preview;
|