create-react-app × electron-packager の最小設定
2020-04-17
本当は electron-builder を入れたかったんですが、エラーが出まくって諦めました。
以下、windows 上での正常動作を確認しました。
electron-packager などをインストールする
npm i --save-dev electron-packager electron-is-dev
main.js を修正する
const { app, BrowserWindow } = require("electron");
const isDev = require("electron-is-dev");
function createWindow() {
const win = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
nodeIntegration: true,
},
});
win.loadURL(
isDev
? "http://localhost:3000/index.html"
: `file://${__dirname}/build/index.html`,
);
if (isDev) {
win.webContents.openDevTools();
}
}
app.allowRendererProcessReuse = false;
app.whenReady().then(createWindow);
app.on("window-all-closed", () => {
if (process.platform !== "darwin") {
app.quit();
}
});
app.on("activate", () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
}
});
パッケージ化するときは build されたファイルを読み込むように設定するだけですね。
package.json に homepage を追加する
"homepage": "./",
ここの設定に気づかず、やたら時間を取られました…。
package.json に パッケージ用のスクリプト を追加する
"scripts": {
"package": "electron-packager . hoge --platform=win32 --arch=x64 --electronVersion=8.2.3 --overwrite"
},
今回は windows x64 向けの設定にしてあります。
--out=dist などのオプションを追加するのも良いですね。
electron-packager を起動する
npm run buildnpm run package
恐らく Mac でも動くはず。