mirror of
				https://github.com/velopack/velopack.git
				synced 2025-10-25 15:19:22 +00:00 
			
		
		
		
	wip electron sample
This commit is contained in:
		
							
								
								
									
										16
									
								
								samples/NodeJSElectron/.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								samples/NodeJSElectron/.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| { | ||||
|   "env": { | ||||
|     "browser": true, | ||||
|     "es6": true, | ||||
|     "node": true | ||||
|   }, | ||||
|   "extends": [ | ||||
|     "eslint:recommended", | ||||
|     "plugin:@typescript-eslint/eslint-recommended", | ||||
|     "plugin:@typescript-eslint/recommended", | ||||
|     "plugin:import/recommended", | ||||
|     "plugin:import/electron", | ||||
|     "plugin:import/typescript" | ||||
|   ], | ||||
|   "parser": "@typescript-eslint/parser" | ||||
| } | ||||
							
								
								
									
										92
									
								
								samples/NodeJSElectron/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								samples/NodeJSElectron/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| # Logs | ||||
| logs | ||||
| *.log | ||||
| npm-debug.log* | ||||
| yarn-debug.log* | ||||
| yarn-error.log* | ||||
| lerna-debug.log* | ||||
|  | ||||
| # Diagnostic reports (https://nodejs.org/api/report.html) | ||||
| report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json | ||||
|  | ||||
| # Runtime data | ||||
| pids | ||||
| *.pid | ||||
| *.seed | ||||
| *.pid.lock | ||||
| .DS_Store | ||||
|  | ||||
| # Directory for instrumented libs generated by jscoverage/JSCover | ||||
| lib-cov | ||||
|  | ||||
| # Coverage directory used by tools like istanbul | ||||
| coverage | ||||
| *.lcov | ||||
|  | ||||
| # nyc test coverage | ||||
| .nyc_output | ||||
|  | ||||
| # node-waf configuration | ||||
| .lock-wscript | ||||
|  | ||||
| # Compiled binary addons (https://nodejs.org/api/addons.html) | ||||
| build/Release | ||||
|  | ||||
| # Dependency directories | ||||
| node_modules/ | ||||
| jspm_packages/ | ||||
|  | ||||
| # TypeScript v1 declaration files | ||||
| typings/ | ||||
|  | ||||
| # TypeScript cache | ||||
| *.tsbuildinfo | ||||
|  | ||||
| # Optional npm cache directory | ||||
| .npm | ||||
|  | ||||
| # Optional eslint cache | ||||
| .eslintcache | ||||
|  | ||||
| # Optional REPL history | ||||
| .node_repl_history | ||||
|  | ||||
| # Output of 'npm pack' | ||||
| *.tgz | ||||
|  | ||||
| # Yarn Integrity file | ||||
| .yarn-integrity | ||||
|  | ||||
| # dotenv environment variables file | ||||
| .env | ||||
| .env.test | ||||
|  | ||||
| # parcel-bundler cache (https://parceljs.org/) | ||||
| .cache | ||||
|  | ||||
| # next.js build output | ||||
| .next | ||||
|  | ||||
| # nuxt.js build output | ||||
| .nuxt | ||||
|  | ||||
| # vuepress build output | ||||
| .vuepress/dist | ||||
|  | ||||
| # Serverless directories | ||||
| .serverless/ | ||||
|  | ||||
| # FuseBox cache | ||||
| .fusebox/ | ||||
|  | ||||
| # DynamoDB Local files | ||||
| .dynamodb/ | ||||
|  | ||||
| # Webpack | ||||
| .webpack/ | ||||
|  | ||||
| # Vite | ||||
| .vite/ | ||||
|  | ||||
| # Electron-Forge | ||||
| out/ | ||||
							
								
								
									
										38
									
								
								samples/NodeJSElectron/build-win.bat
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								samples/NodeJSElectron/build-win.bat
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| @echo off | ||||
| setlocal enabledelayedexpansion | ||||
|  | ||||
| if "%~1"=="" ( | ||||
|     echo Version number is required. | ||||
|     echo Usage: build.bat [version] | ||||
|     exit /b 1 | ||||
| ) | ||||
|  | ||||
| set "version=%~1" | ||||
|  | ||||
| echo. | ||||
| echo Cleaning lib-nodejs | ||||
| cd %~dp0..\..\src\lib-nodejs | ||||
| call npm run clean | ||||
|  | ||||
| echo. | ||||
| echo Compiling lib-nodejs | ||||
| cd %~dp0..\..\src\lib-nodejs | ||||
| call npm run dev | ||||
|  | ||||
| echo. | ||||
| echo Packing lib-nodejs | ||||
| call npm pack | ||||
|  | ||||
| echo. | ||||
| echo Installing lib-nodejs package | ||||
| cd %~dp0 | ||||
| npm install ..\..\src\lib-nodejs\velopack-0.0.0.tgz | ||||
|  | ||||
|  | ||||
| @REM echo. | ||||
| @REM echo Compiling VelopackCSharpWpf with dotnet... | ||||
| @REM dotnet publish -c Release -o %~dp0publish | ||||
| @REM  | ||||
| @REM echo. | ||||
| @REM echo Building Velopack Release v%version% | ||||
| @REM vpk pack -u VelopackCSharpWpf -v %version% -o %~dp0releases -p %~dp0publish -f net8-x64-desktop | ||||
							
								
								
									
										51
									
								
								samples/NodeJSElectron/forge.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								samples/NodeJSElectron/forge.config.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| import type { ForgeConfig } from '@electron-forge/shared-types'; | ||||
