- Show a way of developing desktop apps with only web knowledge
- Easy to use
- Be transparent and open to OSS developers
| next | nextron |
|---|---|
v16.x |
v10.x |
v14.x ~ v16.x |
v9.x |
v12.x ~ v13.x |
v8.x |
v11.x |
v7.x |
v10.x |
v6.x |
v9.x |
v5.x |
v8.x |
v4.x |
v7.x |
v2.x ~ v3.x |
v6.x |
v1.x |
- Upgrade
nextronto v10 - Rename
main/background.tstomain/main.ts - Rename
package.json#mainfield toapp/main.js
That's it!
package.json- Set
package.json#typetomodule
- Set
next.config.js- Use
export defaultinstead ofmodule.exports
- Use
- Codebase
- Replace
__dirnametoimport.meta.dirname
- Replace
We can use examples/* as a template.
To create the examples/with-tailwindcss, run the command below:
# with npx
npx create-nextron-app MY_APP --example with-tailwindcss
# with yarn
yarn create nextron-app MY_APP --example with-tailwindcss
# with pnpm
pnpm dlx create-nextron-app MY_APP --example with-tailwindcssRun npm run dev, and nextron automatically launches an electron app.
{
"scripts": {
"dev": "nextron"
}
}Run npm run build, and nextron outputs packaged bundles under the dist folder.
{
"scripts": {
"build": "nextron build"
}
}.
├── main
│ ├── app.ts
│ └── preload.ts
├── renderer
│ ├── next.config.ts
│ ├── pages
│ │ ├── home.tsx
│ │ └── next.tsx
│ ├── preload.d.ts
│ ├── public
│ │ └── images
│ │ └── logo.png
│ └── tsconfig.json
├── resources
│ ├── icon.icns
│ └── icon.ico
├── nextron.config.ts
├── electron-builder.yml
├── package.json
└── tsconfig.json
// `./renderer/next.config.ts`
import { NextConfig } from 'next'
const config: NextConfig = {
// we need to export static files so as Electron can handle them
output: 'export',
distDir:
process.env.NODE_ENV === 'production'
? // we want to change `distDir` to "../app" so as nextron can build the app in production mode!
'../app'
: // default `distDir` value
'.next',
// e.g. home.html => home/index.html
trailingSlash: true,
// we need to disable image optimization, because it is not compatible with `{ output: 'export' }`
images: {
unoptimized: true,
},
}
export default configIt specifies next dev server port:
{
"scripts": {
"dev": "nextron --renderer-port 7777"
}
}It suppresses hot reloading of the main process:
{
"scripts": {
"dev": "nextron --run-only"
}
}It waits until renderer process is ready (milliseconds):
{
"scripts": {
"dev": "nextron --startup-delay 3000"
}
}We can pass electron args via --electron-options:
{
"scripts": {
"dev": "nextron --electron-options=\"--no-sandbox\""
}
}NOTE:
- To build macOS binary, your host machine must be macOS!
- Please consider to use
electron-builder.ymlinstead of these CLI options.
{
"scripts": {
"build": "nextron build",
"build:mac": "nextron build --mac",
"build:mac:universal": "nextron build --mac --universal",
"build:linux": "nextron build --linux",
"build:win32": "nextron build --win --ia32",
"build:win64": "nextron build --win --x64"
}
}{
"scripts": {
"build": "nextron build --config ./configs/electron-builder.prod.yml"
}
}Note
Highly recommend to use electron-builder.yml:
https://www.electron.build/configuration/publish
This option skips packaging by electron-builder:
{
"scripts": {
"build": "nextron build --no-pack"
}
}Edit electron-builder.yml for custom build configurations:
appId: com.example.nextron
productName: My Nextron App
copyright: Copyright © 2020 Yoshihide Shiono
directories:
output: dist
buildResources: resources
files:
- from: .
filter:
- package.json
- app
publish: null # see https://www.electron.build/configuration/publishFor more information, please check out electron-builder official configuration documents.
import { NextronConfig } from 'nextron'
const config: NextronConfig = {
// specify an alternate main src directory, defaults to 'main'
mainSrcDir: 'main',
// specify an alternate renderer src directory, defaults to 'renderer'
rendererSrcDir: 'renderer',
// main process' webpack config
webpack: (config, env) => {
// do some stuff here
return config
},
}
export default configWe can extends the default babel config of main process by putting .babelrc in our project root like this:
.babelrc:
{
"presets": ["nextron/babel"]
}# with npx
npx create-nextron-app my-app --example basic-lang-javascript
# with yarn
yarn create nextron-app my-app --example basic-lang-javascript
# with pnpm
pnpm dlx create-nextron-app my-app --example basic-lang-javascript# with npx
npx create-nextron-app my-app --example basic-lang-typescript
# with yarn
yarn create nextron-app my-app --example basic-lang-typescript
# with pnpm
pnpm dlx create-nextron-app my-app --example basic-lang-typescriptThis example shows how to open your app from browser URL.
Note: this example works only production build!
# with npx
npx create-nextron-app my-app --example basic-launch-app-from-url
# with yarn
yarn create nextron-app my-app --example basic-launch-app-from-url
# with pnpm
pnpm dlx create-nextron-app my-app --example basic-launch-app-from-url
# --------------------------------------------------------------
# Production build
yarn build (or `npm run build` or `pnpm run build`)After production build, open your-custom-protocol://open?token=jwt-value in your browser, then the app will be shown like a magic!
If you want to change schema URL, please edit electron-builder.yml#protocols:
protocols:
name: Your App Name
schemes: [your-custom-protocol-edited]Then, you can see the app from URL: your-custom-protocol-edited://any-uri-here?data=include-any-data.
# with npx
npx create-nextron-app my-app --example basic-store-data
# with yarn
yarn create nextron-app my-app --example basic-store-data
# with pnpm
pnpm dlx create-nextron-app my-app --example basic-store-data# with npx
npx create-nextron-app my-app --example custom-build-options
# with yarn
yarn create nextron-app my-app --example custom-build-options
# with pnpm
pnpm dlx create-nextron-app my-app --example custom-build-options# with npx
npx create-nextron-app my-app --example custom-renderer-port
# with yarn
yarn create nextron-app my-app --example custom-renderer-port
# with pnpm
pnpm dlx create-nextron-app my-app --example custom-renderer-port# with npx
npx create-nextron-app my-app --example with-ant-design
# with yarn
yarn create nextron-app my-app --example with-ant-design
# with pnpm
pnpm dlx create-nextron-app my-app --example with-ant-design# with npx
npx create-nextron-app my-app --example with-chakra-ui
# with yarn
yarn create nextron-app my-app --example with-chakra-ui
# with pnpm
pnpm dlx create-nextron-app my-app --example with-chakra-ui# with npx
npx create-nextron-app my-app --example with-emotion
# with yarn
yarn create nextron-app my-app --example with-emotion
# with pnpm
pnpm dlx create-nextron-app my-app --example with-emotion# with npx
npx create-nextron-app my-app --example with-material-ui
# with yarn
yarn create nextron-app my-app --example with-material-ui
# with pnpm
pnpm dlx create-nextron-app my-app --example with-material-ui# with npx
npx create-nextron-app my-app --example with-next-i18next
# with yarn
yarn create nextron-app my-app --example with-next-i18next
# with pnpm
pnpm dlx create-nextron-app my-app --example with-next-i18next# with npx
npx create-nextron-app my-app --example with-tailwindcss
# with yarn
yarn create nextron-app my-app --example with-tailwindcss
# with pnpm
pnpm dlx create-nextron-app my-app --example with-tailwindcssgit clone https://github.com/saltyshiomix/nextron.git
cd nextron
pnpm install
npx lefthook install
pnpm dev # default is examples/basic-lang-javascriptpnpm dev <EXAMPLE-FOLDER-NAME>- Install development version of nextron
cd nextron
npm install
npm run build
npm link- Install linked nextron in your project
cd your-project
npm link nextron- On every change in nextron, run
npm run buildin nextron folder and restart your project
- saltyshiomix (Shiono Yoshihide)
- lacymorrow (Lacy Morrow)
- Psycokwet
- m5x5
- andirsun (Anderson Laverde)
- bm777 (Bayang)
- FranciscoJBrito (Francisco Brito)
- pixelass (Gregor Adams)
For more information, please see Looking for maintainers ⚡ #244.
You already create apps with nextron? Feel free to share your apps or services: Made by nextron? #406
- create-nextron-app - Create Nextron (Next.js + Electron) apps in one command ⚡
This project is licensed under the terms of the MIT license.












