internal-electron.d.ts 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323
  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. }
  12. interface App {
  13. _setDefaultAppPaths(packagePath: string | null): void;
  14. setVersion(version: string): void;
  15. setDesktopName(name: string): void;
  16. setAppPath(path: string | null): void;
  17. }
  18. type TouchBarItemType = NonNullable<Electron.TouchBarConstructorOptions['items']>[0];
  19. interface BaseWindow {
  20. _init(): void;
  21. }
  22. interface BrowserWindow {
  23. _init(): void;
  24. _touchBar: Electron.TouchBar | null;
  25. _setTouchBarItems: (items: TouchBarItemType[]) => void;
  26. _setEscapeTouchBarItem: (item: TouchBarItemType | {}) => void;
  27. _refreshTouchBarItem: (itemID: string) => void;
  28. frameName: string;
  29. on(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
  30. removeListener(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
  31. }
  32. interface ContextBridge {
  33. internalContextBridge: {
  34. contextIsolationEnabled: boolean;
  35. overrideGlobalValueFromIsolatedWorld(keys: string[], value: any): void;
  36. overrideGlobalValueWithDynamicPropsFromIsolatedWorld(keys: string[], value: any): void;
  37. overrideGlobalPropertyFromIsolatedWorld(keys: string[], getter: Function, setter?: Function): void;
  38. isInMainWorld(): boolean;
  39. }
  40. }
  41. interface TouchBar {
  42. _removeFromWindow: (win: BrowserWindow) => void;
  43. }
  44. interface WebContents {
  45. _getURL(): string;
  46. _loadURL(url: string, options: ElectronInternal.LoadURLOptions): void;
  47. _stop(): void;
  48. _goBack(): void;
  49. _goForward(): void;
  50. _goToOffset(offset: number): void;
  51. getOwnerBrowserWindow(): Electron.BrowserWindow;
  52. getWebPreferences(): Electron.WebPreferences;
  53. getLastWebPreferences(): Electron.WebPreferences;
  54. _getProcessMemoryInfo(): Electron.ProcessMemoryInfo;
  55. _getPreloadPaths(): string[];
  56. equal(other: WebContents): boolean;
  57. browserWindowOptions: BrowserWindowConstructorOptions;
  58. _windowOpenHandler: ((opts: {url: string, frameName: string, features: string}) => any) | null;
  59. _callWindowOpenHandler(event: any, url: string, frameName: string, rawFeatures: string): Electron.BrowserWindowConstructorOptions | null;
  60. _setNextChildWebPreferences(prefs: Partial<Electron.BrowserWindowConstructorOptions['webPreferences']> & Pick<Electron.BrowserWindowConstructorOptions, 'backgroundColor'>): void;
  61. _send(internal: boolean, channel: string, args: any): boolean;
  62. _sendToFrameInternal(frameId: number | [number, number], channel: string, ...args: any[]): boolean;
  63. _sendInternal(channel: string, ...args: any[]): void;
  64. _printToPDF(options: any): Promise<Buffer>;
  65. _print(options: any, callback?: (success: boolean, failureReason: string) => void): void;
  66. _getPrinters(): Electron.PrinterInfo[];
  67. _init(): void;
  68. canGoToIndex(index: number): boolean;
  69. getActiveIndex(): number;
  70. length(): number;
  71. destroy(): void;
  72. // <webview>
  73. attachToIframe(embedderWebContents: Electron.WebContents, embedderFrameId: number): void;
  74. detachFromOuterFrame(): void;
  75. setEmbedder(embedder: Electron.WebContents): void;
  76. attachParams?: Record<string, any>;
  77. viewInstanceId: number;
  78. }
  79. interface WebFrame {
  80. getWebFrameId(window: Window): number;
  81. allowGuestViewElementDefinition(window: Window, context: any): void;
  82. }
  83. interface WebFrameMain {
  84. _send(internal: boolean, channel: string, args: any): void;
  85. _sendInternal(channel: string, ...args: any[]): void;
  86. _postMessage(channel: string, message: any, transfer?: any[]): void;
  87. }
  88. interface WebPreferences {
  89. guestInstanceId?: number;
  90. openerId?: number;
  91. disablePopups?: boolean;
  92. preloadURL?: string;
  93. embedder?: Electron.WebContents;
  94. type?: 'backgroundPage' | 'window' | 'browserView' | 'remote' | 'webview' | 'offscreen';
  95. }
  96. interface Menu {
  97. _init(): void;
  98. _isCommandIdChecked(id: string): boolean;
  99. _isCommandIdEnabled(id: string): boolean;
  100. _shouldCommandIdWorkWhenHidden(id: string): boolean;
  101. _isCommandIdVisible(id: string): boolean;
  102. _getAcceleratorForCommandId(id: string, useDefaultAccelerator: boolean): Accelerator | undefined;
  103. _shouldRegisterAcceleratorForCommandId(id: string): boolean;
  104. _getSharingItemForCommandId(id: string): SharingItem | null;
  105. _callMenuWillShow(): void;
  106. _executeCommand(event: any, id: number): void;
  107. _menuWillShow(): void;
  108. commandsMap: Record<string, MenuItem>;
  109. groupsMap: Record<string, {
  110. checked: boolean;
  111. }[]>;
  112. getItemCount(): number;
  113. popupAt(window: BaseWindow, x: number, y: number, positioning: number, callback: () => void): void;
  114. closePopupAt(id: number): void;
  115. setSublabel(index: number, label: string): void;
  116. setToolTip(index: number, tooltip: string): void;
  117. setIcon(index: number, image: string | NativeImage): void;
  118. setRole(index: number, role: string): void;
  119. insertItem(index: number, commandId: number, label: string): void;
  120. insertCheckItem(index: number, commandId: number, label: string): void;
  121. insertRadioItem(index: number, commandId: number, label: string, groupId: number): void;
  122. insertSeparator(index: number): void;
  123. insertSubMenu(index: number, commandId: number, label: string, submenu?: Menu): void;
  124. delegate?: any;
  125. getAcceleratorTextAt(index: number): string;
  126. }
  127. interface MenuItem {
  128. overrideReadOnlyProperty(property: string, value: any): void;
  129. groupId: number;
  130. getDefaultRoleAccelerator(): Accelerator | undefined;
  131. getCheckStatus(): boolean;
  132. acceleratorWorksWhenHidden?: boolean;
  133. }
  134. interface IpcMainInvokeEvent {
  135. _reply(value: any): void;
  136. _throw(error: Error): void;
  137. }
  138. const deprecate: ElectronInternal.DeprecationUtil;
  139. namespace Main {
  140. const deprecate: ElectronInternal.DeprecationUtil;
  141. }
  142. class View {}
  143. // Experimental views API
  144. class BaseWindow {
  145. constructor(args: {show: boolean})
  146. setContentView(view: View): void
  147. static fromId(id: number): BaseWindow;
  148. static getAllWindows(): BaseWindow[];
  149. isFocused(): boolean;
  150. static getFocusedWindow(): BaseWindow | undefined;
  151. setMenu(menu: Menu): void;
  152. }
  153. class WebContentsView {
  154. constructor(options: BrowserWindowConstructorOptions)
  155. }
  156. // Deprecated / undocumented BrowserWindow methods
  157. interface BrowserWindow {
  158. getURL(): string;
  159. send(channel: string, ...args: any[]): void;
  160. openDevTools(options?: Electron.OpenDevToolsOptions): void;
  161. closeDevTools(): void;
  162. isDevToolsOpened(): void;
  163. isDevToolsFocused(): void;
  164. toggleDevTools(): void;
  165. inspectElement(x: number, y: number): void;
  166. inspectSharedWorker(): void;
  167. inspectServiceWorker(): void;
  168. getBackgroundThrottling(): void;
  169. setBackgroundThrottling(allowed: boolean): void;
  170. }
  171. namespace Main {
  172. class BaseWindow extends Electron.BaseWindow {}
  173. class View extends Electron.View {}
  174. class WebContentsView extends Electron.WebContentsView {}
  175. }
  176. }
  177. declare namespace ElectronInternal {
  178. type DeprecationHandler = (message: string) => void;
  179. interface DeprecationUtil {
  180. warnOnce(oldName: string, newName?: string): () => void;
  181. setHandler(handler: DeprecationHandler | null): void;
  182. getHandler(): DeprecationHandler | null;
  183. warn(oldName: string, newName: string): void;
  184. log(message: string): void;
  185. removeFunction<T extends Function>(fn: T, removedName: string): T;
  186. renameFunction<T extends Function>(fn: T, newName: string): T;
  187. event(emitter: NodeJS.EventEmitter, oldName: string, newName: string): void;
  188. removeProperty<T, K extends (keyof T & string)>(object: T, propertyName: K, onlyForValues?: any[]): T;
  189. renameProperty<T, K extends (keyof T & string)>(object: T, oldName: string, newName: K): T;
  190. moveAPI<T extends Function>(fn: T, oldUsage: string, newUsage: string): T;
  191. }
  192. interface DesktopCapturer {
  193. startHandling(captureWindow: boolean, captureScreen: boolean, thumbnailSize: Electron.Size, fetchWindowIcons: boolean): void;
  194. _onerror?: (error: string) => void;
  195. _onfinished?: (sources: Electron.DesktopCapturerSource[], fetchWindowIcons: boolean) => void;
  196. }
  197. interface GetSourcesOptions {
  198. captureWindow: boolean;
  199. captureScreen: boolean;
  200. thumbnailSize: Electron.Size;
  201. fetchWindowIcons: boolean;
  202. }
  203. interface GetSourcesResult {
  204. id: string;
  205. name: string;
  206. thumbnail: Electron.NativeImage;
  207. display_id: string;
  208. appIcon: Electron.NativeImage | null;
  209. }
  210. interface IpcRendererInternal extends Electron.IpcRenderer {
  211. invoke<T>(channel: string, ...args: any[]): Promise<T>;
  212. onMessageFromMain(channel: string, listener: (event: Electron.IpcRendererEvent, ...args: any[]) => void): this;
  213. onceMessageFromMain(channel: string, listener: (event: Electron.IpcRendererEvent, ...args: any[]) => void): this;
  214. }
  215. // Internal IPC has _replyInternal and NO reply method
  216. interface IpcMainInternalEvent extends Omit<Electron.IpcMainEvent, 'reply'> {
  217. _replyInternal(...args: any[]): void;
  218. }
  219. interface IpcMainInternal extends NodeJS.EventEmitter {
  220. handle(channel: string, listener: (event: Electron.IpcMainInvokeEvent, ...args: any[]) => Promise<any> | any): void;
  221. on(channel: string, listener: (event: IpcMainInternalEvent, ...args: any[]) => void): this;
  222. once(channel: string, listener: (event: IpcMainInternalEvent, ...args: any[]) => void): this;
  223. }
  224. interface LoadURLOptions extends Electron.LoadURLOptions {
  225. reloadIgnoringCache?: boolean;
  226. }
  227. type ModuleLoader = () => any;
  228. interface ModuleEntry {
  229. name: string;
  230. private?: boolean;
  231. loader: ModuleLoader;
  232. }
  233. interface WebFrameResizeEvent extends WebViewEvent {
  234. newWidth: number;
  235. newHeight: number;
  236. }
  237. interface WebViewEvent extends Event {
  238. url: string;
  239. isMainFrame: boolean;
  240. }
  241. class WebViewElement extends HTMLElement {
  242. static observedAttributes: Array<string>;
  243. public contentWindow: Window;
  244. public connectedCallback?(): void;
  245. public attributeChangedCallback?(): void;
  246. public disconnectedCallback?(): void;
  247. // Created in web-view-impl
  248. public getWebContentsId(): number;
  249. public capturePage(rect?: Electron.Rectangle): Promise<Electron.NativeImage>;
  250. }
  251. class WebContents extends Electron.WebContents {
  252. static create(opts: Electron.WebPreferences): Electron.WebContents;
  253. }
  254. }
  255. declare namespace Chrome {
  256. namespace Tabs {
  257. // https://developer.chrome.com/extensions/tabs#method-executeScript
  258. interface ExecuteScriptDetails {
  259. code?: string;
  260. file?: string;
  261. allFrames?: boolean;
  262. frameId?: number;
  263. matchAboutBlank?: boolean;
  264. runAt?: 'document-start' | 'document-end' | 'document_idle';
  265. cssOrigin: 'author' | 'user';
  266. }
  267. type ExecuteScriptCallback = (result: Array<any>) => void;
  268. // https://developer.chrome.com/extensions/tabs#method-sendMessage
  269. interface SendMessageDetails {
  270. frameId?: number;
  271. }
  272. type SendMessageCallback = (result: any) => void;
  273. }
  274. }
  275. interface Global extends NodeJS.Global {
  276. require: NodeRequire;
  277. module: NodeModule;
  278. __filename: string;
  279. __dirname: string;
  280. }