mirror of
https://github.com/qier222/YesPlayMusic.git
synced 2025-01-23 20:23:17 +08:00
130 lines
3.6 KiB
JavaScript
130 lines
3.6 KiB
JavaScript
const path = require("path");
|
||
const CopyPlugin = require('copy-webpack-plugin')
|
||
function resolve(dir) {
|
||
return path.join(__dirname, dir);
|
||
}
|
||
|
||
module.exports = {
|
||
devServer: {
|
||
disableHostCheck: true,
|
||
port: process.env.DEV_SERVER_PORT || 8080
|
||
},
|
||
pwa: {
|
||
name: "YesPlayMusic",
|
||
iconPaths: {
|
||
favicon32: "img/icons/favicon-32x32.png",
|
||
},
|
||
themeColor: "#ffffff00",
|
||
manifestOptions: {
|
||
background_color: "#335eea",
|
||
},
|
||
// workboxOptions: {
|
||
// swSrc: "dev/sw.js",
|
||
// },
|
||
},
|
||
pages: {
|
||
index: {
|
||
entry: "src/main.js",
|
||
template: "public/index.html",
|
||
filename: "index.html",
|
||
title: "YesPlayMusic",
|
||
chunks: ["main", "chunk-vendors", "chunk-common", "index"],
|
||
},
|
||
},
|
||
chainWebpack(config) {
|
||
config.module.rules.delete("svg");
|
||
config.module.rule("svg").exclude.add(resolve("src/assets/icons")).end();
|
||
config.module
|
||
.rule("icons")
|
||
.test(/\.svg$/)
|
||
.include.add(resolve("src/assets/icons"))
|
||
.end()
|
||
.use("svg-sprite-loader")
|
||
.loader("svg-sprite-loader")
|
||
.options({
|
||
symbolId: "icon-[name]",
|
||
})
|
||
.end();
|
||
},
|
||
// 添加插件的配置
|
||
pluginOptions: {
|
||
// electron-builder的配置文件
|
||
electronBuilder: {
|
||
preload: 'src/electron/preload.js',
|
||
builderOptions: {
|
||
// 应用名称
|
||
productName: 'Yes Play Music',
|
||
// 版权
|
||
copyright: 'Copyright © YesPlayMusic',
|
||
// 机器好的可以打开,配置压缩
|
||
// compression: "maximum",
|
||
publish: [
|
||
{
|
||
"provider": "github",
|
||
"owner": "qier222",
|
||
"repo": "YesPlayMusic",
|
||
"vPrefixedTagName": true,
|
||
"private": true,
|
||
"releaseType": "draft"
|
||
}
|
||
],
|
||
// Compress app using 'electron/asar'
|
||
asar: true,
|
||
|
||
// 项目打包生成的文件目录
|
||
directories: {
|
||
output: 'dist_electron'
|
||
},
|
||
// window 的 icon 头标
|
||
win: {
|
||
publisherName: 'Yes Play Music',
|
||
icon: 'build/icons/icon.ico',
|
||
publish: [
|
||
"github"
|
||
],
|
||
},
|
||
// linux 的配置
|
||
linux: {
|
||
"target": [
|
||
"AppImage",
|
||
"tar.gz",
|
||
"deb"
|
||
],
|
||
icon: "build/icons"
|
||
},
|
||
"dmg": {
|
||
"icon": "build/icons/icon.icns"
|
||
},
|
||
// 是否静默安装
|
||
nsis: {
|
||
// 是否一键安装,建议为 false,可以让用户点击下一步、下一步、下一步的形式安装程序,如果为true,当用户双击构建好的程序,自动安装程序并打开,即:一键安装
|
||
oneClick: false,
|
||
// 允许修改安装目录,建议为 true,是否允许用户改变安装目录,默认是不允许
|
||
allowToChangeInstallationDirectory: true
|
||
},
|
||
},
|
||
// 主线程的配置文件
|
||
chainWebpackMainProcess: config => {
|
||
config.plugin('define').tap((args) => {
|
||
args[0]['IS_ELECTRON'] = true
|
||
return args
|
||
})
|
||
},
|
||
// 渲染线程的配置文件
|
||
chainWebpackRendererProcess: config => {
|
||
// 渲染线程的一些其他配置
|
||
// Chain webpack config for electron renderer process only
|
||
// The following example will set IS_ELECTRON to true in your app
|
||
config.plugin('define').tap((args) => {
|
||
args[0]['IS_ELECTRON'] = true
|
||
return args
|
||
})
|
||
},
|
||
// 主入口文件
|
||
// mainProcessFile: 'src/main.js',
|
||
mainProcessWatch: ['../napi/routes.js'],
|
||
// mainProcessArgs: []
|
||
}
|
||
}
|
||
};
|