siyuan/app/webpack.desktop.js

148 lines
3.8 KiB
JavaScript

const path = require('path')
const webpack = require('webpack')
const pkg = require('./package.json')
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const {CleanWebpackPlugin} = require('clean-webpack-plugin')
const BundleAnalyzerPlugin = require(
'webpack-bundle-analyzer').BundleAnalyzerPlugin
const TerserPlugin = require('terser-webpack-plugin')
module.exports = (env, argv) => {
return {
mode: argv.mode || 'development',
watch: argv.mode !== 'production',
devtool: argv.mode !== 'production' ? 'eval' : false,
output: {
publicPath: '',
filename: '[name].[chunkhash].js',
path: path.resolve(__dirname, 'stage/build/desktop'),
},
entry: {
'main': './src/index.ts',
},
optimization: {
minimize: true,
minimizer: [
new TerserPlugin({
terserOptions: {
format: {
comments: false,
},
},
extractComments: false,
}),
],
},
resolve: {
fallback: {
'path': require.resolve('path-browserify'),
},
extensions: ['.ts', '.js', '.tpl', '.scss'],
},
module: {
rules: [
{
test: /\.tpl/,
include: [
path.resolve(__dirname, 'src/assets/template/desktop/index.tpl')],
loader: 'html-loader',
options: {
sources: false,
},
},
{
test: /\.js$/,
include: [path.resolve(__dirname, 'src/asset/pdf')],
use: {
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env'],
plugins: [
[
'@babel/plugin-transform-runtime',
{
helpers: false,
regenerator: true,
},
],
],
},
},
},
{
test: /\.ts(x?)$/,
include: [path.resolve(__dirname, 'src')],
use: [
{
loader: 'ts-loader',
},
{
loader: 'ifdef-loader',
options: {
'ifdef-verbose': false,
BROWSER: true,
MOBILE: false,
},
},
],
},
{
test: /\.scss$/,
include: [
path.resolve(__dirname, 'src/assets/scss'),
],
use: [
MiniCssExtractPlugin.loader,
{
loader: 'css-loader', // translates CSS into CommonJS
},
{
loader: 'sass-loader', // compiles Sass to CSS
},
],
},
{
test: /\.woff$/,
type: 'asset/resource',
generator: {
filename: '../fonts/JetBrainsMono-Regular.woff',
},
},
{
test: /\.(png|svg)$/,
use: [
{
loader: 'file-loader',
options: {
name: '[name].[ext]',
outputPath: '../../',
},
},
],
},
],
},
plugins: [
// new BundleAnalyzerPlugin(),
new CleanWebpackPlugin({
cleanStaleWebpackAssets: false,
cleanOnceBeforeBuildPatterns: [
path.join(__dirname, 'stage/build/desktop')],
}),
new webpack.DefinePlugin({
SIYUAN_VERSION: JSON.stringify(pkg.version),
NODE_ENV: JSON.stringify(argv.mode),
}),
new MiniCssExtractPlugin({
filename: 'base.[contenthash].css',
}),
new HtmlWebpackPlugin({
inject: 'head',
chunks: ['main'],
filename: 'index.html',
template: 'src/assets/template/desktop/index.tpl',
}),
],
}
}