skyline-console/config/webpack.dev.js
zhangjingwei e018659955 feat: support a custom UI theme
support a custom UI theme

Change-Id: Ic2f25fcc4620b06710c3ff1f26f84aba43881762
2024-01-03 11:45:28 +08:00

187 lines
4.9 KiB
JavaScript

// Copyright 2021 99cloud
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
const { resolve } = require('path');
const autoprefixer = require('autoprefixer');
const webpack = require('webpack');
const merge = require('webpack-merge');
const HtmlWebPackPlugin = require('html-webpack-plugin');
const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin');
const common = require('./webpack.common');
const server = require('./server.dev');
const { getThemeConfig, getCustomStyleVariables } = require('./utils');
const theme = getThemeConfig();
console.log('theme', theme);
const root = (path) => resolve(__dirname, `../${path}`);
const { host, port, proxy } = server;
module.exports = (env) => {
const API = (env || {}).API || 'mock';
console.log('API %s', API);
const devServer = {
host,
port,
contentBase: root('dist'),
historyApiFallback: true,
compress: true,
hot: true,
inline: true,
disableHostCheck: true,
progress: true,
// WARNING: disable the following attribute when debug webpack.
stats: {
children: false,
chunks: false,
chunkModules: false,
modules: false,
reasons: false,
useExports: false,
},
};
if (API === 'mock' || API === 'dev') {
devServer.proxy = proxy;
}
const { version, ...restConfig } = common;
return merge(restConfig, {
entry: {
main: root('src/core/index.jsx'),
},
output: {
filename: '[name].js',
path: root('dist'),
publicPath: '/',
},
mode: 'development',
devtool: 'cheap-module-eval-source-map',
devServer,
module: {
rules: [
// `react-refresh` only works in develop mode
{
test: /\.jsx?$/,
exclude: /node_modules/,
use: [
'thread-loader',
{
loader: 'babel-loader',
options: {
plugins: ['react-refresh/babel'],
},
},
],
},
{
test: /\.css$/,
use: [
{
loader: 'style-loader',
},
'thread-loader',
{
loader: 'css-loader',
},
],
},
{
test: /\.(css|less)$/,
exclude: /node_modules/,
use: [
{
loader: 'style-loader', // creates style nodes from JS strings
},
{
loader: 'css-loader', // translates CSS into CommonJS
options: {
modules: {
mode: 'global',
},
localIdentName: '[name]__[local]--[hash:base64:5]',
},
},
{
loader: 'postcss-loader',
options: {
plugins: [autoprefixer('last 2 version')],
sourceMap: true,
},
},
{
loader: 'less-loader', // compiles Less to CSS
options: {
importLoaders: true,
javascriptEnabled: true,
},
},
{
loader: resolve('config/less-replace-loader'),
options: {
variableFile: getCustomStyleVariables(),
},
},
],
},
{
test: /\.(less)$/,
include: /node_modules/,
use: [
{
loader: 'style-loader', // creates style nodes from JS strings
},
'thread-loader',
{
loader: 'css-loader', // translates CSS into CommonJS
},
{
loader: 'less-loader', // compiles Less to CSS
options: {
javascriptEnabled: true,
modifyVars: theme,
},
},
],
},
],
},
plugins: [
// new webpack.HotModuleReplacementPlugin(), `hmr` is outdated, now using `react-refresh`
new ReactRefreshWebpackPlugin({ overlay: false }),
// new OpenBrowserPlugin({
// url: 'http://localhost:8080',
// browser: "Google Chrome",
// }),
new webpack.DefinePlugin({
// Inject environment variables for the project
'process.env.API': JSON.stringify(API),
}),
new HtmlWebPackPlugin({
template: root('src/asset/template/index.html'),
favicon: root('src/asset/image/favicon.ico'),
}),
],
});
};