NaCl: Update revision in DEPS, r12770 -> r12773
[chromium-blink-merge.git] / chrome / browser / ui / cocoa / apps / native_app_window_cocoa.h
blob9f05cc0c2ef4b56fc65d069b42e2252c19534d8d
1 // Copyright 2013 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 CHROME_BROWSER_UI_COCOA_APPS_NATIVE_APP_WINDOW_COCOA_H_
6 #define CHROME_BROWSER_UI_COCOA_APPS_NATIVE_APP_WINDOW_COCOA_H_
8 #import <Cocoa/Cocoa.h>
9 #include <vector>
11 #include "apps/app_window.h"
12 #include "apps/ui/native_app_window.h"
13 #include "base/mac/scoped_nsobject.h"
14 #include "base/memory/scoped_ptr.h"
15 #import "chrome/browser/ui/cocoa/browser_command_executor.h"
16 #include "content/public/browser/web_contents_observer.h"
17 #include "extensions/common/draggable_region.h"
18 #include "ui/gfx/rect.h"
20 class ExtensionKeybindingRegistryCocoa;
21 class NativeAppWindowCocoa;
22 @class ShellNSWindow;
23 class SkRegion;
25 // A window controller for a minimal window to host a web app view. Passes
26 // Objective-C notifications to the C++ bridge.
27 @interface NativeAppWindowController : NSWindowController
28 <NSWindowDelegate,
29 BrowserCommandExecutor> {
30 @private
31 NativeAppWindowCocoa* appWindow_; // Weak; owns self.
34 @property(assign, nonatomic) NativeAppWindowCocoa* appWindow;
36 // Consults the Command Registry to see if this |event| needs to be handled as
37 // an extension command and returns YES if so (NO otherwise).
38 - (BOOL)handledByExtensionCommand:(NSEvent*)event;
40 @end
42 // Cocoa bridge to AppWindow.
43 class NativeAppWindowCocoa : public apps::NativeAppWindow,
44 public content::WebContentsObserver {
45 public:
46 NativeAppWindowCocoa(apps::AppWindow* app_window,
47 const apps::AppWindow::CreateParams& params);
49 // ui::BaseWindow implementation.
50 virtual bool IsActive() const OVERRIDE;
51 virtual bool IsMaximized() const OVERRIDE;
52 virtual bool IsMinimized() const OVERRIDE;
53 virtual bool IsFullscreen() const OVERRIDE;
54 virtual gfx::NativeWindow GetNativeWindow() OVERRIDE;
55 virtual gfx::Rect GetRestoredBounds() const OVERRIDE;
56 virtual ui::WindowShowState GetRestoredState() const OVERRIDE;
57 virtual gfx::Rect GetBounds() const OVERRIDE;
58 virtual void Show() OVERRIDE;
59 virtual void ShowInactive() OVERRIDE;
60 virtual void Hide() OVERRIDE;
61 virtual void Close() OVERRIDE;
62 virtual void Activate() OVERRIDE;
63 virtual void Deactivate() OVERRIDE;
64 virtual void Maximize() OVERRIDE;
65 virtual void Minimize() OVERRIDE;
66 virtual void Restore() OVERRIDE;
67 virtual void SetBounds(const gfx::Rect& bounds) OVERRIDE;
68 virtual void FlashFrame(bool flash) OVERRIDE;
69 virtual bool IsAlwaysOnTop() const OVERRIDE;
71 // Called when the window is about to be closed.
72 void WindowWillClose();
74 // Called when the window is focused.
75 void WindowDidBecomeKey();
77 // Called when the window is defocused.
78 void WindowDidResignKey();
80 // Called when the window finishes resizing, i.e. after zoom/unzoom, after
81 // entering/leaving fullscreen, and after a user is done resizing.
82 void WindowDidFinishResize();
84 // Called when the window is resized. This is called repeatedly during a
85 // zoom/unzoom, and while a user is resizing.
86 void WindowDidResize();
88 // Called when the window is moved.
89 void WindowDidMove();
91 // Called when the window is minimized.
92 void WindowDidMiniaturize();
94 // Called when the window is un-minimized.
95 void WindowDidDeminiaturize();
97 // Called when the window is zoomed (maximized or de-maximized).
98 void WindowWillZoom();
100 // Called to handle a key event.
101 bool HandledByExtensionCommand(NSEvent* event);
103 // Called to handle a mouse event.
104 void HandleMouseEvent(NSEvent* event);
106 // Returns true if |point| in local Cocoa coordinate system falls within
107 // the draggable region.
108 bool IsWithinDraggableRegion(NSPoint point) const;
110 NSRect restored_bounds() const { return restored_bounds_; }
111 bool use_system_drag() const { return use_system_drag_; }
113 protected:
114 // NativeAppWindow implementation.
115 virtual void SetFullscreen(int fullscreen_types) OVERRIDE;
116 virtual bool IsFullscreenOrPending() const OVERRIDE;
117 virtual bool IsDetached() const OVERRIDE;
118 virtual void UpdateWindowIcon() OVERRIDE;
119 virtual void UpdateWindowTitle() OVERRIDE;
120 virtual void UpdateBadgeIcon() OVERRIDE;
121 virtual void UpdateShape(scoped_ptr<SkRegion> region) OVERRIDE;
122 virtual void UpdateDraggableRegions(
123 const std::vector<extensions::DraggableRegion>& regions) OVERRIDE;
124 virtual SkRegion* GetDraggableRegion() OVERRIDE;
125 virtual void HandleKeyboardEvent(
126 const content::NativeWebKeyboardEvent& event) OVERRIDE;
127 virtual bool IsFrameless() const OVERRIDE;
128 virtual gfx::Insets GetFrameInsets() const OVERRIDE;
130 // These are used to simulate Mac-style hide/show. Since windows can be hidden
131 // and shown using the app.window API, this sets is_hidden_with_app_ to
132 // differentiate the reason a window was hidden.
133 virtual void ShowWithApp() OVERRIDE;
134 virtual void HideWithApp() OVERRIDE;
135 // Calls setContent[Min|Max]Size with the current size constraints.
136 virtual void UpdateWindowMinMaxSize() OVERRIDE;
138 // WebContentsObserver implementation.
139 virtual void RenderViewCreated(content::RenderViewHost* rvh) OVERRIDE;
141 virtual void SetAlwaysOnTop(bool always_on_top) OVERRIDE;
143 // WebContentsModalDialogHost implementation.
144 virtual gfx::NativeView GetHostView() const OVERRIDE;
145 virtual gfx::Point GetDialogPosition(const gfx::Size& size) OVERRIDE;
146 virtual gfx::Size GetMaximumDialogSize() OVERRIDE;
147 virtual void AddObserver(
148 web_modal::ModalDialogHostObserver* observer) OVERRIDE;
149 virtual void RemoveObserver(
150 web_modal::ModalDialogHostObserver* observer) OVERRIDE;
152 private:
153 virtual ~NativeAppWindowCocoa();
155 ShellNSWindow* window() const;
157 content::WebContents* web_contents() const {
158 return app_window_->web_contents();
160 const extensions::Extension* extension() const {
161 return app_window_->extension();
164 // Returns the WindowStyleMask based on the type of window frame.
165 // Specifically, this includes NSResizableWindowMask if the window is
166 // resizable, and does not include NSTexturedBackgroundWindowMask when a
167 // native frame is used.
168 NSUInteger GetWindowStyleMask() const;
170 void InstallView();
171 void UninstallView();
172 void InstallDraggableRegionViews();
173 void UpdateDraggableRegionsForSystemDrag(
174 const std::vector<extensions::DraggableRegion>& regions,
175 const extensions::DraggableRegion* draggable_area);
176 void UpdateDraggableRegionsForCustomDrag(
177 const std::vector<extensions::DraggableRegion>& regions);
179 // Cache |restored_bounds_| only if the window is currently restored.
180 void UpdateRestoredBounds();
182 // Hides the window unconditionally. Used by Hide and HideWithApp.
183 void HideWithoutMarkingHidden();
185 apps::AppWindow* app_window_; // weak - AppWindow owns NativeAppWindow.
187 bool has_frame_;
189 // Whether this window is hidden according to the app.window API. This is set
190 // by Hide, Show, and ShowInactive.
191 bool is_hidden_;
192 // Whether this window last became hidden due to a request to hide the entire
193 // app, e.g. via the dock menu or Cmd+H. This is set by Hide/ShowWithApp.
194 bool is_hidden_with_app_;
196 bool is_maximized_;
197 bool is_fullscreen_;
198 NSRect restored_bounds_;
200 bool shows_resize_controls_;
201 bool shows_fullscreen_controls_;
203 base::scoped_nsobject<NativeAppWindowController> window_controller_;
204 NSInteger attention_request_id_; // identifier from requestUserAttention
206 // Indicates whether system drag or custom drag should be used, depending on
207 // the complexity of draggable regions.
208 bool use_system_drag_;
210 // For system drag, the whole window is draggable and the non-draggable areas
211 // have to been explicitly excluded.
212 std::vector<gfx::Rect> system_drag_exclude_areas_;
214 // For custom drag, the whole window is non-draggable and the draggable region
215 // has to been explicitly provided.
216 scoped_ptr<SkRegion> draggable_region_; // used in custom drag.
218 // Mouse location since the last mouse event, in screen coordinates. This is
219 // used in custom drag to compute the window movement.
220 NSPoint last_mouse_location_;
222 // The Extension Command Registry used to determine which keyboard events to
223 // handle.
224 scoped_ptr<ExtensionKeybindingRegistryCocoa> extension_keybinding_registry_;
226 DISALLOW_COPY_AND_ASSIGN(NativeAppWindowCocoa);
229 #endif // CHROME_BROWSER_UI_COCOA_APPS_NATIVE_APP_WINDOW_COCOA_H_