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
|
// Copyright (c) 2012 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/ui/browser_tabstrip.h"
#include "base/command_line.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/blocked_content/blocked_content_tab_helper.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_navigator.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/url_constants.h"
#include "content/public/browser/navigation_entry.h"
#include "content/public/browser/render_view_host.h"
#include "content/public/browser/web_contents.h"
namespace chrome {
content::WebContents* GetActiveWebContents(const Browser* browser) {
return browser->tab_strip_model()->GetActiveWebContents();
}
content::WebContents* GetWebContentsAt(const Browser* browser, int index) {
return browser->tab_strip_model()->GetWebContentsAt(index);
}
void AddBlankTabAt(Browser* browser, int index, bool foreground) {
// TODO(scottmg): http://crbug.com/128578
// This is necessary because WebContentsViewAura doesn't have enough context
// to get the right StackingClient (and therefore parent window) otherwise.
ScopedForceDesktopType force_desktop_type(browser->host_desktop_type());
// Time new tab page creation time. We keep track of the timing data in
// WebContents, but we want to include the time it takes to create the
// WebContents object too.
base::TimeTicks new_tab_start_time = base::TimeTicks::Now();
chrome::NavigateParams params(browser, GURL(chrome::kChromeUINewTabURL),
content::PAGE_TRANSITION_TYPED);
params.disposition = foreground ? NEW_FOREGROUND_TAB : NEW_BACKGROUND_TAB;
params.tabstrip_index = index;
chrome::Navigate(¶ms);
params.target_contents->SetNewTabStartTime(new_tab_start_time);
}
content::WebContents* AddSelectedTabWithURL(
Browser* browser,
const GURL& url,
content::PageTransition transition) {
NavigateParams params(browser, url, transition);
params.disposition = NEW_FOREGROUND_TAB;
Navigate(¶ms);
return params.target_contents;
}
void AddWebContents(Browser* browser,
content::WebContents* source_contents,
content::WebContents* new_contents,
WindowOpenDisposition disposition,
const gfx::Rect& initial_pos,
bool user_gesture,
bool* was_blocked) {
// No code for this yet.
DCHECK(disposition != SAVE_TO_DISK);
// Can't create a new contents for the current tab - invalid case.
DCHECK(disposition != CURRENT_TAB);
BlockedContentTabHelper* source_blocked_content = NULL;
if (source_contents) {
source_blocked_content =
BlockedContentTabHelper::FromWebContents(source_contents);
}
if (source_blocked_content) {
// Handle blocking of tabs.
if (source_blocked_content->all_contents_blocked()) {
source_blocked_content->AddWebContents(
new_contents, disposition, initial_pos, user_gesture);
if (was_blocked)
*was_blocked = true;
return;
}
// Handle blocking of popups.
if ((disposition == NEW_POPUP || disposition == NEW_FOREGROUND_TAB) &&
!user_gesture &&
!CommandLine::ForCurrentProcess()->HasSwitch(
switches::kDisablePopupBlocking)) {
// Unrequested popups from normal pages are constrained unless they're in
// the white list. The popup owner will handle checking this.
source_blocked_content->AddPopup(
new_contents, disposition, initial_pos, user_gesture);
if (was_blocked)
*was_blocked = true;
return;
}
new_contents->GetRenderViewHost()->DisassociateFromPopupCount();
}
NavigateParams params(browser, new_contents);
params.source_contents = source_contents;
params.disposition = disposition;
params.window_bounds = initial_pos;
params.window_action = NavigateParams::SHOW_WINDOW;
params.user_gesture = user_gesture;
Navigate(¶ms);
}
void CloseWebContents(Browser* browser, content::WebContents* contents) {
int index = browser->tab_strip_model()->GetIndexOfWebContents(contents);
if (index == TabStripModel::kNoTab) {
NOTREACHED() << "CloseWebContents called for tab not in our strip";
return;
}
browser->tab_strip_model()->CloseWebContentsAt(
index,
TabStripModel::CLOSE_CREATE_HISTORICAL_TAB);
}
} // namespace chrome
|