2021-09-20 19:30:19 +03:00
|
|
|
const util = require('util');
|
|
|
|
const webpack = require('webpack');
|
2021-10-07 12:50:04 +03:00
|
|
|
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin');
|
|
|
|
const path = require('path');
|
2022-09-02 12:12:26 +03:00
|
|
|
const remarkSlug = require('remark-slug');
|
|
|
|
const remarkExternalLinks = require('remark-external-links');
|
2021-09-20 19:30:19 +03:00
|
|
|
|
2021-09-28 13:15:34 +03:00
|
|
|
const isConfigDebugMode = process.env.STORYBOOK_CONFIG_LOG === 'debug';
|
|
|
|
|
2021-09-20 19:30:19 +03:00
|
|
|
module.exports = {
|
2022-06-30 17:16:08 +03:00
|
|
|
stories: ['../src/*.mdx', '../src/**/*.stories.@(js|jsx|ts|tsx|mdx)'],
|
2021-09-20 19:30:19 +03:00
|
|
|
babel: async options => {
|
2021-09-28 13:15:34 +03:00
|
|
|
if (isConfigDebugMode) {
|
|
|
|
console.log('------BABEL--------');
|
|
|
|
console.log(util.inspect(options, { showHidden: false, depth: null }));
|
|
|
|
}
|
2021-09-20 19:30:19 +03:00
|
|
|
return options;
|
|
|
|
},
|
2022-06-30 17:16:08 +03:00
|
|
|
webpackFinal: async config => {
|
|
|
|
config.module.rules.push(
|
|
|
|
{
|
|
|
|
test: /\.scss$/,
|
|
|
|
use: [
|
|
|
|
'style-loader',
|
2021-09-20 19:30:19 +03:00
|
|
|
{
|
2022-06-30 17:16:08 +03:00
|
|
|
loader: 'css-loader',
|
|
|
|
options: {
|
|
|
|
importLoaders: 2,
|
|
|
|
modules: {
|
|
|
|
localIdentName: '[local]___[hash:base64:5]',
|
2021-09-20 19:30:19 +03:00
|
|
|
},
|
2022-06-30 17:16:08 +03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
loader: 'sass-loader',
|
|
|
|
options: {
|
|
|
|
// Prefer `dart-sass`
|
|
|
|
implementation: require('sass'),
|
|
|
|
sassOptions: {
|
|
|
|
outputStyle: 'expanded',
|
2021-09-20 19:30:19 +03:00
|
|
|
},
|
2022-06-30 17:16:08 +03:00
|
|
|
sourceMap: true,
|
|
|
|
},
|
2021-09-20 19:30:19 +03:00
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
2022-06-30 17:16:08 +03:00
|
|
|
{
|
|
|
|
test: /\.mjs$/,
|
|
|
|
include: /node_modules/,
|
|
|
|
type: 'javascript/auto',
|
|
|
|
}
|
|
|
|
);
|
|
|
|
config.plugins.push(
|
|
|
|
new webpack.DefinePlugin({
|
|
|
|
CONSOLE_ASSET_VERSION: Date.now().toString(),
|
|
|
|
'process.hrtime': () => null,
|
|
|
|
__CLIENT__: true,
|
|
|
|
__SERVER__: false,
|
|
|
|
__DEVELOPMENT__: true,
|
|
|
|
__DEVTOOLS__: true, // <-------- DISABLE redux-devtools HERE
|
|
|
|
})
|
|
|
|
);
|
|
|
|
config.resolve.plugins.push(
|
|
|
|
new TsconfigPathsPlugin({
|
|
|
|
configFile: path.resolve(__dirname, '../tsconfig.json'),
|
|
|
|
})
|
|
|
|
);
|
2022-09-02 12:12:26 +03:00
|
|
|
// Fix storybook bug preventing ids to be added to MDX items https://github.com/storybookjs/storybook/issues/18395
|
|
|
|
config.module.rules.map(rule => {
|
|
|
|
const useWithMdxCsfLoader = rule?.use?.find(use =>
|
|
|
|
use?.loader?.includes('@storybook/mdx1-csf')
|
|
|
|
);
|
|
|
|
if (useWithMdxCsfLoader) {
|
|
|
|
useWithMdxCsfLoader.options = {
|
|
|
|
skipCsf: false,
|
|
|
|
remarkPlugins: [remarkSlug, remarkExternalLinks],
|
|
|
|
};
|
|
|
|
}
|
|
|
|
return rule;
|
|
|
|
});
|
2022-06-30 17:16:08 +03:00
|
|
|
config.resolve.alias['@'] = path.resolve(__dirname, '../src');
|
2021-09-20 19:30:19 +03:00
|
|
|
|
2022-11-29 22:08:32 +03:00
|
|
|
config.node = { fs: 'empty' };
|
|
|
|
|
2021-09-28 13:15:34 +03:00
|
|
|
if (isConfigDebugMode) {
|
|
|
|
console.log('------WEBPACK--------');
|
|
|
|
console.log(util.inspect(newConfig, { showHidden: false, depth: null }));
|
|
|
|
}
|
2021-09-20 19:30:19 +03:00
|
|
|
|
|
|
|
// Return the altered config
|
2022-06-30 17:16:08 +03:00
|
|
|
return config;
|
2021-09-20 19:30:19 +03:00
|
|
|
},
|
|
|
|
addons: [
|
|
|
|
{
|
|
|
|
name: '@storybook/addon-postcss',
|
|
|
|
options: {
|
|
|
|
postcssLoaderOptions: {
|
|
|
|
implementation: require('postcss'),
|
2022-06-30 17:16:08 +03:00
|
|
|
postcssOptions: {
|
|
|
|
config: path.resolve(__dirname, '../postcss-storybook.config.js'),
|
|
|
|
},
|
2021-09-20 19:30:19 +03:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-06-30 17:16:08 +03:00
|
|
|
'@storybook/addon-docs',
|
2021-09-20 19:30:19 +03:00
|
|
|
'@storybook/addon-links',
|
|
|
|
'@storybook/addon-essentials',
|
2022-04-06 09:10:09 +03:00
|
|
|
'@storybook/addon-interactions',
|
2022-06-30 17:16:08 +03:00
|
|
|
'storybook-dark-mode/register',
|
2021-09-20 19:30:19 +03:00
|
|
|
],
|
2022-04-06 09:10:09 +03:00
|
|
|
features: {
|
|
|
|
interactionsDebugger: true,
|
2022-06-30 17:16:08 +03:00
|
|
|
babelModeV7: true,
|
2022-04-06 09:10:09 +03:00
|
|
|
},
|
2021-09-20 19:30:19 +03:00
|
|
|
};
|