tray_manager 0.3.1 copy "tray_manager: ^0.3.1" to clipboard
tray_manager: ^0.3.1 copied to clipboard

This plugin allows Flutter desktop apps to defines system tray.

tray_manager #

pub version

This plugin allows Flutter desktop apps to defines system tray.


English | 简体中文


Platform Support #

Linux macOS Windows
✔️ ✔️ ✔️

Screenshots #

macOS Linux Windows
image

Known Issues #

When using app_links package alongside tray_manager, you may find that plugin does not work properly. This is because app_links internally blocks event propagation, preventing menu click events from being triggered.

To resolve this issue:

  1. Use my forked version of app_links package and wait for my PR to be merged: https://github.com/llfbandit/app_links/pull/179
dependencies:
  app_links:
    git:
      url: https://github.com/lijy91/app_links.git

Note: This is a temporary solution, and I will remove this repository once my PR is merged.

  1. Use protocol_handler package instead of app_links package.

Quick Start #

Installation #

Add this to your package's pubspec.yaml file:

dependencies:
  tray_manager: ^0.3.1

Or

dependencies:
  tray_manager:
    git:
      url: https://github.com/leanflutter/tray_manager.git
      ref: main

Linux requirements

  • ayatana-appindicator3-0.1 or appindicator3-0.1

Run the following command

sudo apt-get install libayatana-appindicator3-dev

Or

sudo apt-get install appindicator3-0.1 libappindicator3-dev

Usage #

import 'package:flutter/material.dart' hide MenuItem;
import 'package:tray_manager/tray_manager.dart';

await trayManager.setIcon(
  Platform.isWindows
    ? 'images/tray_icon.ico'
    : 'images/tray_icon.png',
);
Menu menu = Menu(
  items: [
    MenuItem(
      key: 'show_window',
      label: 'Show Window',
    ),
    MenuItem.separator(),
    MenuItem(
      key: 'exit_app',
      label: 'Exit App',
    ),
  ],
);
await trayManager.setContextMenu(menu);

Please see the example app of this plugin for a full example.

Listening events

import 'package:flutter/material.dart';
import 'package:tray_manager/tray_manager.dart';

class HomePage extends StatefulWidget {
  @override
  _HomePageState createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> with TrayListener {
  @override
  void initState() {
    trayManager.addListener(this);
    super.initState();
    _init();
  }

  @override
  void dispose() {
    trayManager.removeListener(this);
    super.dispose();
  }

  void _init() {
    // ...
  }

  @override
  Widget build(BuildContext context) {
    // ...
  }

  @override
  void onTrayIconMouseDown() {
    // do something, for example pop up the menu
    trayManager.popUpContextMenu();
  }

  @override
  void onTrayIconRightMouseDown() {
    // do something
  }

  @override
  void onTrayIconRightMouseUp() {
    // do something
  }

  @override
  void onTrayMenuItemClick(MenuItem menuItem) {
    if (menuItem.key == 'show_window') {
      // do something
    } else if (menuItem.key == 'exit_app') {
       // do something
    }
  }
}

Who's using it? #

  • Airclap - Send any file to any device. cross platform, ultra fast and easy to use.
  • Biyi (比译) - A convenient translation and dictionary app.

API #

TrayManager #

Method Description Linux macOS Windows
destroy Destroys the tray icon immediately. ✔️ ✔️ ✔️
setIcon Sets the image associated with this tray icon. ✔️ ✔️ ✔️
setIconPosition Sets the icon position of the tray icon. ✔️
setToolTip Sets the hover text for this tray icon. ✔️ ✔️
setContextMenu Sets the context menu for this icon. ✔️ ✔️ ✔️
popUpContextMenu Pops up the context menu of the tray icon. ✔️ ✔️
getBounds Returns Rect The bounds of this tray icon. ✔️ ✔️

License #

MIT

207
likes
160
points
14.7k
downloads

Publisher

verified publisherleanflutter.dev

Weekly Downloads

This plugin allows Flutter desktop apps to defines system tray.

Repository (GitHub)
View/report issues

Topics

#tray #tray-manager #system-tray

Documentation

API reference

License

MIT (license)

Dependencies

flutter, menu_base, path, shortid

More

Packages that depend on tray_manager