webpack.dev.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. 'use strict';
  2. const merge = require('webpack-merge');
  3. const common = require('./webpack.common.js');
  4. const path = require('path');
  5. const webpack = require('webpack');
  6. const HtmlWebpackPlugin = require("html-webpack-plugin");
  7. const ExtractTextPlugin = require("extract-text-webpack-plugin");
  8. const WebpackCleanupPlugin = require('webpack-cleanup-plugin');
  9. const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
  10. const pkg = require('../../package.json');
  11. const _ = require('lodash');
  12. let dependencies = Object.keys(pkg.dependencies);
  13. // remove jquery
  14. dependencies = _.filter(dependencies, function(key) {
  15. return key !== 'jquery';
  16. });
  17. // add it first
  18. dependencies.unshift('jquery');
  19. module.exports = merge(common, {
  20. devtool: "source-map",
  21. entry: {
  22. dark: './public/sass/grafana.dark.scss',
  23. light: './public/sass/grafana.light.scss',
  24. vendor: dependencies,
  25. },
  26. module: {
  27. rules: [
  28. require('./sass.rule.js')({
  29. sourceMap: true, minimize: false
  30. })
  31. ]
  32. },
  33. plugins: [
  34. new ExtractTextPlugin({ // define where to save the file
  35. filename: 'grafana.[name].css',
  36. }),
  37. new HtmlWebpackPlugin({
  38. filename: path.resolve(__dirname, '../../public/views/index.html'),
  39. template: path.resolve(__dirname, '../../public/views/index.template.html'),
  40. inject: 'body',
  41. chunks: ['manifest', 'vendor', 'app'],
  42. }),
  43. new webpack.DefinePlugin({
  44. 'process.env': {
  45. 'NODE_ENV': JSON.stringify('development')
  46. }
  47. }),
  48. new webpack.optimize.CommonsChunkPlugin({
  49. names: ['vendor', 'manifest'],
  50. }),
  51. new WebpackCleanupPlugin(),
  52. // new BundleAnalyzerPlugin({
  53. // analyzerPort: 8889
  54. // })
  55. ]
  56. });