blob: d566b865e25543b550d90fb6d32a6fa708ec2ef0 (
plain)
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
|
// 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/modal_html_dialog_delegate.h"
#include "chrome/browser/browser_list.h"
#include "chrome/browser/renderer_host/render_view_host.h"
#include "chrome/browser/tab_contents/tab_contents.h"
#include "chrome/common/notification_service.h"
ModalHtmlDialogDelegate::ModalHtmlDialogDelegate(
const GURL& url, int width, int height, const std::string& json_arguments,
IPC::Message* sync_result, TabContents* contents)
: contents_(contents),
sync_response_(sync_result) {
// Listen for when the TabContents or its renderer dies.
registrar_.Add(this, NotificationType::TAB_CONTENTS_DISCONNECTED,
Source<TabContents>(contents_));
// This information is needed to show the dialog HTML content.
params_.url = url;
params_.height = height;
params_.width = width;
params_.json_input = json_arguments;
}
ModalHtmlDialogDelegate::~ModalHtmlDialogDelegate() {
}
void ModalHtmlDialogDelegate::Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details) {
DCHECK(type == NotificationType::TAB_CONTENTS_DISCONNECTED);
DCHECK(Source<TabContents>(source).ptr() == contents_);
registrar_.RemoveAll();
contents_ = NULL;
}
bool ModalHtmlDialogDelegate::IsDialogModal() const {
return true;
}
GURL ModalHtmlDialogDelegate::GetDialogContentURL() const {
return params_.url;
}
void ModalHtmlDialogDelegate::GetDialogSize(gfx::Size* size) const {
size->set_width(params_.width);
size->set_height(params_.height);
}
std::string ModalHtmlDialogDelegate::GetDialogArgs() const {
return params_.json_input;
}
void ModalHtmlDialogDelegate::OnDialogClosed(const std::string& json_retval) {
// Our TabContents may have died before this point.
if (contents_ && contents_->render_view_host()) {
contents_->render_view_host()->ModalHTMLDialogClosed(sync_response_,
json_retval);
}
// We are done with this request, so delete us.
delete this;
}
|