123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- import * as path from 'path'
- import * as electron from 'electron'
- import { EventEmitter } from 'events'
- const bindings = process.electronBinding('app')
- const commandLine = process.electronBinding('command_line')
- const { app, App } = bindings
- // Only one app object permitted.
- export default app
- const { deprecate, Menu } = electron
- let dockMenu: Electron.Menu | null = null
- // App is an EventEmitter.
- Object.setPrototypeOf(App.prototype, EventEmitter.prototype)
- EventEmitter.call(app as any)
- Object.assign(app, {
- // TODO(codebytere): remove in 7.0
- setApplicationMenu (menu: Electron.Menu | null) {
- return Menu.setApplicationMenu(menu)
- },
- // TODO(codebytere): remove in 7.0
- getApplicationMenu () {
- return Menu.getApplicationMenu()
- },
- commandLine: {
- hasSwitch: (theSwitch: string) => commandLine.hasSwitch(String(theSwitch)),
- getSwitchValue: (theSwitch: string) => commandLine.getSwitchValue(String(theSwitch)),
- appendSwitch: (theSwitch: string, value?: string) => commandLine.appendSwitch(String(theSwitch), typeof value === 'undefined' ? value : String(value)),
- appendArgument: (arg: string) => commandLine.appendArgument(String(arg))
- } as Electron.CommandLine,
- enableMixedSandbox () {
- deprecate.log(`'enableMixedSandbox' is deprecated. Mixed-sandbox mode is now enabled by default. You can safely remove the call to enableMixedSandbox().`)
- }
- })
- // we define this here because it'd be overly complicated to
- // do in native land
- Object.defineProperty(app, 'applicationMenu', {
- get () {
- return Menu.getApplicationMenu()
- },
- set (menu: Electron.Menu | null) {
- return Menu.setApplicationMenu(menu)
- }
- })
- app.isPackaged = (() => {
- const execFile = path.basename(process.execPath).toLowerCase()
- if (process.platform === 'win32') {
- return execFile !== 'electron.exe'
- }
- return execFile !== 'electron'
- })()
- app._setDefaultAppPaths = (packagePath) => {
- // Set the user path according to application's name.
- app.setPath('userData', path.join(app.getPath('appData'), app.getName()))
- app.setPath('userCache', path.join(app.getPath('cache'), app.getName()))
- app.setAppPath(packagePath)
- // Add support for --user-data-dir=
- const userDataDirFlag = '--user-data-dir='
- const userDataArg = process.argv.find(arg => arg.startsWith(userDataDirFlag))
- if (userDataArg) {
- const userDataDir = userDataArg.substr(userDataDirFlag.length)
- if (path.isAbsolute(userDataDir)) app.setPath('userData', userDataDir)
- }
- }
- if (process.platform === 'darwin') {
- const setDockMenu = app.dock.setMenu
- app.dock.setMenu = (menu) => {
- dockMenu = menu
- setDockMenu(menu)
- }
- app.dock.getMenu = () => dockMenu
- }
- // Routes the events to webContents.
- const events = ['login', 'certificate-error', 'select-client-certificate']
- for (const name of events) {
- app.on(name as 'login', (event, webContents, ...args: any[]) => {
- webContents.emit(name, event, ...args)
- })
- }
- // Function Deprecations
- app.getFileIcon = deprecate.promisify(app.getFileIcon)
- // Property Deprecations
- deprecate.fnToProperty(app, 'accessibilitySupportEnabled', '_isAccessibilitySupportEnabled', '_setAccessibilitySupportEnabled')
- // Wrappers for native classes.
- const { DownloadItem } = process.electronBinding('download_item')
- Object.setPrototypeOf(DownloadItem.prototype, EventEmitter.prototype)
|