const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const StyleLintPlugin = require('stylelint-webpack-plugin')
const webpack = require('webpack');
const path = require('path');
const dirTree = require('directory-tree');
const jsonminify = require("jsonminify");
const PUBLIC_RESOURCE_PATH = '/';
var langs = [];
dirTree('./src/app/locale/', {extensions:/\.json$/}, (item) => {
langs.push(item.name.slice(item.name.lastIndexOf('-') + 1, -5));
});
module.exports = {
devtool: 'source-map',
entry: [
'./src/app/app.js',
'webpack-hot-middleware/client?reload=true',
'webpack-material-design-icons'
],
output: {
path: path.resolve(__dirname, 'target/generated-resources/public/static'),
publicPath: PUBLIC_RESOURCE_PATH,
filename: 'bundle.js',
},
plugins: [
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
"window.jQuery": "jquery",
tinycolor: "tinycolor2",
tv4: "tv4",
moment: "moment"
}),
new CopyWebpackPlugin([
{
from: './src/thingsboard.ico',
to: 'thingsboard.ico'
},
{
from: './src/app/locale',
to: 'locale',
ignore: [ '*.js' ],
transform: function(content, path) {
return Buffer.from(jsonminify(content.toString()));
}
}
]),
new webpack.HotModuleReplacementPlugin(),
new HtmlWebpackPlugin({
template: './src/index.html',
filename: 'index.html',
title: 'ThingsBoard',
inject: 'body',
}),
new StyleLintPlugin(),
new webpack.optimize.OccurrenceOrderPlugin(),
new webpack.NoErrorsPlugin(),
new ExtractTextPlugin('style.[contentHash].css', {
allChunks: true,
}),
new webpack.DefinePlugin({
THINGSBOARD_VERSION: JSON.stringify(require('./package.json').version),
'__DEVTOOLS__': false,
'process.env': {
NODE_ENV: JSON.stringify('development'),
},
PUBLIC_PATH: JSON.stringify(PUBLIC_RESOURCE_PATH),
SUPPORTED_LANGS: JSON.stringify(langs)
}),
],
node: {
tls: "empty",
fs: "empty"
},
module: {
loaders: [
{
test: /\.jsx$/,
loader: 'babel',
exclude: /node_modules/,
include: __dirname,
},
{
test: /\.js$/,
loaders: ['ng-annotate', 'babel'],
exclude: /node_modules/,
include: __dirname,
},
{
test: /\.js$/,
loader: "eslint-loader?{parser: 'babel-eslint'}",
exclude: /node_modules|vendor/,
include: __dirname,
},
{
test: /\.css$/,
loader: ExtractTextPlugin.extract('style-loader', 'css-loader'),
},
{
test: /\.scss$/,
loader: ExtractTextPlugin.extract('style-loader', 'css-loader!postcss-loader!sass-loader'),
},
{
test: /\.less$/,
loader: ExtractTextPlugin.extract('style-loader', 'css-loader!postcss-loader!less-loader'),
},
{
test: /\.tpl\.html$/,
loader: 'ngtemplate?relativeTo=' + (path.resolve(__dirname, './src/app')) + '/!html!html-minifier-loader'
},
{
test: /\.(svg)(\?v=[0-9]+\.[0-9]+\.[0-9]+)?$/,
loader: 'url?limit=8192'
},
{
test: /\.(png|jpe?g|gif|woff|woff2|ttf|otf|eot|ico)(\?v=[0-9]+\.[0-9]+\.[0-9]+)?$/,
loaders: [
'url?limit=8192',
'img?minimize'
]
}
],
},
'html-minifier-loader': {
caseSensitive: true,
removeComments: true,
collapseWhitespace: false,
preventAttributesEscaping: true,
removeEmptyAttributes: false
}
};