Files
speckle-server/packages/viewer/webpack.config.example.js
T
Dimitrie Stefanescu 87290b9008 feat(viewer): first (rather large) commit
scaffolds the base 3d viewer for speckle.
2021-01-11 15:11:51 +02:00

58 lines
1.4 KiB
JavaScript

/* global __dirname, require, module*/
const HtmlWebpackPlugin = require( 'html-webpack-plugin' )
const { CleanWebpackPlugin } = require( 'clean-webpack-plugin' )
const path = require( 'path' )
const yargs = require( 'yargs' )
const env = yargs.argv.env
let filename = 'demo'
let outputFile, mode
if ( env === 'build' ) {
mode = 'production'
outputFile = filename + '.min.js'
} else {
mode = 'development'
outputFile = filename + '.js'
}
const config = {
mode: mode,
entry: path.resolve( __dirname + '/src/app.js' ),
target: 'web',
devtool: 'source-map',
output: {
path: path.resolve( __dirname + '/example' ) ,
filename: outputFile,
},
module: {
rules: [
{
test: /(\.jsx|\.js|\.ts|\.tsx)$/,
use: {
loader: 'babel-loader',
},
exclude: /(node_modules|bower_components)/,
},
],
},
plugins: [
new CleanWebpackPlugin( { cleanStaleWebpackAssets: false } ),
new HtmlWebpackPlugin( { title: 'Speckle Viewer Example', template: 'src/assets/example.html', filename: 'example.html' } )
],
resolve: {
modules: [ path.resolve( './node_modules' ), path.resolve( './src' ) ],
extensions: [ '.json', '.js' ],
},
devServer: {
contentBase: path.join( __dirname, 'example' ),
compress: false,
port: 9000,
serveIndex: true,
writeToDisk: true
}
}
module.exports = config