Skip to content
Snippets Groups Projects
Select Git revision
  • a3ebc4df45cfbd39e0f124004297c9931df01966
  • master default protected
  • rednatco-v2
  • rednatco
  • test
  • ntc-tube-uniform-color
  • ntc-tube-missing-atoms
  • restore-vertex-array-per-program
  • watlas2
  • dnatco_new
  • cleanup-old-nodejs
  • webmmb
  • fix_auth_seq_id
  • update_deps
  • ext_dev
  • ntc_balls
  • nci-2
  • plugin
  • bugfix-0.4.5
  • nci
  • servers
  • v0.5.0-dev.1
  • v0.4.5
  • v0.4.4
  • v0.4.3
  • v0.4.2
  • v0.4.1
  • v0.4.0
  • v0.3.12
  • v0.3.11
  • v0.3.10
  • v0.3.9
  • v0.3.8
  • v0.3.7
  • v0.3.6
  • v0.3.5
  • v0.3.4
  • v0.3.3
  • v0.3.2
  • v0.3.1
  • v0.3.0
41 results

controls.tsx

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
        }
    }
    
    function createNodeEntryPoint(name, dir, out) {
        return {
            target: 'node',
            entry: path.resolve(__dirname, `lib/${dir}/${name}.js`),
            output: { filename: `${name}.js`, path: path.resolve(__dirname, `build/${out}`) },
            ...sharedConfig
        }
    }
    
    function createApp(name) { return createEntryPoint('index', `apps/${name}`, name) }
    function createBrowserTest(name) { return createEntryPoint(name, 'tests/browser', 'tests') }
    function createNodeApp(name) { return createNodeEntryPoint('index', `apps/${name}`, name) }
    
    module.exports = [
        createApp('viewer'),
        createApp('basic-wrapper'),
        createEntry('examples/proteopedia-wrapper/index', 'examples/proteopedia-wrapper', 'index'),
        createNodeApp('state-docs'),
        createNodeEntryPoint('preprocess', 'servers/model', 'model-server'),
        createApp('model-server-query'),
    
        createBrowserTest('font-atlas'),
        createBrowserTest('render-asa'),
        createBrowserTest('marching-cubes'),
        createBrowserTest('render-lines'),
        createBrowserTest('render-mesh'),
        createBrowserTest('render-shape'),
        createBrowserTest('render-spheres'),
        createBrowserTest('render-structure'),
        createBrowserTest('render-text'),
        createBrowserTest('encoding-config')
    ]