-
Notifications
You must be signed in to change notification settings - Fork 6
/
webpack.dev.js
117 lines (109 loc) · 2.76 KB
/
webpack.dev.js
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
const path = require("path");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const postcssPresetEnv = require("postcss-preset-env");
const FaviconsWebpackPlugin = require("favicons-webpack-plugin");
const API_URL = process.env.API_URL || "127.0.0.1:8080";
const ELM_DEBUG = process.env.ELM_DEBUG || false;
const UI_CORE_SRC = "elm-stuff/gitdeps/github.com/unisonweb/ui-core/src";
module.exports = {
entry: "./src/unisonLocal.js",
resolve: {
alias: {
assets: path.resolve(__dirname, "src/assets/"),
"ui-core": path.resolve(__dirname, UI_CORE_SRC + "/"),
},
},
module: {
rules: [
{
test: /\.css$/i,
use: [
"style-loader",
{
loader: "css-loader",
options: { importLoaders: 1 },
},
{
loader: "postcss-loader",
options: {
postcssOptions: {
plugins: [
postcssPresetEnv({
features: {
"is-pseudo-class": false,
"custom-media-queries": {
importFrom: `${UI_CORE_SRC}/css/ui/viewport.css`,
},
},
}),
],
},
},
},
],
},
{
test: /\.(png|svg|jpg|jpeg|gif)$/i,
type: "asset/resource",
},
{
test: /\.(woff(2)?|ttf|eot)$/i,
type: "asset/resource",
},
{
test: /\.elm$/,
exclude: [/elm-stuff/, /node_modules/],
use: [
{
loader: "elm-asset-webpack-loader",
},
{
loader: "elm-webpack-loader",
options: {
debug: ELM_DEBUG,
cwd: __dirname,
},
},
],
},
],
},
plugins: [
new HtmlWebpackPlugin({
template: "./src/unisonLocal.ejs",
inject: "body",
publicPath: "/",
base: "/",
filename: path.resolve(__dirname, "dist/dev/index.html"),
}),
new FaviconsWebpackPlugin({
logo: "./src/assets/dev-favicon.svg",
inject: true,
favicons: {
appName: "Unison Local",
appDescription: "Explore, read docs about, and share Unison libraries",
developerName: "Unison",
developerURL: "https://unison-lang.org",
background: "#FF9BA3",
theme_color: "#FF9BA3",
},
}),
],
output: {
filename: "[name].[contenthash].js",
path: path.resolve(__dirname, "dist/dev"),
clean: true,
},
devServer: {
historyApiFallback: {
disableDotRule: true,
},
proxy: {
"/api": {
target: API_URL,
pathRewrite: { "^/api": "" },
logLevel: "debug",
},
},
},
};