forked from sindresorhus/get-windows
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.d.ts
172 lines (137 loc) · 4.19 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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
export type Options = {
/**
Enable the accessibility permission check. _(macOS)_
Setting this to `false` will prevent the accessibility permission prompt on macOS versions 10.15 and newer. The `url` property won't be retrieved.
@default true
*/
readonly accessibilityPermission: boolean;
/**
Enable the screen recording permission check. _(macOS)_
Setting this to `false` will prevent the screen recording permission prompt on macOS versions 10.15 and newer. The `title` property in the result will always be set to an empty string.
@default true
*/
readonly screenRecordingPermission: boolean;
};
export type BaseOwner = {
/**
Name of the app.
*/
name: string;
/**
Process identifier
*/
processId: number;
/**
Path to the app.
*/
path: string;
};
export type BaseResult = {
/**
Window title.
*/
title: string;
/**
Window identifier.
On Windows, there isn't a clear notion of a "Window ID". Instead it returns the memory address of the window "handle" in the `id` property. That "handle" is unique per window, so it can be used to identify them. [Read more…](https://msdn.microsoft.com/en-us/library/windows/desktop/ms632597(v=vs.85).aspx#window_handle).
*/
id: number;
/**
Window position and size.
*/
bounds: {
x: number;
y: number;
width: number;
height: number;
};
/**
App that owns the window.
*/
owner: BaseOwner;
/**
Memory usage by the window.
*/
memoryUsage: number;
};
// eslint-disable-next-line @typescript-eslint/naming-convention
export type MacOSOwner = {
/**
Bundle identifier.
*/
bundleId: string;
} & BaseOwner;
// eslint-disable-next-line @typescript-eslint/naming-convention
export type MacOSResult = {
platform: "macos";
owner: MacOSOwner;
/**
URL of the active browser tab if the active window is Safari (includes Technology Preview), Chrome (includes Beta, Dev, and Canary), Edge (includes Beta, Dev, and Canary), Brave (includes Beta and Nightly), Mighty, Ghost Browser, WaveBox, Sidekick, Opera (includes Beta and Developer), or Vivaldi.
*/
url?: string;
} & BaseResult;
export type LinuxResult = {
platform: "linux";
} & BaseResult;
export type WindowsResult = {
platform: "windows";
/**
Window content position and size, which excludes the title bar, menu bar, and frame.
*/
contentBounds: {
x: number;
y: number;
width: number;
height: number;
};
} & BaseResult;
export type Result = MacOSResult | LinuxResult | WindowsResult;
/**
Get metadata about the [active window](https://en.wikipedia.org/wiki/Active_window) (title, id, bounds, owner, etc).
@example
```
import {activeWindow} from 'get-windows';
const result = await activeWindow();
if (!result) {
return;
}
if (result.platform === 'macos') {
// Among other fields, `result.owner.bundleId` is available on macOS.
console.log(`Process title is ${result.title} with bundle id ${result.owner.bundleId}.`);
} else if (result.platform === 'windows') {
console.log(`Process title is ${result.title} with path ${result.owner.path}.`);
} else {
console.log(`Process title is ${result.title} with path ${result.owner.path}.`);
}
```
*/
export function activeWindow(options?: Options): Promise<Result | undefined>;
/**
Get metadata about the [active window](https://en.wikipedia.org/wiki/Active_window) synchronously (title, id, bounds, owner, etc).
@example
```
import {activeWindowSync} from 'get-windows';
const result = activeWindowSync();
if (result) {
if (result.platform === 'macos') {
// Among other fields, `result.owner.bundleId` is available on macOS.
console.log(`Process title is ${result.title} with bundle id ${result.owner.bundleId}.`);
} else if (result.platform === 'windows') {
console.log(`Process title is ${result.title} with path ${result.owner.path}.`);
} else {
console.log(`Process title is ${result.title} with path ${result.owner.path}.`);
}
}
```
*/
export function activeWindowSync(options?: Options): Result | undefined;
/**
Get metadata about all open windows.
Windows are returned in order from front to back.
*/
export function openWindows(options?: Options): Promise<Result[]>;
/**
Get metadata about all open windows synchronously.
Windows are returned in order from front to back.
*/
export function openWindowsSync(options?: Options): Result[];