mirror of https://github.com/Chocobozzz/PeerTube
				
				
				
			
		
			
				
	
	
		
			186 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
| const helpers = require('./helpers')
 | |
| const path = require('path')
 | |
| 
 | |
| const CheckerPlugin = require('awesome-typescript-loader').CheckerPlugin
 | |
| const HtmlWebpackPlugin = require('html-webpack-plugin')
 | |
| const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
 | |
| const HashedModuleIdsPlugin = require('webpack/lib/HashedModuleIdsPlugin')
 | |
| const LoaderOptionsPlugin = require('webpack/lib/LoaderOptionsPlugin')
 | |
| const ExtractTextPlugin = require('extract-text-webpack-plugin')
 | |
| const PurifyCSSPlugin = require('purifycss-webpack')
 | |
| 
 | |
| module.exports = function () {
 | |
|   const isProd = process.env.NODE_ENV === 'production'
 | |
| 
 | |
|   const configuration = {
 | |
|     entry: {
 | |
|       'video-embed': './src/standalone/videos/embed.ts'
 | |
|     },
 | |
| 
 | |
|     resolve: {
 | |
|       /*
 | |
|        * An array of extensions that should be used to resolve modules.
 | |
|        *
 | |
|        * See: http://webpack.github.io/docs/configuration.html#resolve-extensions
 | |
|        */
 | |
|       extensions: [ '.ts', '.js', '.json', '.scss' ],
 | |
| 
 | |
|       modules: [ helpers.root('src'), helpers.root('node_modules') ],
 | |
| 
 | |
|       alias: {
 | |
|         'video.js$': path.resolve('node_modules/video.js/dist/alt/video.core.js')
 | |
|       }
 | |
|     },
 | |
| 
 | |
|     output: {
 | |
|       path: helpers.root('dist/standalone/videos'),
 | |
|       filename: '[name].[hash].bundle.js',
 | |
|       sourceMapFilename: '[file].map',
 | |
|       chunkFilename: '[id].chunk.js',
 | |
|       publicPath: '/client/standalone/videos/'
 | |
|     },
 | |
| 
 | |
|     // devtool: 'source-map',
 | |
| 
 | |
|     module: {
 | |
| 
 | |
|       rules: [
 | |
|         {
 | |
|           test: /\.ts$/,
 | |
|           use: [
 | |
|             {
 | |
|               loader: 'awesome-typescript-loader',
 | |
|               options: {
 | |
|                 configFileName: 'tsconfig.json'
 | |
|               }
 | |
|             }
 | |
|           ],
 | |
|           exclude: [/\.(spec|e2e)\.ts$/]
 | |
|         },
 | |
| 
 | |
|         {
 | |
|           test: /\.(sass|scss)$/,
 | |
|           use: ExtractTextPlugin.extract({
 | |
|             fallback: 'style-loader',
 | |
|             use: [
 | |
|               {
 | |
|                 loader: 'css-loader',
 | |
|                 options: {
 | |
|                   sourceMap: true,
 | |
|                   importLoaders: 1
 | |
|                 }
 | |
|               },
 | |
|               'resolve-url-loader',
 | |
|               {
 | |
|                 loader: 'sass-loader',
 | |
|                 options: {
 | |
|                   sourceMap: true,
 | |
|                   includePaths: [
 | |
|                     helpers.root('src/sass/include')
 | |
|                   ]
 | |
|                 }
 | |
|               }
 | |
|             ]
 | |
|           })
 | |
|         },
 | |
| 
 | |
|         {
 | |
|           test: /\.html$/,
 | |
|           use: 'raw-loader',
 | |
|           exclude: [
 | |
|             helpers.root('src/index.html'),
 | |
|             helpers.root('src/standalone/videos/embed.html')
 | |
|           ]
 | |
|         },
 | |
| 
 | |
|         {
 | |
|           test: /\.(jpg|png|gif)$/,
 | |
|           use: 'url-loader'
 | |
|         },
 | |
| 
 | |
|         { test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/, use: 'url-loader?limit=10000&minetype=application/font-woff' },
 | |
|         { test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/, use: 'file-loader' }
 | |
|       ]
 | |
| 
 | |
|     },
 | |
| 
 | |
|     plugins: [
 | |
|       new ExtractTextPlugin({
 | |
|         filename: '[name].[hash].css'
 | |
|       }),
 | |
| 
 | |
|       new PurifyCSSPlugin({
 | |
|         paths: [ helpers.root('src/standalone/videos/embed.ts') ],
 | |
|         purifyOptions: {
 | |
|           minify: true,
 | |
|           whitelist: [ '*vjs*', '*video-js*' ]
 | |
|         }
 | |
|       }),
 | |
| 
 | |
|       new CheckerPlugin(),
 | |
| 
 | |
|       new HtmlWebpackPlugin({
 | |
|         template: 'src/standalone/videos/embed.html',
 | |
|         filename: 'embed.html',
 | |
|         title: 'PeerTube',
 | |
|         chunksSortMode: 'dependency',
 | |
|         inject: 'body'
 | |
|       }),
 | |
| 
 | |
|       /**
 | |
|        * Plugin LoaderOptionsPlugin (experimental)
 | |
|        *
 | |
|        * See: https://gist.github.com/sokra/27b24881210b56bbaff7
 | |
|        */
 | |
|       new LoaderOptionsPlugin({
 | |
|         options: {
 | |
|           context: __dirname,
 | |
|           output: {
 | |
|             path: helpers.root('dist')
 | |
|           }
 | |
|         }
 | |
|       })
 | |
|     ],
 | |
| 
 | |
|     performance: {
 | |
|       maxEntrypointSize: 700000, // 600kB
 | |
|       maxAssetSize: 700000
 | |
|     },
 | |
| 
 | |
|     node: {
 | |
|       global: true,
 | |
|       crypto: 'empty',
 | |
|       fs: 'empty',
 | |
|       process: true,
 | |
|       module: false,
 | |
|       clearImmediate: false,
 | |
|       setImmediate: false
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   if (isProd) {
 | |
|     configuration.plugins.push(
 | |
|       new UglifyJsPlugin({
 | |
|         uglifyOptions: {
 | |
|           ecma: 6,
 | |
|           warnings: false,
 | |
|           ie8: false,
 | |
|           mangle: true,
 | |
|           compress: {
 | |
|             passes: 3,
 | |
|             pure_getters: true
 | |
|           },
 | |
|           output: {
 | |
|             ascii_only: true,
 | |
|             comments: false
 | |
|           }
 | |
|         }
 | |
|       }),
 | |
| 
 | |
|       new HashedModuleIdsPlugin()
 | |
|     )
 | |
|   }
 | |
| 
 | |
|   return configuration
 | |
| }
 |