summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/browser.cc8
-rw-r--r--chrome/browser/browser_commands.cc39
-rw-r--r--chrome/browser/debugger/debugger_window.cc7
-rw-r--r--chrome/browser/external_protocol_dialog.cc10
-rw-r--r--chrome/browser/external_protocol_dialog.h1
-rw-r--r--chrome/browser/first_run.cc8
-rw-r--r--chrome/browser/importer.cc8
-rw-r--r--chrome/browser/jsmessage_box_handler.cc11
-rw-r--r--chrome/browser/jsmessage_box_handler.h1
-rw-r--r--chrome/browser/page_info_window.cc36
-rw-r--r--chrome/browser/page_info_window.h8
-rw-r--r--chrome/browser/repost_form_warning_dialog.cc18
-rw-r--r--chrome/browser/repost_form_warning_dialog.h5
-rw-r--r--chrome/browser/task_manager.cc25
-rw-r--r--chrome/browser/task_manager.h3
-rw-r--r--chrome/browser/user_data_dir_dialog.cc11
-rw-r--r--chrome/browser/user_data_dir_dialog.h2
-rw-r--r--chrome/browser/views/about_chrome_view.cc15
-rw-r--r--chrome/browser/views/about_chrome_view.h5
-rw-r--r--chrome/browser/views/bookmark_editor_view.cc16
-rw-r--r--chrome/browser/views/bookmark_editor_view.h4
-rw-r--r--chrome/browser/views/bug_report_view.cc9
-rw-r--r--chrome/browser/views/bug_report_view.h3
-rw-r--r--chrome/browser/views/clear_browsing_data.cc15
-rw-r--r--chrome/browser/views/clear_browsing_data.h5
-rw-r--r--chrome/browser/views/constrained_window_impl.cc116
-rw-r--r--chrome/browser/views/constrained_window_impl.h20
-rw-r--r--chrome/browser/views/edit_keyword_controller.cc17
-rw-r--r--chrome/browser/views/edit_keyword_controller.h4
-rw-r--r--chrome/browser/views/first_run_customize_view.cc11
-rw-r--r--chrome/browser/views/first_run_customize_view.h17
-rw-r--r--chrome/browser/views/first_run_view.cc22
-rw-r--r--chrome/browser/views/first_run_view.h1
-rw-r--r--chrome/browser/views/first_run_view_base.cc9
-rw-r--r--chrome/browser/views/first_run_view_base.h6
-rw-r--r--chrome/browser/views/html_dialog_view.cc15
-rw-r--r--chrome/browser/views/html_dialog_view.h6
-rw-r--r--chrome/browser/views/hung_renderer_view.cc36
-rw-r--r--chrome/browser/views/importer_lock_view.cc7
-rw-r--r--chrome/browser/views/importer_lock_view.h7
-rw-r--r--chrome/browser/views/importer_view.cc9
-rw-r--r--chrome/browser/views/importer_view.h5
-rw-r--r--chrome/browser/views/importing_progress_view.cc13
-rw-r--r--chrome/browser/views/importing_progress_view.h6
-rw-r--r--chrome/browser/views/input_window.cc20
-rw-r--r--chrome/browser/views/keyword_editor_view.cc6
-rw-r--r--chrome/browser/views/keyword_editor_view.h1
-rw-r--r--chrome/browser/views/options/advanced_page_view.cc6
-rw-r--r--chrome/browser/views/options/content_page_view.cc9
-rw-r--r--chrome/browser/views/options/cookies_view.cc6
-rw-r--r--chrome/browser/views/options/cookies_view.h1
-rw-r--r--chrome/browser/views/options/fonts_languages_window_view.cc15
-rw-r--r--chrome/browser/views/options/fonts_languages_window_view.h11
-rw-r--r--chrome/browser/views/options/languages_page_view.cc11
-rw-r--r--chrome/browser/views/options/options_window_view.cc22
-rw-r--r--chrome/browser/views/password_manager_view.cc17
-rw-r--r--chrome/browser/views/password_manager_view.h4
-rw-r--r--chrome/browser/views/restart_message_box.cc8
-rw-r--r--chrome/browser/views/restart_message_box.h5
-rw-r--r--chrome/browser/views/shelf_item_dialog.cc31
-rw-r--r--chrome/browser/views/shelf_item_dialog.h4
-rw-r--r--chrome/views/client_view.cc8
-rw-r--r--chrome/views/custom_frame_window.cc19
-rw-r--r--chrome/views/custom_frame_window.h14
-rw-r--r--chrome/views/focus_manager_unittest.cc16
-rw-r--r--chrome/views/view_unittest.cc6
-rw-r--r--chrome/views/window.cc181
-rw-r--r--chrome/views/window.h16
-rw-r--r--chrome/views/window_delegate.h22
69 files changed, 528 insertions, 531 deletions
diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc
index aebd7cf..3795b14 100644
--- a/chrome/browser/browser.cc
+++ b/chrome/browser/browser.cc
@@ -770,10 +770,10 @@ void Browser::ShowHtmlDialog(HtmlDialogContentsDelegate* delegate,
HWND parent_hwnd) {
parent_hwnd = parent_hwnd ? parent_hwnd : GetTopLevelHWND();
HtmlDialogView* html_view = new HtmlDialogView(this, profile_, delegate);
- ChromeViews::Window* html_dialog = ChromeViews::Window::CreateChromeWindow(
- parent_hwnd, gfx::Rect(), html_view, html_view);
- html_view->InitDialog(html_dialog);
- html_dialog->Show();
+ ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(),
+ html_view);
+ html_view->InitDialog();
+ html_view->window()->Show();
}
void Browser::Observe(NotificationType type,
diff --git a/chrome/browser/browser_commands.cc b/chrome/browser/browser_commands.cc
index 0d65b0b..3b5d201 100644
--- a/chrome/browser/browser_commands.cc
+++ b/chrome/browser/browser_commands.cc
@@ -546,14 +546,10 @@ void Browser::ExecuteCommand(int id) {
case IDC_ABOUT: {
UserMetrics::RecordAction(L"AboutChrome", profile_);
- AboutChromeView* about_view = new AboutChromeView(profile_);
- ChromeViews::Window* about_dialog =
- ChromeViews::Window::CreateChromeWindow(GetTopLevelHWND(),
- gfx::Rect(),
- about_view,
- about_view);
- about_dialog->Show();
- about_view->SetDialog(about_dialog);
+ ChromeViews::Window::CreateChromeWindow(
+ GetTopLevelHWND(),
+ gfx::Rect(),
+ new AboutChromeView(profile_))->Show();
break;
}
@@ -944,12 +940,8 @@ void Browser::OpenKeywordEditor() {
}
void Browser::OpenImportSettingsDialog() {
- ImporterView* importer_view = new ImporterView(profile_);
- ChromeViews::Window* importer_dialog =
- ChromeViews::Window::CreateChromeWindow(GetTopLevelHWND(), gfx::Rect(),
- importer_view, importer_view);
- importer_dialog->Show();
- importer_view->set_dialog(importer_dialog);
+ ChromeViews::Window::CreateChromeWindow(GetTopLevelHWND(), gfx::Rect(),
+ new ImporterView(profile_))->Show();
}
void Browser::OpenBugReportDialog() {
@@ -988,22 +980,15 @@ void Browser::OpenBugReportDialog() {
bug_report_view->set_png_data(screenshot_png);
// Create and show the dialog
- ChromeViews::Window* bug_report_dialog =
- ChromeViews::Window::CreateChromeWindow(GetTopLevelHWND(), gfx::Rect(),
- bug_report_view, bug_report_view);
- bug_report_dialog->Show();
- bug_report_view->set_dialog(bug_report_dialog);
+ ChromeViews::Window::CreateChromeWindow(GetTopLevelHWND(), gfx::Rect(),
+ bug_report_view)->Show();
}
void Browser::OpenClearBrowsingDataDialog() {
- ClearBrowsingDataView* clear_browsing_data_view =
- new ClearBrowsingDataView(profile_);
- ChromeViews::Window* clear_browsing_data_dialog =
- ChromeViews::Window::CreateChromeWindow(
- GetTopLevelHWND(), gfx::Rect(),
- clear_browsing_data_view, clear_browsing_data_view);
- clear_browsing_data_dialog->Show();
- clear_browsing_data_view->SetDialog(clear_browsing_data_dialog);
+ ChromeViews::Window::CreateChromeWindow(
+ GetTopLevelHWND(),
+ gfx::Rect(),
+ new ClearBrowsingDataView(profile_))->Show();
}
void Browser::RunSimpleFrameMenu(const CPoint& pt, HWND hwnd) {
diff --git a/chrome/browser/debugger/debugger_window.cc b/chrome/browser/debugger/debugger_window.cc
index ee21dd0..6e94a06 100644
--- a/chrome/browser/debugger/debugger_window.cc
+++ b/chrome/browser/debugger/debugger_window.cc
@@ -62,8 +62,7 @@ void DebuggerWindow::Show(TabContents* tab) {
return;
}
view_ = new DebuggerView(this);
- window_ = ChromeViews::Window::CreateChromeWindow(
- NULL, gfx::Rect(), view_, this);
+ window_ = ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), this);
view_->OnInit();
window_->Show();
view_->OnShow();
@@ -176,6 +175,10 @@ bool DebuggerWindow::CanResize() const {
return true;
}
+ChromeViews::View* DebuggerWindow::GetContentsView() {
+ return view_;
+}
+
///////////////////////////////////////////////////////////////////
// Overridden from ChromeViews::TextField::Controller:
diff --git a/chrome/browser/external_protocol_dialog.cc b/chrome/browser/external_protocol_dialog.cc
index 251a911..e493829 100644
--- a/chrome/browser/external_protocol_dialog.cc
+++ b/chrome/browser/external_protocol_dialog.cc
@@ -105,6 +105,10 @@ bool ExternalProtocolDialog::Accept() {
return true;
}
+ChromeViews::View* ExternalProtocolDialog::GetContentsView() {
+ return message_box_view_;
+}
+
///////////////////////////////////////////////////////////////////////////////
// ExternalProtocolDialog, private:
@@ -135,11 +139,7 @@ ExternalProtocolDialog::ExternalProtocolDialog(TabContents* tab_contents,
root_hwnd = NULL;
}
- ChromeViews::Window* dialog =
- ChromeViews::Window::CreateChromeWindow(root_hwnd, gfx::Rect(),
- message_box_view_, this);
-
- dialog->Show();
+ ChromeViews::Window::CreateChromeWindow(root_hwnd, gfx::Rect(), this)->Show();
}
std::wstring ExternalProtocolDialog::GetApplicationForProtocol() {
diff --git a/chrome/browser/external_protocol_dialog.h b/chrome/browser/external_protocol_dialog.h
index 13777c53..18f56d5 100644
--- a/chrome/browser/external_protocol_dialog.h
+++ b/chrome/browser/external_protocol_dialog.h
@@ -55,6 +55,7 @@ class ExternalProtocolDialog : public ChromeViews::DialogDelegate {
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
virtual bool Accept();
+ virtual ChromeViews::View* GetContentsView();
// ChromeViews::WindowDelegate Methods:
virtual bool IsAlwaysOnTop() const { return false; }
diff --git a/chrome/browser/first_run.cc b/chrome/browser/first_run.cc
index 950391b..51720ab 100644
--- a/chrome/browser/first_run.cc
+++ b/chrome/browser/first_run.cc
@@ -182,12 +182,8 @@ bool Upgrade::RelaunchChromeBrowser(const CommandLine& command_line) {
}
void OpenFirstRunDialog(Profile* profile) {
- FirstRunView* first_run_view = new FirstRunView(profile);
- ChromeViews::Window* first_run_dialog =
- ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(),
- first_run_view, first_run_view);
- first_run_dialog->Show();
- first_run_view->set_dialog(first_run_dialog);
+ ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(),
+ new FirstRunView(profile))->Show();
// We must now run a message loop (will be terminated when the First Run UI
// is closed) so that the window can receive messages and we block the
// browser window from showing up. We pass the accelerator handler here so
diff --git a/chrome/browser/importer.cc b/chrome/browser/importer.cc
index 2053527..f0b2b51 100644
--- a/chrome/browser/importer.cc
+++ b/chrome/browser/importer.cc
@@ -340,12 +340,8 @@ void ImporterHost::Observe(NotificationType type,
}
void ImporterHost::ShowWarningDialog() {
- ImporterLockView* view = new ImporterLockView(this);
- ChromeViews::Window* dialog =
- ChromeViews::Window::CreateChromeWindow(
- GetActiveWindow(), gfx::Rect(), view, view);
- dialog->Show();
- view->set_dialog(dialog);
+ ChromeViews::Window::CreateChromeWindow(GetActiveWindow(), gfx::Rect(),
+ new ImporterLockView(this))->Show();
}
void ImporterHost::OnLockViewEnd(bool is_continue) {
diff --git a/chrome/browser/jsmessage_box_handler.cc b/chrome/browser/jsmessage_box_handler.cc
index d3dacd8..1576a21 100644
--- a/chrome/browser/jsmessage_box_handler.cc
+++ b/chrome/browser/jsmessage_box_handler.cc
@@ -146,8 +146,8 @@ void JavascriptMessageBoxHandler::ShowModalDialog() {
web_contents_->Activate();
HWND root_hwnd = GetAncestor(web_contents_->GetHWND(), GA_ROOT);
- dialog_ = ChromeViews::Window::CreateChromeWindow(root_hwnd, gfx::Rect(),
- message_box_view_, this);
+ dialog_ =
+ ChromeViews::Window::CreateChromeWindow(root_hwnd, gfx::Rect(), this);
dialog_->Show();
}
@@ -160,6 +160,13 @@ void JavascriptMessageBoxHandler::ActivateModalDialog() {
}
///////////////////////////////////////////////////////////////////////////////
+// JavascriptMessageBoxHandler, ChromeViews::WindowDelegate implementation:
+
+ChromeViews::View* JavascriptMessageBoxHandler::GetContentsView() {
+ return message_box_view_;
+}
+
+///////////////////////////////////////////////////////////////////////////////
// JavascriptMessageBoxHandler, private:
void JavascriptMessageBoxHandler::Observe(NotificationType type,
diff --git a/chrome/browser/jsmessage_box_handler.h b/chrome/browser/jsmessage_box_handler.h
index 3369f7f..92a506f 100644
--- a/chrome/browser/jsmessage_box_handler.h
+++ b/chrome/browser/jsmessage_box_handler.h
@@ -72,6 +72,7 @@ class JavascriptMessageBoxHandler
// ChromeViews::WindowDelegate Methods:
virtual bool IsModal() const { return true; }
+ virtual ChromeViews::View* GetContentsView();
protected:
// Use RunJavaScriptMessageBox to use.
diff --git a/chrome/browser/page_info_window.cc b/chrome/browser/page_info_window.cc
index f3ea75e..dc6d8fa 100644
--- a/chrome/browser/page_info_window.cc
+++ b/chrome/browser/page_info_window.cc
@@ -509,7 +509,7 @@ void PageInfoWindow::RegisterPrefs(PrefService* prefs) {
prefs->RegisterDictionaryPref(prefs::kPageInfoWindowPlacement);
}
-PageInfoWindow::PageInfoWindow() : cert_id_(0) {
+PageInfoWindow::PageInfoWindow() : cert_id_(0), contents_(NULL) {
}
PageInfoWindow::~PageInfoWindow() {
@@ -526,15 +526,15 @@ void PageInfoWindow::Init(Profile* profile,
l10n_util::GetString(IDS_PAGEINFO_CERT_INFO_BUTTON));
cert_info_button_->SetListener(this);
- PageInfoContentView* contents = new PageInfoContentView();
+ contents_ = new PageInfoContentView();
DWORD sys_color = ::GetSysColor(COLOR_3DFACE);
SkColor color = SkColorSetRGB(GetRValue(sys_color), GetGValue(sys_color),
GetBValue(sys_color));
- contents->SetBackground(
+ contents_->SetBackground(
ChromeViews::Background::CreateSolidBackground(color));
- ChromeViews::GridLayout* layout = new ChromeViews::GridLayout(contents);
- contents->SetLayoutManager(layout);
+ ChromeViews::GridLayout* layout = new ChromeViews::GridLayout(contents_);
+ contents_->SetLayoutManager(layout);
ChromeViews::ColumnSet* columns = layout->AddColumnSet(0);
columns->AddPaddingColumn(0, kHorizontalPadding);
columns->AddColumn(ChromeViews::GridLayout::FILL, // Horizontal resize.
@@ -569,12 +569,12 @@ void PageInfoWindow::Init(Profile* profile,
}
}
- window_ = ChromeViews::Window::CreateChromeWindow(parent, gfx::Rect(),
- contents, this);
+ ChromeViews::Window::CreateChromeWindow(parent, gfx::Rect(), this);
+ // TODO(beng): (Cleanup) - cert viewer button should use GetExtraView.
if (cert_id_) {
- contents->GetParent()->AddChildView(cert_info_button_);
- contents->set_cert_viewer_button(cert_info_button_);
- contents->Layout();
+ contents_->GetParent()->AddChildView(cert_info_button_);
+ contents_->set_cert_viewer_button(cert_info_button_);
+ contents_->Layout();
}
}
@@ -589,7 +589,7 @@ ChromeViews::View* PageInfoWindow::CreateSecurityTabView(
}
void PageInfoWindow::Show() {
- window_->Show();
+ window()->Show();
opened_window_count_++;
}
@@ -604,20 +604,24 @@ std::wstring PageInfoWindow::GetWindowTitle() const {
void PageInfoWindow::SaveWindowPosition(const CRect& bounds,
bool maximized,
bool always_on_top) {
- window_->SaveWindowPositionToPrefService(g_browser_process->local_state(),
- prefs::kPageInfoWindowPlacement,
- bounds, maximized, always_on_top);
+ window()->SaveWindowPositionToPrefService(g_browser_process->local_state(),
+ prefs::kPageInfoWindowPlacement,
+ bounds, maximized, always_on_top);
}
bool PageInfoWindow::RestoreWindowPosition(CRect* bounds,
bool* maximized,
bool* always_on_top) {
- return window_->RestoreWindowPositionFromPrefService(
+ return window()->RestoreWindowPositionFromPrefService(
g_browser_process->local_state(),
prefs::kPageInfoWindowPlacement,
bounds, maximized, always_on_top);
}
+ChromeViews::View* PageInfoWindow::GetContentsView() {
+ return contents_;
+}
+
void PageInfoWindow::ButtonPressed(ChromeViews::NativeButton* sender) {
if (sender == cert_info_button_) {
DCHECK(cert_id_ != 0);
@@ -675,7 +679,7 @@ void PageInfoWindow::ShowCertDialog(int cert_id) {
view_info.dwSize = sizeof(view_info);
// We set our parent to the tab window. This makes the cert dialog created
// in CryptUIDlgViewCertificate modal to the browser.
- view_info.hwndParent = window_->owning_window();
+ view_info.hwndParent = window()->owning_window();
view_info.dwFlags = CRYPTUI_DISABLE_EDITPROPERTIES |
CRYPTUI_DISABLE_ADDTOSTORE;
view_info.pCertContext = cert->os_cert_handle();
diff --git a/chrome/browser/page_info_window.h b/chrome/browser/page_info_window.h
index 9246089..1e71ddd 100644
--- a/chrome/browser/page_info_window.h
+++ b/chrome/browser/page_info_window.h
@@ -42,6 +42,7 @@ class TabbedPane;
}
class NavigationEntry;
+class PageInfoContentView;
class PrefService;
class Profile;
class X509Certificate;
@@ -85,6 +86,7 @@ class PageInfoWindow : public ChromeViews::DialogDelegate,
virtual bool RestoreWindowPosition(CRect* bounds,
bool* maximized,
bool* always_on_top);
+ virtual ChromeViews::View* GetContentsView();
private:
ChromeViews::View* CreateGeneralTabView();
@@ -103,12 +105,12 @@ class PageInfoWindow : public ChromeViews::DialogDelegate,
// The id of the server cert for this page (0 means no cert).
int cert_id_;
+ // The page info contents.
+ PageInfoContentView* contents_;
+
// A counter of how many page info windows are currently opened.
static int opened_window_count_;
- // The Window
- ChromeViews::Window* window_;
-
DISALLOW_EVIL_CONSTRUCTORS(PageInfoWindow);
};
diff --git a/chrome/browser/repost_form_warning_dialog.cc b/chrome/browser/repost_form_warning_dialog.cc
index 4b19d3b..2d45028 100644
--- a/chrome/browser/repost_form_warning_dialog.cc
+++ b/chrome/browser/repost_form_warning_dialog.cc
@@ -75,18 +75,23 @@ void RepostFormWarningDialog::WindowClosing() {
}
bool RepostFormWarningDialog::Cancel() {
- dialog_ = NULL;
return true;
}
bool RepostFormWarningDialog::Accept() {
- dialog_ = NULL;
if (navigation_controller_)
navigation_controller_->ReloadDontCheckForRepost();
return true;
}
///////////////////////////////////////////////////////////////////////////////
+// RepostFormWarningDialog, ChromeViews::WindowDelegate implementation:
+
+ChromeViews::View* RepostFormWarningDialog::GetContentsView() {
+ return message_box_view_;
+}
+
+///////////////////////////////////////////////////////////////////////////////
// RepostFormWarningDialog, private:
RepostFormWarningDialog::RepostFormWarningDialog(
@@ -100,10 +105,7 @@ RepostFormWarningDialog::RepostFormWarningDialog(
HWND root_hwnd = NULL;
if (BrowserList::GetLastActive())
root_hwnd = BrowserList::GetLastActive()->GetTopLevelHWND();
- ChromeViews::Window* dialog_ =
- ChromeViews::Window::CreateChromeWindow(root_hwnd, gfx::Rect(),
- message_box_view_, this);
- dialog_->Show();
+ ChromeViews::Window::CreateChromeWindow(root_hwnd, gfx::Rect(), this)->Show();
NotificationService::current()->
AddObserver(this, NOTIFY_LOAD_START, NotificationService::AllSources());
NotificationService::current()->
@@ -116,10 +118,10 @@ void RepostFormWarningDialog::Observe(NotificationType type,
// Close the dialog if we load a page (because reloading might not apply to
// the same page anymore) or if the tab is closed, because then we won't have
// a navigation controller anymore.
- if (dialog_ && navigation_controller_ &&
+ if (window() && navigation_controller_ &&
(type == NOTIFY_LOAD_START || type == NOTIFY_TAB_CLOSING) &&
Source<NavigationController>(source).ptr() == navigation_controller_) {
navigation_controller_ = NULL;
- dialog_->Close();
+ window()->Close();
}
}
diff --git a/chrome/browser/repost_form_warning_dialog.h b/chrome/browser/repost_form_warning_dialog.h
index 6df1278..775c934 100644
--- a/chrome/browser/repost_form_warning_dialog.h
+++ b/chrome/browser/repost_form_warning_dialog.h
@@ -57,6 +57,7 @@ class RepostFormWarningDialog : public ChromeViews::DialogDelegate,
// ChromeViews::WindowDelegate Methods:
virtual bool IsModal() const { return true; }
+ virtual ChromeViews::View* GetContentsView();
private:
// Use RunRepostFormWarningDialog to use.
@@ -74,10 +75,6 @@ class RepostFormWarningDialog : public ChromeViews::DialogDelegate,
// Navigation controller, used to continue the reload.
NavigationController* navigation_controller_;
- // Our window. Used to close the dialog if we navigate or lose our navigation
- // controller before the user makes a decision.
- ChromeViews::Window* dialog_;
-
DISALLOW_EVIL_CONSTRUCTORS(RepostFormWarningDialog);
};
diff --git a/chrome/browser/task_manager.cc b/chrome/browser/task_manager.cc
index 26731c9..17cddba 100644
--- a/chrome/browser/task_manager.cc
+++ b/chrome/browser/task_manager.cc
@@ -823,7 +823,7 @@ void TaskManager::RegisterPrefs(PrefService* prefs) {
prefs->RegisterDictionaryPref(prefs::kTaskManagerWindowPlacement);
}
-TaskManager::TaskManager() : window_(NULL) {
+TaskManager::TaskManager() {
table_model_ = new TaskManagerTableModel(this);
contents_.reset(new TaskManagerContents(this, table_model_));
}
@@ -834,19 +834,16 @@ TaskManager::~TaskManager() {
// static
void TaskManager::Open() {
TaskManager* task_manager = GetInstance();
- if (task_manager->window_) {
- task_manager->window_->MoveToFront(true);
+ if (task_manager->window()) {
+ task_manager->window()->MoveToFront(true);
} else {
- task_manager->window_ =
- ChromeViews::Window::CreateChromeWindow(
- NULL, gfx::Rect(), task_manager->contents_.get(), task_manager);
+ ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), task_manager);
task_manager->table_model_->StartUpdating();
- task_manager->window_->Show();
+ task_manager->window()->Show();
}
}
void TaskManager::Close() {
- window_ = NULL;
table_model_->StopUpdating();
table_model_->Clear();
}
@@ -923,15 +920,15 @@ std::wstring TaskManager::GetWindowTitle() const {
void TaskManager::SaveWindowPosition(const CRect& bounds,
bool maximized,
bool always_on_top) {
- window_->SaveWindowPositionToPrefService(g_browser_process->local_state(),
- prefs::kTaskManagerWindowPlacement,
- bounds, maximized, always_on_top);
+ window()->SaveWindowPositionToPrefService(g_browser_process->local_state(),
+ prefs::kTaskManagerWindowPlacement,
+ bounds, maximized, always_on_top);
}
bool TaskManager::RestoreWindowPosition(CRect* bounds,
bool* maximized,
bool* always_on_top) {
- return window_->RestoreWindowPositionFromPrefService(
+ return window()->RestoreWindowPositionFromPrefService(
g_browser_process->local_state(),
prefs::kTaskManagerWindowPlacement,
bounds, maximized, always_on_top);
@@ -949,6 +946,10 @@ void TaskManager::WindowClosing() {
Close();
}
+ChromeViews::View* TaskManager::GetContentsView() {
+ return contents_.get();
+}
+
// static
TaskManager* TaskManager::GetInstance() {
return Singleton<TaskManager>::get();
diff --git a/chrome/browser/task_manager.h b/chrome/browser/task_manager.h
index 3dc89e8..dd5431e 100644
--- a/chrome/browser/task_manager.h
+++ b/chrome/browser/task_manager.h
@@ -150,6 +150,7 @@ class TaskManager : public ChromeViews::DialogDelegate {
bool* always_on_top);
virtual int GetDialogButtons() const;
virtual void WindowClosing();
+ virtual ChromeViews::View* GetContentsView();
private:
// Obtain an instance via GetInstance().
@@ -163,8 +164,6 @@ class TaskManager : public ChromeViews::DialogDelegate {
// Returns the singleton instance (and initializes it if necessary).
static TaskManager* GetInstance();
- ChromeViews::Window* window_;
-
// The model used for the list in the table that displays the list of tab
// processes. It is ref counted because it is passed as a parameter to
// MessageLoop::InvokeLater().
diff --git a/chrome/browser/user_data_dir_dialog.cc b/chrome/browser/user_data_dir_dialog.cc
index be0b9d9..56b6ba2 100644
--- a/chrome/browser/user_data_dir_dialog.cc
+++ b/chrome/browser/user_data_dir_dialog.cc
@@ -53,10 +53,7 @@ UserDataDirDialog::UserDataDirDialog(const std::wstring& user_data_dir)
message_box_view_ = new MessageBoxView(MessageBoxView::kIsConfirmMessageBox,
message_text.c_str(), std::wstring(), kDialogWidth);
- message_box_window_ = ChromeViews::Window::CreateChromeWindow(
- NULL, gfx::Rect(), message_box_view_, this);
-
- message_box_window_->Show();
+ ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), this)->Show();
}
UserDataDirDialog::~UserDataDirDialog() {
@@ -109,6 +106,10 @@ bool UserDataDirDialog::Cancel() {
return true;
}
+ChromeViews::View* UserDataDirDialog::GetContentsView() {
+ return message_box_view_;
+}
+
bool UserDataDirDialog::Dispatch(const MSG& msg) {
TranslateMessage(&msg);
DispatchMessage(&msg);
@@ -118,7 +119,7 @@ bool UserDataDirDialog::Dispatch(const MSG& msg) {
void UserDataDirDialog::FileSelected(const std::wstring& path, void* params) {
user_data_dir_ = path;
is_blocking_ = false;
- message_box_window_->Close();
+ window()->Close();
}
void UserDataDirDialog::FileSelectionCanceled(void* params) {
diff --git a/chrome/browser/user_data_dir_dialog.h b/chrome/browser/user_data_dir_dialog.h
index eca34e5..ce1bff5 100644
--- a/chrome/browser/user_data_dir_dialog.h
+++ b/chrome/browser/user_data_dir_dialog.h
@@ -67,6 +67,7 @@ class UserDataDirDialog : public ChromeViews::DialogDelegate,
// ChromeViews::WindowDelegate Methods:
virtual bool IsAlwaysOnTop() const { return false; }
virtual bool IsModal() const { return false; }
+ virtual ChromeViews::View* GetContentsView();
// MessageLoop::Dispatcher Method:
virtual bool Dispatch(const MSG& msg);
@@ -82,7 +83,6 @@ class UserDataDirDialog : public ChromeViews::DialogDelegate,
std::wstring user_data_dir_;
MessageBoxView* message_box_view_;
- ChromeViews::Window* message_box_window_;
scoped_refptr<SelectFileDialog> select_file_dialog_;
// Used to keep track of whether or not to block the message loop (still
diff --git a/chrome/browser/views/about_chrome_view.cc b/chrome/browser/views/about_chrome_view.cc
index 157ccc6..4ad5908 100644
--- a/chrome/browser/views/about_chrome_view.cc
+++ b/chrome/browser/views/about_chrome_view.cc
@@ -54,8 +54,7 @@
// AboutChromeView, public:
AboutChromeView::AboutChromeView(Profile* profile)
- : dialog_(NULL),
- profile_(profile),
+ : profile_(profile),
about_dlg_background_(NULL),
about_title_label_(NULL),
version_label_(NULL),
@@ -372,6 +371,10 @@ bool AboutChromeView::Accept() {
return false; // We never allow this button to close the window.
}
+ChromeViews::View* AboutChromeView::GetContentsView() {
+ return this;
+}
+
////////////////////////////////////////////////////////////////////////////////
// AboutChromeView, GoogleUpdateStatusListener implementation:
@@ -456,7 +459,7 @@ void AboutChromeView::UpdateStatus(GoogleUpdateUpgradeResult result,
l10n_util::GetString(IDS_PRODUCT_NAME),
new_version_available_));
show_success_indicator = true;
- RestartMessageBox::ShowMessageBox(dialog_->GetHWND());
+ RestartMessageBox::ShowMessageBox(window()->GetHWND());
break;
case UPGRADE_ERROR:
UserMetrics::RecordAction(L"UpgradeCheck_Error", profile_);
@@ -484,7 +487,7 @@ void AboutChromeView::UpdateStatus(GoogleUpdateUpgradeResult result,
parent->Layout();
// Check button may have appeared/disappeared. We cannot call this during
- // ViewHierarchyChanged because the |dialog_| pointer hasn't been set yet.
- if (dialog_)
- dialog_->UpdateDialogButtons();
+ // ViewHierarchyChanged because the |window()| pointer hasn't been set yet.
+ if (window())
+ window()->UpdateDialogButtons();
}
diff --git a/chrome/browser/views/about_chrome_view.h b/chrome/browser/views/about_chrome_view.h
index b304218..a46a741 100644
--- a/chrome/browser/views/about_chrome_view.h
+++ b/chrome/browser/views/about_chrome_view.h
@@ -61,8 +61,6 @@ class AboutChromeView : public ChromeViews::View,
// Initialize the controls on the dialog.
void Init();
- void SetDialog(ChromeViews::Window* dialog) { dialog_ = dialog; }
-
// Overridden from ChromeViews::View:
virtual void GetPreferredSize(CSize *out);
virtual void Layout();
@@ -82,6 +80,7 @@ class AboutChromeView : public ChromeViews::View,
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual bool Accept();
+ virtual ChromeViews::View* GetContentsView();
// Overridden from GoogleUpdateStatusListener:
virtual void OnReportResults(GoogleUpdateUpgradeResult result,
@@ -100,8 +99,6 @@ class AboutChromeView : public ChromeViews::View,
void UpdateStatus(GoogleUpdateUpgradeResult result,
GoogleUpdateErrorCode error_code);
- ChromeViews::Window* dialog_;
-
Profile* profile_;
// UI elements on the dialog.
diff --git a/chrome/browser/views/bookmark_editor_view.cc b/chrome/browser/views/bookmark_editor_view.cc
index e7a834a..da5a92d 100644
--- a/chrome/browser/views/bookmark_editor_view.cc
+++ b/chrome/browser/views/bookmark_editor_view.cc
@@ -79,7 +79,6 @@ BookmarkEditorView::BookmarkEditorView(Profile* profile,
#pragma warning(suppress: 4355) // Okay to pass "this" here.
new_group_button_(
l10n_util::GetString(IDS_BOOMARK_EDITOR_NEW_FOLDER_BUTTON)),
- dialog_(NULL),
url_(url),
title_(title),
running_menu_for_root_(false) {
@@ -122,6 +121,10 @@ bool BookmarkEditorView::AreAcceleratorsEnabled(DialogButton button) {
return !tree_view_.GetEditingNode();
}
+ChromeViews::View* BookmarkEditorView::GetContentsView() {
+ return this;
+}
+
void BookmarkEditorView::Layout() {
// Let the grid layout manager lay out most of the dialog...
GetLayoutManager()->Layout(this);
@@ -205,12 +208,11 @@ bool BookmarkEditorView::IsCommandEnabled(int id) const {
}
void BookmarkEditorView::Show(HWND parent_hwnd) {
- dialog_ = ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(),
- this, this);
+ ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(), this);
UserInputChanged();
if (bb_model_->IsLoaded())
ExpandAndSelect();
- dialog_->Show();
+ window()->Show();
// Select all the text in the name textfield.
title_tf_.SelectAll();
// Give focus to the name textfield.
@@ -218,8 +220,8 @@ void BookmarkEditorView::Show(HWND parent_hwnd) {
}
void BookmarkEditorView::Close() {
- DCHECK(dialog_);
- dialog_->Close();
+ DCHECK(window());
+ window()->Close();
}
void BookmarkEditorView::ShowContextMenu(View* source,
@@ -389,7 +391,7 @@ void BookmarkEditorView::UserInputChanged() {
url_tf_.SetBackgroundColor(kErrorColor);
else
url_tf_.SetDefaultBackgroundColor();
- dialog_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
void BookmarkEditorView::NewGroup() {
diff --git a/chrome/browser/views/bookmark_editor_view.h b/chrome/browser/views/bookmark_editor_view.h
index c12abeb..5a2b9d6 100644
--- a/chrome/browser/views/bookmark_editor_view.h
+++ b/chrome/browser/views/bookmark_editor_view.h
@@ -83,6 +83,7 @@ class BookmarkEditorView : public ChromeViews::View,
virtual std::wstring GetWindowTitle() const;
virtual bool Accept();
virtual bool AreAcceleratorsEnabled(DialogButton button);
+ virtual ChromeViews::View* GetContentsView();
// View methods.
virtual void Layout();
@@ -244,9 +245,6 @@ class BookmarkEditorView : public ChromeViews::View,
// Used for editing the title.
ChromeViews::TextField title_tf_;
- // Dialog we're contained in.
- ChromeViews::Window* dialog_;
-
// URL we were created with.
const GURL url_;
diff --git a/chrome/browser/views/bug_report_view.cc b/chrome/browser/views/bug_report_view.cc
index 2977409..45023e5 100644
--- a/chrome/browser/views/bug_report_view.cc
+++ b/chrome/browser/views/bug_report_view.cc
@@ -154,8 +154,7 @@ void BugReportView::PostCleanup::OnURLFetchComplete(
// This is separate from crash reporting, which is handled by Breakpad.
//
BugReportView::BugReportView(Profile* profile, TabContents* tab)
- : dialog_(NULL),
- include_page_source_checkbox_(NULL),
+ : include_page_source_checkbox_(NULL),
include_page_image_checkbox_(NULL),
profile_(profile),
post_url_(l10n_util::GetString(IDS_BUGREPORT_POST_URL)),
@@ -279,7 +278,7 @@ void BugReportView::ItemChanged(ChromeViews::ComboBox* combo_box,
include_page_image_checkbox_->SetEnabled(!is_phishing_report);
include_page_image_checkbox_->SetIsSelected(!is_phishing_report);
- dialog_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
void BugReportView::ContentsChanged(ChromeViews::TextField* sender,
@@ -340,6 +339,10 @@ bool BugReportView::Accept() {
return true;
}
+ChromeViews::View* BugReportView::GetContentsView() {
+ return this;
+}
+
void BugReportView::SetUrl(const GURL& url) {
page_url_text_->SetText(UTF8ToWide(url.spec()));
}
diff --git a/chrome/browser/views/bug_report_view.h b/chrome/browser/views/bug_report_view.h
index f50e63c..07919d3 100644
--- a/chrome/browser/views/bug_report_view.h
+++ b/chrome/browser/views/bug_report_view.h
@@ -67,7 +67,6 @@ class BugReportView : public ChromeViews::View,
explicit BugReportView(Profile* profile, TabContents* tab);
virtual ~BugReportView();
- void set_dialog(ChromeViews::Window* dialog) { dialog_ = dialog; }
void set_version(const std::wstring& version) { version_ = version; }
// NOTE: set_png_data takes ownership of the vector
void set_png_data(std::vector<unsigned char> *png_data) {
@@ -98,6 +97,7 @@ class BugReportView : public ChromeViews::View,
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual bool Accept();
+ virtual ChromeViews::View* GetContentsView();
void SetUrl(const GURL& url);
@@ -129,7 +129,6 @@ class BugReportView : public ChromeViews::View,
ChromeViews::CheckBox* include_page_image_checkbox_;
scoped_ptr<BugReportComboBoxModel> bug_type_model_;
- ChromeViews::Window* dialog_;
Profile* profile_;
diff --git a/chrome/browser/views/clear_browsing_data.cc b/chrome/browser/views/clear_browsing_data.cc
index 17341cd..b3721ab 100644
--- a/chrome/browser/views/clear_browsing_data.cc
+++ b/chrome/browser/views/clear_browsing_data.cc
@@ -54,8 +54,7 @@ static const int kExtraMarginForTimePeriodLabel = 3;
// ClearBrowsingDataView, public:
ClearBrowsingDataView::ClearBrowsingDataView(Profile* profile)
- : dialog_(NULL),
- del_history_checkbox_(NULL),
+ : del_history_checkbox_(NULL),
del_downloads_checkbox_(NULL),
del_cache_checkbox_(NULL),
del_cookies_checkbox_(NULL),
@@ -292,6 +291,10 @@ bool ClearBrowsingDataView::Accept() {
return false; // We close the dialog in OnDeletionDone().
}
+ChromeViews::View* ClearBrowsingDataView::GetContentsView() {
+ return this;
+}
+
////////////////////////////////////////////////////////////////////////////////
// ClearBrowsingDataView, ChromeViews::ComboBox::Model implementation:
@@ -319,7 +322,7 @@ std::wstring ClearBrowsingDataView::GetItemAt(ChromeViews::ComboBox* source,
void ClearBrowsingDataView::ButtonPressed(ChromeViews::NativeButton* sender) {
// When no checkbox is checked we should not have the action button enabled.
// This forces the button to evaluate what state they should be in.
- dialog_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
////////////////////////////////////////////////////////////////////////////////
@@ -335,7 +338,7 @@ ChromeViews::CheckBox* ClearBrowsingDataView::AddCheckbox(
}
void ClearBrowsingDataView::UpdateControlEnabledState() {
- dialog_->EnableClose(!delete_in_progress_);
+ window()->EnableClose(!delete_in_progress_);
del_history_checkbox_->SetEnabled(!delete_in_progress_);
del_downloads_checkbox_->SetEnabled(!delete_in_progress_);
@@ -352,7 +355,7 @@ void ClearBrowsingDataView::UpdateControlEnabledState() {
throbber_->Stop();
// Make sure to update the state for OK and Cancel buttons.
- dialog_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
// Convenience method that returns true if the supplied checkbox is selected
@@ -399,5 +402,5 @@ void ClearBrowsingDataView::OnDelete() {
}
void ClearBrowsingDataView::OnBrowsingDataRemoverDone() {
- dialog_->Close();
+ window()->Close();
}
diff --git a/chrome/browser/views/clear_browsing_data.h b/chrome/browser/views/clear_browsing_data.h
index bb41ef5..87cbc91 100644
--- a/chrome/browser/views/clear_browsing_data.h
+++ b/chrome/browser/views/clear_browsing_data.h
@@ -67,8 +67,6 @@ class ClearBrowsingDataView : public ChromeViews::View,
// Initialize the controls on the dialog.
void Init();
- void SetDialog(ChromeViews::Window* dialog) { dialog_ = dialog; }
-
// Overridden from ChromeViews::View:
virtual void GetPreferredSize(CSize *out);
virtual void Layout();
@@ -86,6 +84,7 @@ class ClearBrowsingDataView : public ChromeViews::View,
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual bool Accept();
+ virtual ChromeViews::View* GetContentsView();
// Overridden from ChromeViews::ComboBox::Model:
virtual int GetItemCount(ChromeViews::ComboBox* source);
@@ -125,8 +124,6 @@ class ClearBrowsingDataView : public ChromeViews::View,
// Used to signal enabled/disabled state for controls in the UI.
bool delete_in_progress_;
- ChromeViews::Window* dialog_;
-
Profile* profile_;
DISALLOW_EVIL_CONSTRUCTORS(ClearBrowsingDataView);
diff --git a/chrome/browser/views/constrained_window_impl.cc b/chrome/browser/views/constrained_window_impl.cc
index 2e7f837..d61e1dc 100644
--- a/chrome/browser/views/constrained_window_impl.cc
+++ b/chrome/browser/views/constrained_window_impl.cc
@@ -449,8 +449,8 @@ void ConstrainedWindowNonClientView::UpdateLocationBar() {
if (ShouldDisplayURLField()) {
std::wstring url_spec;
TabContents* tab = container_->constrained_contents();
- url_spec = gfx::ElideUrl(tab->GetURL(),
- ChromeFont(),
+ url_spec = gfx::ElideUrl(tab->GetURL(),
+ ChromeFont(),
0,
tab->profile()->GetPrefs()->GetString(prefs::kAcceptLanguages));
std::wstring ev_text, ev_tooltip_text;
@@ -727,7 +727,7 @@ void ConstrainedWindowNonClientView::Layout() {
client_bounds_ = CalculateClientAreaBounds(GetWidth(), GetHeight());
if (should_display_url_field) {
location_bar_->SetBounds(client_bounds_.x() - kLocationBarOffset,
- client_bounds_.y() - location_bar_height -
+ client_bounds_.y() - location_bar_height -
kLocationBarSpacing,
client_bounds_.width() + kLocationBarOffset * 2,
location_bar_height);
@@ -914,9 +914,13 @@ void ConstrainedWindowNonClientView::InitClass() {
class ConstrainedTabContentsWindowDelegate
: public ChromeViews::WindowDelegate {
public:
- explicit ConstrainedTabContentsWindowDelegate(
- ConstrainedWindowImpl* window)
- : window_(window) {
+ explicit ConstrainedTabContentsWindowDelegate(TabContents* contents)
+ : contents_(contents),
+ contents_view_(NULL) {
+ }
+
+ void set_contents_view(ChromeViews::View* contents_view) {
+ contents_view_ = contents_view;
}
// ChromeViews::WindowDelegate implementation:
@@ -924,25 +928,21 @@ class ConstrainedTabContentsWindowDelegate
return true;
}
virtual std::wstring GetWindowTitle() const {
- TabContents* constrained_contents = window_->constrained_contents();
- if (constrained_contents)
- return constrained_contents->GetTitle();
-
- return std::wstring();
+ return contents_->GetTitle();
}
virtual bool ShouldShowWindowIcon() const {
return true;
}
virtual SkBitmap GetWindowIcon() {
- TabContents* constrained_contents = window_->constrained_contents();
- if (constrained_contents)
- return constrained_contents->GetFavIcon();
-
- return SkBitmap();
+ return contents_->GetFavIcon();
+ }
+ virtual ChromeViews::View* GetContentsView() {
+ return contents_view_;
}
private:
- ConstrainedWindowImpl* window_;
+ TabContents* contents_;
+ ChromeViews::View* contents_view_;
DISALLOW_EVIL_CONSTRUCTORS(ConstrainedTabContentsWindowDelegate);
};
@@ -955,19 +955,6 @@ class ConstrainedTabContentsWindowDelegate
static const int kPopupRepositionOffset = 5;
static const int kConstrainedWindowEdgePadding = 10;
-ConstrainedWindowImpl::ConstrainedWindowImpl(TabContents* owner)
- : CustomFrameWindow(new ConstrainedWindowNonClientView(this, owner)),
- owner_(owner),
- constrained_contents_(NULL),
- focus_restoration_disabled_(false),
- is_dialog_(false),
- titlebar_visibility_(0.0),
- contents_container_(NULL) {
- set_window_style(WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | WS_CAPTION |
- WS_THICKFRAME | WS_SYSMENU);
- set_focus_on_creation(false);
-}
-
ConstrainedWindowImpl::~ConstrainedWindowImpl() {
}
@@ -1120,6 +1107,7 @@ void ConstrainedWindowImpl::OpenURLFromTab(TabContents* source,
const GURL& url,
WindowOpenDisposition disposition,
PageTransition::Type transition) {
+ // We ignore source right now.
owner_->OpenURL(this, url, disposition, transition);
}
@@ -1165,15 +1153,46 @@ TabContents* ConstrainedWindowImpl::GetConstrainingContents(
return owner_;
}
-void ConstrainedWindowImpl::ToolbarSizeChanged(TabContents* source,
+void ConstrainedWindowImpl::ToolbarSizeChanged(TabContents* source,
bool finished) {
- // We don't control the layout of anything that could be animating,
+ // We don't control the layout of anything that could be animating,
// so do nothing.
}
////////////////////////////////////////////////////////////////////////////////
// ConstrainedWindowImpl, private:
+ConstrainedWindowImpl::ConstrainedWindowImpl(
+ TabContents* owner,
+ ChromeViews::WindowDelegate* window_delegate,
+ TabContents* constrained_contents)
+ : CustomFrameWindow(window_delegate,
+ new ConstrainedWindowNonClientView(this, owner)),
+ contents_window_delegate_(window_delegate),
+ constrained_contents_(constrained_contents),
+ titlebar_visibility_(0.0) {
+ Init(owner);
+}
+
+ConstrainedWindowImpl::ConstrainedWindowImpl(
+ TabContents* owner,
+ ChromeViews::WindowDelegate* window_delegate)
+ : CustomFrameWindow(window_delegate,
+ new ConstrainedWindowNonClientView(this, owner)),
+ constrained_contents_(NULL) {
+ Init(owner);
+}
+
+void ConstrainedWindowImpl::Init(TabContents* owner) {
+ owner_ = owner;
+ focus_restoration_disabled_ = false;
+ is_dialog_ = false;
+ contents_container_ = NULL;
+ set_window_style(WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | WS_CAPTION |
+ WS_THICKFRAME | WS_SYSMENU);
+ set_focus_on_creation(false);
+}
+
void ConstrainedWindowImpl::ResizeConstrainedTitlebar() {
DCHECK(constrained_contents_)
<< "ResizeConstrainedTitlebar() is only valid for web popups";
@@ -1196,32 +1215,26 @@ void ConstrainedWindowImpl::ResizeConstrainedTitlebar() {
SWP_NOZORDER | SWP_NOACTIVATE | SWP_SHOWWINDOW);
}
-void ConstrainedWindowImpl::InitAsDialog(
- const gfx::Rect& initial_bounds,
- ChromeViews::View* contents_view,
- ChromeViews::WindowDelegate* window_delegate) {
+void ConstrainedWindowImpl::InitAsDialog(const gfx::Rect& initial_bounds) {
is_dialog_ = true;
- non_client_view()->set_window_delegate(window_delegate);
- CustomFrameWindow::Init(owner_->GetContainerHWND(), initial_bounds,
- contents_view, window_delegate);
+ non_client_view()->set_window_delegate(window_delegate());
+ CustomFrameWindow::Init(owner_->GetContainerHWND(), initial_bounds);
ActivateConstrainedWindow();
}
void ConstrainedWindowImpl::InitWindowForContents(
- TabContents* constrained_contents) {
+ TabContents* constrained_contents,
+ ConstrainedTabContentsWindowDelegate* delegate) {
constrained_contents_ = constrained_contents;
constrained_contents_->set_delegate(this);
contents_container_ = new ChromeViews::HWNDView;
- contents_window_delegate_.reset(
- new ConstrainedTabContentsWindowDelegate(this));
-
+ delegate->set_contents_view(contents_container_);
non_client_view()->set_window_delegate(contents_window_delegate_.get());
}
void ConstrainedWindowImpl::InitSizeForContents(
const gfx::Rect& initial_bounds) {
- CustomFrameWindow::Init(owner_->GetContainerHWND(), initial_bounds,
- contents_container_, contents_window_delegate_.get());
+ CustomFrameWindow::Init(owner_->GetContainerHWND(), initial_bounds);
contents_container_->Attach(constrained_contents_->GetContainerHWND());
constrained_contents_->SizeContents(
@@ -1412,7 +1425,7 @@ void ConstrainedWindow::GenerateInitialBounds(
// behvaiors below interact.
std::wstring app_name;
- if (parent->delegate() && parent->delegate()->IsApplication() &&
+ if (parent->delegate() && parent->delegate()->IsApplication() &&
parent->AsWebContents() && parent->AsWebContents()->web_app()) {
app_name = parent->AsWebContents()->web_app()->name();
}
@@ -1460,8 +1473,9 @@ ConstrainedWindow* ConstrainedWindow::CreateConstrainedDialog(
const gfx::Rect& initial_bounds,
ChromeViews::View* contents_view,
ChromeViews::WindowDelegate* window_delegate) {
- ConstrainedWindowImpl* window = new ConstrainedWindowImpl(parent);
- window->InitAsDialog(initial_bounds, contents_view, window_delegate);
+ ConstrainedWindowImpl* window = new ConstrainedWindowImpl(parent,
+ window_delegate);
+ window->InitAsDialog(initial_bounds);
return window;
}
@@ -1470,9 +1484,11 @@ ConstrainedWindow* ConstrainedWindow::CreateConstrainedPopup(
TabContents* parent,
const gfx::Rect& initial_bounds,
TabContents* constrained_contents) {
+ ConstrainedTabContentsWindowDelegate* d =
+ new ConstrainedTabContentsWindowDelegate(constrained_contents);
ConstrainedWindowImpl* window =
- new ConstrainedWindowImpl(parent);
- window->InitWindowForContents(constrained_contents);
+ new ConstrainedWindowImpl(parent, d, constrained_contents);
+ window->InitWindowForContents(constrained_contents, d);
gfx::Rect window_bounds;
if (initial_bounds.width() == 0 || initial_bounds.height() == 0) {
diff --git a/chrome/browser/views/constrained_window_impl.h b/chrome/browser/views/constrained_window_impl.h
index f3916ab..9e8c0b3 100644
--- a/chrome/browser/views/constrained_window_impl.h
+++ b/chrome/browser/views/constrained_window_impl.h
@@ -73,11 +73,13 @@ class ConstrainedWindowImpl : public ConstrainedWindow,
virtual void UpdateWindowTitle();
virtual const gfx::Rect& GetCurrentBounds() const;
- // Overridden from TabContentsDelegate:
+ // Overridden from PageNavigator (TabContentsDelegate's base interface):
virtual void OpenURLFromTab(TabContents* source,
const GURL& url,
WindowOpenDisposition disposition,
PageTransition::Type transition);
+
+ // Overridden from TabContentsDelegate:
virtual void NavigationStateChanged(const TabContents* source,
unsigned changed_flags);
virtual void ReplaceContents(TabContents* source,
@@ -123,7 +125,12 @@ class ConstrainedWindowImpl : public ConstrainedWindow,
private:
// Use the static factory methods on ConstrainedWindow to construct a
// ConstrainedWindow.
- ConstrainedWindowImpl(TabContents* owner);
+ ConstrainedWindowImpl(TabContents* owner,
+ ChromeViews::WindowDelegate* window_delegate,
+ TabContents* constrained_contents);
+ ConstrainedWindowImpl(TabContents* owner,
+ ChromeViews::WindowDelegate* window_delegate);
+ void Init(TabContents* owner);
friend class ConstrainedWindow;
@@ -136,9 +143,7 @@ class ConstrainedWindowImpl : public ConstrainedWindow,
// Initialize the Constrained Window as a Constrained Dialog containing a
// ChromeViews::View client area.
- void InitAsDialog(const gfx::Rect& initial_bounds,
- ChromeViews::View* contents_view,
- ChromeViews::WindowDelegate* window_delegate);
+ void InitAsDialog(const gfx::Rect& initial_bounds);
// Builds the underlying HWND and window delegates for a newly
// created popup window.
@@ -148,7 +153,8 @@ class ConstrainedWindowImpl : public ConstrainedWindow,
// so that when we query for desired size, we get accurate data. If
// we didn't do this, windows will initialize to being smaller then
// the desired content size plus room for browser chrome.
- void InitWindowForContents(TabContents* constrained_contents);
+ void InitWindowForContents(TabContents* constrained_contents,
+ ConstrainedTabContentsWindowDelegate* delegate);
// Sets the initial bounds for a newly created popup window.
//
@@ -183,7 +189,7 @@ class ConstrainedWindowImpl : public ConstrainedWindow,
// A default ChromeViews::WindowDelegate implementation for this window when
// a TabContents is being constrained. (For the Constrained Dialog case, the
// caller is required to provide the WindowDelegate).
- scoped_ptr<ConstrainedTabContentsWindowDelegate> contents_window_delegate_;
+ scoped_ptr<ChromeViews::WindowDelegate> contents_window_delegate_;
// We keep a reference on the HWNDView so we can properly detach the tab
// contents when detaching.
diff --git a/chrome/browser/views/edit_keyword_controller.cc b/chrome/browser/views/edit_keyword_controller.cc
index 413f91c..8fe9b00 100644
--- a/chrome/browser/views/edit_keyword_controller.cc
+++ b/chrome/browser/views/edit_keyword_controller.cc
@@ -78,13 +78,10 @@ EditKeywordController::EditKeywordController(
void EditKeywordController::Show() {
// Window interprets an empty rectangle as needing to query the content for
// the size as well as centering relative to the parent.
- window_ = ChromeViews::Window::CreateChromeWindow(
- ::IsWindow(parent_) ? parent_ : NULL,
- gfx::Rect(),
- view_,
- this);
- window_->Show();
- window_->UpdateDialogButtons();
+ ChromeViews::Window::CreateChromeWindow(::IsWindow(parent_) ? parent_ : NULL,
+ gfx::Rect(), this);
+ window()->Show();
+ window()->UpdateDialogButtons();
title_tf_->SelectAll();
title_tf_->RequestFocus();
}
@@ -180,9 +177,13 @@ bool EditKeywordController::Accept() {
return true;
}
+ChromeViews::View* EditKeywordController::GetContentsView() {
+ return view_;
+}
+
void EditKeywordController::ContentsChanged(TextField* sender,
const std::wstring& new_contents) {
- window_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
UpdateImageViews();
}
diff --git a/chrome/browser/views/edit_keyword_controller.h b/chrome/browser/views/edit_keyword_controller.h
index c7e362e..1050d99 100644
--- a/chrome/browser/views/edit_keyword_controller.h
+++ b/chrome/browser/views/edit_keyword_controller.h
@@ -74,6 +74,7 @@ class EditKeywordController : public ChromeViews::TextField::Controller,
virtual void WindowClosing();
virtual bool Cancel();
virtual bool Accept();
+ virtual ChromeViews::View* GetContentsView();
// ChromeViews::TextField::Controller overrides. Updates whether the user can
// accept the dialog as well as updating image views showing whether value is
@@ -142,9 +143,6 @@ class EditKeywordController : public ChromeViews::TextField::Controller,
// Profile whose TemplateURLModel we're modifying.
Profile* profile_;
- // Container for displaying the contents.
- ChromeViews::Window* window_;
-
// Text fields.
ChromeViews::TextField* title_tf_;
ChromeViews::TextField* keyword_tf_;
diff --git a/chrome/browser/views/first_run_customize_view.cc b/chrome/browser/views/first_run_customize_view.cc
index 6b8263a..88c824c 100644
--- a/chrome/browser/views/first_run_customize_view.cc
+++ b/chrome/browser/views/first_run_customize_view.cc
@@ -48,7 +48,8 @@
#include "generated_resources.h"
FirstRunCustomizeView::FirstRunCustomizeView(Profile* profile,
- ImporterHost* importer_host)
+ ImporterHost* importer_host,
+ CustomizeViewObserver* observer)
: FirstRunViewBase(profile),
main_label_(NULL),
import_cbox_(NULL),
@@ -57,7 +58,7 @@ FirstRunCustomizeView::FirstRunCustomizeView(Profile* profile,
shortcuts_label_(NULL),
desktop_shortcut_cbox_(NULL),
quick_shortcut_cbox_(NULL),
- customize_observer_(NULL) {
+ customize_observer_(observer) {
importer_host_ = importer_host;
DCHECK(importer_host_);
SetupControls();
@@ -202,6 +203,10 @@ std::wstring FirstRunCustomizeView::GetWindowTitle() const {
return l10n_util::GetString(IDS_FR_CUSTOMIZE_DLG_TITLE);
}
+ChromeViews::View* FirstRunCustomizeView::GetContentsView() {
+ return this;
+}
+
bool FirstRunCustomizeView::Accept() {
if (!IsDialogButtonEnabled(DIALOGBUTTON_OK))
return false;
@@ -226,7 +231,7 @@ bool FirstRunCustomizeView::Accept() {
} else {
int browser_selected = import_from_combo_->GetSelectedItem();
FirstRun::ImportSettings(profile_, browser_selected,
- GetDefaultImportItems(), dialog_->GetHWND());
+ GetDefaultImportItems(), window()->GetHWND());
}
if (default_browser_cbox_->IsSelected()) {
UserMetrics::RecordAction(L"FirstRunCustom_Do_DefBrowser", profile_);
diff --git a/chrome/browser/views/first_run_customize_view.h b/chrome/browser/views/first_run_customize_view.h
index 4a22cb6..69cf46e 100644
--- a/chrome/browser/views/first_run_customize_view.h
+++ b/chrome/browser/views/first_run_customize_view.h
@@ -63,16 +63,11 @@ class FirstRunCustomizeView : public FirstRunViewBase,
virtual void CustomizeCanceled() = 0;
};
- FirstRunCustomizeView(Profile* profile, ImporterHost* importer_host);
+ FirstRunCustomizeView(Profile* profile,
+ ImporterHost* importer_host,
+ CustomizeViewObserver* observer);
virtual ~FirstRunCustomizeView();
- void set_dialog(ChromeViews::Window* dialog) { dialog_ = dialog; }
-
- // Sets the object that receives UserAccept and UserCancel notifications.
- void set_observer(CustomizeViewObserver* observer) {
- customize_observer_ = observer;
- };
-
// Overridden from ChromeViews::View.
virtual void GetPreferredSize(CSize *out);
virtual void Layout();
@@ -90,13 +85,11 @@ class FirstRunCustomizeView : public FirstRunViewBase,
// Overridden from ChromeViews::WindowDelegate.
virtual std::wstring GetWindowTitle() const;
-
+ virtual ChromeViews::View* GetContentsView();
// Yes, we're modal.
// NOTE: if you change this you'll need to make sure it isn't possible to
// close the window while importing.
- virtual bool IsModal() const {
- return true;
- }
+ virtual bool IsModal() const { return true; }
private:
// Initializes the controls on the dialog.
diff --git a/chrome/browser/views/first_run_view.cc b/chrome/browser/views/first_run_view.cc
index 1beed44..d230efa 100644
--- a/chrome/browser/views/first_run_view.cc
+++ b/chrome/browser/views/first_run_view.cc
@@ -180,16 +180,10 @@ std::wstring FirstRunView::GetDialogButtonLabel(DialogButton button) const {
void FirstRunView::OpenCustomizeDialog() {
// The customize dialog now owns the importer host object.
- FirstRunCustomizeView* customize_view =
- new FirstRunCustomizeView(profile_, importer_host_);
-
- ChromeViews::Window* customize_dialog =
- ChromeViews::Window::CreateChromeWindow(dialog_->GetHWND(),
- gfx::Rect(), customize_view,
- customize_view);
- customize_dialog->Show();
- customize_view->set_dialog(customize_dialog);
- customize_view->set_observer(this);
+ ChromeViews::Window::CreateChromeWindow(
+ window()->GetHWND(),
+ gfx::Rect(),
+ new FirstRunCustomizeView(profile_, importer_host_, this))->Show();
}
void FirstRunView::LinkActivated(ChromeViews::Link* source, int event_flags) {
@@ -200,6 +194,10 @@ std::wstring FirstRunView::GetWindowTitle() const {
return l10n_util::GetString(IDS_FIRSTRUN_DLG_TITLE);
}
+ChromeViews::View* FirstRunView::GetContentsView() {
+ return this;
+}
+
bool FirstRunView::Accept() {
if (!IsDialogButtonEnabled(DIALOGBUTTON_OK))
return false;
@@ -210,7 +208,7 @@ bool FirstRunView::Accept() {
CreateQuickLaunchShortcut();
// Index 0 is the default browser.
FirstRun::ImportSettings(profile_, 0, GetDefaultImportItems(),
- dialog_->GetHWND());
+ window()->GetHWND());
UserMetrics::RecordAction(L"FirstRunDef_Accept", profile_);
return true;
@@ -224,7 +222,7 @@ bool FirstRunView::Cancel() {
// Notification from the customize dialog that the user accepted. Since all
// the work is done there we got nothing else to do.
void FirstRunView::CustomizeAccepted() {
- dialog_->Close();
+ window()->Close();
}
// Notification from the customize dialog that the user cancelled.
diff --git a/chrome/browser/views/first_run_view.h b/chrome/browser/views/first_run_view.h
index 47e3645..728ac96 100644
--- a/chrome/browser/views/first_run_view.h
+++ b/chrome/browser/views/first_run_view.h
@@ -66,6 +66,7 @@ class FirstRunView : public FirstRunViewBase,
// Overridden from ChromeViews::WindowDelegate:
virtual std::wstring GetWindowTitle() const;
+ virtual ChromeViews::View* GetContentsView();
// Overridden from ChromeViews::LinkActivated:
virtual void LinkActivated(ChromeViews::Link* source, int event_flags);
diff --git a/chrome/browser/views/first_run_view_base.cc b/chrome/browser/views/first_run_view_base.cc
index b9c04fe..4ee8aceb 100644
--- a/chrome/browser/views/first_run_view_base.cc
+++ b/chrome/browser/views/first_run_view_base.cc
@@ -54,8 +54,7 @@
#include "generated_resources.h"
FirstRunViewBase::FirstRunViewBase(Profile* profile)
- : dialog_(NULL),
- preferred_width_(0),
+ : preferred_width_(0),
background_image_(NULL),
separator_1_(NULL),
separator_2_(NULL),
@@ -148,9 +147,7 @@ void FirstRunViewBase::Layout() {
background_image_->GetHeight() - 2;
separator_1_->GetPreferredSize(&pref_size);
- separator_1_->SetBounds(0, next_v_space,
- canvas.cx + 1,
- pref_size.cy);
+ separator_1_->SetBounds(0 , next_v_space, canvas.cx + 1, pref_size.cy);
next_v_space = canvas.cy - kPanelSubVerticalSpacing;
separator_2_->GetPreferredSize(&pref_size);
@@ -182,7 +179,7 @@ int FirstRunViewBase::GetDefaultImportItems() const {
};
void FirstRunViewBase::DisableButtons() {
- dialog_->EnableClose(false);
+ window()->EnableClose(false);
ChromeViews::ClientView* cv =
reinterpret_cast<ChromeViews::ClientView*>(GetParent());
if (cv) {
diff --git a/chrome/browser/views/first_run_view_base.h b/chrome/browser/views/first_run_view_base.h
index 9266ce8..e18fd7b 100644
--- a/chrome/browser/views/first_run_view_base.h
+++ b/chrome/browser/views/first_run_view_base.h
@@ -54,9 +54,6 @@ class FirstRunViewBase : public ChromeViews::View,
explicit FirstRunViewBase(Profile* profile);
virtual ~FirstRunViewBase();
- // Sets the dialog window that host the view.
- void set_dialog(ChromeViews::Window* dialog) { dialog_ = dialog; }
-
// Overridden from ChromeViews::View.
virtual void Layout();
@@ -78,7 +75,7 @@ class FirstRunViewBase : public ChromeViews::View,
// Modifies the chrome configuration so that the first-run dialogs are not
// shown again.
bool FirstRunComplete();
-
+
// Disables the standard buttons of the dialog. Useful when importing.
void DisableButtons();
// Computes a tight dialog width given a contained UI element.
@@ -99,7 +96,6 @@ class FirstRunViewBase : public ChromeViews::View,
scoped_refptr<ImporterHost> importer_host_;
Profile* profile_;
- ChromeViews::Window* dialog_;
private:
// Initializes the controls on the dialog.
diff --git a/chrome/browser/views/html_dialog_view.cc b/chrome/browser/views/html_dialog_view.cc
index 1be835f..cdf48e8 100644
--- a/chrome/browser/views/html_dialog_view.cc
+++ b/chrome/browser/views/html_dialog_view.cc
@@ -39,7 +39,6 @@ HtmlDialogView::HtmlDialogView(Browser* parent_browser,
Profile* profile,
HtmlDialogContentsDelegate* delegate)
: DOMView(delegate->GetDialogContentURL()),
- dialog_(NULL),
parent_browser_(parent_browser),
profile_(profile),
delegate_(delegate) {
@@ -80,6 +79,10 @@ void HtmlDialogView::WindowClosing() {
OnDialogClosed("");
}
+ChromeViews::View* HtmlDialogView::GetContentsView() {
+ return this;
+}
+
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogContentsDelegate implementation:
@@ -98,7 +101,7 @@ std::string HtmlDialogView::GetDialogArgs() const {
void HtmlDialogView::OnDialogClosed(const std::string& json_retval) {
delegate_->OnDialogClosed(json_retval);
delegate_ = NULL; // We will not communicate further with the delegate.
- dialog_->Close();
+ window()->Close();
}
////////////////////////////////////////////////////////////////////////////////
@@ -155,14 +158,14 @@ void HtmlDialogView::MoveContents(TabContents* source, const gfx::Rect& pos) {
// Determine the size the window containing the dialog at its requested size.
gfx::Size window_size =
- dialog_->CalculateWindowSizeForClientSize(pos.size());
+ window()->CalculateWindowSizeForClientSize(pos.size());
// Actually size the window.
CRect vc_bounds;
GetViewContainer()->GetBounds(&vc_bounds, true);
gfx::Rect bounds(vc_bounds.left, vc_bounds.top, window_size.width(),
window_size.height());
- dialog_->SetBounds(bounds);
+ window()->SetBounds(bounds);
}
bool HtmlDialogView::IsPopup(TabContents* source) {
@@ -187,9 +190,7 @@ void HtmlDialogView::UpdateTargetURL(TabContents* source, const GURL& url) {
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogView:
-void HtmlDialogView::InitDialog(ChromeViews::Window* dialog) {
- dialog_ = dialog;
-
+void HtmlDialogView::InitDialog() {
// Now Init the DOMView. This view runs in its own process to render the html.
DOMView::Init(profile_, NULL);
diff --git a/chrome/browser/views/html_dialog_view.h b/chrome/browser/views/html_dialog_view.h
index 54f8f15..a07e5e3 100644
--- a/chrome/browser/views/html_dialog_view.h
+++ b/chrome/browser/views/html_dialog_view.h
@@ -60,7 +60,7 @@ class HtmlDialogView
virtual ~HtmlDialogView();
// Initializes the contents of the dialog (the DOMView and the callbacks).
- void InitDialog(ChromeViews::Window* dialog);
+ void InitDialog();
// Overridden from ChromeViews::View:
virtual void GetPreferredSize(CSize *out);
@@ -70,6 +70,7 @@ class HtmlDialogView
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
+ virtual ChromeViews::View* GetContentsView();
// Overridden from HtmlDialogContentsDelegate:
virtual GURL GetDialogContentURL() const;
@@ -101,9 +102,6 @@ class HtmlDialogView
virtual void UpdateTargetURL(TabContents* source, const GURL& url);
private:
- // The dialog this view is displayed in.
- ChromeViews::Window* dialog_;
-
// The Browser object which created this html dialog; we send all
// window opening/navigations to this object.
Browser* parent_browser_;
diff --git a/chrome/browser/views/hung_renderer_view.cc b/chrome/browser/views/hung_renderer_view.cc
index 645c6df..2434118 100644
--- a/chrome/browser/views/hung_renderer_view.cc
+++ b/chrome/browser/views/hung_renderer_view.cc
@@ -140,8 +140,6 @@ class HungRendererWarningView : public ChromeViews::View,
void ShowForWebContents(WebContents* contents);
void EndForWebContents(WebContents* contents);
- void set_window(ChromeViews::Window* window) { window_ = window; }
-
// ChromeViews::WindowDelegate overrides:
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
@@ -150,7 +148,8 @@ class HungRendererWarningView : public ChromeViews::View,
ChromeViews::DialogDelegate::DialogButton button) const;
virtual ChromeViews::View* GetExtraView();
virtual bool Accept(bool window_closing);
-
+ virtual ChromeViews::View* GetContentsView();
+
// ChromeViews::NativeButton::Listener overrides:
virtual void ButtonPressed(ChromeViews::NativeButton* sender);
@@ -193,9 +192,6 @@ class HungRendererWarningView : public ChromeViews::View,
};
ButtonContainer* kill_button_container_;
- // The Window that contains this view.
- ChromeViews::Window* window_;
-
// The model that provides the contents of the table that shows a list of
// pages affected by the hang.
scoped_ptr<HungPagesTableModel> hung_pages_table_model_;
@@ -233,7 +229,6 @@ HungRendererWarningView::HungRendererWarningView()
hung_pages_table_(NULL),
kill_button_(NULL),
kill_button_container_(NULL),
- window_(NULL),
contents_(NULL),
initialized_(false) {
InitClass();
@@ -244,7 +239,7 @@ HungRendererWarningView::~HungRendererWarningView() {
}
void HungRendererWarningView::ShowForWebContents(WebContents* contents) {
- DCHECK(contents && window_);
+ DCHECK(contents && window());
contents_ = contents;
// Don't show the warning unless the foreground window is the frame, or this
@@ -253,13 +248,13 @@ void HungRendererWarningView::ShowForWebContents(WebContents* contents) {
HWND frame_hwnd = GetAncestor(contents->GetContainerHWND(), GA_ROOT);
HWND foreground_window = GetForegroundWindow();
if (foreground_window != frame_hwnd &&
- foreground_window != window_->GetHWND()) {
+ foreground_window != window()->GetHWND()) {
return;
}
- if (!window_->IsActive()) {
+ if (!window()->IsActive()) {
gfx::Rect bounds = GetDisplayBounds(contents);
- window_->SetBounds(bounds, frame_hwnd);
+ window()->SetBounds(bounds, frame_hwnd);
// We only do this if the window isn't active (i.e. hasn't been shown yet,
// or is currently shown but deactivated for another WebContents). This is
@@ -268,14 +263,14 @@ void HungRendererWarningView::ShowForWebContents(WebContents* contents) {
// the list of hung pages for a potentially unrelated renderer while this
// one is showing.
hung_pages_table_model_->InitForWebContents(contents);
- window_->Show();
+ window()->Show();
}
}
void HungRendererWarningView::EndForWebContents(WebContents* contents) {
DCHECK(contents);
if (contents_ && contents_->process() == contents->process()) {
- window_->Close();
+ window()->Close();
// Since we're closing, we no longer need this WebContents.
contents_ = NULL;
}
@@ -326,6 +321,13 @@ bool HungRendererWarningView::Accept(bool window_closing) {
return true;
}
+ChromeViews::View* HungRendererWarningView::GetContentsView() {
+ return this;
+}
+
+///////////////////////////////////////////////////////////////////////////////
+// HungRendererWarningView, ChromeViews::NativeButton::Listener implementation:
+
void HungRendererWarningView::ButtonPressed(
ChromeViews::NativeButton* sender) {
if (sender == kill_button_) {
@@ -401,7 +403,7 @@ void HungRendererWarningView::CreateKillButtonView() {
kill_button_->SetListener(this);
kill_button_container_ = new ButtonContainer;
-
+
using ChromeViews::GridLayout;
using ChromeViews::ColumnSet;
@@ -426,7 +428,7 @@ gfx::Rect HungRendererWarningView::GetDisplayBounds(
GetWindowRect(contents_hwnd, &contents_bounds);
CRect window_bounds;
- window_->GetBounds(&window_bounds, true);
+ window()->GetBounds(&window_bounds, true);
int window_x = contents_bounds.left +
(contents_bounds.Width() - window_bounds.Width()) / 2;
@@ -453,9 +455,7 @@ HungRendererWarningView* HungRendererWarning::instance_ = NULL;
static HungRendererWarningView* CreateHungRendererWarningView() {
HungRendererWarningView* cv = new HungRendererWarningView;
- ChromeViews::Window* window =
- ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), cv, cv);
- cv->set_window(window);
+ ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), cv);
return cv;
}
diff --git a/chrome/browser/views/importer_lock_view.cc b/chrome/browser/views/importer_lock_view.cc
index 9e4b00e..c48df4c 100644
--- a/chrome/browser/views/importer_lock_view.cc
+++ b/chrome/browser/views/importer_lock_view.cc
@@ -44,8 +44,7 @@ static const int kDefaultWindowWidth = 320;
static const int kDefaultWindowHeight = 100;
ImporterLockView::ImporterLockView(ImporterHost* host)
- : dialog_(NULL),
- description_label_(NULL),
+ : description_label_(NULL),
importer_host_(host) {
description_label_ = new ChromeViews::Label(
l10n_util::GetString(IDS_IMPORTER_LOCK_TEXT));
@@ -97,3 +96,7 @@ bool ImporterLockView::Cancel() {
importer_host_, &ImporterHost::OnLockViewEnd, false));
return true;
}
+
+ChromeViews::View* ImporterLockView::GetContentsView() {
+ return this;
+}
diff --git a/chrome/browser/views/importer_lock_view.h b/chrome/browser/views/importer_lock_view.h
index 876560a..4714656 100644
--- a/chrome/browser/views/importer_lock_view.h
+++ b/chrome/browser/views/importer_lock_view.h
@@ -50,10 +50,6 @@ class ImporterLockView : public ChromeViews::View,
explicit ImporterLockView(ImporterHost* host);
virtual ~ImporterLockView();
- void set_dialog(ChromeViews::Window* dialog) {
- dialog_ = dialog;
- }
-
// Overridden from ChromeViews::View.
virtual void GetPreferredSize(CSize *out);
virtual void Layout();
@@ -64,12 +60,11 @@ class ImporterLockView : public ChromeViews::View,
virtual std::wstring GetWindowTitle() const;
virtual bool Accept();
virtual bool Cancel();
+ virtual ChromeViews::View* GetContentsView();
private:
ChromeViews::Label* description_label_;
- ChromeViews::Window* dialog_;
-
ImporterHost* importer_host_;
DISALLOW_EVIL_CONSTRUCTORS(ImporterLockView);
diff --git a/chrome/browser/views/importer_view.cc b/chrome/browser/views/importer_view.cc
index bd71637..cd875ea 100644
--- a/chrome/browser/views/importer_view.cc
+++ b/chrome/browser/views/importer_view.cc
@@ -44,8 +44,7 @@ using ChromeViews::ColumnSet;
using ChromeViews::GridLayout;
ImporterView::ImporterView(Profile* profile)
- : dialog_(NULL),
- import_from_label_(NULL),
+ : import_from_label_(NULL),
profile_combobox_(NULL),
import_items_label_(NULL),
history_checkbox_(NULL),
@@ -169,6 +168,10 @@ bool ImporterView::Accept() {
return false;
}
+ChromeViews::View* ImporterView::GetContentsView() {
+ return this;
+}
+
int ImporterView::GetItemCount(ChromeViews::ComboBox* source) {
DCHECK(source == profile_combobox_);
DCHECK(importer_host_.get());
@@ -188,7 +191,7 @@ void ImporterView::ImportCanceled() {
void ImporterView::ImportComplete() {
// Now close this window since the import completed or was canceled.
- dialog_->Close();
+ window()->Close();
}
ChromeViews::CheckBox* ImporterView::InitCheckbox(
diff --git a/chrome/browser/views/importer_view.h b/chrome/browser/views/importer_view.h
index fe9ab11..cbfd2df 100644
--- a/chrome/browser/views/importer_view.h
+++ b/chrome/browser/views/importer_view.h
@@ -58,8 +58,6 @@ class ImporterView : public ChromeViews::View,
explicit ImporterView(Profile* profile);
virtual ~ImporterView();
- void set_dialog(ChromeViews::Window* dialog) { dialog_ = dialog; }
-
// Overridden from ChromeViews::View.
virtual void GetPreferredSize(CSize *out);
virtual void Layout();
@@ -69,6 +67,7 @@ class ImporterView : public ChromeViews::View,
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual bool Accept();
+ virtual ChromeViews::View* GetContentsView();
// Overridden from ChromeViews::ComboBox::Model.
virtual int GetItemCount(ChromeViews::ComboBox* source);
@@ -93,8 +92,6 @@ class ImporterView : public ChromeViews::View,
ChromeViews::CheckBox* passwords_checkbox_;
ChromeViews::CheckBox* search_engines_checkbox_;
- ChromeViews::Window* dialog_;
-
scoped_refptr<ImporterHost> importer_host_;
Profile* profile_;
diff --git a/chrome/browser/views/importing_progress_view.cc b/chrome/browser/views/importing_progress_view.cc
index aa99455..60953b3 100644
--- a/chrome/browser/views/importing_progress_view.cc
+++ b/chrome/browser/views/importing_progress_view.cc
@@ -63,7 +63,6 @@ ImportingProgressView::ImportingProgressView(const std::wstring& source_name,
l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_HISTORY))),
label_cookies_(new ChromeViews::Label(
l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_COOKIES))),
- window_(NULL),
parent_window_(parent_window),
coordinator_(coordinator),
import_observer_(observer),
@@ -167,7 +166,7 @@ void ImportingProgressView::ImportEnded() {
// In every case, we need to close the UI now.
importing_ = false;
coordinator_->SetObserver(NULL);
- window_->Close();
+ window()->Close();
if (import_observer_)
import_observer_->ImportComplete();
}
@@ -220,6 +219,10 @@ bool ImportingProgressView::Cancel() {
return false;
}
+ChromeViews::View* ImportingProgressView::GetContentsView() {
+ return this;
+}
+
////////////////////////////////////////////////////////////////////////////////
// ImportingProgressView, private:
@@ -296,10 +299,8 @@ void StartImportingWithUI(HWND parent_window,
DCHECK(items != 0);
ImportingProgressView* v = new ImportingProgressView(
source_profile.description, items, coordinator, observer, parent_window);
- ChromeViews::Window* window = ChromeViews::Window::CreateChromeWindow(
- parent_window, gfx::Rect(), v, v);
- v->set_window(window);
- window->Show();
+ ChromeViews::Window::CreateChromeWindow(parent_window, gfx::Rect(),
+ v)->Show();
coordinator->StartImportSettings(source_profile, items,
new ProfileWriter(target_profile),
first_run);
diff --git a/chrome/browser/views/importing_progress_view.h b/chrome/browser/views/importing_progress_view.h
index c3a560d..643868f 100644
--- a/chrome/browser/views/importing_progress_view.h
+++ b/chrome/browser/views/importing_progress_view.h
@@ -51,8 +51,6 @@ class ImportingProgressView : public ChromeViews::View,
HWND parent_window);
virtual ~ImportingProgressView();
- void set_window(ChromeViews::Window* window) { window_ = window; }
-
protected:
// Overridden from ImporterHost::Observer:
virtual void ImportItemStarted(ImportItem item);
@@ -66,6 +64,7 @@ class ImportingProgressView : public ChromeViews::View,
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual bool Cancel();
+ virtual ChromeViews::View* GetContentsView();
// Overridden from ChromeViews::View:
virtual void GetPreferredSize(CSize *out);
@@ -90,9 +89,6 @@ class ImportingProgressView : public ChromeViews::View,
scoped_ptr<ChromeViews::Label> label_history_;
scoped_ptr<ChromeViews::Label> label_cookies_;
- // The window that contains us.
- ChromeViews::Window* window_;
-
// The native window that we are parented to. Can be NULL.
HWND parent_window_;
diff --git a/chrome/browser/views/input_window.cc b/chrome/browser/views/input_window.cc
index 058e29d..f4c560e 100644
--- a/chrome/browser/views/input_window.cc
+++ b/chrome/browser/views/input_window.cc
@@ -51,13 +51,10 @@ class ContentView : public ChromeViews::View,
public:
explicit ContentView(InputWindowDelegate* delegate)
: delegate_(delegate),
- window_(NULL),
focus_grabber_factory_(this) {
DCHECK(delegate_);
}
- void set_window(ChromeViews::Window* window) { window_ = window; }
-
// ChromeViews::DialogDelegate overrides:
virtual bool IsDialogButtonEnabled(DialogButton button) const;
virtual bool Accept();
@@ -65,6 +62,7 @@ class ContentView : public ChromeViews::View,
virtual void WindowClosing();
virtual std::wstring GetWindowTitle() const;
virtual bool IsModal() const { return true; }
+ virtual ChromeViews::View* GetContentsView();
// ChromeViews::TextField::Controller overrides:
virtual void ContentsChanged(ChromeViews::TextField* sender,
@@ -91,9 +89,6 @@ class ContentView : public ChromeViews::View,
// caller.
InputWindowDelegate* delegate_;
- // The Window that owns this view.
- ChromeViews::Window* window_;
-
// Helps us set focus to the first TextField in the window.
ScopedRunnableMethodFactory<ContentView> focus_grabber_factory_;
@@ -127,12 +122,16 @@ std::wstring ContentView::GetWindowTitle() const {
return delegate_->GetWindowTitle();
}
+ChromeViews::View* ContentView::GetContentsView() {
+ return this;
+}
+
///////////////////////////////////////////////////////////////////////////////
// ContentView, ChromeViews::TextField::Controller implementation:
void ContentView::ContentsChanged(ChromeViews::TextField* sender,
const std::wstring& new_contents) {
- window_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
///////////////////////////////////////////////////////////////////////////////
@@ -185,10 +184,9 @@ void ContentView::FocusFirstFocusableControl() {
ChromeViews::Window* CreateInputWindow(HWND parent_hwnd,
InputWindowDelegate* delegate) {
- ContentView* cv = new ContentView(delegate);
- ChromeViews::Window* window = ChromeViews::Window::CreateChromeWindow(
- parent_hwnd, gfx::Rect(), cv, cv);
- cv->set_window(window);
+ ChromeViews::Window* window =
+ ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(),
+ new ContentView(delegate));
window->UpdateDialogButtons();
return window;
}
diff --git a/chrome/browser/views/keyword_editor_view.cc b/chrome/browser/views/keyword_editor_view.cc
index 04acd38..799d2e2 100644
--- a/chrome/browser/views/keyword_editor_view.cc
+++ b/chrome/browser/views/keyword_editor_view.cc
@@ -362,7 +362,7 @@ void KeywordEditorView::Show(Profile* profile) {
// Initialize the UI. By passing in an empty rect KeywordEditorView is
// queried for its preferred size.
open_window = ChromeViews::Window::CreateChromeWindow(
- NULL, gfx::Rect(), keyword_editor, keyword_editor);
+ NULL, gfx::Rect(), keyword_editor);
open_window->Show();
}
@@ -480,6 +480,10 @@ bool KeywordEditorView::Cancel() {
return true;
}
+ChromeViews::View* KeywordEditorView::GetContentsView() {
+ return this;
+}
+
void KeywordEditorView::Init() {
DCHECK(!table_model_.get());
diff --git a/chrome/browser/views/keyword_editor_view.h b/chrome/browser/views/keyword_editor_view.h
index 3512648..4d9fa3e 100644
--- a/chrome/browser/views/keyword_editor_view.h
+++ b/chrome/browser/views/keyword_editor_view.h
@@ -178,6 +178,7 @@ class KeywordEditorView : public ChromeViews::View,
virtual int GetDialogButtons() const;
virtual bool Accept();
virtual bool Cancel();
+ virtual ChromeViews::View* GetContentsView();
// Returns the TemplateURLModel we're using.
TemplateURLModel* template_url_model() const { return url_model_; }
diff --git a/chrome/browser/views/options/advanced_page_view.cc b/chrome/browser/views/options/advanced_page_view.cc
index f47e5a6..37c6936 100644
--- a/chrome/browser/views/options/advanced_page_view.cc
+++ b/chrome/browser/views/options/advanced_page_view.cc
@@ -84,22 +84,24 @@ class ResetDefaultsConfirmBox : public ChromeViews::DialogDelegate {
// ChromeViews::WindowDelegate
virtual void WindowClosing() { delete this; }
virtual bool IsModal() const { return true; }
+ virtual ChromeViews::View* GetContentsView() { return message_box_view_; }
private:
ResetDefaultsConfirmBox(HWND parent_hwnd, AdvancedPageView* page_view)
: advanced_page_view_(page_view) {
const int kDialogWidth = 400;
// Also deleted when the window closes.
- MessageBoxView* message_box_view = new MessageBoxView(
+ message_box_view_ = new MessageBoxView(
MessageBoxView::kFlagHasMessage | MessageBoxView::kFlagHasOKButton,
l10n_util::GetString(IDS_OPTIONS_RESET_MESSAGE).c_str(),
std::wstring(),
kDialogWidth);
ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(),
- message_box_view, this)->Show();
+ this)->Show();
}
virtual ~ResetDefaultsConfirmBox() { }
+ MessageBoxView* message_box_view_;
AdvancedPageView* advanced_page_view_;
DISALLOW_EVIL_CONSTRUCTORS(ResetDefaultsConfirmBox);
diff --git a/chrome/browser/views/options/content_page_view.cc b/chrome/browser/views/options/content_page_view.cc
index 6ed056f..8814986 100644
--- a/chrome/browser/views/options/content_page_view.cc
+++ b/chrome/browser/views/options/content_page_view.cc
@@ -249,11 +249,10 @@ void ContentPageView::ButtonPressed(ChromeViews::NativeButton* sender) {
UserMetricsRecordAction(L"Options_ShowPasswordManager", NULL);
PasswordManagerView::Show(profile());
} else if (sender == change_content_fonts_button_) {
- FontsLanguagesWindowView* flwv = new FontsLanguagesWindowView(profile());
- ChromeViews::Window* w =
- ChromeViews::Window::CreateChromeWindow(GetRootWindow(), gfx::Rect(),
- flwv, flwv);
- w->Show();
+ ChromeViews::Window::CreateChromeWindow(
+ GetRootWindow(),
+ gfx::Rect(),
+ new FontsLanguagesWindowView(profile()))->Show();
}
}
diff --git a/chrome/browser/views/options/cookies_view.cc b/chrome/browser/views/options/cookies_view.cc
index 3b59198..bd5424d 100644
--- a/chrome/browser/views/options/cookies_view.cc
+++ b/chrome/browser/views/options/cookies_view.cc
@@ -561,7 +561,7 @@ void CookiesView::ShowCookiesWindow(Profile* profile) {
if (!instance_) {
CookiesView* cookies_view = new CookiesView(profile);
instance_ = ChromeViews::Window::CreateChromeWindow(
- NULL, gfx::Rect(), cookies_view, cookies_view);
+ NULL, gfx::Rect(), cookies_view);
}
if (!instance_->IsVisible()) {
instance_->Show();
@@ -649,6 +649,10 @@ void CookiesView::WindowClosing() {
instance_ = NULL;
}
+ChromeViews::View* CookiesView::GetContentsView() {
+ return this;
+}
+
///////////////////////////////////////////////////////////////////////////////
// CookiesView, ChromeViews::View overrides:
diff --git a/chrome/browser/views/options/cookies_view.h b/chrome/browser/views/options/cookies_view.h
index 9547acc..1f72a5c 100644
--- a/chrome/browser/views/options/cookies_view.h
+++ b/chrome/browser/views/options/cookies_view.h
@@ -81,6 +81,7 @@ class CookiesView : public ChromeViews::View,
virtual bool CanResize() const { return true; }
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
+ virtual ChromeViews::View* GetContentsView();
// ChromeViews::View overrides:
virtual void Layout();
diff --git a/chrome/browser/views/options/fonts_languages_window_view.cc b/chrome/browser/views/options/fonts_languages_window_view.cc
index 7b7788d..a6d9948 100644
--- a/chrome/browser/views/options/fonts_languages_window_view.cc
+++ b/chrome/browser/views/options/fonts_languages_window_view.cc
@@ -63,15 +63,22 @@ FontsLanguagesWindowView::~FontsLanguagesWindowView() {
///////////////////////////////////////////////////////////////////////////////
// FontsLanguagesWindowView, ChromeViews::DialogDelegate implementation:
+bool FontsLanguagesWindowView::Accept() {
+ fonts_page_->SaveChanges();
+ languages_page_->SaveChanges();
+ return true;
+}
+
+///////////////////////////////////////////////////////////////////////////////
+// FontsLanguagesWindowView, ChromeViews::WindowDelegate implementation:
+
std::wstring FontsLanguagesWindowView::GetWindowTitle() const {
return l10n_util::GetStringF(IDS_FONT_LANGUAGE_SETTING_WINDOWS_TITLE,
l10n_util::GetString(IDS_PRODUCT_NAME));
}
-bool FontsLanguagesWindowView::Accept() {
- fonts_page_->SaveChanges();
- languages_page_->SaveChanges();
- return true;
+ChromeViews::View* FontsLanguagesWindowView::GetContentsView() {
+ return this;
}
///////////////////////////////////////////////////////////////////////////////
diff --git a/chrome/browser/views/options/fonts_languages_window_view.h b/chrome/browser/views/options/fonts_languages_window_view.h
index bdae5ea..c3e6a40 100644
--- a/chrome/browser/views/options/fonts_languages_window_view.h
+++ b/chrome/browser/views/options/fonts_languages_window_view.h
@@ -50,17 +50,13 @@ class FontsLanguagesWindowView : public ChromeViews::View,
explicit FontsLanguagesWindowView(Profile* profile);
virtual ~FontsLanguagesWindowView();
- ChromeViews::Window* container() const { return container_; }
- void set_container(ChromeViews::Window* container) {
- container_ = container;
- }
-
// ChromeViews::DialogDelegate implementation:
virtual bool Accept();
- virtual std::wstring GetWindowTitle() const;
// ChromeViews::WindowDelegate Methods:
virtual bool IsModal() const { return true; }
+ virtual std::wstring GetWindowTitle() const;
+ virtual ChromeViews::View* GetContentsView();
// ChromeViews::View overrides:
virtual void Layout();
@@ -78,9 +74,6 @@ class FontsLanguagesWindowView : public ChromeViews::View,
// The Tab view that contains all of the options pages.
ChromeViews::TabbedPane* tabs_;
- // The Options dialog window.
- ChromeViews::Window* container_;
-
// Fonts Page View handle remembered so that prefs is updated only when
// OK is pressed.
FontsPageView* fonts_page_;
diff --git a/chrome/browser/views/options/languages_page_view.cc b/chrome/browser/views/options/languages_page_view.cc
index 2c9ef19..fb449fc 100644
--- a/chrome/browser/views/options/languages_page_view.cc
+++ b/chrome/browser/views/options/languages_page_view.cc
@@ -243,6 +243,7 @@ class AddLanguageWindowView : public ChromeViews::View,
// ChromeViews::WindowDelegate method.
virtual bool IsModal() const { return true; }
+ virtual ChromeViews::View* GetContentsView() { return this; }
// ChromeViews::ComboBox::Listener implementation:
virtual void ItemChanged(ChromeViews::ComboBox* combo_box,
@@ -525,12 +526,10 @@ void LanguagesPageView::ButtonPressed(ChromeViews::NativeButton* sender) {
OnRemoveLanguage();
language_table_edited_ = true;
} else if (sender == add_button_) {
- AddLanguageWindowView* instance = new AddLanguageWindowView(this, profile());
- HWND parent_hwnd = GetViewContainer()->GetHWND();
- ChromeViews::Window* w =
- ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(),
- instance, instance);
- w->Show();
+ ChromeViews::Window::CreateChromeWindow(
+ GetViewContainer()->GetHWND(),
+ gfx::Rect(),
+ new AddLanguageWindowView(this, profile()))->Show();
language_table_edited_ = true;
}
}
diff --git a/chrome/browser/views/options/options_window_view.cc b/chrome/browser/views/options/options_window_view.cc
index 72c7029..5b29fdb 100644
--- a/chrome/browser/views/options/options_window_view.cc
+++ b/chrome/browser/views/options/options_window_view.cc
@@ -60,11 +60,6 @@ class OptionsWindowView : public ChromeViews::View,
explicit OptionsWindowView(Profile* profile);
virtual ~OptionsWindowView();
- ChromeViews::Window* container() const { return container_; }
- void set_container(ChromeViews::Window* container) {
- container_ = container;
- }
-
// Shows the Tab corresponding to the specified OptionsPage.
void ShowOptionsPage(OptionsPage page, OptionsGroup highlight_group);
@@ -73,6 +68,7 @@ class OptionsWindowView : public ChromeViews::View,
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
virtual bool Cancel();
+ virtual ChromeViews::View* GetContentsView();
// ChromeViews::TabbedPane::Listener implementation:
virtual void TabSelectedAt(int index);
@@ -96,9 +92,6 @@ class OptionsWindowView : public ChromeViews::View,
// The Tab view that contains all of the options pages.
ChromeViews::TabbedPane* tabs_;
- // The Options dialog window.
- ChromeViews::Window* container_;
-
// The Profile associated with these options.
Profile* profile_;
@@ -135,10 +128,10 @@ void OptionsWindowView::ShowOptionsPage(OptionsPage page,
OptionsGroup highlight_group) {
// If the window is not yet visible, we need to show it (it will become
// active), otherwise just bring it to the front.
- if (!container_->IsVisible()) {
- container_->Show();
+ if (!window()->IsVisible()) {
+ window()->Show();
} else {
- container_->Activate();
+ window()->Activate();
}
if (page == OPTIONS_PAGE_DEFAULT) {
@@ -171,6 +164,10 @@ bool OptionsWindowView::Cancel() {
return GetCurrentOptionsPageView()->CanClose();
}
+ChromeViews::View* OptionsWindowView::GetContentsView() {
+ return this;
+}
+
///////////////////////////////////////////////////////////////////////////////
// OptionsWindowView, ChromeViews::TabbedPane::Listener implementation:
@@ -246,8 +243,7 @@ void ShowOptionsWindow(OptionsPage page,
// about this case this will have to be fixed.
if (!instance_) {
instance_ = new OptionsWindowView(profile);
- instance_->set_container(ChromeViews::Window::CreateChromeWindow(
- NULL, gfx::Rect(), instance_, instance_));
+ ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), instance_);
// The window is alive by itself now...
}
instance_->ShowOptionsPage(page, highlight_group);
diff --git a/chrome/browser/views/password_manager_view.cc b/chrome/browser/views/password_manager_view.cc
index cf5eb50..86c6434 100644
--- a/chrome/browser/views/password_manager_view.cc
+++ b/chrome/browser/views/password_manager_view.cc
@@ -185,15 +185,12 @@ void PasswordManagerView::Show(Profile* profile) {
instance_ = new PasswordManagerView(profile);
// manager is owned by the dialog window, so Close() will delete it.
- instance_->dialog_ = ChromeViews::Window::CreateChromeWindow(NULL,
- gfx::Rect(),
- instance_,
- instance_);
+ ChromeViews::Window::CreateChromeWindow(NULL, gfx::Rect(), instance_);
}
- if (!instance_->dialog_->IsVisible()) {
- instance_->dialog_->Show();
+ if (!instance_->window()->IsVisible()) {
+ instance_->window()->Show();
} else {
- instance_->dialog_->Activate();
+ instance_->window()->Activate();
}
}
@@ -358,7 +355,7 @@ std::wstring PasswordManagerView::GetWindowTitle() const {
}
void PasswordManagerView::ButtonPressed(ChromeViews::NativeButton* sender) {
- DCHECK(dialog_);
+ DCHECK(window());
// Close will result in our destruction.
if (sender == &remove_all_button_) {
table_model_.ForgetAndRemoveAllSignons();
@@ -397,3 +394,7 @@ void PasswordManagerView::WindowClosing() {
// instance is created.
instance_ = NULL;
}
+
+ChromeViews::View* PasswordManagerView::GetContentsView() {
+ return this;
+}
diff --git a/chrome/browser/views/password_manager_view.h b/chrome/browser/views/password_manager_view.h
index 19c92ad..a9eeb39 100644
--- a/chrome/browser/views/password_manager_view.h
+++ b/chrome/browser/views/password_manager_view.h
@@ -140,6 +140,7 @@ class PasswordManagerView : public ChromeViews::View,
virtual bool HasAlwaysOnTopMenu() const;
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
+ virtual ChromeViews::View* GetContentsView();
private:
// Wire up buttons, the model, and the table view, and query the DB for
@@ -162,9 +163,6 @@ class PasswordManagerView : public ChromeViews::View,
ChromeViews::NativeButton remove_all_button_;
ChromeViews::Label password_label_;
- // The window containing this view.
- ChromeViews::Window* dialog_;
-
DISALLOW_EVIL_CONSTRUCTORS(PasswordManagerView);
};
#endif // CHROME_BROWSER_PASSWORD_MANAGER_VIEW_H__
diff --git a/chrome/browser/views/restart_message_box.cc b/chrome/browser/views/restart_message_box.cc
index 3d940ab..d3f52cd 100644
--- a/chrome/browser/views/restart_message_box.cc
+++ b/chrome/browser/views/restart_message_box.cc
@@ -65,19 +65,23 @@ bool RestartMessageBox::IsModal() const {
return true;
}
+ChromeViews::View* RestartMessageBox::GetContentsView() {
+ return message_box_view_;
+}
+
////////////////////////////////////////////////////////////////////////////////
// RestartMessageBox, private:
RestartMessageBox::RestartMessageBox(HWND parent_hwnd) {
const int kDialogWidth = 400;
// Also deleted when the window closes.
- MessageBoxView* message_box_view = new MessageBoxView(
+ message_box_view_ = new MessageBoxView(
MessageBoxView::kFlagHasMessage | MessageBoxView::kFlagHasOKButton,
l10n_util::GetString(IDS_OPTIONS_RESTART_REQUIRED).c_str(),
std::wstring(),
kDialogWidth);
ChromeViews::Window::CreateChromeWindow(parent_hwnd, gfx::Rect(),
- message_box_view, this)->Show();
+ this)->Show();
}
RestartMessageBox::~RestartMessageBox() {
diff --git a/chrome/browser/views/restart_message_box.h b/chrome/browser/views/restart_message_box.h
index 5a5da45..3ae42dd 100644
--- a/chrome/browser/views/restart_message_box.h
+++ b/chrome/browser/views/restart_message_box.h
@@ -33,6 +33,8 @@
#include "base/basictypes.h"
#include "chrome/views/dialog_delegate.h"
+class MessageBoxView;
+
// A dialog box that tells the user that s/he needs to restart Chrome
// for a change to take effect.
class RestartMessageBox : public ChromeViews::DialogDelegate {
@@ -49,11 +51,14 @@ class RestartMessageBox : public ChromeViews::DialogDelegate {
// ChromeViews::WindowDelegate:
virtual void WindowClosing();
virtual bool IsModal() const;
+ virtual ChromeViews::View* GetContentsView();
private:
explicit RestartMessageBox(HWND parent_hwnd);
virtual ~RestartMessageBox();
+ MessageBoxView* message_box_view_;
+
DISALLOW_EVIL_CONSTRUCTORS(RestartMessageBox);
};
diff --git a/chrome/browser/views/shelf_item_dialog.cc b/chrome/browser/views/shelf_item_dialog.cc
index bbec8e9..670453a 100644
--- a/chrome/browser/views/shelf_item_dialog.cc
+++ b/chrome/browser/views/shelf_item_dialog.cc
@@ -242,8 +242,7 @@ class PossibleURLModel : public ChromeViews::TableModel {
ShelfItemDialog::ShelfItemDialog(ShelfItemDialogDelegate* delegate,
Profile* profile,
bool show_title)
- : dialog_(NULL),
- profile_(profile),
+ : profile_(profile),
expected_title_handle_(0),
delegate_(delegate) {
DCHECK(profile_);
@@ -338,10 +337,8 @@ ShelfItemDialog::~ShelfItemDialog() {
}
void ShelfItemDialog::Show(HWND parent) {
- DCHECK(!dialog_);
- dialog_ =
- ChromeViews::Window::CreateChromeWindow(parent, gfx::Rect(), this, this);
- dialog_->Show();
+ DCHECK(!window());
+ ChromeViews::Window::CreateChromeWindow(parent, gfx::Rect(), this)->Show();
if (title_field_) {
title_field_->SetText(l10n_util::GetString(IDS_ASI_DEFAULT_TITLE));
title_field_->SelectAll();
@@ -354,8 +351,8 @@ void ShelfItemDialog::Show(HWND parent) {
}
void ShelfItemDialog::Close() {
- DCHECK(dialog_);
- dialog_->Close();
+ DCHECK(window());
+ window()->Close();
}
std::wstring ShelfItemDialog::GetWindowTitle() const {
@@ -416,7 +413,7 @@ void ShelfItemDialog::ContentsChanged(ChromeViews::TextField* sender,
// so we reset the expected handle to an impossible value.
if (sender == title_field_)
expected_title_handle_ = 0;
- dialog_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
bool ShelfItemDialog::Accept() {
@@ -437,6 +434,10 @@ bool ShelfItemDialog::IsDialogButtonEnabled(DialogButton button) const {
return true;
}
+ChromeViews::View* ShelfItemDialog::GetContentsView() {
+ return this;
+}
+
void ShelfItemDialog::PerformModelChange() {
DCHECK(delegate_);
GURL url(GetInputURL());
@@ -455,7 +456,7 @@ void ShelfItemDialog::GetPreferredSize(CSize *out) {
bool ShelfItemDialog::AcceleratorPressed(
const ChromeViews::Accelerator& accelerator) {
if (accelerator.GetKeyCode() == VK_ESCAPE) {
- dialog_->Close();
+ window()->Close();
} else if (accelerator.GetKeyCode() == VK_RETURN) {
ChromeViews::FocusManager* fm = ChromeViews::FocusManager::GetFocusManager(
GetViewContainer()->GetHWND());
@@ -467,8 +468,8 @@ bool ShelfItemDialog::AcceleratorPressed(
// is invalid, focus is left on the url field.
if (GetInputURL().is_valid()) {
PerformModelChange();
- if (dialog_)
- dialog_->Close();
+ if (window())
+ window()->Close();
} else {
url_field_->SelectAll();
}
@@ -492,7 +493,7 @@ void ShelfItemDialog::OnSelectionChanged() {
UTF8ToWide(url_table_model_->GetURL(selection).spec()));
if (title_field_)
title_field_->SetText(url_table_model_->GetTitle(selection));
- dialog_->UpdateDialogButtons();
+ window()->UpdateDialogButtons();
}
}
@@ -501,8 +502,8 @@ void ShelfItemDialog::OnDoubleClick() {
if (selection >= 0 && selection < url_table_model_->RowCount()) {
OnSelectionChanged();
PerformModelChange();
- if (dialog_)
- dialog_->Close();
+ if (window())
+ window()->Close();
}
}
diff --git a/chrome/browser/views/shelf_item_dialog.h b/chrome/browser/views/shelf_item_dialog.h
index e5c0b7d..e7f9161 100644
--- a/chrome/browser/views/shelf_item_dialog.h
+++ b/chrome/browser/views/shelf_item_dialog.h
@@ -88,6 +88,7 @@ class ShelfItemDialog : public ChromeViews::View,
virtual std::wstring GetDialogButtonLabel(DialogButton button) const;
virtual bool Accept();
virtual bool IsDialogButtonEnabled(DialogButton button) const;
+ virtual ChromeViews::View* GetContentsView();
// TextField::Controller.
virtual void ContentsChanged(ChromeViews::TextField* sender,
@@ -122,9 +123,6 @@ class ShelfItemDialog : public ChromeViews::View,
// Returns the URL the user has typed.
GURL GetInputURL() const;
- // The dialog controller for our current dialog.
- ChromeViews::Window* dialog_;
-
// Profile.
Profile* profile_;
diff --git a/chrome/views/client_view.cc b/chrome/views/client_view.cc
index 2ae6870..7bc7638 100644
--- a/chrome/views/client_view.cc
+++ b/chrome/views/client_view.cc
@@ -243,16 +243,16 @@ void ClientView::Layout() {
void ClientView::ViewHierarchyChanged(bool is_add, View* parent, View* child) {
if (is_add && child == this) {
+ // Can only add and update the dialog buttons _after_ they are added to the
+ // view hierarchy since they are native controls and require the
+ // ViewContainer's HWND.
+ ShowDialogButtons();
// Only add the contents_view_ once, and only when we ourselves are added
// to the view hierarchy, since some contents_view_s assume that when they
// are added to the hierarchy a HWND exists, when it may not, since we are
// not yet added...
if (contents_view_ && contents_view_->GetParent() != this)
AddChildView(contents_view_);
- // Can only add and update the dialog buttons _after_ they are added to the
- // view hierarchy since they are native controls and require the
- // ViewContainer's HWND.
- ShowDialogButtons();
UpdateDialogButtons();
Layout();
}
diff --git a/chrome/views/custom_frame_window.cc b/chrome/views/custom_frame_window.cc
index 02af912..a7434aa 100644
--- a/chrome/views/custom_frame_window.cc
+++ b/chrome/views/custom_frame_window.cc
@@ -507,8 +507,7 @@ int DefaultNonClientView::HitTest(const gfx::Point& point) {
// If the window can't be resized, there are no resize boundaries, just
// window borders.
if (component != HTNOWHERE) {
- if (container_->window_delegate() &&
- !container_->window_delegate()->CanResize()) {
+ if (!container_->window_delegate()->CanResize()) {
return HTBORDER;
}
return component;
@@ -571,6 +570,7 @@ void DefaultNonClientView::Layout() {
LayoutWindowControls();
LayoutTitleBar();
LayoutClientView();
+ SchedulePaint();
}
void DefaultNonClientView::GetPreferredSize(CSize* out) {
@@ -880,15 +880,16 @@ void DefaultNonClientView::InitClass() {
////////////////////////////////////////////////////////////////////////////////
// CustomFrameWindow, public:
-CustomFrameWindow::CustomFrameWindow()
- : Window(),
+CustomFrameWindow::CustomFrameWindow(WindowDelegate* window_delegate)
+ : Window(window_delegate),
non_client_view_(new DefaultNonClientView(this)),
is_active_(false) {
InitClass();
}
-CustomFrameWindow::CustomFrameWindow(NonClientView* non_client_view)
- : Window(),
+CustomFrameWindow::CustomFrameWindow(WindowDelegate* window_delegate,
+ NonClientView* non_client_view)
+ : Window(window_delegate),
non_client_view_(non_client_view) {
InitClass();
}
@@ -896,10 +897,8 @@ CustomFrameWindow::CustomFrameWindow(NonClientView* non_client_view)
CustomFrameWindow::~CustomFrameWindow() {
}
-void CustomFrameWindow::Init(HWND owner, const gfx::Rect& bounds,
- View* contents_view,
- WindowDelegate* window_delegate) {
- Window::Init(owner, bounds, contents_view, window_delegate);
+void CustomFrameWindow::Init(HWND owner, const gfx::Rect& bounds) {
+ Window::Init(owner, bounds);
// We need to re-parent the client view to the non-client view.
GetRootView()->RemoveChildView(client_view_);
GetRootView()->AddChildView(non_client_view_);
diff --git a/chrome/views/custom_frame_window.h b/chrome/views/custom_frame_window.h
index 8dab9d9..52356b2 100644
--- a/chrome/views/custom_frame_window.h
+++ b/chrome/views/custom_frame_window.h
@@ -48,9 +48,10 @@ namespace ChromeViews {
////////////////////////////////////////////////////////////////////////////////
class CustomFrameWindow : public Window {
public:
- CustomFrameWindow();
+ explicit CustomFrameWindow(WindowDelegate* window_delegate);
class NonClientView;
- explicit CustomFrameWindow(NonClientView* non_client_view);
+ CustomFrameWindow(WindowDelegate* window_delegate,
+ NonClientView* non_client_view);
virtual ~CustomFrameWindow();
// Create the CustomFrameWindow.
@@ -58,14 +59,7 @@ class CustomFrameWindow : public Window {
// window that this window is dependent on, if this window is opened as a
// modal dialog or dependent window. This is NULL if the window is not
// dependent on any other window.
- // |contents_view| is the view to be displayed in the client area of the
- // window.
- // |window_delegate| is an object implementing the WindowDelegate interface
- // that supplies information to the window such as its title, icon, etc.
- virtual void Init(HWND owner,
- const gfx::Rect& bounds,
- View* contents_view,
- WindowDelegate* window_delegate);
+ virtual void Init(HWND owner, const gfx::Rect& bounds);
// Executes the specified SC_command.
void ExecuteSystemMenuCommand(int command);
diff --git a/chrome/views/focus_manager_unittest.cc b/chrome/views/focus_manager_unittest.cc
index a7a8379..ed5127e 100644
--- a/chrome/views/focus_manager_unittest.cc
+++ b/chrome/views/focus_manager_unittest.cc
@@ -192,14 +192,15 @@ private:
DISALLOW_EVIL_CONSTRUCTORS(BorderView);
};
-class TestViewWindow : public ChromeViews::Window,
- public ChromeViews::WindowDelegate {
+class TestViewWindow : public ChromeViews::HWNDViewContainer {
public:
explicit TestViewWindow(FocusManagerTest* test);
~TestViewWindow() { }
void Init();
- virtual std::wstring GetWindowTitle() const;
+
+ ChromeViews::View* contents() const { return contents_; }
+
// Return the ID of the component that currently has the focus.
int GetFocusedComponentID();
@@ -262,7 +263,7 @@ void TestViewWindow::Init() {
contents_->SetBackground(
ChromeViews::Background::CreateSolidBackground(255, 255, 255));
- Window::Init(NULL, bounds, contents_, this);
+ HWNDViewContainer::Init(NULL, bounds, contents_, true);
ChromeViews::CheckBox* cb =
new ChromeViews::CheckBox(L"This is a checkbox");
@@ -521,11 +522,6 @@ void TestViewWindow::Init() {
contents->SetBounds(200, y, 200, 50);
}
-// WindowDelegate Implementation.
-std::wstring TestViewWindow::GetWindowTitle() const {
- return L"Focus Manager Test Window";
-}
-
////////////////////////////////////////////////////////////////////////////////
// FocusManagerTest
////////////////////////////////////////////////////////////////////////////////
@@ -543,7 +539,7 @@ TestViewWindow* FocusManagerTest::GetWindow() {
void FocusManagerTest::SetUp() {
test_window_ = new TestViewWindow(this);
test_window_->Init();
- test_window_->Show();
+ ShowWindow(test_window_->GetHWND(), SW_SHOW);
}
void FocusManagerTest::TearDown() {
diff --git a/chrome/views/view_unittest.cc b/chrome/views/view_unittest.cc
index 0cb5af1..44de0c0 100644
--- a/chrome/views/view_unittest.cc
+++ b/chrome/views/view_unittest.cc
@@ -309,10 +309,10 @@ TEST_F(ViewTest, MouseEvent) {
TestView* v2 = new TestView();
v2->SetBounds (100, 100, 100, 100);
- ChromeViews::Window window;
+ ChromeViews::HWNDViewContainer window;
window.set_delete_on_destroy(false);
window.set_window_style(WS_OVERLAPPEDWINDOW);
- window.Init(NULL, gfx::Rect(50, 50, 650, 650), NULL, NULL);
+ window.Init(NULL, gfx::Rect(50, 50, 650, 650), NULL, false);
RootView* root = window.GetRootView();
root->AddChildView(v1);
@@ -470,7 +470,7 @@ TEST_F(ViewTest, RemoveNotification) {
NotificationService::current()->AddObserver(
observer.get(), NOTIFY_VIEW_REMOVED, NotificationService::AllSources());
- ChromeViews::Window* window = new ChromeViews::Window;
+ ChromeViews::HWNDViewContainer* window = new ChromeViews::HWNDViewContainer;
ChromeViews::RootView* root_view = window->GetRootView();
View* v1 = new View;
diff --git a/chrome/views/window.cc b/chrome/views/window.cc
index 24b4925..5976d53 100644
--- a/chrome/views/window.cc
+++ b/chrome/views/window.cc
@@ -55,11 +55,11 @@ static const int kMonitorEdgePadding = 10;
////////////////////////////////////////////////////////////////////////////////
// Window, public:
-Window::Window()
+Window::Window(WindowDelegate* window_delegate)
: HWNDViewContainer(),
focus_on_creation_(true),
+ window_delegate_(window_delegate),
client_view_(NULL),
- window_delegate_(NULL),
owning_hwnd_(NULL),
minimum_size_(100, 100),
is_modal_(false),
@@ -69,6 +69,8 @@ Window::Window()
accepted_(false),
window_closed_(false) {
InitClass();
+ DCHECK(window_delegate_);
+ window_delegate_->window_.reset(this);
// Initialize these values to 0 so that subclasses can override the default
// behavior before calling Init.
set_window_style(0);
@@ -83,34 +85,27 @@ Window::~Window() {
// static
Window* Window::CreateChromeWindow(HWND parent,
const gfx::Rect& bounds,
- View* contents_view,
WindowDelegate* window_delegate) {
+ Window* window = NULL;
if (win_util::ShouldUseVistaFrame()) {
- Window* window = new Window;
- window->Init(parent, bounds, contents_view, window_delegate);
- return window;
+ window = new Window(window_delegate);
+ } else {
+ window = new CustomFrameWindow(window_delegate);
}
- CustomFrameWindow* window = new CustomFrameWindow;
- window->Init(parent, bounds, contents_view, window_delegate);
+ window->Init(parent, bounds);
return window;
}
-void Window::Init(HWND parent,
- const gfx::Rect& bounds,
- View* contents_view,
- WindowDelegate* window_delegate) {
- window_delegate_ = window_delegate;
+void Window::Init(HWND parent, const gfx::Rect& bounds) {
// We need to save the parent window, since later calls to GetParent() will
// return NULL.
owning_hwnd_ = parent;
// We call this after initializing our members since our implementations of
// assorted HWNDViewContainer functions may be called during initialization.
- if (window_delegate_) {
- is_modal_ = window_delegate_->IsModal();
- if (is_modal_)
- BecomeModal();
- is_always_on_top_ = window_delegate_->IsAlwaysOnTop();
- }
+ is_modal_ = window_delegate_->IsModal();
+ if (is_modal_)
+ BecomeModal();
+ is_always_on_top_ = window_delegate_->IsAlwaysOnTop();
if (window_style() == 0)
set_window_style(CalculateWindowStyle());
@@ -120,6 +115,9 @@ void Window::Init(HWND parent,
// A child window never owns its own focus manager, it uses the one
// associated with the root of the window tree...
if (use_client_view_) {
+ View* contents_view = window_delegate_->GetContentsView();
+ if (!contents_view)
+ contents_view = new View;
client_view_ = new ClientView(this, contents_view);
// A Window almost always owns its own focus manager, even if it's a child
// window. File a bug if you find a circumstance where this isn't the case
@@ -128,21 +126,19 @@ void Window::Init(HWND parent,
// manager.
HWNDViewContainer::Init(parent, bounds, client_view_, true);
} else {
- HWNDViewContainer::Init(parent, bounds, contents_view, true);
+ HWNDViewContainer::Init(parent, bounds,
+ window_delegate_->GetContentsView(), true);
}
- if (window_delegate_) {
- std::wstring window_title = window_delegate_->GetWindowTitle();
- SetWindowText(GetHWND(), window_title.c_str());
- }
+ std::wstring window_title = window_delegate_->GetWindowTitle();
+ SetWindowText(GetHWND(), window_title.c_str());
win_util::SetWindowUserData(GetHWND(), this);
// Restore the window's placement from the controller.
CRect saved_bounds(0, 0, 0, 0);
bool maximized = false;
- if (window_delegate_ &&
- window_delegate_->RestoreWindowPosition(&saved_bounds,
+ if (window_delegate_->RestoreWindowPosition(&saved_bounds,
&maximized,
&is_always_on_top_)) {
// Make sure the bounds are at least the minimum size.
@@ -174,7 +170,7 @@ void Window::Init(HWND parent,
SizeWindowToDefault();
}
- if (window_delegate_ && window_delegate->HasAlwaysOnTopMenu())
+ if (window_delegate_->HasAlwaysOnTopMenu())
AddAlwaysOnTopSystemMenuItem();
}
@@ -243,7 +239,7 @@ void Window::Close() {
// process of being closed. Furthermore, if we have only an OK button, but no
// Cancel button, and we're closing without being accepted, call Accept to
// see if we should close.
- if (!accepted_ && window_delegate_) {
+ if (!accepted_) {
DialogDelegate* dd = window_delegate_->AsDialogDelegate();
if (dd) {
int buttons = dd->GetDialogButtons();
@@ -302,11 +298,9 @@ void Window::UpdateDialogButtons() {
void Window::AcceptWindow() {
accepted_ = true;
- if (window_delegate_) {
- DialogDelegate* dd = window_delegate_->AsDialogDelegate();
- if (dd)
- accepted_ = dd->Accept(false);
- }
+ DialogDelegate* dd = window_delegate_->AsDialogDelegate();
+ if (dd)
+ accepted_ = dd->Accept(false);
if (accepted_)
Close();
}
@@ -319,10 +313,8 @@ void Window::CancelWindow() {
}
void Window::UpdateWindowTitle() {
- if (window_delegate_) {
- std::wstring window_title = window_delegate_->GetWindowTitle();
- SetWindowText(GetHWND(), window_title.c_str());
- }
+ std::wstring window_title = window_delegate_->GetWindowTitle();
+ SetWindowText(GetHWND(), window_title.c_str());
}
// static
@@ -411,26 +403,24 @@ void Window::SetInitialFocus() {
return;
bool focus_set = false;
- if (window_delegate_) {
- ChromeViews::View* v = window_delegate_->GetInitiallyFocusedView();
- // For dialogs, try to focus either the OK or Cancel buttons if any.
- if (!v && window_delegate_->AsDialogDelegate() && client_view_) {
- if (client_view_->ok_button())
- v = client_view_->ok_button();
- else if (client_view_->cancel_button())
- v = client_view_->cancel_button();
- }
- if (v) {
- focus_set = true;
- // In order to make that view the initially focused one, we make it the
- // focused view on the focus manager and we store the focused view.
- // When the window is activated, the focus manager will restore the
- // stored focused view.
- FocusManager* focus_manager = FocusManager::GetFocusManager(GetHWND());
- DCHECK(focus_manager);
- focus_manager->SetFocusedView(v);
- focus_manager->StoreFocusedView();
- }
+ ChromeViews::View* v = window_delegate_->GetInitiallyFocusedView();
+ // For dialogs, try to focus either the OK or Cancel buttons if any.
+ if (!v && window_delegate_->AsDialogDelegate() && client_view_) {
+ if (client_view_->ok_button())
+ v = client_view_->ok_button();
+ else if (client_view_->cancel_button())
+ v = client_view_->cancel_button();
+ }
+ if (v) {
+ focus_set = true;
+ // In order to make that view the initially focused one, we make it the
+ // focused view on the focus manager and we store the focused view.
+ // When the window is activated, the focus manager will restore the
+ // stored focused view.
+ FocusManager* focus_manager = FocusManager::GetFocusManager(GetHWND());
+ DCHECK(focus_manager);
+ focus_manager->SetFocusedView(v);
+ focus_manager->StoreFocusedView();
}
if (!focus_set && focus_on_creation_) {
@@ -449,8 +439,7 @@ void Window::OnActivate(UINT action, BOOL minimized, HWND window) {
}
void Window::OnCommand(UINT notification_code, int command_id, HWND window) {
- if (window_delegate_)
- window_delegate_->ExecuteWindowsCommand(command_id);
+ window_delegate_->ExecuteWindowsCommand(command_id);
}
void Window::OnDestroy() {
@@ -596,57 +585,49 @@ void Window::AlwaysOnTopChanged() {
}
DWORD Window::CalculateWindowStyle() {
- if (window_delegate_) {
- DWORD window_styles = WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_SYSMENU;
- bool can_resize = window_delegate_->CanResize();
- bool can_maximize = window_delegate_->CanMaximize();
- if ((can_resize && can_maximize) || can_maximize) {
- window_styles |= WS_OVERLAPPEDWINDOW;
- } else if (can_resize) {
- window_styles |= WS_OVERLAPPED | WS_THICKFRAME;
- }
- if (window_delegate_->AsDialogDelegate()) {
- window_styles |= DS_MODALFRAME;
- // NOTE: Turning this off means we lose the close button, which is bad.
- // Turning it on though means the user can maximize or size the window
- // from the system menu, which is worse. We may need to provide our own
- // menu to get the close button to appear properly.
- // window_styles &= ~WS_SYSMENU;
- }
- return window_styles;
+ DWORD window_styles = WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_SYSMENU;
+ bool can_resize = window_delegate_->CanResize();
+ bool can_maximize = window_delegate_->CanMaximize();
+ if ((can_resize && can_maximize) || can_maximize) {
+ window_styles |= WS_OVERLAPPEDWINDOW;
+ } else if (can_resize) {
+ window_styles |= WS_OVERLAPPED | WS_THICKFRAME;
+ }
+ if (window_delegate_->AsDialogDelegate()) {
+ window_styles |= DS_MODALFRAME;
+ // NOTE: Turning this off means we lose the close button, which is bad.
+ // Turning it on though means the user can maximize or size the window
+ // from the system menu, which is worse. We may need to provide our own
+ // menu to get the close button to appear properly.
+ // window_styles &= ~WS_SYSMENU;
}
- return window_style();
+ return window_styles;
}
DWORD Window::CalculateWindowExStyle() {
- if (window_delegate_) {
- DWORD window_ex_styles = 0;
- if (window_delegate_->AsDialogDelegate()) {
- window_ex_styles |= WS_EX_DLGMODALFRAME;
- } else if (!(window_style() & WS_CHILD)) {
- window_ex_styles |= WS_EX_APPWINDOW;
- }
- if (window_delegate_->IsAlwaysOnTop())
- window_ex_styles |= WS_EX_TOPMOST;
- return window_ex_styles;
+ DWORD window_ex_styles = 0;
+ if (window_delegate_->AsDialogDelegate()) {
+ window_ex_styles |= WS_EX_DLGMODALFRAME;
+ } else if (!(window_style() & WS_CHILD)) {
+ window_ex_styles |= WS_EX_APPWINDOW;
}
- return window_ex_style();
+ if (window_delegate_->IsAlwaysOnTop())
+ window_ex_styles |= WS_EX_TOPMOST;
+ return window_ex_styles;
}
void Window::SaveWindowPosition() {
- if (window_delegate_) {
- WINDOWPLACEMENT win_placement = { 0 };
- win_placement.length = sizeof(WINDOWPLACEMENT);
+ WINDOWPLACEMENT win_placement = { 0 };
+ win_placement.length = sizeof(WINDOWPLACEMENT);
- BOOL r = GetWindowPlacement(GetHWND(), &win_placement);
- DCHECK(r);
+ BOOL r = GetWindowPlacement(GetHWND(), &win_placement);
+ DCHECK(r);
- bool maximized = (win_placement.showCmd == SW_SHOWMAXIMIZED);
- CRect window_bounds(win_placement.rcNormalPosition);
- window_delegate_->SaveWindowPosition(window_bounds,
- maximized,
- is_always_on_top_);
- }
+ bool maximized = (win_placement.showCmd == SW_SHOWMAXIMIZED);
+ CRect window_bounds(win_placement.rcNormalPosition);
+ window_delegate_->SaveWindowPosition(window_bounds,
+ maximized,
+ is_always_on_top_);
}
void Window::InitClass() {
diff --git a/chrome/views/window.h b/chrome/views/window.h
index 8e30ad9..0e86555 100644
--- a/chrome/views/window.h
+++ b/chrome/views/window.h
@@ -61,30 +61,22 @@ class Window : public HWNDViewContainer {
// ChromeViews. Users in browser/ should always construct with
// CreateChromeWindow which will give the right version,
// depending on platform & configuration.
- Window();
+ // Create a Window using the specified delegate. The delegate must not be
+ // NULL.
+ explicit Window(WindowDelegate* window_delegate);
virtual ~Window();
// Creates the appropriate Window class for a Chrome dialog or window. This
// means a ChromeWindow or a standard Windows frame.
static Window* CreateChromeWindow(HWND parent,
const gfx::Rect& bounds,
- View* contents_view,
WindowDelegate* window_delegate);
// Create the Window.
// If parent is NULL, this Window is top level on the desktop.
- // |contents_view| is a ChromeView that will be displayed in the client area
- // of the Window, as the sole child view of the RootView.
- // |window_delegate| is an object implementing WindowDelegate that can perform
- // controller-like tasks for this window, such as obtaining its preferred
- // placement and state from preferences (which override the default position
- // and size specified in |bounds|) and executing commands. Can be NULL.
// If |bounds| is empty, the view is queried for its preferred size and
// centered on screen.
- void Init(HWND parent,
- const gfx::Rect& bounds,
- View* contents_view,
- WindowDelegate* window_delegate);
+ virtual void Init(HWND parent, const gfx::Rect& bounds);
// Return the size of window (including non-client area) required to contain
// a window of the specified client size.
diff --git a/chrome/views/window_delegate.h b/chrome/views/window_delegate.h
index 17b81f0..8f506d2 100644
--- a/chrome/views/window_delegate.h
+++ b/chrome/views/window_delegate.h
@@ -35,6 +35,7 @@
#include <atlmisc.h>
#include <string>
+#include "chrome/views/window.h"
#include "skia/include/SkBitmap.h"
namespace ChromeViews {
@@ -53,6 +54,10 @@ class View;
///////////////////////////////////////////////////////////////////////////////
class WindowDelegate {
public:
+ virtual ~WindowDelegate() {
+ window_.release();
+ }
+
virtual DialogDelegate* AsDialogDelegate() { return NULL; }
// Returns true if the window can be resized.
@@ -128,6 +133,23 @@ class WindowDelegate {
// Called when the window closes.
virtual void WindowClosing() { }
+
+ // Returns the View that is contained within this Window.
+ virtual View* GetContentsView() {
+ return NULL;
+ }
+
+ // An accessor to the Window this delegate is bound to.
+ Window* window() const { return window_.get(); }
+
+ private:
+ friend Window;
+ // This is a little unusual. We use a scoped_ptr here because it's
+ // initialized to NULL automatically. We do this because we want to allow
+ // people using this helper to not have to call a ctor on this object.
+ // Instead we just release the owning ref this pointer has when we are
+ // destroyed.
+ scoped_ptr<ChromeViews::Window> window_;
};
} // namespace ChromeViews