forked from mawie81/electron-window-state
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.d.ts
48 lines (44 loc) · 2.59 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import * as Electron from 'electron'
declare function windowStateKeeper(opts: windowStateKeeper.Options): windowStateKeeper.State;
declare namespace windowStateKeeper {
interface Options {
/** The height that should be returned if no file exists yet. Defaults to `600`. */
defaultHeight?: number;
/** The width that should be returned if no file exists yet. Defaults to `800`. */
defaultWidth?: number;
fullScreen?: boolean;
/** The path where the state file should be written to. Defaults to `app.getPath('userData')`. */
path?: string;
/** The name of file. Defaults to `window-state.json`. */
file?: string;
/** Should we automatically maximize the window, if it was last closed maximized. Defaults to `true`. */
maximize?: boolean;
/** Allow the window to go out of bounds as long as one corner is still in view. */
outOfBounds?: boolean;
}
interface State {
displayBounds: {
height: number;
width: number;
};
/** The saved height of loaded state. `defaultHeight` if the state has not been saved yet. */
height: number;
/** true if the window state was saved while the window was in full screen mode. `undefined` if the state has not been saved yet. */
isFullScreen: boolean;
/** `true` if the window state was saved while the window was maximized. `undefined` if the state has not been saved yet. */
isMaximized: boolean;
/** Register listeners on the given `BrowserWindow` for events that are related to size or position changes (resize, move). It will also restore the window's maximized or full screen state. When the window is closed we automatically remove the listeners and save the state. */
manage: (window: Electron.BrowserWindow) => void;
/** Saves the current state of the given `BrowserWindow`. This exists mostly for legacy purposes, and in most cases it's better to just use `manage()`. */
saveState: (window: Electron.BrowserWindow) => void;
/** Removes all listeners of the managed `BrowserWindow` in case it does not need to be managed anymore. */
unmanage: () => void;
/** The saved width of loaded state. `defaultWidth` if the state has not been saved yet. */
width: number;
/** The saved x coordinate of the loaded state. `undefined` if the state has not been saved yet. */
x: number;
/** The saved y coordinate of the loaded state. `undefined` if the state has not been saved yet. */
y: number;
}
}
export = windowStateKeeper;