internal-electron.d.ts 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. /// <reference path="../electron.d.ts" />
  2. /**
  3. * This file augments the Electron TS namespace with the internal APIs
  4. * that are not documented but are used by Electron internally
  5. */
  6. declare namespace Electron {
  7. enum ProcessType {
  8. browser = 'browser',
  9. renderer = 'renderer',
  10. worker = 'worker',
  11. utility = 'utility'
  12. }
  13. interface App {
  14. setVersion(version: string): void;
  15. setDesktopName(name: string): void;
  16. setAppPath(path: string | null): void;
  17. _clientCertRequestPasswordHandler: ((params: ClientCertRequestParams) => Promise<string>) | null;
  18. on(event: '-client-certificate-request-password', listener: (event: Event<ClientCertRequestParams>, callback: (password: string) => void) => Promise<void>): this;
  19. }
  20. interface AutoUpdater {
  21. isVersionAllowedForUpdate?(currentVersion: string, targetVersion: string): boolean;
  22. }
  23. type TouchBarItemType = NonNullable<Electron.TouchBarConstructorOptions['items']>[0];
  24. interface BaseWindow {
  25. _init(): void;
  26. _touchBar: Electron.TouchBar | null;
  27. _setTouchBarItems: (items: TouchBarItemType[]) => void;
  28. _setEscapeTouchBarItem: (item: TouchBarItemType | {}) => void;
  29. _refreshTouchBarItem: (itemID: string) => void;
  30. on(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
  31. removeListener(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
  32. }
  33. interface BrowserWindow extends BaseWindow {
  34. _init(): void;
  35. _getWindowButtonVisibility: () => boolean;
  36. _getAlwaysOnTopLevel: () => string;
  37. devToolsWebContents: WebContents;
  38. frameName: string;
  39. _browserViews: BrowserView[];
  40. on(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
  41. removeListener(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
  42. }
  43. interface BrowserView {
  44. ownerWindow: BrowserWindow | null
  45. webContentsView: WebContentsView
  46. }
  47. interface BrowserWindowConstructorOptions {
  48. webContents?: WebContents;
  49. }
  50. interface ContextBridge {
  51. internalContextBridge?: {
  52. contextIsolationEnabled: boolean;
  53. overrideGlobalValueFromIsolatedWorld(keys: string[], value: any): void;
  54. overrideGlobalValueWithDynamicPropsFromIsolatedWorld(keys: string[], value: any): void;
  55. overrideGlobalPropertyFromIsolatedWorld(keys: string[], getter: Function, setter?: Function): void;
  56. }
  57. }
  58. interface ServiceWorkers {
  59. _getWorkerFromVersionIDIfExists(versionId: number): Electron.ServiceWorkerMain | undefined;
  60. _stopAllWorkers(): Promise<void>;
  61. }
  62. interface ServiceWorkerMain {
  63. _send(internal: boolean, channel: string, args: any): void;
  64. _startExternalRequest(hasTimeout: boolean): { id: string, ok: boolean };
  65. _finishExternalRequest(uuid: string): void;
  66. _countExternalRequests(): number;
  67. }
  68. interface Session {
  69. _init(): void;
  70. }
  71. interface TouchBar {
  72. _removeFromWindow: (win: BaseWindow) => void;
  73. }
  74. interface WebContents {
  75. _awaitNextLoad(expectedUrl: string): Promise<void>;
  76. _loadURL(url: string, options: ElectronInternal.LoadURLOptions): void;
  77. getOwnerBrowserWindow(): Electron.BrowserWindow | null;
  78. getLastWebPreferences(): Electron.WebPreferences | null;
  79. _getProcessMemoryInfo(): Electron.ProcessMemoryInfo;
  80. _getPreloadScript(): Electron.PreloadScript | null;
  81. equal(other: WebContents): boolean;
  82. browserWindowOptions: BrowserWindowConstructorOptions;
  83. _windowOpenHandler: ((details: Electron.HandlerDetails) => any) | null;
  84. _callWindowOpenHandler(event: any, details: Electron.HandlerDetails): {browserWindowConstructorOptions: Electron.BrowserWindowConstructorOptions | null, outlivesOpener: boolean, createWindow?: Electron.CreateWindowFunction};
  85. _setNextChildWebPreferences(prefs: Partial<Electron.BrowserWindowConstructorOptions['webPreferences']> & Pick<Electron.BrowserWindowConstructorOptions, 'backgroundColor'>): void;
  86. _send(internal: boolean, channel: string, args: any): boolean;
  87. _sendInternal(channel: string, ...args: any[]): void;
  88. _printToPDF(options: any): Promise<Buffer>;
  89. _print(options: any, callback?: (success: boolean, failureReason: string) => void): void;
  90. _getPrintersAsync(): Promise<Electron.PrinterInfo[]>;
  91. _init(): void;
  92. _getNavigationEntryAtIndex(index: number): Electron.NavigationEntry | null;
  93. _getActiveIndex(): number;
  94. _historyLength(): number;
  95. _canGoBack(): boolean;
  96. _canGoForward(): boolean;
  97. _canGoToOffset(index: number): boolean;
  98. _goBack(): void;
  99. _goForward(): void;
  100. _goToOffset(index: number): void;
  101. _goToIndex(index: number): void;
  102. _removeNavigationEntryAtIndex(index: number): boolean;
  103. _getHistory(): Electron.NavigationEntry[];
  104. _restoreHistory(index: number, entries: Electron.NavigationEntry[]): void
  105. _clearHistory():void
  106. canGoToIndex(index: number): boolean;
  107. destroy(): void;
  108. // <webview>
  109. attachToIframe(embedderWebContents: Electron.WebContents, embedderFrameId: number): void;
  110. detachFromOuterFrame(): void;
  111. setEmbedder(embedder: Electron.WebContents): void;
  112. viewInstanceId: number;
  113. _setOwnerWindow(w: BaseWindow | null): void;
  114. }
  115. interface WebFrameMain {
  116. _send(internal: boolean, channel: string, args: any): void;
  117. _sendInternal(channel: string, ...args: any[]): void;
  118. _postMessage(channel: string, message: any, transfer?: any[]): void;
  119. _lifecycleStateForTesting: string;
  120. }
  121. interface WebFrame {
  122. _isEvalAllowed(): boolean;
  123. }
  124. interface WebPreferences {
  125. disablePopups?: boolean;
  126. embedder?: Electron.WebContents;
  127. type?: 'backgroundPage' | 'window' | 'browserView' | 'remote' | 'webview' | 'offscreen';
  128. }
  129. interface Session {
  130. _setDisplayMediaRequestHandler: Electron.Session['setDisplayMediaRequestHandler'];
  131. }
  132. type CreateWindowFunction = (options: BrowserWindowConstructorOptions) => WebContents;
  133. interface Menu {
  134. _init(): void;
  135. _isCommandIdChecked(id: string): boolean;
  136. _isCommandIdEnabled(id: string): boolean;
  137. _shouldCommandIdWorkWhenHidden(id: string): boolean;
  138. _isCommandIdVisible(id: string): boolean;
  139. _getAcceleratorForCommandId(id: string, useDefaultAccelerator: boolean): Accelerator | undefined;
  140. _shouldRegisterAcceleratorForCommandId(id: string): boolean;
  141. _getSharingItemForCommandId(id: string): SharingItem | null;
  142. _callMenuWillShow(): void;
  143. _executeCommand(event: KeyboardEvent, id: number): void;
  144. _menuWillShow(): void;
  145. commandsMap: Record<string, MenuItem>;
  146. groupsMap: Record<string, MenuItem[]>;
  147. getItemCount(): number;
  148. popupAt(window: BaseWindow, x: number, y: number, positioning: number, sourceType: Required<Electron.PopupOptions>['sourceType'], callback: () => void): void;
  149. closePopupAt(id: number): void;
  150. setSublabel(index: number, label: string): void;
  151. setToolTip(index: number, tooltip: string): void;
  152. setIcon(index: number, image: string | NativeImage): void;
  153. setRole(index: number, role: string): void;
  154. insertItem(index: number, commandId: number, label: string): void;
  155. insertCheckItem(index: number, commandId: number, label: string): void;
  156. insertRadioItem(index: number, commandId: number, label: string, groupId: number): void;
  157. insertSeparator(index: number): void;
  158. insertSubMenu(index: number, commandId: number, label: string, submenu?: Menu): void;
  159. delegate?: any;
  160. _getAcceleratorTextAt(index: number): string;
  161. }
  162. interface MenuItem {
  163. overrideReadOnlyProperty(property: string, value: any): void;
  164. groupId: number;
  165. getDefaultRoleAccelerator(): Accelerator | undefined;
  166. getCheckStatus(): boolean;
  167. acceleratorWorksWhenHidden?: boolean;
  168. }
  169. interface ReplyChannel {
  170. sendReply(value: any): void;
  171. }
  172. interface IpcMainEvent {
  173. _replyChannel: ReplyChannel;
  174. frameTreeNodeId?: number;
  175. }
  176. interface IpcMainInvokeEvent {
  177. _replyChannel: ReplyChannel;
  178. frameTreeNodeId?: number;
  179. }
  180. interface IpcMainServiceWorkerEvent {
  181. _replyChannel: ReplyChannel;
  182. }
  183. interface IpcMainServiceWorkerInvokeEvent {
  184. _replyChannel: ReplyChannel;
  185. }
  186. // Deprecated / undocumented BrowserWindow methods
  187. interface BrowserWindow {
  188. getURL(): string;
  189. send(channel: string, ...args: any[]): void;
  190. openDevTools(options?: Electron.OpenDevToolsOptions): void;
  191. closeDevTools(): void;
  192. isDevToolsOpened(): void;
  193. isDevToolsFocused(): void;
  194. toggleDevTools(): void;
  195. inspectElement(x: number, y: number): void;
  196. inspectSharedWorker(): void;
  197. inspectServiceWorker(): void;
  198. getBackgroundThrottling(): void;
  199. setBackgroundThrottling(allowed: boolean): void;
  200. }
  201. interface Protocol {
  202. registerProtocol(scheme: string, handler: any): boolean;
  203. interceptProtocol(scheme: string, handler: any): boolean;
  204. }
  205. interface WebContents {
  206. on(event: '-new-window', listener: (event: Electron.Event, url: string, frameName: string, disposition: Electron.HandlerDetails['disposition'],
  207. rawFeatures: string, referrer: Electron.Referrer, postData: LoadURLOptions['postData']) => void): this;
  208. on(event: '-add-new-contents', listener: (event: Event, webContents: Electron.WebContents, disposition: string,
  209. _userGesture: boolean, _left: number, _top: number, _width: number, _height: number, url: string, frameName: string,
  210. referrer: Electron.Referrer, rawFeatures: string, postData: LoadURLOptions['postData']) => void): this;
  211. on(event: '-will-add-new-contents', listener: (event: Electron.Event, url: string, frameName: string, rawFeatures: string, disposition: Electron.HandlerDetails['disposition'], referrer: Electron.Referrer, postData: LoadURLOptions['postData']) => void): this;
  212. on(event: '-ipc-message', listener: (event: Electron.IpcMainEvent, internal: boolean, channel: string, args: any[]) => void): this;
  213. on(event: '-ipc-message-sync', listener: (event: Electron.IpcMainEvent, internal: boolean, channel: string, args: any[]) => void): this;
  214. on(event: '-ipc-invoke', listener: (event: Electron.IpcMainInvokeEvent, internal: boolean, channel: string, args: any[]) => void): this;
  215. on(event: '-ipc-ports', listener: (event: Electron.IpcMainEvent, internal: boolean, channel: string, message: any, ports: any[]) => void): this;
  216. on(event: '-run-dialog', listener: (info: {frame: WebFrameMain, dialogType: 'prompt' | 'confirm' | 'alert', messageText: string, defaultPromptText: string}, callback: (success: boolean, user_input: string) => void) => void): this;
  217. on(event: '-cancel-dialogs', listener: () => void): this;
  218. on(event: 'ready-to-show', listener: () => void): this;
  219. on(event: '-before-unload-fired', listener: (event: Electron.Event, proceed: boolean) => void): this;
  220. on(event: '-window-visibility-change', listener: (visibilityState: 'hidden' | 'visible') => void): this;
  221. removeListener(event: '-window-visibility-change', listener: (visibilityState: 'hidden' | 'visible') => void): this;
  222. once(event: 'destroyed', listener: (event: Electron.Event) => void): this;
  223. }
  224. interface WebContentsWillFrameNavigateEventParams {
  225. processId: number;
  226. routingId: number;
  227. }
  228. }
  229. declare namespace ElectronInternal {
  230. interface DesktopCapturer {
  231. startHandling(captureWindow: boolean, captureScreen: boolean, thumbnailSize: Electron.Size, fetchWindowIcons: boolean): void;
  232. _onerror?: (error: string) => void;
  233. _onfinished?: (sources: Electron.DesktopCapturerSource[], fetchWindowIcons: boolean) => void;
  234. }
  235. interface GetSourcesOptions {
  236. captureWindow: boolean;
  237. captureScreen: boolean;
  238. thumbnailSize: Electron.Size;
  239. fetchWindowIcons: boolean;
  240. }
  241. interface GetSourcesResult {
  242. id: string;
  243. name: string;
  244. thumbnail: Electron.NativeImage;
  245. display_id: string;
  246. appIcon: Electron.NativeImage | null;
  247. }
  248. interface IpcRendererInternal extends NodeJS.EventEmitter, Pick<Electron.IpcRenderer, 'send' | 'sendSync' | 'invoke'> {
  249. invoke<T>(channel: string, ...args: any[]): Promise<T>;
  250. }
  251. type IpcMainInternalEvent = Omit<Electron.IpcMainEvent, 'reply'> | Omit<Electron.IpcMainServiceWorkerEvent, 'reply'>;
  252. type IpcMainInternalInvokeEvent = Electron.IpcMainInvokeEvent | Electron.IpcMainServiceWorkerInvokeEvent;
  253. interface IpcMainInternal extends NodeJS.EventEmitter {
  254. handle(channel: string, listener: (event: IpcMainInternalInvokeEvent, ...args: any[]) => Promise<any> | any): void;
  255. on(channel: string, listener: (event: IpcMainInternalEvent, ...args: any[]) => void): this;
  256. once(channel: string, listener: (event: IpcMainInternalEvent, ...args: any[]) => void): this;
  257. }
  258. interface LoadURLOptions extends Electron.LoadURLOptions {
  259. reloadIgnoringCache?: boolean;
  260. }
  261. interface WebContentsPrintOptions extends Electron.WebContentsPrintOptions {
  262. mediaSize?: MediaSize;
  263. }
  264. type MediaSize = {
  265. name: string,
  266. custom_display_name: string,
  267. height_microns: number,
  268. width_microns: number,
  269. imageable_area_left_microns?: number,
  270. imageable_area_bottom_microns?: number,
  271. imageable_area_right_microns?: number,
  272. imageable_area_top_microns?: number,
  273. is_default?: 'true',
  274. }
  275. type PageSize = {
  276. width: number,
  277. height: number,
  278. }
  279. type ModuleLoader = () => any;
  280. interface ModuleEntry {
  281. name: string;
  282. loader: ModuleLoader;
  283. }
  284. interface UtilityProcessWrapper extends NodeJS.EventEmitter {
  285. readonly pid: (number) | (undefined);
  286. kill(): boolean;
  287. postMessage(message: any, transfer?: any[]): void;
  288. }
  289. interface ParentPort extends NodeJS.EventEmitter {
  290. start(): void;
  291. pause(): void;
  292. postMessage(message: any): void;
  293. }
  294. class WebViewElement extends HTMLElement {
  295. static observedAttributes: Array<string>;
  296. public contentWindow: Window;
  297. public connectedCallback?(): void;
  298. public attributeChangedCallback?(): void;
  299. public disconnectedCallback?(): void;
  300. // Created in web-view-impl
  301. public getWebContentsId(): number;
  302. public capturePage(rect?: Electron.Rectangle): Promise<Electron.NativeImage>;
  303. }
  304. class WebContents extends Electron.WebContents {
  305. static create(opts?: Electron.WebPreferences): Electron.WebContents;
  306. }
  307. interface PreloadScript extends Electron.PreloadScript {
  308. contents?: string;
  309. error?: Error;
  310. }
  311. }
  312. declare namespace Chrome {
  313. namespace Tabs {
  314. // https://developer.chrome.com/docs/extensions/tabs#method-executeScript
  315. interface ExecuteScriptDetails {
  316. code?: string;
  317. file?: string;
  318. allFrames?: boolean;
  319. frameId?: number;
  320. matchAboutBlank?: boolean;
  321. runAt?: 'document-start' | 'document-end' | 'document_idle';
  322. cssOrigin: 'author' | 'user';
  323. }
  324. type ExecuteScriptCallback = (result: Array<any>) => void;
  325. // https://developer.chrome.com/docs/extensions/tabs#method-sendMessage
  326. interface SendMessageDetails {
  327. frameId?: number;
  328. }
  329. type SendMessageCallback = (result: any) => void;
  330. }
  331. }
  332. interface Global extends NodeJS.Global {
  333. require: NodeRequire;
  334. module: NodeModule;
  335. __filename: string;
  336. __dirname: string;
  337. }