window
Provides APIs to create windows, communicate with other windows and manipulate the current window.
Window events
Section titled “Window events”Events can be listened to using Window.listen:
import { getCurrentWindow } from "@tauri-apps/api/window";getCurrentWindow().listen("my-window-event", ({ event, payload }) => { });References
Section titled “References”Re-exports Color
DragDropEvent
Section titled “DragDropEvent”Re-exports DragDropEvent
LogicalPosition
Section titled “LogicalPosition”Re-exports LogicalPosition
LogicalSize
Section titled “LogicalSize”Re-exports LogicalSize
PhysicalPosition
Section titled “PhysicalPosition”Re-exports PhysicalPosition
PhysicalSize
Section titled “PhysicalSize”Re-exports PhysicalSize
Enumerations
Section titled “Enumerations”BackgroundThrottlingPolicy
Section titled “BackgroundThrottlingPolicy”Background throttling policy
2.0.0
Enumeration Members
Section titled “Enumeration Members”Disabled
Section titled “Disabled”Disabled: "disabled";Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2133
Suspend
Section titled “Suspend”Suspend: "suspend";Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2135
Throttle
Section titled “Throttle”Throttle: "throttle";Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2134
Effect
Section titled “Effect”Platform-specific window effects
2.0.0
Enumeration Members
Section titled “Enumeration Members”Acrylic
Section titled “Acrylic”Acrylic: "acrylic";Windows 10/11
This effect has bad performance when resizing/dragging the window on Windows 10 v1903+ and Windows 11 build 22000.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2272
AppearanceBased
Section titled “AppearanceBased”AppearanceBased: "appearanceBased";A default material appropriate for the view’s effectiveAppearance. macOS 10.14-
Deprecated
Section titled “Deprecated”since macOS 10.14. You should instead choose an appropriate semantic material.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2172
Blur: "blur";Windows 7/10/11(22H1) Only
This effect has bad performance when resizing/dragging the window on Windows 11 build 22621.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2264
ContentBackground
Section titled “ContentBackground”ContentBackground: "contentBackground";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2244
Dark: "dark";macOS 10.14-
Deprecated
Section titled “Deprecated”since macOS 10.14. Use a semantic material instead.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2184
FullScreenUI
Section titled “FullScreenUI”FullScreenUI: "fullScreenUI";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2236
HeaderView
Section titled “HeaderView”HeaderView: "headerView";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2220
HudWindow
Section titled “HudWindow”HudWindow: "hudWindow";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2232
Light: "light";macOS 10.14-
Deprecated
Section titled “Deprecated”since macOS 10.14. Use a semantic material instead.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2178
MediumLight
Section titled “MediumLight”MediumLight: "mediumLight";macOS 10.14-
Deprecated
Section titled “Deprecated”since macOS 10.14. Use a semantic material instead.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2190
Menu: "menu";macOS 10.11+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2208
Mica: "mica";Windows 11 Only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2256
Popover
Section titled “Popover”Popover: "popover";macOS 10.11+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2212
Selection
Section titled “Selection”Selection: "selection";macOS 10.10+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2204
Sheet: "sheet";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2224
Sidebar
Section titled “Sidebar”Sidebar: "sidebar";macOS 10.11+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2216
Tabbed
Section titled “Tabbed”Tabbed: "tabbed";Tabbed effect that matches the system dark preference Windows 11 Only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2276
TabbedDark
Section titled “TabbedDark”TabbedDark: "tabbedDark";Tabbed effect with dark mode but only if dark mode is enabled on the system Windows 11 Only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2280
TabbedLight
Section titled “TabbedLight”TabbedLight: "tabbedLight";Tabbed effect with light mode Windows 11 Only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2284
Titlebar
Section titled “Titlebar”Titlebar: "titlebar";macOS 10.10+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2200
Tooltip
Section titled “Tooltip”Tooltip: "tooltip";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2240
UltraDark
Section titled “UltraDark”UltraDark: "ultraDark";macOS 10.14-
Deprecated
Section titled “Deprecated”since macOS 10.14. Use a semantic material instead.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2196
UnderPageBackground
Section titled “UnderPageBackground”UnderPageBackground: "underPageBackground";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2252
UnderWindowBackground
Section titled “UnderWindowBackground”UnderWindowBackground: "underWindowBackground";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2248
WindowBackground
Section titled “WindowBackground”WindowBackground: "windowBackground";macOS 10.14+
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2228
EffectState
Section titled “EffectState”Window effect state macOS only
https://developer.apple.com/documentation/appkit/nsvisualeffectview/state
2.0.0
Enumeration Members
Section titled “Enumeration Members”Active
Section titled “Active”Active: "active";Make window effect state always active macOS only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2302
FollowsWindowActiveState
Section titled “FollowsWindowActiveState”FollowsWindowActiveState: "followsWindowActiveState";Make window effect state follow the window’s active state macOS only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2298
Inactive
Section titled “Inactive”Inactive: "inactive";Make window effect state always inactive macOS only
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2306
ProgressBarStatus
Section titled “ProgressBarStatus”Enumeration Members
Section titled “Enumeration Members”Error: "error";Error state. Treated as Normal on linux
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L220
Indeterminate
Section titled “Indeterminate”Indeterminate: "indeterminate";Indeterminate state. Treated as Normal on Linux and macOS
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L212
None: "none";Hide progress bar.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L204
Normal
Section titled “Normal”Normal: "normal";Normal state.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L208
Paused
Section titled “Paused”Paused: "paused";Paused state. Treated as Normal on Linux
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L216
ScrollBarStyle
Section titled “ScrollBarStyle”The scrollbar style to use in the webview.
Platform-specific
Section titled “Platform-specific”Windows: This option must be given the same value for all webviews.
2.8.0
Enumeration Members
Section titled “Enumeration Members”Default
Section titled “Default”Default: "default";The default scrollbar style for the webview.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2151
FluentOverlay
Section titled “FluentOverlay”FluentOverlay: "fluentOverlay";Fluent UI style overlay scrollbars. Windows Only
Requires WebView2 Runtime version 125.0.2535.41 or higher, does nothing on older versions, see https://learn.microsoft.com/en-us/microsoft-edge/webview2/release-notes/?tabs=dotnetcsharp#10253541
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2158
UserAttentionType
Section titled “UserAttentionType”Attention type to request on a window.
1.0.0
Enumeration Members
Section titled “Enumeration Members”Critical
Section titled “Critical”Critical: 1;Platform-specific
- macOS: Bounces the dock icon until the application is in focus.
- Windows: Flashes both the window and the taskbar button until the application is in focus.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L129
Informational
Section titled “Informational”Informational: 2;Platform-specific
- macOS: Bounces the dock icon once.
- Windows: Flashes the taskbar button until the application is in focus.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L135
Classes
Section titled “Classes”CloseRequestedEvent
Section titled “CloseRequestedEvent”Constructors
Section titled “Constructors”new CloseRequestedEvent()
Section titled “new CloseRequestedEvent()”new CloseRequestedEvent(event): CloseRequestedEventParameters
Section titled “Parameters”| Parameter | Type |
|---|---|
event |
Event<unknown> |
Returns
Section titled “Returns”Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L145
Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
event |
EventName |
Event name | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L140 |
id |
number |
Event identifier used to unlisten | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L142 |
Methods
Section titled “Methods”isPreventDefault()
Section titled “isPreventDefault()”isPreventDefault(): booleanReturns
Section titled “Returns”boolean
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L154
preventDefault()
Section titled “preventDefault()”preventDefault(): voidReturns
Section titled “Returns”void
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L150
Window
Section titled “Window”Create new window or get a handle to an existing one.
Windows are identified by a label a unique identifier that can be used to reference it later.
It may only contain alphanumeric characters a-zA-Z plus the following special characters -, /, : and _.
Example
Section titled “Example”import { Window } from "@tauri-apps/api/window"
const appWindow = new Window('theUniqueLabel');
appWindow.once('tauri://created', function () { // window successfully created});appWindow.once('tauri://error', function (e) { // an error happened creating the window});
// emit an event to the backendawait appWindow.emit("some-event", "data");// listen to an event from the backendconst unlisten = await appWindow.listen("event-name", e => {});unlisten();2.0.0
Extended by
Section titled “Extended by”Constructors
Section titled “Constructors”new Window()
Section titled “new Window()”new Window(label, options): WindowCreates a new Window.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
label |
string |
The unique window label. Must be alphanumeric: a-zA-Z-/:_. |
options |
WindowOptions |
- |
Returns
Section titled “Returns”The Window instance to communicate with the window.
Example
Section titled “Example”import { Window } from '@tauri-apps/api/window';const appWindow = new Window('my-label');appWindow.once('tauri://created', function () { // window successfully created});appWindow.once('tauri://error', function (e) { // an error happened creating the window});Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L328
Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
label |
string |
The window label. It is a unique identifier for the window, can be used to reference it later. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L306 |
listeners |
Record<string, EventCallback<any>[]> |
Local event listeners. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L309 |
Methods
Section titled “Methods”activityName()
Section titled “activityName()”activityName(): Promise<string>Returns
Section titled “Returns”Promise<string>
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L853
center()
Section titled “center()”center(): Promise<void>Centers the window.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().center();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L877
clearEffects()
Section titled “clearEffects()”clearEffects(): Promise<void>Clear any applied effects if possible.
Returns
Section titled “Returns”Promise<void>
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1265
close()
Section titled “close()”close(): Promise<void>Closes the window.
Note this emits a closeRequested event so you can intercept it. To force window close, use Window.destroy.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().close();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1186
destroy()
Section titled “destroy()”destroy(): Promise<void>Destroys the window. Behaves like Window.close but forces the window close instead of emitting a closeRequested event.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().destroy();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1202
emit()
Section titled “emit()”emit<T>(event, payload?): Promise<void>Emits an event to all targets.
Type Parameters
Section titled “Type Parameters”| Type Parameter |
|---|
T |
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
event |
string |
Event name. Must include only alphanumeric characters, -, /, : and _. |
payload? |
T |
Event payload. |
Returns
Section titled “Returns”Promise<void>
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().emit('window-loaded', { loggedIn: true, token: 'authToken' });Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L479
emitTo()
Section titled “emitTo()”emitTo<T>( target, event,payload?): Promise<void>Emits an event to all targets matching the given target.
Type Parameters
Section titled “Type Parameters”| Type Parameter |
|---|
T |
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
target |
string | EventTarget |
Label of the target Window/Webview/WebviewWindow or raw EventTarget object. |
event |
string |
Event name. Must include only alphanumeric characters, -, /, : and _. |
payload? |
T |
Event payload. |
Returns
Section titled “Returns”Promise<void>
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().emit('main', 'window-loaded', { loggedIn: true, token: 'authToken' });Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L506
hide()
Section titled “hide()”hide(): Promise<void>Sets the window visibility to false.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().hide();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1168
innerPosition()
Section titled “innerPosition()”innerPosition(): Promise<PhysicalPosition>The position of the top-left hand corner of the window’s client area relative to the top-left hand corner of the desktop.
Returns
Section titled “Returns”The window’s inner position.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const position = await getCurrentWindow().innerPosition();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L567
innerSize()
Section titled “innerSize()”innerSize(): Promise<PhysicalSize>The physical size of the window’s client area. The client area is the content of the window, excluding the title bar and borders.
Returns
Section titled “Returns”The window’s inner size.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const size = await getCurrentWindow().innerSize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L600
isAlwaysOnTop()
Section titled “isAlwaysOnTop()”isAlwaysOnTop(): Promise<boolean>Whether the window is configured to be always on top of other windows or not.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is visible or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const alwaysOnTop = await getCurrentWindow().isAlwaysOnTop();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L847
isClosable()
Section titled “isClosable()”isClosable(): Promise<boolean>Gets the window’s native close button state.
Platform-specific
- iOS / Android: Unsupported.
Returns
Section titled “Returns”Promise<boolean>
Whether the window’s native close button is enabled or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const closable = await getCurrentWindow().isClosable();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L780
isDecorated()
Section titled “isDecorated()”isDecorated(): Promise<boolean>Gets the window’s current decorated state.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is decorated or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const decorated = await getCurrentWindow().isDecorated();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L701
isEnabled()
Section titled “isEnabled()”isEnabled(): Promise<boolean>Whether the window is enabled or disabled.
Returns
Section titled “Returns”Promise<boolean>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setEnabled(false);2.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L969
isFocused()
Section titled “isFocused()”isFocused(): Promise<boolean>Gets the window’s current focus state.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is focused or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const focused = await getCurrentWindow().isFocused();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L685
isFullscreen()
Section titled “isFullscreen()”isFullscreen(): Promise<boolean>Gets the window’s current fullscreen state.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is in fullscreen mode or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const fullscreen = await getCurrentWindow().isFullscreen();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L639
isMaximizable()
Section titled “isMaximizable()”isMaximizable(): Promise<boolean>Gets the window’s native maximize button state.
Platform-specific
- Linux / iOS / Android: Unsupported.
Returns
Section titled “Returns”Promise<boolean>
Whether the window’s native maximize button is enabled or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const maximizable = await getCurrentWindow().isMaximizable();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L738
isMaximized()
Section titled “isMaximized()”isMaximized(): Promise<boolean>Gets the window’s current maximized state.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is maximized or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const maximized = await getCurrentWindow().isMaximized();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L669
isMinimizable()
Section titled “isMinimizable()”isMinimizable(): Promise<boolean>Gets the window’s native minimize button state.
Platform-specific
- Linux / iOS / Android: Unsupported.
Returns
Section titled “Returns”Promise<boolean>
Whether the window’s native minimize button is enabled or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const minimizable = await getCurrentWindow().isMinimizable();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L759
isMinimized()
Section titled “isMinimized()”isMinimized(): Promise<boolean>Gets the window’s current minimized state.
Returns
Section titled “Returns”Promise<boolean>
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const minimized = await getCurrentWindow().isMinimized();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L653
isResizable()
Section titled “isResizable()”isResizable(): Promise<boolean>Gets the window’s current resizable state.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is resizable or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const resizable = await getCurrentWindow().isResizable();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L717
isVisible()
Section titled “isVisible()”isVisible(): Promise<boolean>Gets the window’s current visible state.
Returns
Section titled “Returns”Promise<boolean>
Whether the window is visible or not.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const visible = await getCurrentWindow().isVisible();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L796
listen()
Section titled “listen()”listen<T>(event, handler): Promise<UnlistenFn>Listen to an emitted event on this window.
Type Parameters
Section titled “Type Parameters”| Type Parameter |
|---|
T |
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
event |
EventName |
Event name. Must include only alphanumeric characters, -, /, : and _. |
handler |
EventCallback<T> |
Event handler. |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const unlisten = await getCurrentWindow().listen<string>('state-changed', (event) => { console.log(`Got error: ${payload}`);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L417
maximize()
Section titled “maximize()”maximize(): Promise<void>Maximizes the window.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().maximize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1072
minimize()
Section titled “minimize()”minimize(): Promise<void>Minimizes the window.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().minimize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1120
onCloseRequested()
Section titled “onCloseRequested()”onCloseRequested(handler): Promise<UnlistenFn>Listen to window close requested. Emitted when the user requests to closes the window.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
(event) => void | Promise<void> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/window";import { confirm } from '@tauri-apps/api/dialog';const unlisten = await getCurrentWindow().onCloseRequested(async (event) => { const confirmed = await confirm('Are you sure?'); if (!confirmed) { // user did not confirm closing the window; let's prevent it event.preventDefault(); }});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1927
onDragDropEvent()
Section titled “onDragDropEvent()”onDragDropEvent(handler): Promise<UnlistenFn>Listen to a file drop event. The listener is triggered when the user hovers the selected files on the webview, drops the files or cancels the operation.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
EventCallback<DragDropEvent> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/webview";const unlisten = await getCurrentWindow().onDragDropEvent((event) => { if (event.payload.type === 'over') { console.log('User hovering', event.payload.position); } else if (event.payload.type === 'drop') { console.log('User dropped', event.payload.paths); } else { console.log('File drop cancelled'); }});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1965
onFocusChanged()
Section titled “onFocusChanged()”onFocusChanged(handler): Promise<UnlistenFn>Listen to window focus change.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
EventCallback<boolean> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/window";const unlisten = await getCurrentWindow().onFocusChanged(({ payload: focused }) => { console.log('Focus changed, window is focused? ' + focused);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2043
onMoved()
Section titled “onMoved()”onMoved(handler): Promise<UnlistenFn>Listen to window move.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
EventCallback<PhysicalPosition> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/window";const unlisten = await getCurrentWindow().onMoved(({ payload: position }) => { console.log('Window moved', position);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1898
onResized()
Section titled “onResized()”onResized(handler): Promise<UnlistenFn>Listen to window resize.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
EventCallback<PhysicalSize> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/window";const unlisten = await getCurrentWindow().onResized(({ payload: size }) => { console.log('Window resized', size);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1874
onScaleChanged()
Section titled “onScaleChanged()”onScaleChanged(handler): Promise<UnlistenFn>Listen to window scale change. Emitted when the window’s scale factor has changed. The following user actions can cause DPI changes:
- Changing the display’s resolution.
- Changing the display’s scale factor (e.g. in Control Panel on Windows).
- Moving the window to a display with a different scale factor.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
EventCallback<ScaleFactorChanged> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/window";const unlisten = await getCurrentWindow().onScaleChanged(({ payload }) => { console.log('Scale changed', payload.scaleFactor, payload.size);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2083
onThemeChanged()
Section titled “onThemeChanged()”onThemeChanged(handler): Promise<UnlistenFn>Listen to the system theme change.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
handler |
EventCallback<Theme> |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from "@tauri-apps/api/window";const unlisten = await getCurrentWindow().onThemeChanged(({ payload: theme }) => { console.log('New theme: ' + theme);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2109
once()
Section titled “once()”once<T>(event, handler): Promise<UnlistenFn>Listen to an emitted event on this window only once.
Type Parameters
Section titled “Type Parameters”| Type Parameter |
|---|
T |
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
event |
EventName |
Event name. Must include only alphanumeric characters, -, /, : and _. |
handler |
EventCallback<T> |
Event handler. |
Returns
Section titled “Returns”A promise resolving to a function to unlisten to the event. Note that removing the listener is required if your listener goes out of scope e.g. the component is unmounted.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const unlisten = await getCurrentWindow().once<null>('initialized', (event) => { console.log(`Window initialized!`);});
// you need to call unlisten if your handler goes out of scope e.g. the component is unmountedunlisten();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L452
outerPosition()
Section titled “outerPosition()”outerPosition(): Promise<PhysicalPosition>The position of the top-left hand corner of the window relative to the top-left hand corner of the desktop.
Returns
Section titled “Returns”The window’s outer position.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const position = await getCurrentWindow().outerPosition();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L583
outerSize()
Section titled “outerSize()”outerSize(): Promise<PhysicalSize>The physical size of the entire window. These dimensions include the title bar and borders. If you don’t want that (and you usually don’t), use inner_size instead.
Returns
Section titled “Returns”The window’s outer size.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const size = await getCurrentWindow().outerSize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L620
requestUserAttention()
Section titled “requestUserAttention()”requestUserAttention(requestType): Promise<void>Requests user attention to the window, this has no effect if the application
is already focused. How requesting for user attention manifests is platform dependent,
see UserAttentionType for details.
Providing null will unset the request for user attention. Unsetting the request for
user attention might not be done automatically by the WM when the window receives input.
Platform-specific
- macOS:
nullhas no effect. - Linux: Urgency levels have the same effect.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
requestType |
null | UserAttentionType |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().requestUserAttention();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L903
scaleFactor()
Section titled “scaleFactor()”scaleFactor(): Promise<number>The scale factor that can be used to map physical pixels to logical pixels.
Returns
Section titled “Returns”Promise<number>
The window’s monitor scale factor.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const factor = await getCurrentWindow().scaleFactor();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L551
sceneIdentifier()
Section titled “sceneIdentifier()”sceneIdentifier(): Promise<string>Returns
Section titled “Returns”Promise<string>
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L859
setAlwaysOnBottom()
Section titled “setAlwaysOnBottom()”setAlwaysOnBottom(alwaysOnBottom): Promise<void>Whether the window should always be below other windows.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
alwaysOnBottom |
boolean |
Whether the window should always be below other windows or not. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setAlwaysOnBottom(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1301
setAlwaysOnTop()
Section titled “setAlwaysOnTop()”setAlwaysOnTop(alwaysOnTop): Promise<void>Whether the window should always be on top of other windows.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
alwaysOnTop |
boolean |
Whether the window should always be on top of other windows or not. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setAlwaysOnTop(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1283
setBackgroundColor()
Section titled “setBackgroundColor()”setBackgroundColor(color): Promise<void>Sets the window background color.
Platform-specific:
- Windows: alpha channel is ignored.
- iOS / Android: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
color |
Color |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
2.1.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1635
setBadgeCount()
Section titled “setBadgeCount()”setBadgeCount(count?): Promise<void>Sets the badge count. It is app wide and not specific to this window.
Platform-specific
- Windows: Unsupported. Use @{linkcode Window.setOverlayIcon} instead.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
count? |
number |
The badge count. Use undefined to remove the badge. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setBadgeCount(5);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1727
setBadgeLabel()
Section titled “setBadgeLabel()”setBadgeLabel(label?): Promise<void>Sets the badge cont macOS only.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
label? |
string |
The badge label. Use undefined to remove the badge. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setBadgeLabel("Hello");Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1746
setClosable()
Section titled “setClosable()”setClosable(closable): Promise<void>Sets whether the window’s native close button is enabled or not.
Platform-specific
- Linux: GTK+ will do its best to convince the window manager not to show a close button. Depending on the system, this function may not have any effect when called on a window that is already visible
- iOS / Android: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
closable |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setClosable(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1037
setContentProtected()
Section titled “setContentProtected()”setContentProtected(protected_): Promise<void>Prevents the window contents from being captured by other apps.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
protected_ |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setContentProtected(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1318
setCursorGrab()
Section titled “setCursorGrab()”setCursorGrab(grab): Promise<void>Grabs the cursor, preventing it from leaving the window.
There’s no guarantee that the cursor will be hidden. You should hide it by yourself if you want so.
Platform-specific
- Linux: Unsupported.
- macOS: This locks the cursor in a fixed location, which looks visually awkward.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
grab |
boolean |
true to grab the cursor icon, false to release it. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setCursorGrab(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1574
setCursorIcon()
Section titled “setCursorIcon()”setCursorIcon(icon): Promise<void>Modifies the cursor icon of the window.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
icon |
CursorIcon |
The new cursor icon. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setCursorIcon('help');Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1616
setCursorPosition()
Section titled “setCursorPosition()”setCursorPosition(position): Promise<void>Changes the position of the cursor in window coordinates.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
position |
LogicalPosition | PhysicalPosition | Position |
The new cursor position. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow, LogicalPosition } from '@tauri-apps/api/window';await getCurrentWindow().setCursorPosition(new LogicalPosition(600, 300));Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1650
setCursorVisible()
Section titled “setCursorVisible()”setCursorVisible(visible): Promise<void>Modifies the cursor’s visibility.
Platform-specific
- Windows: The cursor is only hidden within the confines of the window.
- macOS: The cursor is hidden as long as the window has input focus, even if the cursor is outside of the window.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
visible |
boolean |
If false, this will hide the cursor. If true, this will show the cursor. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setCursorVisible(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1598
setDecorations()
Section titled “setDecorations()”setDecorations(decorations): Promise<void>Whether the window should have borders and bars.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
decorations |
boolean |
Whether the window should have borders and bars. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setDecorations(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1219
setEffects()
Section titled “setEffects()”setEffects(effects): Promise<void>Set window effects.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
effects |
Effects |
Returns
Section titled “Returns”Promise<void>
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1255
setEnabled()
Section titled “setEnabled()”setEnabled(enabled): Promise<void>Enable or disable the window.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
enabled |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setEnabled(false);2.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L950
setFocus()
Section titled “setFocus()”setFocus(): Promise<void>Bring the window to front and focus.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setFocus();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1476
setFocusable()
Section titled “setFocusable()”setFocusable(focusable): Promise<void>Sets whether the window can be focused.
Platform-specific
- macOS: If the window is already focused, it is not possible to unfocus it after calling
set_focusable(false). In this case, you might consider calling Window.setFocus but it will move the window to the back i.e. at the bottom in terms of z-order.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
focusable |
boolean |
Whether the window can be focused. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setFocusable(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1499
setFullscreen()
Section titled “setFullscreen()”setFullscreen(fullscreen): Promise<void>Sets the window fullscreen state.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
fullscreen |
boolean |
Whether the window should go to fullscreen or not. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setFullscreen(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1443
setIcon()
Section titled “setIcon()”setIcon(icon): Promise<void>Sets the window icon.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
icon |
| string | number[] | ArrayBuffer | Uint8Array<ArrayBufferLike> | Image |
Icon bytes or path to the icon file. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setIcon('/tauri/awesome.png');Note that you may need the image-ico or image-png Cargo features to use this API.
To enable it, change your Cargo.toml file:
[dependencies]tauri = { version = "...", features = ["...", "image-png"] }Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1524
setIgnoreCursorEvents()
Section titled “setIgnoreCursorEvents()”setIgnoreCursorEvents(ignore): Promise<void>Changes the cursor events behavior.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
ignore |
boolean |
true to ignore the cursor events; false to process them as usual. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setIgnoreCursorEvents(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1671
setMaxSize()
Section titled “setMaxSize()”setMaxSize(size): Promise<void>Sets the window maximum inner size. If the size argument is undefined, the constraint is unset.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
size |
| undefined | null | LogicalSize | PhysicalSize | Size |
The logical or physical inner size, or null to unset the constraint. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow, LogicalSize } from '@tauri-apps/api/window';await getCurrentWindow().setMaxSize(new LogicalSize(600, 500));Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1374
setMaximizable()
Section titled “setMaximizable()”setMaximizable(maximizable): Promise<void>Sets whether the window’s native maximize button is enabled or not. If resizable is set to false, this setting is ignored.
Platform-specific
- macOS: Disables the “zoom” button in the window titlebar, which is also used to enter fullscreen mode.
- Linux / iOS / Android: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
maximizable |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setMaximizable(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L992
setMinSize()
Section titled “setMinSize()”setMinSize(size): Promise<void>Sets the window minimum inner size. If the size argument is not provided, the constraint is unset.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
size |
| undefined | null | LogicalSize | PhysicalSize | Size |
The logical or physical inner size, or null to unset the constraint. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow, PhysicalSize } from '@tauri-apps/api/window';await getCurrentWindow().setMinSize(new PhysicalSize(600, 500));Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1354
setMinimizable()
Section titled “setMinimizable()”setMinimizable(minimizable): Promise<void>Sets whether the window’s native minimize button is enabled or not.
Platform-specific
- Linux / iOS / Android: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
minimizable |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setMinimizable(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1014
setOverlayIcon()
Section titled “setOverlayIcon()”setOverlayIcon(icon?): Promise<void>Sets the overlay icon. Windows only The overlay icon can be set for every window.
Note that you may need the image-ico or image-png Cargo features to use this API.
To enable it, change your Cargo.toml file:
[dependencies]tauri = { version = "...", features = ["...", "image-png"] }Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
icon? |
| string | number[] | ArrayBuffer | Uint8Array<ArrayBufferLike> | Image |
Icon bytes or path to the icon file. Use undefined to remove the overlay icon. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setOverlayIcon("/tauri/awesome.png");Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1775
setPosition()
Section titled “setPosition()”setPosition(position): Promise<void>Sets the window outer position.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
position |
LogicalPosition | PhysicalPosition | Position |
The new position, in logical or physical pixels. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow, LogicalPosition } from '@tauri-apps/api/window';await getCurrentWindow().setPosition(new LogicalPosition(600, 500));Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1423
setProgressBar()
Section titled “setProgressBar()”setProgressBar(state): Promise<void>Sets the taskbar progress state.
Platform-specific
- Linux / macOS: Progress bar is app-wide and not specific to this window.
- Linux: Only supported desktop environments with
libunity(e.g. GNOME).
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
state |
ProgressBarState |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow, ProgressBarStatus } from '@tauri-apps/api/window';await getCurrentWindow().setProgressBar({ status: ProgressBarStatus.Normal, progress: 50,});Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1803
setResizable()
Section titled “setResizable()”setResizable(resizable): Promise<void>Updates the window resizable flag.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
resizable |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setResizable(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L931
setShadow()
Section titled “setShadow()”setShadow(enable): Promise<void>Whether or not the window should have shadow.
Platform-specific
- Windows:
falsehas no effect on decorated window, shadows are always ON.truewill make undecorated window have a 1px white border, and on Windows 11, it will have a rounded corners.
- Linux: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
enable |
boolean |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setShadow(false);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1245
setSimpleFullscreen()
Section titled “setSimpleFullscreen()”setSimpleFullscreen(fullscreen): Promise<void>On macOS, Toggles a fullscreen mode that doesn’t require a new macOS space. Returns a boolean indicating whether the transition was successful (this won’t work if the window was already in the native fullscreen). This is how fullscreen used to work on macOS in versions before Lion. And allows the user to have a fullscreen window without using another space or taking control over the entire monitor.
On other platforms, this is the same as Window.setFullscreen.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
fullscreen |
boolean |
Whether the window should go to simple fullscreen or not. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1459
setSize()
Section titled “setSize()”setSize(size): Promise<void>Resizes the window with a new inner size.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
size |
LogicalSize | PhysicalSize | Size |
The logical or physical inner size. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow, LogicalSize } from '@tauri-apps/api/window';await getCurrentWindow().setSize(new LogicalSize(600, 500));Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1336
setSizeConstraints()
Section titled “setSizeConstraints()”setSizeConstraints(constraints): Promise<void>Sets the window inner size constraints.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
constraints |
undefined | null | WindowSizeConstraints |
The logical or physical inner size, or null to unset the constraint. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setSizeConstraints({ minWidth: 300 });Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1394
setSkipTaskbar()
Section titled “setSkipTaskbar()”setSkipTaskbar(skip): Promise<void>Whether the window icon should be hidden from the taskbar or not.
Platform-specific
- macOS: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
skip |
boolean |
true to hide window icon, false to show it. |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setSkipTaskbar(true);Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1548
setTheme()
Section titled “setTheme()”setTheme(theme?): Promise<void>Set window theme, pass in null or undefined to follow system theme
Platform-specific
- Linux / macOS: Theme is app-wide and not specific to this window.
- iOS / Android: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
theme? |
null | Theme |
Returns
Section titled “Returns”Promise<void>
2.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1848
setTitle()
Section titled “setTitle()”setTitle(title): Promise<void>Sets the window title.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
title |
string |
The new title |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().setTitle('Tauri');Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1055
setTitleBarStyle()
Section titled “setTitleBarStyle()”setTitleBarStyle(style): Promise<void>Sets the title bar style. macOS only.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
style |
TitleBarStyle |
Returns
Section titled “Returns”Promise<void>
2.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1831
setVisibleOnAllWorkspaces()
Section titled “setVisibleOnAllWorkspaces()”setVisibleOnAllWorkspaces(visible): Promise<void>Sets whether the window should be visible on all workspaces or virtual desktops.
Platform-specific
- Windows / iOS / Android: Unsupported.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
visible |
boolean |
Returns
Section titled “Returns”Promise<void>
2.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1819
show()
Section titled “show()”show(): Promise<void>Sets the window visibility to true.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().show();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1152
startDragging()
Section titled “startDragging()”startDragging(): Promise<void>Starts dragging the window.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().startDragging();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1688
startResizeDragging()
Section titled “startResizeDragging()”startResizeDragging(direction): Promise<void>Starts resize-dragging the window.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
direction |
ResizeDirection |
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().startResizeDragging();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1704
theme()
Section titled “theme()”theme(): Promise<null | Theme>Gets the window’s current theme.
Platform-specific
- macOS: Theme was introduced on macOS 10.14. Returns
lighton macOS 10.13 and below.
Returns
Section titled “Returns”The window theme.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const theme = await getCurrentWindow().theme();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L831
title()
Section titled “title()”title(): Promise<string>Gets the window’s current title.
Returns
Section titled “Returns”Promise<string>
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';const title = await getCurrentWindow().title();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L810
toggleMaximize()
Section titled “toggleMaximize()”toggleMaximize(): Promise<void>Toggles the window maximized state.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().toggleMaximize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1104
unmaximize()
Section titled “unmaximize()”unmaximize(): Promise<void>Unmaximizes the window.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().unmaximize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1088
unminimize()
Section titled “unminimize()”unminimize(): Promise<void>Unminimizes the window.
Returns
Section titled “Returns”Promise<void>
A promise indicating the success or failure of the operation.
Example
Section titled “Example”import { getCurrentWindow } from '@tauri-apps/api/window';await getCurrentWindow().unminimize();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L1136
getAll()
Section titled “getAll()”static getAll(): Promise<Window[]>Gets a list of instances of Window for all available windows.
Returns
Section titled “Returns”Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L375
getByLabel()
Section titled “getByLabel()”static getByLabel(label): Promise<null | Window>Gets the Window associated with the given label.
Parameters
Section titled “Parameters”| Parameter | Type | Description |
|---|---|---|
label |
string |
The window label. |
Returns
Section titled “Returns”The Window instance to communicate with the window or null if the window doesn’t exist.
Example
Section titled “Example”import { Window } from '@tauri-apps/api/window';const mainWindow = Window.getByLabel('main');Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L361
getCurrent()
Section titled “getCurrent()”static getCurrent(): WindowGet an instance of Window for the current window.
Returns
Section titled “Returns”Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L368
getFocusedWindow()
Section titled “getFocusedWindow()”static getFocusedWindow(): Promise<null | Window>Gets the focused window.
Returns
Section titled “Returns”The Window instance or undefined if there is not any focused window.
Example
Section titled “Example”import { Window } from '@tauri-apps/api/window';const focusedWindow = Window.getFocusedWindow();Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L389
Interfaces
Section titled “Interfaces”Effects
Section titled “Effects”The window effects configuration object
2.0.0
Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
color? |
Color |
Window effect color. Affects Effect.Blur and Effect.Acrylic only on Windows 10 v1903+. Doesn’t have any effect on Windows 7 or Windows 11. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2331 |
effects |
Effect[] |
List of Window effects to apply to the Window. Conflicting effects will apply the first one and ignore the rest. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2318 |
radius? |
number |
Window effect corner radius macOS Only | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2326 |
state? |
EffectState |
Window effect state macOS Only | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2322 |
Monitor
Section titled “Monitor”Allows you to retrieve information about a given monitor.
1.0.0
Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
name |
null | string |
Human-readable name of the monitor | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L49 |
position |
PhysicalPosition |
the Top-left corner position of the monitor relative to the larger full screen area, in physical pixels. Note that window creation options such as x, y, width and height expect logical pixels, so convert with Monitor.scaleFactor first: import { currentMonitor } from '@tauri-apps/api/window'; import { WebviewWindow } from '@tauri-apps/api/webviewWindow'; const monitor = await currentMonitor(); if (monitor) { const position = monitor.position.toLogical(monitor.scaleFactor); const webview = new WebviewWindow('my-label', { x: position.x, y: position.y }); } |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L75 |
scaleFactor |
number |
The scale factor that can be used to map physical pixels to logical pixels, e.g. monitor.position.toLogical(monitor.scaleFactor). |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L90 |
size |
PhysicalSize |
The monitor’s resolution in physical pixels. Use Monitor.scaleFactor to convert to logical pixels: const logicalSize = monitor.size.toLogical(monitor.scaleFactor); |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L58 |
workArea |
object |
The monitor’s work area (the monitor area excluding taskbars and docks) in physical pixels. Use Monitor.scaleFactor to convert to logical pixels as shown in Monitor.position. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L82 |
workArea.position |
PhysicalPosition |
- | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L83 |
workArea.size |
PhysicalSize |
- | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L84 |
ProgressBarState
Section titled “ProgressBarState”Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
progress? |
number |
The progress bar progress. This can be a value ranging from 0 to 100 |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L238 |
status? |
ProgressBarStatus |
The progress bar status. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L234 |
ScaleFactorChanged
Section titled “ScaleFactorChanged”The payload for the scaleChange event.
1.0.2
Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
scaleFactor |
number |
The new window scale factor. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L113 |
size |
PhysicalSize |
The new window size | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L115 |
WindowOptions
Section titled “WindowOptions”Configuration for the window to create.
1.0.0
Properties
Section titled “Properties”| Property | Type | Description | Defined in |
|---|---|---|---|
activityName? |
string |
The name of the Android activity to create for this window. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2559 |
allowLinkPreview? |
boolean |
on macOS and iOS there is a link preview on long pressing links, this is enabled by default. see https://docs.rs/objc2-web-kit/latest/objc2_web_kit/struct.WKWebView.html#method.allowsLinkPreview | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2533 |
alwaysOnBottom? |
boolean |
Whether the window should always be below other windows. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2406 |
alwaysOnTop? |
boolean |
Whether the window should always be on top of other windows or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2404 |
backgroundColor? |
Color |
Set the window background color. Platform-specific: - Android / iOS: Unsupported. - Windows: alpha channel is ignored. Since 2.1.0 | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2510 |
backgroundThrottling? |
BackgroundThrottlingPolicy |
Change the default background throttling behaviour. ## Platform-specific - Linux / Windows / Android: Unsupported. Workarounds like a pending WebLock transaction might suffice. - iOS: Supported since version 17.0+. - macOS: Supported since version 14.0+. see https://github.com/tauri-apps/tauri/issues/5250#issuecomment-2569380578 Since 2.3.0 | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2524 |
center? |
boolean |
Show window in the center of the screen.. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2349 |
closable? |
boolean |
Whether the window’s native close button is enabled or not. Defaults to true. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2465 |
contentProtected? |
boolean |
Prevents the window contents from being captured by other apps. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2408 |
createdByActivityName? |
string |
The name of the Android activity that is creating this webview window. This is important to determine which stack the activity will belong to. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2565 |
decorations? |
boolean |
Whether the window should have borders and bars or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2402 |
disableInputAccessoryView? |
boolean |
Allows disabling the input accessory view on iOS. The accessory view is the view that appears above the keyboard when a text input element is focused. It usually displays a view with “Done”, “Next” buttons. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2540 |
focus? |
boolean |
Whether the window will be initially focused or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2388 |
focusable? |
boolean |
Whether the window can be focused or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2390 |
fullscreen? |
boolean |
Whether the window is in fullscreen mode or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2386 |
height? |
number |
The initial height in logical pixels. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2357 |
hiddenTitle? |
boolean |
If true, sets the window title to be hidden on macOS. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2446 |
javascriptDisabled? |
boolean |
Whether we should disable JavaScript code execution on the webview or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2528 |
maxHeight? |
number |
The maximum height in logical pixels. Only applies if maxWidth is also set. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2365 |
maxWidth? |
number |
The maximum width in logical pixels. Only applies if maxHeight is also set. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2363 |
maximizable? |
boolean |
Whether the window’s native maximize button is enabled or not. Defaults to true. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2457 |
maximized? |
boolean |
Whether the window should be maximized upon creation or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2398 |
minHeight? |
number |
The minimum height in logical pixels. Only applies if minWidth is also set. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2361 |
minWidth? |
number |
The minimum width in logical pixels. Only applies if minHeight is also set. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2359 |
minimizable? |
boolean |
Whether the window’s native minimize button is enabled or not. Defaults to true. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2461 |
parent? |
string | Window | WebviewWindow |
Sets a parent to the window to be created. Can be either a Window or a label of the window. Platform-specific - Windows: This sets the passed parent as an owner window to the window to be created. From MSDN owned windows docs: - An owned window is always above its owner in the z-order. - The system automatically destroys an owned window when its owner is destroyed. - An owned window is hidden when its owner is minimized. - Linux: This makes the new window transient for parent, see https://docs.gtk.org/gtk3/method.Window.set_transient_for.html - macOS: This adds the window as a child of parent, see https://developer.apple.com/documentation/appkit/nswindow/1419152-addchildwindow?language=objc |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2479 |
preventOverflow? |
boolean | PreventOverflowMargin |
Prevent the window from overflowing the working area (e.g. monitor size - taskbar size) on creation, which means the window size will be limited to monitor size - taskbar size Can either be set to true or to a PreventOverflowMargin object to set an additional margin that should be considered to determine the working area (in this case the window size will be limited to monitor size - taskbar size - margin) NOTE: The overflow check is only performed on window creation, resizes can still overflow Platform-specific - iOS / Android: Unsupported. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2380 |
requestedBySceneIdentifier? |
string |
Sets the identifier of the UIScene that is requesting the creation of this new scene, establishing a relationship between the two scenes. By default the system uses the foreground scene. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2572 |
resizable? |
boolean |
Whether the window is resizable or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2382 |
scrollBarStyle? |
ScrollBarStyle |
Specifies the native scrollbar style to use with the webview. CSS styles that modify the scrollbar are applied on top of the native appearance configured here. Defaults to default, which is the browser default. ## Platform-specific - Windows: - fluentOverlay requires WebView2 Runtime version 125.0.2535.41 or higher, and does nothing on older versions. - This option must be given the same value for all webviews. - Linux / Android / iOS / macOS: Unsupported. Only supports Default and performs no operation. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2555 |
shadow? |
boolean |
Whether or not the window has shadow. Platform-specific - Windows: - false has no effect on decorated window, shadows are always ON. - true will make undecorated window have a 1px white border, and on Windows 11, it will have a rounded corners. - Linux: Unsupported. Since 2.0.0 |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2424 |
skipTaskbar? |
boolean |
Whether or not the window icon should be added to the taskbar. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2410 |
tabbingIdentifier? |
string |
Defines the window tabbing identifier on macOS. Windows with the same tabbing identifier will be grouped together. If the tabbing identifier is not set, automatic tabbing will be disabled. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2453 |
theme? |
Theme |
The initial window theme. Defaults to the system theme. Only implemented on Windows and macOS 10.14+. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2430 |
title? |
string |
Window title. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2384 |
titleBarStyle? |
TitleBarStyle |
The style of the macOS title bar. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2434 |
trafficLightPosition? |
LogicalPosition |
The position of the window controls on macOS. Requires titleBarStyle: 'overlay' and decorations: true. Since 2.4.0 |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2442 |
transparent? |
boolean |
Whether the window is transparent or not. Note that on macOS this requires the macos-private-api feature flag, enabled under tauri.conf.json > app > macOSPrivateApi. WARNING: Using private APIs on macOS prevents your application from being accepted to the App Store. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2396 |
visible? |
boolean |
Whether the window should be immediately visible upon creation or not. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2400 |
visibleOnAllWorkspaces? |
boolean |
Whether the window should be visible on all workspaces or virtual desktops. Platform-specific - Windows / iOS / Android: Unsupported. Since 2.0.0 | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2488 |
width? |
number |
The initial width in logical pixels. | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2355 |
windowEffects? |
Effects |
Window effects. Requires the window to be transparent. Platform-specific: - Windows: If using decorations or shadows, you may want to try this workaround https://github.com/tauri-apps/tao/issues/72#issuecomment-975607891 - Linux: Unsupported | Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2499 |
x? |
number |
The initial vertical position in logical pixels. Only applies if y is also set. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2351 |
y? |
number |
The initial horizontal position in logical pixels. Only applies if x is also set. |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2353 |
WindowSizeConstraints
Section titled “WindowSizeConstraints”Properties
Section titled “Properties”| Property | Type | Defined in |
|---|---|---|
maxHeight? |
number |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L227 |
maxWidth? |
number |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L226 |
minHeight? |
number |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L225 |
minWidth? |
number |
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L224 |
Type Aliases
Section titled “Type Aliases”CursorIcon
Section titled “CursorIcon”type CursorIcon: | "default" | "crosshair" | "hand" | "arrow" | "move" | "text" | "wait" | "help" | "progress" | "notAllowed" | "contextMenu" | "cell" | "verticalText" | "alias" | "copy" | "noDrop" | "grab" | "grabbing" | "allScroll" | "zoomIn" | "zoomOut" | "eResize" | "nResize" | "neResize" | "nwResize" | "sResize" | "seResize" | "swResize" | "wResize" | "ewResize" | "nsResize" | "neswResize" | "nwseResize" | "colResize" | "rowResize";Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L159
type Theme: "light" | "dark";Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L93
TitleBarStyle
Section titled “TitleBarStyle”type TitleBarStyle: "visible" | "transparent" | "overlay";Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L94
Functions
Section titled “Functions”availableMonitors()
Section titled “availableMonitors()”function availableMonitors(): Promise<Monitor[]>Returns the list of all the monitors available on the system.
Returns
Section titled “Returns”Example
Section titled “Example”import { availableMonitors } from '@tauri-apps/api/window';const monitors = await availableMonitors();1.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2651
currentMonitor()
Section titled “currentMonitor()”function currentMonitor(): Promise<Monitor | null>Returns the monitor on which the window currently resides.
Returns null if current monitor can’t be detected.
Returns
Section titled “Returns”Example
Section titled “Example”import { currentMonitor } from '@tauri-apps/api/window';const monitor = await currentMonitor();1.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2601
cursorPosition()
Section titled “cursorPosition()”function cursorPosition(): Promise<PhysicalPosition>Get the cursor position relative to the top-left hand corner of the desktop.
Note that the top-left hand corner of the desktop is not necessarily the same as the screen. If the user uses a desktop with multiple monitors, the top-left hand corner of the desktop is the top-left hand corner of the main monitor on Windows and macOS or the top-left of the leftmost monitor on X11.
The coordinates can be negative if the top-left hand corner of the window is outside of the visible screen region.
Returns
Section titled “Returns”Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2667
getAllWindows()
Section titled “getAllWindows()”function getAllWindows(): Promise<Window[]>Gets a list of instances of Window for all available windows.
Returns
Section titled “Returns”1.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L258
getCurrentWindow()
Section titled “getCurrentWindow()”function getCurrentWindow(): WindowGet an instance of Window for the current window.
Returns
Section titled “Returns”1.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L246
monitorFromPoint()
Section titled “monitorFromPoint()”function monitorFromPoint(x, y): Promise<Monitor | null>Returns the monitor that contains the given point. Returns null if can’t find any.
Parameters
Section titled “Parameters”| Parameter | Type |
|---|---|
x |
number |
y |
number |
Returns
Section titled “Returns”Example
Section titled “Example”import { monitorFromPoint } from '@tauri-apps/api/window';const monitor = await monitorFromPoint(100.0, 200.0);1.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2634
primaryMonitor()
Section titled “primaryMonitor()”function primaryMonitor(): Promise<Monitor | null>Returns the primary monitor of the system.
Returns null if it can’t identify any monitor as a primary one.
Returns
Section titled “Returns”Example
Section titled “Example”import { primaryMonitor } from '@tauri-apps/api/window';const monitor = await primaryMonitor();1.0.0
Source: https://github.com/tauri-apps/tauri/blob/dev/packages/api/src/window.ts#L2618
© 2026 Tauri Contributors. CC-BY / MIT