Window focus plugin
Language Versions
Window Focus is a Flutter plugin that allows you to track user activity and focus on the active window for Windows and macOS platforms. The plugin provides features such as detecting user inactivity, identifying the active application, and enabling debug mode for enhanced logging.
Key Features:
User Inactivity Tracking:
The plugin enables you to detect periods of user inactivity within your Flutter application. You can customize the inactivity threshold and handle inactivity events according to your needs.
Active Window Title Retrieval:
Provides the ability to retrieve the title of the active window of the operating system. For Mac OS, this is the application name, and for Windows, it's the window title.
Debug Mode
Enable detailed logs for troubleshooting during development.
Set Custom Idle Threshold
Define the timeout period after which the user is considered inactive.
Plugin Installation
Windows
No action required.
Mac OS
You need to add the following code to the Info.plist file for MacOS:
<key>NSApplicationSupportsSecureRestorableState</key>
<true/>
Plugin Usage
Import the plugin:
import 'package:window_focus/window_focus.dart';
Example
void main() {
final windowFocus = WindowFocus(debug: true, duration: Duration(seconds: 10));
// Add focus change listener
windowFocus.addFocusChangeListener((appWindow) {
print('Active window: ${appWindow.appName}, Title: ${appWindow.windowTitle}');
});
// Add user activity listener
windowFocus.addUserActiveListener((isActive) {
if (isActive) {
print('User is active');
} else {
print('User is inactive');
}
});
}
API Reference
Constructor
WindowFocus({bool debug = false, Duration duration = const Duration(seconds: 1)})
- debug (optional): Enables debug mode for detailed logs.
- duration (optional): Sets the user inactivity timeout. Default is 1 second.
Methods
Future
Sets the threshold for detecting user inactivity.
- Parameters:
duration
: The duration after which the user is considered inactive.
await windowFocus.setIdleThreshold(Duration(seconds: 15));
Future
Gets the current idle threshold.
- Returns:
Duration
- The currently set idle threshold.
final threshold = await windowFocus.getIdleThreshold();
print('Idle threshold: ${threshold.inSeconds} seconds');
void addFocusChangeListener(Function(AppWindowDto) listener)
Adds a listener for changes in the focused window.
- Parameters:
listener
: A callback function that receives an AppWindowDto object containing:appName
: The name of the active application.windowTitle
: The title of the active window.
Platform-specific Details
- Windows:
- appName is the name of the executable file (e.g., chrome.exe).
- windowTitle is the title of the active window (e.g., Flutter Documentation).
- macOS:
- appName and windowTitle are the same and represent the name of the active application (e.g., Safari).
windowFocus.addFocusChangeListener((appWindow) {
print('Active application: ${appWindow.appName}, Window title: ${appWindow.windowTitle}');
});
void addUserActiveListener(Function(bool) listener)
Adds a listener for user activity changes.
- Parameters:
listener
: A callback function that receives a bool indicating user activity (true for active, false for inactive).
windowFocus.addUserActiveListener((isActive) {
if (isActive) {
print('User is active');
} else {
print('User is inactive');
}
});
Future
Enables or disables debug mode.
- Parameters:
value
: true to enable debug mode, false to disable it.
await windowFocus.setDebug(true);
DTO: AppWindowDto
Represents the active application and window information.
Properties
appName
: String - The name of the active application.windowTitle
: String - The title of the active window.
Example
final appWindow = AppWindowDto(appName: "Chrome", windowTitle: "Flutter Documentation");
print(appWindow); // Output: Window title: Flutter Documentation. AppName: Chrome
About the author
My telegram channel - @kotelnikoff_dev Contributions
Contributions are welcome! Feel free to open issues or create pull requests on the GitHub repository.