1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
- const path = require('path')
- const MiniCssExtractPlugin = require('mini-css-extract-plugin')
- const CopyWebpackPlugin = require('copy-webpack-plugin')
- const { EnvironmentPlugin } = require('webpack')
- const { reactBabelOptions } = require('./lib/react/babel')
- module.exports = {
- devtool: 'source-map', // this prevents webpack from using eval
- entry: './javascripts/index.js',
- output: {
- filename: 'index.js',
- path: path.resolve(__dirname, 'dist'),
- publicPath: '/dist'
- },
- module: {
- rules: [
- {
- test: /\.js$/,
- include: [
- path.resolve(__dirname, 'react')
- ],
- use: {
- loader: 'babel-loader',
- options: reactBabelOptions
- }
- },
- {
- test: /\.m?js$/,
- exclude: /(node_modules|bower_components|react)/,
- use: {
- loader: 'babel-loader',
- options: {
- exclude: /node_modules\/lodash/,
- presets: [
- ['@babel/preset-env', { targets: '> 0.25%, not dead' }]
- ],
- plugins: [
- '@babel/transform-runtime'
- ]
- }
- }
- },
- {
- test: /\.css$/i,
- use: ['style-loader', 'css-loader']
- },
- {
- test: /\.s[ac]ss$/i,
- use: [
- MiniCssExtractPlugin.loader,
- {
- loader: 'css-loader',
- options: {
- sourceMap: true,
- url: false
- }
- },
- {
- // Needed to resolve image url()s within @primer/css
- loader: 'resolve-url-loader',
- options: {}
- },
- {
- loader: 'sass-loader',
- options: {
- sassOptions: {
- includePaths: ['./stylesheets', './node_modules'],
- options: {
- sourceMap: true,
- sourceMapContents: false
- }
- }
- }
- }
- ]
- }
- ]
- },
- plugins: [
- new MiniCssExtractPlugin({
- filename: 'index.css'
- }),
- new CopyWebpackPlugin({
- patterns: [
- { from: 'node_modules/@primer/css/fonts', to: 'fonts' }
- ]
- }),
- new EnvironmentPlugin(['NODE_ENV'])
- ]
- }
|