3a6ac4e5ec
We need to remove the metadata without breaking the animation. For that we use sharp which incooperates libvips (binaries for most common distros included). This also decreases client side upload complexity as we remove the metadata on the serverside. Sharp: https://sharp.pixelplumbing.com/ libvips: https://libvips.github.io/libvips/
148 lines
2.9 KiB
JavaScript
148 lines
2.9 KiB
JavaScript
"use strict";
|
|
|
|
const webpack = require("webpack");
|
|
const path = require("path");
|
|
const CopyPlugin = require("copy-webpack-plugin");
|
|
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
|
|
const VueLoaderPlugin = require("vue-loader/lib/plugin");
|
|
const Helper = require("./src/helper.js");
|
|
|
|
const isProduction = process.env.NODE_ENV === "production";
|
|
const config = {
|
|
mode: isProduction ? "production" : "development",
|
|
entry: {
|
|
"js/bundle.js": [path.resolve(__dirname, "client/js/vue.js")],
|
|
},
|
|
devtool: "source-map",
|
|
output: {
|
|
path: path.resolve(__dirname, "public"),
|
|
filename: "[name]",
|
|
publicPath: "/",
|
|
},
|
|
performance: {
|
|
hints: false,
|
|
},
|
|
module: {
|
|
rules: [
|
|
{
|
|
test: /\.vue$/,
|
|
use: {
|
|
loader: "vue-loader",
|
|
options: {
|
|
compilerOptions: {
|
|
preserveWhitespace: false,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
test: /\.css$/,
|
|
use: [
|
|
{
|
|
loader: MiniCssExtractPlugin.loader,
|
|
options: {
|
|
esModule: false,
|
|
},
|
|
},
|
|
{
|
|
loader: "css-loader",
|
|
options: {
|
|
url: false,
|
|
importLoaders: 1,
|
|
sourceMap: true,
|
|
},
|
|
},
|
|
{
|
|
loader: "postcss-loader",
|
|
options: {
|
|
sourceMap: true,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
test: /\.js$/,
|
|
include: [path.resolve(__dirname, "client")],
|
|
use: {
|
|
loader: "babel-loader",
|
|
options: {
|
|
presets: [["@babel/env"]],
|
|
},
|
|
},
|
|
},
|
|
],
|
|
},
|
|
optimization: {
|
|
splitChunks: {
|
|
cacheGroups: {
|
|
commons: {
|
|
test: /[\\/]node_modules[\\/]/,
|
|
name: "js/bundle.vendor.js",
|
|
chunks: "all",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
externals: {
|
|
json3: "JSON", // socket.io uses json3.js, but we do not target any browsers that need it
|
|
sharp: "commonjs sharp",
|
|
},
|
|
plugins: [
|
|
new VueLoaderPlugin(),
|
|
new MiniCssExtractPlugin({
|
|
filename: "css/style.css",
|
|
}),
|
|
new CopyPlugin({
|
|
patterns: [
|
|
{
|
|
from:
|
|
"./node_modules/@fortawesome/fontawesome-free/webfonts/fa-solid-900.woff*",
|
|
to: "fonts/[name].[ext]",
|
|
},
|
|
{
|
|
from: "./client/js/loading-error-handlers.js",
|
|
to: "js/[name].[ext]",
|
|
},
|
|
{
|
|
from: "./client/*",
|
|
to: "[name].[ext]",
|
|
globOptions: {
|
|
ignore: ["**/index.html.tpl", "**/service-worker.js"],
|
|
},
|
|
},
|
|
{
|
|
from: "./client/service-worker.js",
|
|
to: "[name].[ext]",
|
|
transform(content) {
|
|
return content
|
|
.toString()
|
|
.replace(
|
|
"__HASH__",
|
|
isProduction ? Helper.getVersionCacheBust() : "dev"
|
|
);
|
|
},
|
|
},
|
|
{
|
|
from: "./client/audio/*",
|
|
to: "audio/[name].[ext]",
|
|
},
|
|
{
|
|
from: "./client/img/*",
|
|
to: "img/[name].[ext]",
|
|
},
|
|
{
|
|
from: "./client/themes/*",
|
|
to: "themes/[name].[ext]",
|
|
},
|
|
],
|
|
}),
|
|
// socket.io uses debug, we don't need it
|
|
new webpack.NormalModuleReplacementPlugin(
|
|
/debug/,
|
|
path.resolve(__dirname, "scripts/noop.js")
|
|
),
|
|
],
|
|
};
|
|
|
|
module.exports = config;
|