1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
|
// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/views/html_dialog_view.h"
#include "chrome/browser/browser.h"
#include "chrome/views/root_view.h"
#include "chrome/views/window.h"
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogView, public:
HtmlDialogView::HtmlDialogView(Browser* parent_browser,
Profile* profile,
HtmlDialogContentsDelegate* delegate)
: DOMView(delegate->GetDialogContentURL()),
parent_browser_(parent_browser),
profile_(profile),
delegate_(delegate) {
DCHECK(parent_browser);
DCHECK(profile);
}
HtmlDialogView::~HtmlDialogView() {
}
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogView, ChromeViews::View implementation:
gfx::Size HtmlDialogView::GetPreferredSize() {
CSize out;
delegate_->GetDialogSize(&out);
return gfx::Size(out.cx, out.cy);
}
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogView, ChromeViews::WindowDelegate implementation:
bool HtmlDialogView::CanResize() const {
return true;
}
bool HtmlDialogView::IsModal() const {
return delegate_->IsModal();
}
std::wstring HtmlDialogView::GetWindowTitle() const {
return L"Google Gears";
}
void HtmlDialogView::WindowClosing() {
// If we still have a delegate that means we haven't notified it of the
// dialog closing. This happens if the user clicks the Close button on the
// dialog.
if (delegate_)
OnDialogClosed("");
}
ChromeViews::View* HtmlDialogView::GetContentsView() {
return this;
}
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogContentsDelegate implementation:
GURL HtmlDialogView::GetDialogContentURL() const {
return delegate_->GetDialogContentURL();
}
void HtmlDialogView::GetDialogSize(CSize* size) const {
return delegate_->GetDialogSize(size);
}
std::string HtmlDialogView::GetDialogArgs() const {
return delegate_->GetDialogArgs();
}
void HtmlDialogView::OnDialogClosed(const std::string& json_retval) {
delegate_->OnDialogClosed(json_retval);
delegate_ = NULL; // We will not communicate further with the delegate.
window()->Close();
}
////////////////////////////////////////////////////////////////////////////////
// PageNavigator implementation:
void HtmlDialogView::OpenURLFromTab(TabContents* source,
const GURL& url,
WindowOpenDisposition disposition,
PageTransition::Type transition) {
// Force all links to open in a new window, ignoring the incoming
// disposition. This is a tabless, modal dialog so we can't just
// open it in the current frame.
parent_browser_->OpenURLFromTab(source, url, NEW_WINDOW, transition);
}
////////////////////////////////////////////////////////////////////////////////
// TabContentsDelegate implementation:
void HtmlDialogView::NavigationStateChanged(const TabContents* source,
unsigned changed_flags) {
// We shouldn't receive any NavigationStateChanged except the first
// one, which we ignore because we're a dialog box.
}
void HtmlDialogView::ReplaceContents(TabContents* source,
TabContents* new_contents) {
}
void HtmlDialogView::AddNewContents(TabContents* source,
TabContents* new_contents,
WindowOpenDisposition disposition,
const gfx::Rect& initial_pos,
bool user_gesture) {
parent_browser_->AddNewContents(
source, new_contents, NEW_WINDOW, initial_pos, user_gesture);
}
void HtmlDialogView::ActivateContents(TabContents* contents) {
// We don't do anything here because there's only one TabContents in
// this frame and we don't have a TabStripModel.
}
void HtmlDialogView::LoadingStateChanged(TabContents* source) {
// We don't care about this notification
}
void HtmlDialogView::CloseContents(TabContents* source) {
// We receive this message but don't handle it because we really do the
// cleanup in OnDialogClosed().
}
void HtmlDialogView::MoveContents(TabContents* source, const gfx::Rect& pos) {
// The contained web page wishes to resize itself. We let it do this because
// if it's a dialog we know about, we trust it not to be mean to the user.
window()->SetBounds(pos);
}
bool HtmlDialogView::IsPopup(TabContents* source) {
// This needs to return true so that we are allowed to be resized by our
// contents.
return true;
}
void HtmlDialogView::ToolbarSizeChanged(TabContents* source, bool is_animating) {
Layout();
}
void HtmlDialogView::URLStarredChanged(TabContents* source, bool starred) {
// We don't have a visible star to click in the window.
NOTREACHED();
}
void HtmlDialogView::UpdateTargetURL(TabContents* source, const GURL& url) {
// Ignored.
}
////////////////////////////////////////////////////////////////////////////////
// HtmlDialogView:
void HtmlDialogView::InitDialog() {
// Now Init the DOMView. This view runs in its own process to render the html.
DOMView::Init(profile_, NULL);
// Make sure this new TabContents we just created in Init() knows about us.
DCHECK(host_->type() == TAB_CONTENTS_HTML_DIALOG);
HtmlDialogContents* host = static_cast<HtmlDialogContents*>(host_);
host->Init(this);
host->set_delegate(this);
}
|