mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-06 07:21:16 +08:00
142 lines
4.2 KiB
TypeScript
142 lines
4.2 KiB
TypeScript
import path from 'path';
|
|
import remarkSlug from 'remark-slug';
|
|
import remarkExternalLinks from 'remark-external-links';
|
|
|
|
import { DllReferencePlugin } from 'webpack';
|
|
|
|
// @ts-ignore
|
|
import createCompiler from '../../mdx/mdx-compiler-plugin';
|
|
|
|
const coreDirName = path.dirname(require.resolve('@storybook/core/package.json'));
|
|
// TODO: improve node_modules detection
|
|
const context = coreDirName.includes('node_modules')
|
|
? path.join(coreDirName, '../../') // Real life case, already in node_modules
|
|
: path.join(coreDirName, '../../node_modules'); // SB Monorepo
|
|
|
|
function createBabelOptions(babelOptions?: any, configureJSX?: boolean) {
|
|
// for frameworks that are not working with react, we need to configure
|
|
// the jsx to transpile mdx, for now there will be a flag for that
|
|
// for more complex solutions we can find alone that we need to add '@babel/plugin-transform-react-jsx'
|
|
const babelPlugins = (babelOptions && babelOptions.plugins) || [];
|
|
const plugins = configureJSX
|
|
? [...babelPlugins, '@babel/plugin-transform-react-jsx']
|
|
: babelPlugins;
|
|
|
|
return {
|
|
// don't use the root babelrc by default (users can override this in babelOptions)
|
|
babelrc: false,
|
|
...babelOptions,
|
|
plugins,
|
|
};
|
|
}
|
|
|
|
export const webpackDlls = (dlls: string[], options: any) => {
|
|
return options.dll ? [...dlls, './sb_dll/storybook_docs_dll.js'] : [];
|
|
};
|
|
|
|
export function webpack(webpackConfig: any = {}, options: any = {}) {
|
|
const { module = {} } = webpackConfig;
|
|
// it will reuse babel options that are already in use in storybook
|
|
// also, these babel options are chained with other presets.
|
|
const {
|
|
babelOptions,
|
|
configureJSX = options.framework !== 'react', // if not user-specified
|
|
sourceLoaderOptions = {},
|
|
} = options;
|
|
|
|
const mdxLoaderOptions = {
|
|
remarkPlugins: [remarkSlug, remarkExternalLinks],
|
|
};
|
|
|
|
// set `sourceLoaderOptions` to `null` to disable for manual configuration
|
|
const sourceLoader = sourceLoaderOptions
|
|
? [
|
|
{
|
|
test: /\.(stories|story)\.[tj]sx?$/,
|
|
loader: require.resolve('@storybook/source-loader'),
|
|
options: { ...sourceLoaderOptions, inspectLocalDependencies: true },
|
|
enforce: 'pre',
|
|
},
|
|
]
|
|
: [];
|
|
|
|
const result = {
|
|
...webpackConfig,
|
|
module: {
|
|
...module,
|
|
rules: [
|
|
...(module.rules || []),
|
|
{
|
|
test: /\.js$/,
|
|
include: new RegExp(`node_modules\\${path.sep}acorn-jsx`),
|
|
use: [
|
|
{
|
|
loader: require.resolve('babel-loader'),
|
|
options: {
|
|
presets: [[require.resolve('@babel/preset-env'), { modules: 'commonjs' }]],
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
test: /\.(stories|story).mdx$/,
|
|
use: [
|
|
{
|
|
loader: require.resolve('babel-loader'),
|
|
options: createBabelOptions(babelOptions, configureJSX),
|
|
},
|
|
{
|
|
loader: require.resolve('@mdx-js/loader'),
|
|
options: {
|
|
compilers: [createCompiler(options)],
|
|
...mdxLoaderOptions,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
test: /\.mdx$/,
|
|
exclude: /\.(stories|story).mdx$/,
|
|
use: [
|
|
{
|
|
loader: require.resolve('babel-loader'),
|
|
options: createBabelOptions(babelOptions, configureJSX),
|
|
},
|
|
{
|
|
loader: require.resolve('@mdx-js/loader'),
|
|
options: mdxLoaderOptions,
|
|
},
|
|
],
|
|
},
|
|
...sourceLoader,
|
|
],
|
|
},
|
|
};
|
|
|
|
if (options.dll) {
|
|
result.plugins.push(
|
|
new DllReferencePlugin({
|
|
context,
|
|
manifest: require.resolve('@storybook/core/dll/storybook_docs-manifest.json'),
|
|
})
|
|
);
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
export function managerEntries(entry: any[] = [], options: any) {
|
|
return [...entry, require.resolve('../../register')];
|
|
}
|
|
|
|
export function config(entry: any[] = [], options: any = {}) {
|
|
const { framework } = options;
|
|
const docsConfig = [require.resolve('./config')];
|
|
try {
|
|
docsConfig.push(require.resolve(`../${framework}/config`));
|
|
} catch (err) {
|
|
// there is no custom config for the user's framework, do nothing
|
|
}
|
|
return [...docsConfig, ...entry];
|
|
}
|