demo for electron packaging

This commit is contained in:
Philipp Dormann 2021-03-14 19:55:21 +01:00
parent f14885854e
commit 7377b4c9d0
5 changed files with 100 additions and 21 deletions

1
.gitignore vendored
View File

@ -3,3 +3,4 @@
.DS_Store .DS_Store
package-lock.json package-lock.json
yarn.lock yarn.lock
/out

View File

@ -16,5 +16,5 @@ yarn electron:dev
# Package electron # Package electron
``` ```
yarn electron:pack yarn electron:package
``` ```

View File

@ -5,11 +5,12 @@
<meta charset="UTF-8" /> <meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>LfK!Scan</title> <title>LfK!Scan</title>
<link rel="icon" type="image/png" href="/favicon.png" /> <base href="./">
<link rel="icon" type="image/png" href="favicon.png" />
</head> </head>
<body class="bg-white font-family-karla h-screen"> <body class="bg-white font-family-karla h-screen">
<script type="module" src="/src/main.js"></script> <script type="module" src="src/main.js"></script>
</body> </body>
</html> </html>

39
main.js Normal file
View File

@ -0,0 +1,39 @@
const { app, BrowserWindow } = require('electron');
const path = require('path');
function createWindow() {
const mainWindow = new BrowserWindow({
width: 800,
height: 600,
fullscreen: true
// webPreferences: {
// preload: path.join(__dirname, 'preload.js')
// }
});
mainWindow.loadFile('dist/index.html');
// mainWindow.removeMenu();
// mainWindow.webContents.openDevTools()
}
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.whenReady().then(() => {
createWindow();
app.on('activate', function() {
// On macOS it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (BrowserWindow.getAllWindows().length === 0) createWindow();
});
});
// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits
// explicitly with Cmd + Q.
app.on('window-all-closed', function() {
if (process.platform !== 'darwin') app.quit();
});
// In this file you can include the rest of your app's specific main process
// code. You can also put them in separate files and require them here.

View File

@ -1,20 +1,58 @@
{ {
"name": "@lfk/scanclient", "name": "@lfk/scanclient",
"version": "0.0.0", "version": "0.0.0",
"scripts": { "description": "minimal electron application",
"dev": "vite ", "main": "main.js",
"build": "vite build" "scripts": {
}, "dev": "vite ",
"devDependencies": { "build": "vite build",
"@svitejs/vite-plugin-svelte": "^0.11.0", "electron:start": "vite build && electron-forge start",
"@tsconfig/svelte": "^1.0.10", "electron:package": "vite build && electron-forge package"
"@types/html-minifier": "^4.0.0", },
"axios": "^0.21.1", "devDependencies": {
"glob": "^7.1.6", "@svitejs/vite-plugin-svelte": "^0.11.0",
"html-minifier": "^4.0.0", "@tsconfig/svelte": "^1.0.10",
"svelte": "^3.35.0", "@types/html-minifier": "^4.0.0",
"svelte-preprocess": "^4.6.9", "axios": "^0.21.1",
"vite": "^2.0.5", "glob": "^7.1.6",
"vite-plugin-windicss": "^0.8.2" "html-minifier": "^4.0.0",
} "svelte": "^3.35.0",
"svelte-preprocess": "^4.6.9",
"vite": "^2.0.5",
"vite-plugin-windicss": "^0.8.2",
"@electron-forge/cli": "^6.0.0-beta.54",
"@electron-forge/maker-deb": "^6.0.0-beta.54",
"@electron-forge/maker-rpm": "^6.0.0-beta.54",
"@electron-forge/maker-squirrel": "^6.0.0-beta.54",
"@electron-forge/maker-zip": "^6.0.0-beta.54",
"electron-nightly": "14.0.0-nightly.20210311"
},
"dependencies": {
"electron-squirrel-startup": "^1.0.0"
},
"config": {
"forge": {
"packagerConfig": {},
"makers": [
{
"name": "@electron-forge/maker-squirrel",
"config": {
"name": "@lfk/scanclient"
}
},
{
"name": "@electron-forge/maker-zip",
"platforms": [ "darwin" ]
},
{
"name": "@electron-forge/maker-deb",
"config": {}
},
{
"name": "@electron-forge/maker-rpm",
"config": {}
}
]
}
}
} }