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
|
// Copyright (c) 2009 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/dom_ui/html_dialog_tab_contents_delegate.h"
#include "chrome/browser/browser.h"
#include "chrome/browser/browser_window.h"
#include "chrome/browser/profile.h"
#include "chrome/browser/tab_contents/tab_contents.h"
// Incognito profiles are not long-lived, so we always want to store a
// non-incognito profile.
//
// TODO(akalin): Should we make it so that we have a default incognito
// profile that's long-lived? Of course, we'd still have to clear it out
// when all incognito browsers close.
HtmlDialogTabContentsDelegate::HtmlDialogTabContentsDelegate(Profile* profile)
: profile_(profile->GetOriginalProfile()) {}
HtmlDialogTabContentsDelegate::~HtmlDialogTabContentsDelegate() {}
Profile* HtmlDialogTabContentsDelegate::profile() const { return profile_; }
void HtmlDialogTabContentsDelegate::Detach() {
profile_ = NULL;
}
Browser* HtmlDialogTabContentsDelegate::CreateBrowser() {
DCHECK(profile_);
return Browser::Create(profile_);
}
void HtmlDialogTabContentsDelegate::OpenURLFromTab(
TabContents* source, const GURL& url, const GURL& referrer,
WindowOpenDisposition disposition, PageTransition::Type transition) {
if (profile_) {
// 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. Code adapted from
// Browser::OpenURLFromTab() with disposition == NEW_WINDOW.
Browser* browser = CreateBrowser();
TabContents* new_contents =
browser->AddTabWithURL(url, referrer, transition, -1,
TabStripModel::ADD_SELECTED, NULL,
std::string(), &browser);
DCHECK(new_contents);
browser->window()->Show();
new_contents->Focus();
}
}
void HtmlDialogTabContentsDelegate::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 HtmlDialogTabContentsDelegate::AddNewContents(
TabContents* source, TabContents* new_contents,
WindowOpenDisposition disposition, const gfx::Rect& initial_pos,
bool user_gesture) {
if (profile_) {
// Force this to open in a new window, too. Code adapted from
// Browser::AddNewContents() with disposition == NEW_WINDOW.
Browser* browser = CreateBrowser();
static_cast<TabContentsDelegate*>(browser)->
AddNewContents(source, new_contents, NEW_FOREGROUND_TAB,
initial_pos, user_gesture);
browser->window()->Show();
}
}
void HtmlDialogTabContentsDelegate::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 HtmlDialogTabContentsDelegate::LoadingStateChanged(TabContents* source) {
// We don't care about this notification.
}
void HtmlDialogTabContentsDelegate::CloseContents(TabContents* source) {
// We receive this message but don't handle it because we really do the
// cleanup somewhere else (namely, HtmlDialogUIDelegate::OnDialogClosed()).
}
bool HtmlDialogTabContentsDelegate::IsPopup(const TabContents* source) const {
// This needs to return true so that we are allowed to be resized by our
// contents.
return true;
}
void HtmlDialogTabContentsDelegate::URLStarredChanged(TabContents* source,
bool starred) {
// We don't have a visible star to click in the window.
NOTREACHED();
}
void HtmlDialogTabContentsDelegate::UpdateTargetURL(TabContents* source,
const GURL& url) {
// Ignored.
}
bool HtmlDialogTabContentsDelegate::ShouldAddNavigationToHistory() const {
return false;
}
|