123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- /*eslint-env node*/
- /*eslint import/no-nodejs-modules:0 */
- const path = require('path');
- const webpack = require('webpack');
- const appConfig = require('../webpack.config');
- const staticPath = path.resolve(
- __dirname,
- '..',
- 'src',
- 'sentry',
- 'static',
- 'sentry',
- 'app'
- );
- /**
- * Default the config parameter that storybook passes into our webpack config
- * to an empty object specifically for eslint, since it will load this config
- * without passing in a config object.
- */
- const emptyConfig = {
- module: {rules: []},
- resolve: {alias: {}, extensions: []},
- plugins: [],
- };
- module.exports = ({config} = {config: emptyConfig}) => {
- const [firstRule, ...rules] = config.module.rules;
- const filteredRules = rules.filter(rule => {
- return (
- (!rule.loader || !rule.loader.includes('file-loader')) &&
- (!Array.isArray(rule.use) ||
- !rule.use.find(({loader}) => loader && loader.includes('postcss-loader')))
- );
- });
- const newConfig = {
- ...config,
- module: {
- ...config.module,
- rules: [
- {
- ...firstRule,
- test: /\.(mjs|[tj]sx?)$/,
- include: [path.join(__dirname), staticPath, path.join(__dirname, '../docs-ui')],
- },
- {
- test: /app\/icons\/.*\.svg$/,
- use: [
- {
- loader: 'svg-sprite-loader',
- },
- {
- loader: 'svgo-loader',
- },
- ],
- },
- {
- test: /\.css$/,
- use: ['style-loader', 'css-loader'],
- },
- {
- test: /\.less$/,
- use: [
- {
- loader: 'style-loader',
- },
- {
- loader: 'css-loader',
- },
- {
- loader: 'less-loader',
- },
- ],
- },
- {
- test: /\.(woff|woff2|ttf|eot|svg|png|gif|ico|jpg)($|\?)/,
- exclude: /app\/icons\/.*\.svg$/,
- loader: 'file-loader?name=' + '[name].[ext]',
- },
- {
- test: /\.po$/,
- loader: 'po-catalog-loader',
- query: {
- referenceExtensions: ['.js', '.jsx'],
- domain: 'sentry',
- },
- },
- ...filteredRules,
- ],
- },
- plugins: [
- ...config.plugins,
- new webpack.ProvidePlugin({
- $: 'jquery',
- jQuery: 'jquery',
- 'window.jQuery': 'jquery',
- 'root.jQuery': 'jquery',
- underscore: 'underscore',
- _: 'underscore',
- }),
- new webpack.DefinePlugin({
- 'process.env': {
- FIXED_DYNAMIC_CONTENT: true,
- },
- }),
- ],
- resolve: {
- ...config.resolve,
- extensions: Array.from(
- new Set([...config.resolve.extensions, ...appConfig.resolve.extensions])
- ),
- alias: {
- ...config.resolve.alias,
- ...appConfig.resolve.alias,
- app: staticPath,
- },
- },
- };
- return newConfig;
- };
|