Revert 268405 "Make sure that ScratchBuffer::Allocate() always r..."
[chromium-blink-merge.git] / ui / wm / public / activation_client.h
blobfc351319bc2dcf222e41b009a97a0a772274cf21
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef UI_WM_PUBLIC_ACTIVATION_CLIENT_H_
6 #define UI_WM_PUBLIC_ACTIVATION_CLIENT_H_
8 #include "ui/aura/aura_export.h"
10 namespace ui {
11 class Event;
14 namespace aura {
15 class Window;
17 namespace client {
18 class ActivationChangeObserver;
20 // An interface implemented by an object that manages window activation.
21 class AURA_EXPORT ActivationClient {
22 public:
23 // Adds/Removes ActivationChangeObservers.
24 virtual void AddObserver(ActivationChangeObserver* observer) = 0;
25 virtual void RemoveObserver(ActivationChangeObserver* observer) = 0;
27 // Activates |window|. If |window| is NULL, nothing happens.
28 virtual void ActivateWindow(Window* window) = 0;
30 // Deactivates |window|. What (if anything) is activated next is up to the
31 // client. If |window| is NULL, nothing happens.
32 virtual void DeactivateWindow(Window* window) = 0;
34 // Retrieves the active window, or NULL if there is none.
35 virtual Window* GetActiveWindow() = 0;
37 // Retrieves the activatable window for |window|, or NULL if there is none.
38 // Note that this is often but not always the toplevel window (see
39 // GetToplevelWindow() below), as the toplevel window may not be activatable
40 // (for example it may be blocked by a modal transient, or some other
41 // condition).
42 virtual Window* GetActivatableWindow(Window* window) = 0;
44 // Retrieves the toplevel window for |window|, or NULL if there is none.
45 virtual Window* GetToplevelWindow(Window* window) = 0;
47 // Invoked prior to |window| getting focus as a result of the |event|. |event|
48 // may be NULL. Returning false blocks |window| from getting focus.
49 virtual bool OnWillFocusWindow(Window* window, const ui::Event* event) = 0;
51 // Returns true if |window| can be activated, false otherwise. If |window| has
52 // a modal child it can not be activated.
53 virtual bool CanActivateWindow(Window* window) const = 0;
55 protected:
56 virtual ~ActivationClient() {}
59 // Sets/Gets the activation client on the root Window.
60 AURA_EXPORT void SetActivationClient(Window* root_window,
61 ActivationClient* client);
62 AURA_EXPORT ActivationClient* GetActivationClient(Window* root_window);
64 // Some types of transient window are only visible when active.
65 // The transient parents of these windows may have visual appearance properties
66 // that differ from transient parents that can be deactivated.
67 // The presence of this property implies these traits.
68 // TODO(beng): currently the UI framework (views) implements the actual
69 // close-on-deactivate component of this feature but it should be
70 // possible to implement in the aura client.
71 AURA_EXPORT void SetHideOnDeactivate(Window* window, bool hide_on_deactivate);
72 AURA_EXPORT bool GetHideOnDeactivate(Window* window);
74 } // namespace clients
75 } // namespace aura
77 #endif // UI_WM_PUBLIC_ACTIVATION_CLIENT_H_