@anansi/webpack-config
Version:
Production ready webpack for React
111 lines (106 loc) • 15.4 kB
JavaScript
;
exports.__esModule = true;
exports.default = makeStorybookConfigGenerator;
function makeStorybookConfigGenerator(baseConfig) {
return ({
config: storybookConfig,
mode
}) => {
const env = mode.toLowerCase();
const argv = {
mode: env
};
const envConfig = typeof baseConfig === 'function' ? baseConfig(env, argv) : baseConfig;
// we need some of their plugins (https://github.com/storybooks/storybook/pull/1775/files)
const storybookPlugins = storybookConfig.plugins.filter(plugin =>
// exclude ones we configure
!['DefinePlugin', 'EnvironmentPlugin', 'ReactRefreshPlugin',
//'HotModuleReplacementPlugin', since storybook 6.4 we need this again
'CaseSensitivePathsPlugin',
// this makes process redundant
'ProvidePlugin'].includes(plugin.constructor.name));
const basePlugins = envConfig.plugins.filter(plugin =>
// defer to storybook's version in this case
// TODO: try to simply copy configuration and reuse our HtmlWebpackPlugin
![
// storybook runs this build after building the storybook chrome ui, so we don't want to clear that out
// they also clean the directory in that stage anyway
'CleanWebpackPlugin', 'HtmlWebpackPlugin', 'ErrorOverlayPlugin', 'StatsPlugin',
// storybook puts .cache in node_modules so this prevents infinite loop
'WatchMissingNodeModulesPlugin'].includes(plugin.constructor.name));
// included rules:
// - .mdx
// - acorn-jsx node_modules rule
// - any storybook specific loaders
const isStorybookSpecific = loader => /@storybook\/[^/-]+-loader\//.test(loader);
const storybookRules = storybookConfig.module.rules.filter(rule => {
if (rule.test?.test?.('test.mdx') || rule.test?.test?.('test.story.mdx')) return true;
if (rule.include instanceof RegExp && rule.include.test('node_modules/acorn-jsx/')) return true;
if (rule.loader) {
return isStorybookSpecific(rule.loader);
} else if (rule.use) {
return rule.use.find(loadConfig => {
const loader = typeof loadConfig === 'string' ? loadConfig : loadConfig.loader;
return isStorybookSpecific(loader);
});
} else {
return false;
}
});
// this transforms storybook node_modules files...not sure why this isn't done at publish time
const libraryRule = storybookConfig.module.rules[1];
// don't run this on our project source
libraryRule.exclude = [envConfig?.resolve?.modules?.[0]];
// storybook doesn't like us setting this very much.
delete envConfig.devServer;
const config = {
watchOptions: storybookConfig.watchOptions,
...envConfig,
resolveLoader: {
...envConfig.resolveLoader,
plugins: [...(envConfig.resolveLoader?.plugins ?? []), ...(storybookConfig.resolveLoader?.plugins ?? [])]
},
resolve: {
...storybookConfig.resolve,
modules: envConfig.resolve.modules,
extensions: envConfig.resolve.extensions,
alias: {
...envConfig.resolve.alias,
...storybookConfig.resolve.alias
},
plugins: [...(envConfig.resolve?.plugins ?? []), ...(storybookConfig.resolve?.plugins ?? [])]
},
entry: storybookConfig.entry,
output: storybookConfig.output,
plugins: [...storybookPlugins, ...basePlugins],
module: {
...envConfig.module,
rules: [
// js rules (worker and normal)
{
test: envConfig.module.rules[0].test,
exclude: /storybook-stories.js/,
rules: [envConfig.module.rules[0]]
},
// storybook node_module compiles
libraryRule,
// the rest of our rules
...envConfig.module.rules.slice(1),
// typically these are various plugins
...storybookRules]
}
};
if (envConfig.cache) {
if (typeof envConfig.cache === 'object' && envConfig.cache.type === 'filesystem') {
config.cache = {
...envConfig.cache,
version: envConfig.cache.version + 'storybook'
};
} else {
config.cache = envConfig.cache;
}
}
return config;
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["makeStorybookConfigGenerator","baseConfig","config","storybookConfig","mode","env","toLowerCase","argv","envConfig","storybookPlugins","plugins","filter","plugin","includes","constructor","name","basePlugins","isStorybookSpecific","loader","test","storybookRules","module","rules","rule","include","RegExp","use","find","loadConfig","libraryRule","exclude","resolve","modules","devServer","watchOptions","resolveLoader","extensions","alias","entry","output","slice","cache","type","version"],"sources":["../src/storybook.js"],"sourcesContent":["export default function makeStorybookConfigGenerator(baseConfig) {\n  return ({ config: storybookConfig, mode }) => {\n    const env = mode.toLowerCase();\n    const argv = { mode: env };\n    const envConfig =\n      typeof baseConfig === 'function' ? baseConfig(env, argv) : baseConfig;\n\n    // we need some of their plugins (https://github.com/storybooks/storybook/pull/1775/files)\n    const storybookPlugins = storybookConfig.plugins.filter(\n      plugin =>\n        // exclude ones we configure\n        ![\n          'DefinePlugin',\n          'EnvironmentPlugin',\n          'ReactRefreshPlugin',\n          //'HotModuleReplacementPlugin', since storybook 6.4 we need this again\n          'CaseSensitivePathsPlugin',\n          // this makes process redundant\n          'ProvidePlugin',\n        ].includes(plugin.constructor.name),\n    );\n    const basePlugins = envConfig.plugins.filter(\n      plugin =>\n        // defer to storybook's version in this case\n        // TODO: try to simply copy configuration and reuse our HtmlWebpackPlugin\n        ![\n          // storybook runs this build after building the storybook chrome ui, so we don't want to clear that out\n          // they also clean the directory in that stage anyway\n          'CleanWebpackPlugin',\n          'HtmlWebpackPlugin',\n          'ErrorOverlayPlugin',\n          'StatsPlugin',\n          // storybook puts .cache in node_modules so this prevents infinite loop\n          'WatchMissingNodeModulesPlugin',\n        ].includes(plugin.constructor.name),\n    );\n\n    // included rules:\n    // - .mdx\n    // - acorn-jsx node_modules rule\n    // - any storybook specific loaders\n    const isStorybookSpecific = loader =>\n      /@storybook\\/[^/-]+-loader\\//.test(loader);\n    const storybookRules = storybookConfig.module.rules.filter(rule => {\n      if (rule.test?.test?.('test.mdx') || rule.test?.test?.('test.story.mdx'))\n        return true;\n      if (\n        rule.include instanceof RegExp &&\n        rule.include.test('node_modules/acorn-jsx/')\n      )\n        return true;\n      if (rule.loader) {\n        return isStorybookSpecific(rule.loader);\n      } else if (rule.use) {\n        return rule.use.find(loadConfig => {\n          const loader =\n            typeof loadConfig === 'string' ? loadConfig : loadConfig.loader;\n          return isStorybookSpecific(loader);\n        });\n      } else {\n        return false;\n      }\n    });\n\n    // this transforms storybook node_modules files...not sure why this isn't done at publish time\n    const libraryRule = storybookConfig.module.rules[1];\n    // don't run this on our project source\n    libraryRule.exclude = [envConfig?.resolve?.modules?.[0]];\n\n    // storybook doesn't like us setting this very much.\n    delete envConfig.devServer;\n\n    const config = {\n      watchOptions: storybookConfig.watchOptions,\n      ...envConfig,\n      resolveLoader: {\n        ...envConfig.resolveLoader,\n        plugins: [\n          ...(envConfig.resolveLoader?.plugins ?? []),\n          ...(storybookConfig.resolveLoader?.plugins ?? []),\n        ],\n      },\n      resolve: {\n        ...storybookConfig.resolve,\n        modules: envConfig.resolve.modules,\n        extensions: envConfig.resolve.extensions,\n        alias: { ...envConfig.resolve.alias, ...storybookConfig.resolve.alias },\n        plugins: [\n          ...(envConfig.resolve?.plugins ?? []),\n          ...(storybookConfig.resolve?.plugins ?? []),\n        ],\n      },\n\n      entry: storybookConfig.entry,\n      output: storybookConfig.output,\n      plugins: [...storybookPlugins, ...basePlugins],\n      module: {\n        ...envConfig.module,\n        rules: [\n          // js rules (worker and normal)\n          {\n            test: envConfig.module.rules[0].test,\n            exclude: /storybook-stories.js/,\n            rules: [envConfig.module.rules[0]],\n          },\n          // storybook node_module compiles\n          libraryRule,\n          // the rest of our rules\n          ...envConfig.module.rules.slice(1),\n          // typically these are various plugins\n          ...storybookRules,\n        ],\n      },\n    };\n    if (envConfig.cache) {\n      if (\n        typeof envConfig.cache === 'object' &&\n        envConfig.cache.type === 'filesystem'\n      ) {\n        config.cache = {\n          ...envConfig.cache,\n          version: envConfig.cache.version + 'storybook',\n        };\n      } else {\n        config.cache = envConfig.cache;\n      }\n    }\n    return config;\n  };\n}\n"],"mappings":"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","ignoreList":[]}