1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- /*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You 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 webpack = require('webpack')
- const merge = require('webpack-merge')
- const { assetsDir, baseConfig } = require('./config')
- const MiniCssExtractPlugin = require('mini-css-extract-plugin')
- const ProgressPlugin = require('progress-bar-webpack-plugin')
- const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
- const portfinder = require('portfinder')
- const getEnv = require('env-parse').getEnv
- const config = merge.smart(baseConfig, {
- devtool: 'eval-source-map',
- output: {
- filename: 'js/[name].js'
- },
- devServer: {
- hot: true,
- contentBase: assetsDir,
- publicPath: baseConfig.output.publicPath,
- host: getEnv('DEV_HOST', 'localhost'),
- port: getEnv('DEV_PORT', 8888),
- noInfo: false,
- overlay: { warnings: false, errors: true },
- historyApiFallback: true,
- disableHostCheck: true,
- proxy: {
- '/dolphinscheduler': {
- timeout: 1800000,
- target: getEnv('API_BASE', 'http://local.dev:8080/backend'),
- changeOrigin: true
- }
- },
- progress: true,
- quiet: true,
- stats: {
- colors: true
- },
- clientLogLevel: 'warning'
- },
- plugins: [
- new ProgressPlugin(),
- new webpack.HotModuleReplacementPlugin(),
- new MiniCssExtractPlugin({ filename: 'css/[name].css' })
- ],
- mode: 'development'
- })
- module.exports = new Promise((resolve, reject) => {
- portfinder.basePort = process.env.PORT || config.devServer.port
- portfinder.getPort((err, port) => {
- if (err) {
- reject(err)
- } else {
- // publish the new Port, necessary for e2e tests
- process.env.PORT = port
- // add port to devServer config
- config.devServer.port = port
- // Add FriendlyErrorsPlugin
- config.plugins.push(new FriendlyErrorsPlugin({
- compilationSuccessInfo: {
- messages: [`Your application is running here: http://${config.devServer.host}:${port}`],
- },
- onErrors: () => {
- const notifier = require('node-notifier')
- return (severity, errors) => {
- if (severity !== 'error') return
- const error = errors[0]
- const filename = error.file && error.file.split('!').pop()
- notifier.notify({
- title: packageConfig.name,
- message: severity + ': ' + error.name,
- subtitle: filename || ''
- })
- }
- }
- }))
- resolve(config)
- }
- })
- })
|