root/chrome/browser/ui/views/app_list/win/activation_tracker_win.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_BROWSER_UI_VIEWS_APP_LIST_WIN_ACTIVATION_TRACKER_WIN_H_
#define CHROME_BROWSER_UI_VIEWS_APP_LIST_WIN_ACTIVATION_TRACKER_WIN_H_

#include "base/basictypes.h"
#include "base/callback.h"
#include "base/timer/timer.h"
#include "ui/app_list/views/app_list_view_observer.h"

namespace app_list {
class AppListView;
}

// Periodically checks to see if an AppListView has lost focus using a timer.
class ActivationTrackerWin : public app_list::AppListViewObserver {
 public:
  ActivationTrackerWin(app_list::AppListView* view,
                       const base::Closure& on_should_dismiss);
  ~ActivationTrackerWin();

  void ReactivateOnNextFocusLoss() {
    reactivate_on_next_focus_loss_ = true;
  }

  // app_list::AppListViewObserver:
  virtual void OnActivationChanged(views::Widget* widget, bool active) OVERRIDE;

  void OnViewHidden();

 private:
  // Dismisses the app launcher if it has lost focus and the user is not trying
  // to pin it. If it is time to dismiss the app launcher, but
  // ReactivateOnNextFocusLoss has been called, reactivates the app launcher
  // instead of dismissing it.
  void MaybeDismissAppList();

  // Determines whether the app launcher should be dismissed. This should be
  // called at most once per timer tick, as it is not idempotent (if the taskbar
  // is focused, it waits until it has been called twice before dismissing the
  // app list).
  bool ShouldDismissAppList();

  // The window to track the active state of.
  app_list::AppListView* view_;

  // Called to request |view_| be closed.
  base::Closure on_should_dismiss_;

  // True if we are anticipating that the app list will lose focus, and we want
  // to take it back. This is used when switching out of Metro mode, and the
  // browser regains focus after showing the app list.
  bool reactivate_on_next_focus_loss_;

  // Records whether, on the previous timer tick, the taskbar had focus without
  // the right mouse button being down. We allow the taskbar to have focus for
  // one tick before dismissing the app list. This allows the app list to be
  // kept visible if the taskbar is seen briefly without the right mouse button
  // down, but not if this happens for two consecutive ticks.
  bool taskbar_has_focus_;

  // Timer used to check if the taskbar or app list is active. Using a timer
  // means we don't need to hook Windows, which is apparently not possible
  // since Vista (and is not nice at any time).
  base::RepeatingTimer<ActivationTrackerWin> timer_;

  DISALLOW_COPY_AND_ASSIGN(ActivationTrackerWin);
};

#endif  // CHROME_BROWSER_UI_VIEWS_APP_LIST_WIN_ACTIVATION_TRACKER_WIN_H_

/* [<][>][^][v][top][bottom][index][help] */