Skip to content
Snippets Groups Projects
Select Git revision
  • be94e0fe09936b76c3000a3def87eaac0bd13bf6
  • master default protected
  • devel
  • hruska-feature-clients-api
  • malostik-#5066-deduplicate-idea-ids
  • warden-postgresql-port
  • hruska-feature-#6799-filter-keys
  • hruska-feature-5066-duplicateIdeaID
  • warden-client-3.0-beta3
  • warden-server-3.0-beta3
  • warden-client-2.2-final
  • warden-server-2.2-final
  • warden-client-3.0-beta2
  • warden-server-3.0-beta2
  • warden-client-2.2
  • warden-server-2.2-patch3
  • warden-client-3.0-beta1
  • warden-server-3.0-beta1
  • warden-server-2.2-patch1
  • warden-client-3.0-beta0
  • warden-server-3.0-beta0
  • warden-server-2.2
  • warden-server-2.1-patch1
  • warden-client-2.1
  • warden-server-2.1
  • warden-server-2.1-beta6
  • warden-server-2.1-beta5
  • warden-server-2.1-beta4
28 results

getWebStatus.sh

Blame
  • webpack.config.js 3.57 KiB
    const path = require('path');
    const webpack = require('webpack');
    const ExtraWatchWebpackPlugin = require('extra-watch-webpack-plugin');
    const MiniCssExtractPlugin = require('mini-css-extract-plugin');
    // const CircularDependencyPlugin = require('circular-dependency-plugin');
    
    const sharedConfig = {
        module: {
            rules: [
                {
                    loader: 'file-loader',
                    test: /\.(woff2?|ttf|otf|eot|svg|html)$/,
                    include: [path.resolve(__dirname, 'lib/')],
                    options: {
                        name: '[name].[ext]'
                    }
                },
                {
                    test: /\.(s*)css$/,
                    use: [MiniCssExtractPlugin.loader, 'css-loader', 'resolve-url-loader', 'sass-loader']
                }
            ]
        },
        plugins: [
            // new CircularDependencyPlugin({
            //     include: [ path.resolve(__dirname, 'lib/') ],
            //     failOnError: false,
            //     cwd: process.cwd(),
            // }),
            new ExtraWatchWebpackPlugin({
                files: [
                    './lib/**/*.scss',
                    './lib/**/*.html'
                ],
            }),
            new webpack.DefinePlugin({
                __PLUGIN_VERSION_TIMESTAMP__: webpack.DefinePlugin.runtimeValue(() => `${new Date().valueOf()}`, true),
                'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV),
                'process.env.DEBUG': JSON.stringify(process.env.DEBUG)
            }),
            new MiniCssExtractPlugin({ filename: 'app.css' })
        ],
        resolve: {
            modules: [
                'node_modules',
                path.resolve(__dirname, 'lib/')
            ],
        }
    }
    
    
    function createEntry(src, outFolder, outFilename, isNode) {
        return {
            node: isNode ? void 0 : { fs: 'empty' }, // TODO find better solution? Currently used in file-handle.ts
            target: isNode ? 'node' : void 0,
            entry: path.resolve(__dirname, `lib/${src}.js`),
            output: { filename: `${outFilename}.js`, path: path.resolve(__dirname, `build/${outFolder}`) },
            ...sharedConfig
        }
    }
    
    function createEntryPoint(name, dir, out) {
        return {
            node: { fs: 'empty' }, // TODO find better solution? Currently used in file-handle.ts
            entry: path.resolve(__dirname, `lib/${dir}/${name}.js`),
            output: { filename: `${name}.js`, path: path.resolve(__dirname, `build/${out}`) },
            ...sharedConfig
        }
    }