forked from sindresorhus/get-windows
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathindex.d.ts
More file actions
138 lines (111 loc) · 2.95 KB
/
index.d.ts
File metadata and controls
138 lines (111 loc) · 2.95 KB
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
declare namespace activeWin {
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: number;
}
interface MacOSResult extends BaseResult {
platform: 'macos';
owner: MacOSOwner;
/**
URL of the active browser tab if the active window is Safari, Chrome, Edge, or Brave.
*/
url?: string;
}
interface LinuxResult extends BaseResult {
platform: 'linux';
}
interface WindowsResult extends BaseResult {
platform: 'windows';
}
type Result = MacOSResult | LinuxResult | WindowsResult;
}
declare const activeWin: {
/**
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 activeWin = require('active-win');
(async () => {
const result = await activeWin();
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}.`);
}
})();
```
*/
(): Promise<activeWin.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 activeWin = require('active-win');
const result = activeWin.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(): activeWin.Result | undefined;
};
export = activeWin;