summaryrefslogtreecommitdiffstats
path: root/chrome/browser/cocoa/html_dialog_window_controller.h
diff options
context:
space:
mode:
authorakalin@chromium.org <akalin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-30 19:50:29 +0000
committerakalin@chromium.org <akalin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-30 19:50:29 +0000
commitc4f7dfb44992c8fb9139133107e0ac9200edf241 (patch)
treee6ca6cdc567628d3481d96d56e24d58359148631 /chrome/browser/cocoa/html_dialog_window_controller.h
parent25e979d39063ea83e0635010a3204aa6ec0b166b (diff)
downloadchromium_src-c4f7dfb44992c8fb9139133107e0ac9200edf241.zip
chromium_src-c4f7dfb44992c8fb9139133107e0ac9200edf241.tar.gz
chromium_src-c4f7dfb44992c8fb9139133107e0ac9200edf241.tar.bz2
Implemented most of HtmlDialogWindowController, which is a Cocoa port
of HtmlDialogView. Added TODO to fix inaccurate font height metric for OS X font class (and maybe width). Added the BrowserCommandExecutor protocol so that not just a BrowserWindowController can be the window controller for a ChromeEventProcessingWindow. Added unittests. Also tested manually with the bookmark sync setup wizard dialog. BUG=23073 TEST=added unittests, trybot, and manual testing Review URL: http://codereview.chromium.org/344008 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30619 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/cocoa/html_dialog_window_controller.h')
-rw-r--r--chrome/browser/cocoa/html_dialog_window_controller.h121
1 files changed, 121 insertions, 0 deletions
diff --git a/chrome/browser/cocoa/html_dialog_window_controller.h b/chrome/browser/cocoa/html_dialog_window_controller.h
new file mode 100644
index 0000000..e5a9297
--- /dev/null
+++ b/chrome/browser/cocoa/html_dialog_window_controller.h
@@ -0,0 +1,121 @@
+// Copyright (c) 2009 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_COCOA_HTML_DIALOG_WINDOW_CONTROLLER_H_
+#define CHROME_BROWSER_COCOA_HTML_DIALOG_WINDOW_CONTROLLER_H_
+
+#include <string>
+#include <vector>
+
+#import <Cocoa/Cocoa.h>
+
+#include "app/gfx/native_widget_types.h"
+#include "base/basictypes.h"
+#include "base/scoped_ptr.h"
+#include "chrome/browser/dom_ui/html_dialog_ui.h"
+#include "chrome/browser/tab_contents/tab_contents_delegate.h"
+#include "googleurl/src/gurl.h"
+
+class Browser;
+
+// Thin bridge that routes notifications to
+// HtmlDialogWindowController's member variables.
+class HtmlDialogWindowDelegateBridge : public HtmlDialogUIDelegate,
+ public TabContentsDelegate {
+ public:
+ // All parameters must be non-NULL/non-nil.
+ HtmlDialogWindowDelegateBridge(HtmlDialogUIDelegate* delegate,
+ NSWindowController* controller,
+ NSWindow* window,
+ Browser* browser);
+
+ virtual ~HtmlDialogWindowDelegateBridge();
+
+ // Called when the window is directly closed, e.g. from the close
+ // button or from an accelerator.
+ void WindowControllerClosed();
+
+ // HtmlDialogUIDelegate declarations.
+ virtual bool IsDialogModal() const;
+ virtual std::wstring GetDialogTitle() const;
+ virtual GURL GetDialogContentURL() const;
+ virtual void GetDOMMessageHandlers(
+ std::vector<DOMMessageHandler*>* handlers) const;
+ virtual void GetDialogSize(gfx::Size* size) const;
+ virtual std::string GetDialogArgs() const;
+ virtual void OnDialogClosed(const std::string& json_retval);
+
+ // TabContentsDelegate declarations.
+ virtual void OpenURLFromTab(TabContents* source,
+ const GURL& url, const GURL& referrer,
+ WindowOpenDisposition disposition,
+ PageTransition::Type transition);
+ virtual void NavigationStateChanged(const TabContents* source,
+ unsigned changed_flags);
+ virtual void AddNewContents(TabContents* source,
+ TabContents* new_contents,
+ WindowOpenDisposition disposition,
+ const gfx::Rect& initial_pos,
+ bool user_gesture);
+ virtual void ActivateContents(TabContents* contents);
+ virtual void LoadingStateChanged(TabContents* source);
+ virtual void CloseContents(TabContents* source);
+ virtual void MoveContents(TabContents* source, const gfx::Rect& pos);
+ virtual bool IsPopup(TabContents* source);
+ virtual void ToolbarSizeChanged(TabContents* source, bool is_animating);
+ virtual void URLStarredChanged(TabContents* source, bool starred);
+ virtual void UpdateTargetURL(TabContents* source, const GURL& url);
+
+ private:
+ HtmlDialogUIDelegate* delegate_; // weak
+ NSWindowController* controller_; // weak
+ NSWindow* window_; // weak
+ Browser* browser_; // weak
+
+ // Calls delegate_'s OnDialogClosed() exactly once, nulling it out
+ // afterwards so that no other HtmlDialogUIDelegate calls are sent
+ // to it. Returns whether or not the OnDialogClosed() was actually
+ // called on the delegate.
+ bool DelegateOnDialogClosed(const std::string& json_retval);
+
+ DISALLOW_COPY_AND_ASSIGN(HtmlDialogWindowDelegateBridge);
+};
+
+// This controller manages a dialog box with properties and HTML content taken
+// from a HTMLDialogUIDelegate object.
+@interface HtmlDialogWindowController : NSWindowController {
+ @private
+ Browser* browser_; // weak
+ // Order here is important, as tab_contents_ may send messages to
+ // delegate_ when it gets destroyed.
+ scoped_ptr<HtmlDialogWindowDelegateBridge> delegate_;
+ scoped_ptr<TabContents> tab_contents_;
+}
+
+// Creates and shows an HtmlDialogWindowController with the given
+// delegate, parent window, and browser, none of which may be NULL.
+// The window is automatically destroyed when it is closed.
++ (void)showHtmlDialog:(HtmlDialogUIDelegate*)delegate
+ parentWindow:(gfx::NativeWindow)parent_window
+ browser:(Browser*)browser;
+
+@end
+
+@interface HtmlDialogWindowController (TestingAPI)
+
+// This is the designated initializer. However, this is exposed only
+// for testing; use showHtmlDialog instead.
+- (id)initWithDelegate:(HtmlDialogUIDelegate*)delegate
+ parentWindow:(gfx::NativeWindow)parent_window
+ browser:(Browser*)browser;
+
+// Loads the HTML content from the delegate; this is not a lightweight
+// process which is why it is not part of the constructor. Must be
+// called before showWindow.
+- (void)loadDialogContents;
+
+@end
+
+#endif // CHROME_BROWSER_COCOA_HTML_DIALOG_WINDOW_CONTROLLER_H_
+