Build an Electron + Next.js app for speed ⚡
(The screenshot above is a top page of examples/with-typescript-material-ui.)
nextron | next |
---|---|
v5.x |
v9.x |
v4.x |
v8.x |
v2.x / v3.x |
v7.x |
v1.x |
v6.x |
👍 JavaScript frontend/backend
👍 TypeScript frontend/backend
👍 TypeScript frontend/Python backend
- Show a way of developing desktop apps only web knowledge
- Easy to use
- Be transparent (Open to OSS developers)
- If you need more performance with Electron, you should see these boilerplates
- If you want to use Nextron as production, please take responsibility for your actions
- But, if you have any troubles, questions or ideas, I'll support you, I promise
$ npm install --global nextron@latest
To create <MY-APP>
, just run the command below:
$ nextron init <MY-APP>
Or, you can use a create-nextron-app
command without installing the nextron
command globally:
# with npx
$ npx create-nextron-app <MY-APP>
# with yarn
$ yarn create nextron-app <MY-APP>
You can use examples/*
apps as a template.
To create the examples/with-typescript-material-ui
app, run the command below:
# with `nextron`
$ nextron init <MY-APP> --example with-typescript-material-ui
# with npx
$ npx create-nextron-app <MY-APP> --example with-typescript-material-ui
# with yarn
$ yarn create nextron-app <MY-APP> --example with-typescript-material-ui
Run 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"
}
}
To build Windows 32 bit version, run npm run build:win32
like below:
{
"scripts": {
"build": "nextron build",
"build:all": "nextron build --all",
"build:win32": "nextron build --win --ia32",
"build:win64": "nextron build --win --x64",
"build:mac": "nextron build --mac --x64",
"build:linux": "nextron build --linux"
}
}
CAUTION: To build macOS binary, your host machine must be macOS!
Edit electron-builder.yml
properties for custom build configuration.
appId: com.example.nextron
productName: My Nextron App
copyright: Copyright © 2018 Yoshihide Shiono
directories:
output: dist
buildResources: resources
files:
- from: .
filter:
- package.json
- app
publish: null
For more information, please check out electron-builder official configuration documents.
module.exports = {
// main process' webpack config
webpack: (defaultConfig, env) => {
// do some stuff here
return defaultConfig;
},
};
See examples folder for more information.
Or you can start the example app by nextron init <app-name> --example <example-dirname>
.
To list all examples, just type the command below:
$ nextron list
# with `nextron`
$ nextron init my-app --example api-routes
# with npx
$ npx create-nextron-app my-app --example api-routes
# with yarn
$ yarn create nextron-app my-app --example api-routes
# with `nextron`
$ nextron init my-app --example custom-build-options
# 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 `nextron`
$ nextron init my-app --example custom-main-entry
# with npx
$ npx create-nextron-app my-app --example custom-main-entry
# with yarn
$ yarn create nextron-app my-app --example custom-main-entry
# with `nextron`
$ nextron init my-app --example custom-server
# with npx
$ npx create-nextron-app my-app --example custom-server
# with yarn
$ yarn create nextron-app my-app --example custom-server
# with `nextron`
$ nextron init my-app --example custom-server-nodemon
# with npx
$ npx create-nextron-app my-app --example custom-server-nodemon
# with yarn
$ yarn create nextron-app my-app --example custom-server-nodemon
# with `nextron`
$ nextron init my-app --example custom-server-typescript
# with npx
$ npx create-nextron-app my-app --example custom-server-typescript
# with yarn
$ yarn create nextron-app my-app --example custom-server-typescript
# with `nextron`
$ nextron init my-app --example ipc-communication
# with npx
$ npx create-nextron-app my-app --example ipc-communication
# with yarn
$ yarn create nextron-app my-app --example ipc-communication
# with `nextron`
$ nextron init my-app --example parameterized-routing
# with npx
$ npx create-nextron-app my-app --example parameterized-routing
# with yarn
$ yarn create nextron-app my-app --example parameterized-routing
# with `nextron`
$ nextron init my-app --example remote-require
# with npx
$ npx create-nextron-app my-app --example remote-require
# with yarn
$ yarn create nextron-app my-app --example remote-require
# with `nextron`
$ nextron init my-app --example store-data
# with npx
$ npx create-nextron-app my-app --example store-data
# with yarn
$ yarn create nextron-app my-app --example store-data
# with `nextron`
$ nextron init my-app --example web-worker
# with npx
$ npx create-nextron-app my-app --example web-worker
# with yarn
$ yarn create nextron-app my-app --example web-worker
# with `nextron`
$ nextron init my-app --example with-javascript
# with npx
$ npx create-nextron-app my-app --example with-javascript
# with yarn
$ yarn create nextron-app my-app --example with-javascript
# with `nextron`
$ nextron init my-app --example with-javascript-ant-design
# with npx
$ npx create-nextron-app my-app --example with-javascript-ant-design
# with yarn
$ yarn create nextron-app my-app --example with-javascript-ant-design
# with `nextron`
$ nextron init my-app --example with-javascript-emotion
# with npx
$ npx create-nextron-app my-app --example with-javascript-emotion
# with yarn
$ yarn create nextron-app my-app --example with-javascript-emotion
# with `nextron`
$ nextron init my-app --example with-javascript-material-ui
# with npx
$ npx create-nextron-app my-app --example with-javascript-material-ui
# with yarn
$ yarn create nextron-app my-app --example with-javascript-material-ui
# with `nextron`
$ nextron init my-app --example with-typescript
# with npx
$ npx create-nextron-app my-app --example with-typescript
# with yarn
$ yarn create nextron-app my-app --example with-typescript
# with `nextron`
$ nextron init my-app --example with-typescript-emotion
# with npx
$ npx create-nextron-app my-app --example with-typescript-emotion
# with yarn
$ yarn create nextron-app my-app --example with-typescript-emotion
# with `nextron`
$ nextron init my-app --example with-typescript-less
# with npx
$ npx create-nextron-app my-app --example with-typescript-less
# with yarn
$ yarn create nextron-app my-app --example with-typescript-less
# with `nextron`
$ nextron init my-app --example with-typescript-material-ui
# with npx
$ npx create-nextron-app my-app --example with-typescript-material-ui
# with yarn
$ yarn create nextron-app my-app --example with-typescript-material-ui
(Note: When working with the with-typescript-python-api example, see the example's readme file for python setup details)
# with `nextron`
$ nextron init my-app --example with-typescript-python-api
# with npx
$ npx create-nextron-app my-app --example with-typescript-python-api
# with yarn
$ yarn create nextron-app my-app --example with-typescript-python-api
$ git clone https://github.com/saltyshiomix/nextron.git
$ cd nextron
$ yarn
$ yarn dev # default is examples/with-javascript-emotion
$ yarn dev <EXAMPLE-FOLDER-NAME>
- create-nextron-app - Create Nextron (Electron + Next.js) apps in one command ⚡
- Nuxtron - ⚡ Electron + Nuxt.js ⚡
This project is licensed under the terms of the MIT license.