From 80b0816718d0e14dde901c41d24086e615053389 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Sun, 3 Jun 2018 19:35:50 -0700 Subject: [PATCH] Better support for CSS and JS --- .babelrc | 3 +- app/Services/Helpers/AssetHashService.php | 29 +++++++++++++-- .../pterodactyl/templates/wrapper.blade.php | 4 +-- webpack.config.js | 36 ++++++++++--------- 4 files changed, 50 insertions(+), 22 deletions(-) diff --git a/.babelrc b/.babelrc index 8bafa56b4..e17a11004 100644 --- a/.babelrc +++ b/.babelrc @@ -1,6 +1,7 @@ { "presets": [ - "@babel/preset-env" + "@babel/preset-env", + "minify" ], "plugins": [ "@babel/plugin-proposal-object-rest-spread" diff --git a/app/Services/Helpers/AssetHashService.php b/app/Services/Helpers/AssetHashService.php index 3f721c409..89564ff78 100644 --- a/app/Services/Helpers/AssetHashService.php +++ b/app/Services/Helpers/AssetHashService.php @@ -58,8 +58,25 @@ class AssetHashService public function url(string $resource): string { $file = last(explode('/', $resource)); + $data = array_get($this->manifest(), $file, $file); - return '/' . ltrim(str_replace($file, array_get($this->manifest(), $file, $file), $resource), '/'); + return '/' . ltrim(str_replace($file, array_get($data, 'src', $file), $resource), '/'); + } + + /** + * Return the data integrity hash for a resource. + * + * @param string $resource + * @return string + * + * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException + */ + public function integrity(string $resource): string + { + $file = last(explode('/', $resource)); + $data = array_get($this->manifest(), $file, $file); + + return array_get($data, 'integrity', ''); } /** @@ -72,7 +89,11 @@ class AssetHashService */ public function css(string $resource): string { - return ''; + return ''; } /** @@ -85,7 +106,9 @@ class AssetHashService */ public function js(string $resource): string { - return ''; + return ''; } /** diff --git a/resources/themes/pterodactyl/templates/wrapper.blade.php b/resources/themes/pterodactyl/templates/wrapper.blade.php index 1a03ee2fa..9f8d8d50a 100644 --- a/resources/themes/pterodactyl/templates/wrapper.blade.php +++ b/resources/themes/pterodactyl/templates/wrapper.blade.php @@ -10,7 +10,7 @@ @show @section('assets') - {!! $asset->css('assets/bundle.css') !!} + {!! $asset->css('main.css') !!} @show @include('layouts.scripts') @@ -24,7 +24,7 @@ @yield('below-container') @show @section('scripts') - {!! $asset->js('assets/bundle.js') !!} + {!! $asset->js('main.js') !!} @show diff --git a/webpack.config.js b/webpack.config.js index 484e7cc83..2348f83b5 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -1,9 +1,9 @@ const path = require('path'); +const AssetsManifestPlugin = require('webpack-assets-manifest'); const CleanPlugin = require('clean-webpack-plugin'); const ExtractTextPlugin = require('extract-text-webpack-plugin'); -const ManifestPlugin = require('webpack-manifest-plugin'); const ShellPlugin = require('webpack-shell-plugin'); -const UglifyJsPLugin = require('uglifyjs-webpack-plugin'); +const MinifyPlugin = require('babel-minify-webpack-plugin'); module.exports = { mode: 'development', @@ -36,19 +36,22 @@ module.exports = { { test: /\.js$/, include: [ - path.resolve(__dirname, 'resources/assets/scripts'), + path.resolve(__dirname, 'resources'), ], loader: 'babel-loader', }, { test: /\.css$/, include: [ - path.resolve(__dirname, 'resources/assets/styles'), + path.resolve(__dirname, 'resources'), ], use: ExtractTextPlugin.extract({ fallback: 'style-loader', - use: ['css-loader', { - loader: 'postcss-loader', + use: [{ + loader: 'css-loader', + options: {importLoaders: 1}, + }, { + loader: 'postcss-loader', options: { ident: 'postcss', plugins: [ @@ -80,18 +83,19 @@ module.exports = { new ExtractTextPlugin('bundle-[chunkhash].css', { allChunks: true, }), - new UglifyJsPLugin({ + new MinifyPlugin({ + mangle: {topLevel: true}, + }, { include: [ - path.resolve(__dirname, 'resources/assets/scripts'), + path.resolve(__dirname, 'resources'), + path.resolve(__dirname, 'node_modules'), ], - parallel: 2, - sourceMap: false, - uglifyOptions: { - ecma: 5, - toplevel: true, - safari10: true, - } }), - new ManifestPlugin(), + new AssetsManifestPlugin({ + writeToDisk: true, + publicPath: true, + integrity: true, + integrityHashes: ['sha384'], + }), ] };