forked from JoseMoreville/active-win
-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.d.ts
149 lines (119 loc) · 3.58 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
declare namespace activeWindow {
interface Options {
/**
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;
}
interface BaseOwner {
/**
Name of the app.
*/
name: string;
/**
Process identifier
*/
processId: number;
/**
Path to the app.
*/
path: string;
}
interface 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;
}
interface MacOSOwner extends BaseOwner {
/**
Bundle identifier.
*/
bundleId: string;
}
interface MacOSResult extends BaseResult {
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;
}
interface LinuxResult extends BaseResult {
platform: 'linux';
}
interface WindowsResult extends BaseResult {
platform: 'windows';
}
type Result = MacOSResult | LinuxResult | WindowsResult;
}
declare const activeWindow: {
/**
Get metadata about the [active window](https://en.wikipedia.org/wiki/Active_window) (title, id, bounds, owner, etc).
@returns The active window metadata.
@example
```
import activeWindow = require('active-win');
(async () => {
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}.`);
}
})();
```
*/
(options?: activeWindow.Options): Promise<activeWindow.Result | undefined>;
/**
Synchronously get metadata about the [active window](https://en.wikipedia.org/wiki/Active_window) (title, id, bounds, owner, etc).
@returns The active window metadata.
@example
```
import activeWindow = require('active-win');
const result = activeWindow.sync();
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}.`);
}
}
```
*/
sync(options?: activeWindow.Options): activeWindow.Result | undefined;
};
export = activeWindow;