4
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Next.JSのElectronデスクトップアプリを作る(Nextronを使わず)

Last updated at Posted at 2024-01-20

この記事は
Building Desktop Apps with Electron + Next.JS (without Nextron)
を抜粋して翻訳したものです。

Step1: Next.JSのプロジェクトを作る

npx create-next-app@latest my-app

このコマンドを実行すると、以下プロジェクトの設定が行われる

What is your project named? my-app
Would you like to use TypeScript? No / Yes
Would you like to use ESLint? No / Yes
Would you like to use Tailwind CSS? No / Yes
Would you like to use `src/` directory? No / Yes
Would you like to use App Router? (recommended) No / Yes
Would you like to customize the default import alias (@/*)? No / Yes
What import alias would you like configured? @/*

Step2: Electronと依頼パッケージをインストールする

プロジェクトのルートディレクトリにcdして、electron、electron-builder、concurrentlyをdev依頼としてインストールする

npm install --save-dev electron electron-builder concurrently

そして、プロジェクトの依頼パッケージをインストールする

npm install electron-serve

Step3: package.jsonを編集する

package.jsonに下記の内容を追加する

{
  ...
  "main": "main.js",
  "description": "Electron + NextJS example project",
  "scripts": {
    "dev": "concurrently -n \"NEXT,ELECTRON\" -c \"yellow,blue\" --kill-others \"next dev\" \"electron .\"",
    "build": "next build && electron-builder",
    ...
  }
  ...
}

scriptsをこのように記載することで、npm run devでNext.JSの開発サーバーとElectronの開発サーバーが同時に起動するようになる

Step4: Next.JSを設定する

プロジェクトのルートディレクトリにはnext.config.jsがあるはずなので、下記の内容に変更する

const nextConfig = {
  ...
  output: "export",
  images: {
    unoptimized: true
  }
  ...
}

Step5: main.jsを作る

プロジェクトのルートディレクトリでmain.jsを下記の内容で作成する

const { app, BrowserWindow } = require("electron");
const serve = require("electron-serve");
const path = require("path");

const appServe = app.isPackaged ? serve({
  directory: path.join(__dirname, "../out")
}) : null;

const createWindow = () => {
  const win = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      preload: path.join(__dirname, "preload.js")
    }
  });

  if (app.isPackaged) {
    appServe(win).then(() => {
      win.loadURL("app://-");
    });
  } else {
    win.loadURL("http://localhost:3000");
    win.webContents.openDevTools();
    win.webContents.on("did-fail-load", (e, code, desc) => {
      win.webContents.reloadIgnoringCache();
    });
  }
}

app.on("ready", () => {
    createWindow();
});

app.on("window-all-closed", () => {
    if(process.platform !== "darwin"){
        app.quit();
    }
});

Step6: preload.jsを作る

プロジェクトのルートディレクトリでpreload.jsを下記の内容で作成する

const { contextBridge, ipcRenderer } = require("electron");

contextBridge.exposeInMainWorld("electronAPI", {
    on: (channel, callback) => {
        ipcRenderer.on(channel, callback);
    },
    send: (channel, args) => {
        ipcRenderer.send(channel, args);
    }
});

Step7: 実行してテストする

npm run devを実行して、アプリが起動できることを確認する。

Step8: ビルドする

プロジェクトのルートディレクトリでelectron-builder.yamlを作成して、コードビルドの設定を記載する

appId: "io.github.rbfraphael.electron-next"
productName: "Electron Next.JS"
copyright: "Copyright (c) 2023 RBFraphael"
win:
  target: ["dir", "portable", "zip"]
  icon: "resources/icon.ico"
linux:
  target: ["dir", "appimage", "zip"]
  icon: "resources/icon.png"
mac:
  target: ["dir", "dmg", "zip"]
  icon: "resources/icon.icns"

これにより、npm run buildでビルドできるようになる。

4
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?