mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-05 04:11:06 +08:00
Docs: Vite builder updates
This commit is contained in:
parent
d139b74b93
commit
cca1bad2a2
@ -6,7 +6,7 @@ Parent: [main.js|ts configuration](./main-config.md)
|
||||
|
||||
Type: `(config: Vite.InlineConfig, options: Options) => Vite.InlineConfig | Promise<Vite.InlineConfig>`
|
||||
|
||||
Customize Storybook's Vite setup when using the [vite builder](../builders/vite.md).
|
||||
Customize Storybook's Vite setup when using the [Vite builder](../builders/vite.md).
|
||||
|
||||
<!-- prettier-ignore-start -->
|
||||
|
||||
|
@ -39,9 +39,9 @@ Update your Storybook configuration (in `.storybook/main.js|ts`) to include the
|
||||
|
||||
## Configuration
|
||||
|
||||
Out of the box, Storybook's Vite builder includes a set of configuration defaults for the supported frameworks, which are merged alongside your existing configuration file. For an optimal experience when using the Vite builder, we recommend applying any configuration directly inside Vite's configuration file (i.e., [`vite.config.js`](https://vitejs.dev/config/)).
|
||||
Out of the box, Storybook's Vite builder includes a set of configuration defaults for the supported frameworks, which are merged alongside your existing configuration file. For an optimal experience when using the Vite builder, we recommend applying any configuration directly inside Vite's configuration file (i.e., [`vite.config.js|ts`](https://vitejs.dev/config/)).
|
||||
|
||||
When Storybook loads, it automatically merges the configuration into its own. However, not all projects have the same requirements, and you may need to provide a custom configuration created specifically for Storybook. In that case, you can adjust your configuration file (.storybook/main.js|ts) and add the `viteFinal` configuration function as follows:
|
||||
When Storybook loads, it automatically merges the configuration into its own. However, since different projects may have specific requirements, you may need to provide a custom configuration for Storybook. In such cases, you can modify your configuration file (`.storybook/main.js|ts`) and add the `viteFinal` configuration function as follows:
|
||||
|
||||
<!-- prettier-ignore-start -->
|
||||
|
||||
@ -53,15 +53,31 @@ When Storybook loads, it automatically merges the configuration into its own. Ho
|
||||
|
||||
<!-- prettier-ignore-end -->
|
||||
|
||||
The asynchronous function `viteFinal` receives a `config` object with the default builder configuration and returns the updated configuration.
|
||||
The asynchronous function [`viteFinal`](../api/main-config-vite-final.md) receives a `config` object with the default builder configuration and returns the updated configuration.
|
||||
|
||||
You can also override the builder's configuration based on the environment. For instance, if you need to provide a custom configuration for development purposes and another for production, you can extend the default configuration as follows:
|
||||
### Environment-based configuration
|
||||
|
||||
If you need to customize the builder's configuration and apply specific options based on your environment, extend the `viteFinal` function as follows:
|
||||
|
||||
<!-- prettier-ignore-start -->
|
||||
|
||||
<CodeSnippets
|
||||
paths={[
|
||||
'common/main-config-vite-final.js.mdx',
|
||||
'common/main-config-vite-final-env.js.mdx'
|
||||
]}
|
||||
/>
|
||||
|
||||
<!-- prettier-ignore-end -->
|
||||
|
||||
### Override the default configuration
|
||||
|
||||
By default, the Vite builder in Storybook searches for the Vite configuration file in the root directory of your Storybook project. However, you can customize it to look for the configuration file in a different location. For example:
|
||||
|
||||
<!-- prettier-ignore-start -->
|
||||
|
||||
<CodeSnippets
|
||||
paths={[
|
||||
'common/main-config-builder-custom-config.js.mdx',
|
||||
]}
|
||||
/>
|
||||
|
||||
|
@ -0,0 +1,15 @@
|
||||
```js
|
||||
// .storybook/main.js|ts
|
||||
|
||||
export default {
|
||||
stories: ['../src/**/*.mdx', '../src/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
|
||||
core: {
|
||||
builder: {
|
||||
name: '@storybook/builder-vite',
|
||||
options: {
|
||||
viteConfigPath: '../customVite.config.js',
|
||||
},
|
||||
},
|
||||
},
|
||||
};
|
||||
```
|
21
docs/snippets/common/main-config-core-builder.ts-4-9.mdx
Normal file
21
docs/snippets/common/main-config-core-builder.ts-4-9.mdx
Normal file
@ -0,0 +1,21 @@
|
||||
```ts
|
||||
// .storybook/main.ts
|
||||
|
||||
// Replace your-framework with the framework you are using (e.g., react-webpack5, vue3-vite)
|
||||
import type { StorybookConfig } from '@storybook/your-framework';
|
||||
|
||||
const config: StorybookConfig = {
|
||||
stories: ['../src/**/*.mdx', '../src/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
|
||||
framework: '@storybook/your-framework',
|
||||
core: {
|
||||
builder: {
|
||||
name: '@storybook/builder-vite',
|
||||
options: {
|
||||
viteConfigPath: '../../../vite.config.js',
|
||||
},
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
export default config;
|
||||
```
|
23
docs/snippets/common/main-config-vite-final-env.js.mdx
Normal file
23
docs/snippets/common/main-config-vite-final-env.js.mdx
Normal file
@ -0,0 +1,23 @@
|
||||
```js
|
||||
// .storybook/main.js|ts
|
||||
|
||||
import { mergeConfig } from 'vite';
|
||||
|
||||
export default {
|
||||
stories: ['../src/**/*.mdx', '../stories/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
|
||||
core: {
|
||||
builder: '@storybook/builder-vite',
|
||||
},
|
||||
async viteFinal(config, { configType }) {
|
||||
if (configType === 'DEVELOPMENT') {
|
||||
// Your development configuration goes here
|
||||
}
|
||||
if (configType === 'PRODUCTION') {
|
||||
// Your production configuration goes here.
|
||||
}
|
||||
return mergeConfig(config, {
|
||||
// Your environment configuration here
|
||||
});
|
||||
},
|
||||
};
|
||||
```
|
27
docs/snippets/common/main-config-vite-final.ts-4-9.mdx
Normal file
27
docs/snippets/common/main-config-vite-final.ts-4-9.mdx
Normal file
@ -0,0 +1,27 @@
|
||||
```ts
|
||||
// .storybook/main.ts
|
||||
|
||||
// Replace your-framework with the framework you are using (e.g., react-vite, vue3-vite)
|
||||
import type { StorybookConfig } from '@storybook/your-framework';
|
||||
|
||||
import { mergeConfig } from 'vite';
|
||||
|
||||
const config: StorybookConfig = {
|
||||
// Replace your-framework with the framework you are using (e.g., react-vite, vue3-vite)
|
||||
framework: '@storybook/your-framework',
|
||||
stories: ['../src/**/*.mdx', '../stories/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
|
||||
async viteFinal(config, { configType }) {
|
||||
if (configType === 'DEVELOPMENT') {
|
||||
// Your development configuration goes here
|
||||
}
|
||||
if (configType === 'PRODUCTION') {
|
||||
// Your production configuration goes here.
|
||||
}
|
||||
return mergeConfig(config, {
|
||||
// Your environment configuration here
|
||||
});
|
||||
},
|
||||
};
|
||||
|
||||
export default config;
|
||||
```
|
@ -1,5 +1,5 @@
|
||||
```js
|
||||
// .storybook/main.js
|
||||
// .storybook/main.js|ts
|
||||
|
||||
export default {
|
||||
stories: ['../src/**/*.mdx', '../stories/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
|
||||
|
@ -0,0 +1,17 @@
|
||||
```ts
|
||||
// .storybook/main.ts
|
||||
|
||||
// Replace your-framework with the framework you are using (e.g., react-vite, vue3-vite)
|
||||
import type { StorybookConfig } from '@storybook/your-framework';
|
||||
|
||||
const config: StorybookConfig = {
|
||||
framework: '@storybook/your-framework',
|
||||
stories: ['../src/**/*.mdx', '../src/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
|
||||
async viteFinal(config, options) {
|
||||
// Add your configuration here
|
||||
return config;
|
||||
},
|
||||
};
|
||||
|
||||
export default config;
|
||||
```
|
Loading…
x
Reference in New Issue
Block a user