| // Copyright (c) 2011 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_COCOA_CONSTRAINED_WINDOW_MAC_H_ |
| #define CHROME_BROWSER_UI_COCOA_CONSTRAINED_WINDOW_MAC_H_ |
| #pragma once |
| |
| #import <Cocoa/Cocoa.h> |
| |
| #include "content/browser/tab_contents/constrained_window.h" |
| |
| #include "base/basictypes.h" |
| #include "base/logging.h" |
| #include "base/memory/scoped_nsobject.h" |
| |
| @class BrowserWindowController; |
| @class GTMWindowSheetController; |
| @class NSView; |
| @class NSWindow; |
| class TabContents; |
| |
| // Base class for constrained dialog delegates. Never inherit from this |
| // directly. |
| class ConstrainedWindowMacDelegate { |
| public: |
| ConstrainedWindowMacDelegate() : is_sheet_open_(false) {} |
| virtual ~ConstrainedWindowMacDelegate() {} |
| |
| // Tells the delegate to either delete itself or set up a task to delete |
| // itself later. Note that you MUST close the sheet belonging to your delegate |
| // in this method. |
| virtual void DeleteDelegate() = 0; |
| |
| // Called by the tab controller, you do not need to do anything yourself |
| // with this method. |
| virtual void RunSheet(GTMWindowSheetController* sheetController, |
| NSView* view) = 0; |
| protected: |
| // Returns true if this delegate's sheet is currently showing. |
| bool is_sheet_open() { return is_sheet_open_; } |
| |
| private: |
| bool is_sheet_open_; |
| void set_sheet_open(bool is_open) { is_sheet_open_ = is_open; } |
| friend class ConstrainedWindowMac; |
| }; |
| |
| // Subclass this for a dialog delegate that displays a system sheet such as |
| // an NSAlert, an open or save file panel, etc. |
| class ConstrainedWindowMacDelegateSystemSheet |
| : public ConstrainedWindowMacDelegate { |
| public: |
| ConstrainedWindowMacDelegateSystemSheet(id delegate, SEL didEndSelector); |
| virtual ~ConstrainedWindowMacDelegateSystemSheet(); |
| |
| protected: |
| void set_sheet(id sheet); |
| id sheet() { return systemSheet_; } |
| |
| // Returns an NSArray to be passed as parameters to GTMWindowSheetController. |
| // Array's contents should be the arguments passed to the system sheet's |
| // beginSheetForWindow:... method. The window argument must be [NSNull null]. |
| // |
| // The default implementation returns |
| // [null window, delegate, didEndSelector, null contextInfo] |
| // Subclasses may override this if they show a system sheet which takes |
| // different parameters. |
| virtual NSArray* GetSheetParameters(id delegate, SEL didEndSelector); |
| |
| private: |
| virtual void RunSheet(GTMWindowSheetController* sheetController, |
| NSView* view); |
| scoped_nsobject<id> systemSheet_; |
| scoped_nsobject<id> delegate_; |
| SEL didEndSelector_; |
| }; |
| |
| // Subclass this for a dialog delegate that displays a custom sheet, e.g. loaded |
| // from a nib file. |
| class ConstrainedWindowMacDelegateCustomSheet |
| : public ConstrainedWindowMacDelegate { |
| public: |
| ConstrainedWindowMacDelegateCustomSheet(); |
| ConstrainedWindowMacDelegateCustomSheet(id delegate, SEL didEndSelector); |
| ~ConstrainedWindowMacDelegateCustomSheet(); |
| |
| protected: |
| // For when you need to delay initalization after the constructor call. |
| void init(NSWindow* sheet, id delegate, SEL didEndSelector); |
| void set_sheet(NSWindow* sheet); |
| NSWindow* sheet() { return customSheet_; } |
| |
| private: |
| virtual void RunSheet(GTMWindowSheetController* sheetController, |
| NSView* view); |
| scoped_nsobject<NSWindow> customSheet_; |
| scoped_nsobject<id> delegate_; |
| SEL didEndSelector_; |
| }; |
| |
| // Constrained window implementation for the Mac port. A constrained window |
| // is a per-tab sheet on OS X. |
| // |
| // Constrained windows work slightly differently on OS X than on the other |
| // platforms: |
| // 1. A constrained window is bound to both a tab and window on OS X. |
| // 2. The delegate is responsible for closing the sheet again when it is |
| // deleted. |
| class ConstrainedWindowMac : public ConstrainedWindow { |
| public: |
| virtual ~ConstrainedWindowMac(); |
| |
| // Overridden from ConstrainedWindow: |
| virtual void ShowConstrainedWindow(); |
| virtual void CloseConstrainedWindow(); |
| |
| // Returns the TabContents that constrains this Constrained Window. |
| TabContents* owner() const { return owner_; } |
| |
| // Returns the window's delegate. |
| ConstrainedWindowMacDelegate* delegate() { return delegate_; } |
| |
| // Makes the constrained window visible, if it is not yet visible. |
| void Realize(BrowserWindowController* controller); |
| |
| private: |
| friend class ConstrainedWindow; |
| |
| ConstrainedWindowMac(TabContents* owner, |
| ConstrainedWindowMacDelegate* delegate); |
| |
| // The TabContents that owns and constrains this ConstrainedWindow. |
| TabContents* owner_; |
| |
| // Delegate that provides the contents of this constrained window. |
| ConstrainedWindowMacDelegate* delegate_; |
| |
| // Controller of the window that contains this sheet. |
| BrowserWindowController* controller_; |
| |
| // Stores if |ShowConstrainedWindow()| was called. |
| bool should_be_visible_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ConstrainedWindowMac); |
| }; |
| |
| #endif // CHROME_BROWSER_UI_COCOA_CONSTRAINED_WINDOW_MAC_H_ |
| |