| import { MakerZIP } from '@electron-forge/maker-zip'; | ||||
| import { MakerDeb } from '@electron-forge/maker-deb'; | ||||
| import { MakerRpm } from '@electron-forge/maker-rpm'; | ||||
| import { AutoUnpackNativesPlugin } from '@electron-forge/plugin-auto-unpack-natives'; | ||||
| import { WebpackPlugin } from '@electron-forge/plugin-webpack'; | ||||
| import { FusesPlugin } from '@electron-forge/plugin-fuses'; | ||||
| import { FuseV1Options, FuseVersion } from '@electron/fuses'; | ||||
|  | ||||
| import { mainConfig } from './webpack.main.config'; | ||||
| import { rendererConfig } from './webpack.renderer.config'; | ||||
|  | ||||
| const config: ForgeConfig = { | ||||
|   packagerConfig: { | ||||
|     asar: true, | ||||
|   }, | ||||
|   rebuildConfig: {}, | ||||
|   makers: [new MakerZIP({}, ['darwin']), new MakerRpm({}), new MakerDeb({})], | ||||
|   plugins: [ | ||||
|     new AutoUnpackNativesPlugin({}), | ||||
|     new WebpackPlugin({ | ||||
|       mainConfig, | ||||
|       renderer: { | ||||
|         config: rendererConfig, | ||||
|         entryPoints: [ | ||||
|           { | ||||
|             html: './src/index.html', | ||||
|             js: './src/renderer.ts', | ||||
|             name: 'main_window', | ||||
|             preload: { | ||||
|               js: './src/preload.ts', | ||||
|             }, | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|     }), | ||||
|     // Fuses are used to enable/disable various Electron functionality | ||||
|     // at package time, before code signing the application | ||||
|     new FusesPlugin({ | ||||
|       version: FuseVersion.V1, | ||||
|       [FuseV1Options.RunAsNode]: false, | ||||
|       [FuseV1Options.EnableCookieEncryption]: true, | ||||
|       [FuseV1Options.EnableNodeOptionsEnvironmentVariable]: false, | ||||
|       [FuseV1Options.EnableNodeCliInspectArguments]: false, | ||||
|       [FuseV1Options.EnableEmbeddedAsarIntegrityValidation]: true, | ||||
|       [FuseV1Options.OnlyLoadAppFromAsar]: true, | ||||
|     }), | ||||
|   ], | ||||
| }; | ||||
|  | ||||
| export default config; | ||||
							
								
								
									
										12064
									
								
								samples/NodeJSElectron/package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										12064
									
								
								samples/NodeJSElectron/package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										46
									
								
								samples/NodeJSElectron/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								samples/NodeJSElectron/package.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| { | ||||
|   "name": "electron-webpack-test", | ||||
|   "productName": "electron-webpack-test", | ||||
|   "version": "1.0.0", | ||||
|   "description": "My Electron application description", | ||||
|   "main": ".webpack/main", | ||||
|   "scripts": { | ||||
|     "start": "electron-forge start", | ||||
|     "package": "electron-forge package", | ||||
|     "make": "electron-forge make", | ||||
|     "publish": "electron-forge publish", | ||||
|     "lint": "eslint --ext .ts,.tsx ." | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@electron-forge/cli": "^7.5.0", | ||||
|     "@electron-forge/maker-deb": "^7.5.0", | ||||
|     "@electron-forge/maker-rpm": "^7.5.0", | ||||
|     "@electron-forge/maker-zip": "^7.5.0", | ||||
|     "@electron-forge/plugin-auto-unpack-natives": "^7.5.0", | ||||
|     "@electron-forge/plugin-fuses": "^7.5.0", | ||||
|     "@electron-forge/plugin-webpack": "^7.5.0", | ||||
|     "@electron/fuses": "^1.8.0", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.62.0", | ||||
|     "@typescript-eslint/parser": "^5.62.0", | ||||
|     "@vercel/webpack-asset-relocator-loader": "^1.7.3", | ||||
|     "css-loader": "^6.11.0", | ||||
|     "electron": "32.1.2", | ||||
|     "eslint": "^8.57.1", | ||||
|     "eslint-plugin-import": "^2.31.0", | ||||
|     "fork-ts-checker-webpack-plugin": "^7.3.0", | ||||
|     "node-loader": "^2.0.0", | ||||
|     "style-loader": "^3.3.4", | ||||
|     "ts-loader": "^9.5.1", | ||||
|     "ts-node": "^10.9.2", | ||||
|     "typescript": "~4.5.4" | ||||
|   }, | ||||
|   "keywords": [], | ||||
|   "author": { | ||||
|     "name": "Caelan", | ||||
|     "email": "git@caesay.com" | ||||
|   }, | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
|     "velopack": "file:../../src/lib-nodejs/velopack-0.0.0.tgz" | ||||
|   } | ||||
| } | ||||
							
								
								
									
										7
									
								
								samples/NodeJSElectron/src/index.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								samples/NodeJSElectron/src/index.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| body { | ||||
|   font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, | ||||
|     Arial, sans-serif; | ||||
|   margin: auto; | ||||
|   max-width: 38rem; | ||||
|   padding: 2rem; | ||||
| } | ||||
							
								
								
									
										12
									
								
								samples/NodeJSElectron/src/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								samples/NodeJSElectron/src/index.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
|   <head> | ||||
|     <meta charset="UTF-8" /> | ||||
|     <title>Hello World!</title> | ||||
|  | ||||
|   </head> | ||||
|   <body> | ||||
|     <h1>💖 Hello World!</h1> | ||||
|     <p>Welcome to your Electron application.</p> | ||||
|   </body> | ||||
| </html> | ||||
							
								
								
									
										55
									
								
								samples/NodeJSElectron/src/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								samples/NodeJSElectron/src/index.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | ||||
| import { app, BrowserWindow } from 'electron'; | ||||
| import { VelopackApp } from "velopack"; | ||||
| // This allows TypeScript to pick up the magic constants that's auto-generated by Forge's Webpack | ||||
| // plugin that tells the Electron app where to look for the Webpack-bundled app code (depending on | ||||
| // whether you're running in development or production). | ||||
| declare const MAIN_WINDOW_WEBPACK_ENTRY: string; | ||||
| declare const MAIN_WINDOW_PRELOAD_WEBPACK_ENTRY: string; | ||||
|  | ||||
| // VelopackApp should be the first thing to run in startup | ||||
| // as it may need to quit / restart the application at certain points | ||||
| VelopackApp.build() | ||||
|   .setLogger((lvl, msg) => console.log(`Velopack [${lvl}] ${msg}`)) | ||||
|   .run(); | ||||
|  | ||||
| const createWindow = (): void => { | ||||
|   // Create the browser window. | ||||
|   const mainWindow = new BrowserWindow({ | ||||
|     height: 600, | ||||
|     width: 800, | ||||
|     webPreferences: { | ||||
|       preload: MAIN_WINDOW_PRELOAD_WEBPACK_ENTRY, | ||||
|     }, | ||||
|   }); | ||||
|  | ||||
|   // and load the index.html of the app. | ||||
|   mainWindow.loadURL(MAIN_WINDOW_WEBPACK_ENTRY); | ||||
|  | ||||
|   // Open the DevTools. | ||||
|   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.on('ready', 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', () => { | ||||
|   if (process.platform !== 'darwin') { | ||||
|     app.quit(); | ||||
|   } | ||||
| }); | ||||
|  | ||||
| app.on('activate', () => { | ||||
|   // On OS X 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(); | ||||
|   } | ||||
| }); | ||||
|  | ||||
| // 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 import them here. | ||||
							
								
								
									
										2
									
								
								samples/NodeJSElectron/src/preload.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								samples/NodeJSElectron/src/preload.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| // See the Electron documentation for details on how to use preload scripts: | ||||
| // https://www.electronjs.org/docs/latest/tutorial/process-model#preload-scripts | ||||
							
								
								
									
										31
									
								
								samples/NodeJSElectron/src/renderer.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								samples/NodeJSElectron/src/renderer.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| /** | ||||
|  * This file will automatically be loaded by webpack and run in the "renderer" context. | ||||
|  * To learn more about the differences between the "main" and the "renderer" context in | ||||
|  * Electron, visit: | ||||
|  * | ||||
|  * https://electronjs.org/docs/latest/tutorial/process-model | ||||
|  * | ||||
|  * By default, Node.js integration in this file is disabled. When enabling Node.js integration | ||||
|  * in a renderer process, please be aware of potential security implications. You can read | ||||
|  * more about security risks here: | ||||
|  * | ||||
|  * https://electronjs.org/docs/tutorial/security | ||||
|  * | ||||
|  * To enable Node.js integration in this file, open up `main.js` and enable the `nodeIntegration` | ||||
|  * flag: | ||||
|  * | ||||
|  * ``` | ||||
|  *  // Create the browser window. | ||||
|  *  mainWindow = new BrowserWindow({ | ||||
|  *    width: 800, | ||||
|  *    height: 600, | ||||
|  *    webPreferences: { | ||||
|  *      nodeIntegration: true | ||||
|  *    } | ||||
|  *  }); | ||||
|  * ``` | ||||
|  */ | ||||
|  | ||||
| import './index.css'; | ||||
|  | ||||
| console.log('👋 This message is being logged by "renderer.js", included via webpack'); | ||||
							
								
								
									
										19
									
								
								samples/NodeJSElectron/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								samples/NodeJSElectron/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| { | ||||
|   "compilerOptions": { | ||||
|     "target": "ES6", | ||||
|     "allowJs": true, | ||||
|     "module": "commonjs", | ||||
|     "skipLibCheck": true, | ||||
|     "esModuleInterop": true, | ||||
|     "noImplicitAny": true, | ||||
|     "sourceMap": true, | ||||
|     "baseUrl": ".", | ||||
|     "outDir": "dist", | ||||
|     "moduleResolution": "node", | ||||
|     "resolveJsonModule": true, | ||||
|     "paths": { | ||||
|       "*": ["node_modules/*"] | ||||
|     } | ||||
|   }, | ||||
|   "include": ["src/**/*"] | ||||
| } | ||||
							
								
								
									
										20
									
								
								samples/NodeJSElectron/webpack.main.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								samples/NodeJSElectron/webpack.main.config.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| import type { Configuration } from 'webpack'; | ||||
|  | ||||
| import { rules } from './webpack.rules'; | ||||
| import { plugins } from './webpack.plugins'; | ||||
|  | ||||
| export const mainConfig: Configuration = { | ||||
|   /** | ||||
|    * This is the main entry point for your application, it's the first file | ||||
|    * that runs in the main process. | ||||
|    */ | ||||
|   entry: './src/index.ts', | ||||
|   // Put your normal webpack config below here | ||||
|   module: { | ||||
|     rules, | ||||
|   }, | ||||
|   plugins, | ||||
|   resolve: { | ||||
|     extensions: ['.js', '.ts', '.jsx', '.tsx', '.css', '.json'], | ||||
|   }, | ||||
| }; | ||||
							
								
								
									
										10
									
								
								samples/NodeJSElectron/webpack.plugins.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								samples/NodeJSElectron/webpack.plugins.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| import type IForkTsCheckerWebpackPlugin from 'fork-ts-checker-webpack-plugin'; | ||||
|  | ||||
| // eslint-disable-next-line @typescript-eslint/no-var-requires | ||||
| const ForkTsCheckerWebpackPlugin: typeof IForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin'); | ||||
|  | ||||
| export const plugins = [ | ||||
|   new ForkTsCheckerWebpackPlugin({ | ||||
|     logger: 'webpack-infrastructure', | ||||
|   }), | ||||
| ]; | ||||
							
								
								
									
										19
									
								
								samples/NodeJSElectron/webpack.renderer.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								samples/NodeJSElectron/webpack.renderer.config.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| import type { Configuration } from 'webpack'; | ||||
|  | ||||
| import { rules } from './webpack.rules'; | ||||
| import { plugins } from './webpack.plugins'; | ||||
|  | ||||
| rules.push({ | ||||
|   test: /\.css$/, | ||||
|   use: [{ loader: 'style-loader' }, { loader: 'css-loader' }], | ||||
| }); | ||||
|  | ||||
| export const rendererConfig: Configuration = { | ||||
|   module: { | ||||
|     rules, | ||||
|   }, | ||||
|   plugins, | ||||
|   resolve: { | ||||
|     extensions: ['.js', '.ts', '.jsx', '.tsx', '.css'], | ||||
|   }, | ||||
| }; | ||||
							
								
								
									
										31
									
								
								samples/NodeJSElectron/webpack.rules.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								samples/NodeJSElectron/webpack.rules.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| import type { ModuleOptions } from 'webpack'; | ||||
|  | ||||
| export const rules: Required<ModuleOptions>['rules'] = [ | ||||
|   // Add support for native node modules | ||||
|   { | ||||
|     // We're specifying native_modules in the test because the asset relocator loader generates a | ||||
|     // "fake" .node file which is really a cjs file. | ||||
|     test: /native_modules[/\\].+\.node$/, | ||||
|     use: 'node-loader', | ||||
|   }, | ||||
|   { | ||||
|     test: /[/\\]node_modules[/\\].+\.(m?js|node)$/, | ||||
|     parser: { amd: false }, | ||||
|     use: { | ||||
|       loader: '@vercel/webpack-asset-relocator-loader', | ||||
|       options: { | ||||
|         outputAssetBase: 'native_modules', | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|   { | ||||
|     test: /\.tsx?$/, | ||||
|     exclude: /(node_modules|\.webpack)/, | ||||
|     use: { | ||||
|       loader: 'ts-loader', | ||||
|       options: { | ||||
|         transpileOnly: true, | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
| ]; | ||||
| @@ -5,4 +5,5 @@ | ||||
| - [**CSharpUnityMono**](CSharpUnityMono) - Velopack with [Unity Game Engine](https://unity.com/) and Mono. | ||||
| - [**CSharpUno**](CSharpUno) - Velopack in a cross-platform app with [Uno Platform](https://github.com/unoplatform/uno). | ||||
| - [**CSharpWpf**](CSharpWpf) - Velopack with WPF on Windows. | ||||
| - [**NodeJSElectron**](NodeJSElectron) - Velopack in a cross-platform javascript app with [Electron](https://www.electronjs.org/). | ||||
| - [**RustIced**](RustIced) - Velopack in a cross-platform app with [Iced](https://github.com/iced-rs/iced). | ||||
|   | ||||
		Reference in New Issue
	
	Block a user