2022-05-09 15:33:44 +02:00
|
|
|
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin')
|
|
|
|
|
|
|
|
module.exports = {
|
2022-05-12 12:35:07 +02:00
|
|
|
core: { builder: 'webpack5' },
|
|
|
|
stories: ['../src/**/*.stories.tsx'],
|
|
|
|
addons: ['@storybook/addon-essentials'],
|
2022-05-09 15:33:44 +02:00
|
|
|
framework: '@storybook/react',
|
|
|
|
webpackFinal: async (config) => {
|
|
|
|
config.resolve.plugins = [
|
|
|
|
...(config.resolve.plugins || []),
|
|
|
|
new TsconfigPathsPlugin({
|
|
|
|
extensions: config.resolve.extensions
|
|
|
|
})
|
|
|
|
]
|
2022-05-12 12:35:07 +02:00
|
|
|
|
|
|
|
// Mimic next.config.js webpack config
|
2022-05-16 18:11:43 +02:00
|
|
|
config.module.rules.push({
|
|
|
|
test: /\.gif$/,
|
|
|
|
// yay for webpack 5
|
|
|
|
// https://webpack.js.org/guides/asset-management/#loading-images
|
|
|
|
type: 'asset/resource'
|
|
|
|
})
|
|
|
|
|
|
|
|
// Modify storybook's file-loader rule to avoid conflicts with svgr
|
|
|
|
const fileLoaderRule = config.module.rules.find(
|
|
|
|
(rule) => rule.test && rule.test.test('.svg')
|
2022-05-12 12:35:07 +02:00
|
|
|
)
|
2022-05-16 18:11:43 +02:00
|
|
|
fileLoaderRule.exclude = /\.svg$/
|
|
|
|
|
|
|
|
config.module.rules.push({
|
|
|
|
test: /\.svg$/,
|
|
|
|
issuer: /\.(tsx|ts)$/,
|
|
|
|
use: [
|
|
|
|
{ loader: require.resolve('@svgr/webpack'), options: { icon: true } }
|
|
|
|
]
|
|
|
|
})
|
2022-05-12 12:35:07 +02:00
|
|
|
|
|
|
|
const fallback = config.resolve.fallback || {}
|
|
|
|
Object.assign(fallback, {
|
|
|
|
http: require.resolve('stream-http'),
|
|
|
|
https: require.resolve('https-browserify'),
|
|
|
|
fs: false,
|
|
|
|
crypto: false,
|
|
|
|
os: false,
|
|
|
|
stream: false,
|
|
|
|
assert: false
|
|
|
|
})
|
|
|
|
config.resolve.fallback = fallback
|
|
|
|
|
2022-05-09 15:33:44 +02:00
|
|
|
return config
|
|
|
|
}
|
|
|
|
}
|