// Copyright (c) 2014 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #ifndef ATOM_BROWSER_UI_WIN_NOTIFY_ICON_HOST_H_ #define ATOM_BROWSER_UI_WIN_NOTIFY_ICON_HOST_H_ #include <windows.h> #include <vector> #include "base/macros.h" namespace atom { class NotifyIcon; class NotifyIconHost { public: NotifyIconHost(); ~NotifyIconHost(); NotifyIcon* CreateNotifyIcon(); void Remove(NotifyIcon* notify_icon); private: typedef std::vector<NotifyIcon*> NotifyIcons; // Static callback invoked when a message comes in to our messaging window. static LRESULT CALLBACK WndProcStatic(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam); LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam); UINT NextIconId(); // The unique icon ID we will assign to the next icon. UINT next_icon_id_ = 1; // List containing all active NotifyIcons. NotifyIcons notify_icons_; // The window class of |window_|. ATOM atom_ = 0; // The handle of the module that contains the window procedure of |window_|. HMODULE instance_ = nullptr; // The window used for processing events. HWND window_ = nullptr; // The message ID of the "TaskbarCreated" message, sent to us when we need to // reset our status icons. UINT taskbar_created_message_ = 0; DISALLOW_COPY_AND_ASSIGN(NotifyIconHost); }; } // namespace atom #endif // ATOM_BROWSER_UI_WIN_NOTIFY_ICON_HOST_H_