Newer
Older
const path = require('path');
const ExtraWatchWebpackPlugin = require('extra-watch-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
// const CircularDependencyPlugin = require('circular-dependency-plugin');
module: {
rules: [
{
loader: 'raw-loader',
test: /\.(glsl|frag|vert)$/,
},
{
loader: 'glslify-loader',
test: /\.(glsl|frag|vert)$/,
},
{
loader: 'file-loader',
test: /\.(woff2?|ttf|otf|eot|svg|html)$/,
options: {
name: '[name].[ext]'
}
},
{
test:/\.(s*)css$/,
Alexander Rose
committed
use: [ MiniCssExtractPlugin.loader, 'css-loader', 'resolve-url-loader', 'sass-loader' ]
// new CircularDependencyPlugin({
// include: [ path.resolve(__dirname, 'build/src/') ],
// failOnError: false,
// cwd: process.cwd(),
// }),
'./build/src/**/*.vert',
'./build/src/**/*.frag',
'./build/src/**/*.glsl',
'./build/src/**/*.scss',
'./build/src/**/*.html'
new MiniCssExtractPlugin({ filename: 'app.css' })
],
resolve: {
modules: [
'node_modules',
path.resolve(__dirname, 'build/src/')
],
}
}
function createEntryPoint(name, dir, out) {
return {
entry: path.resolve(__dirname, `build/src/${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') }
module.exports = [
createApp('viewer'),
createApp('model-server-query'),
createBrowserTest('render-text'),
createBrowserTest('render-spheres'),
createBrowserTest('render-mesh')
]