summaryrefslogtreecommitdiffstats
path: root/chrome/browser/ui/webui/web_dialog_web_contents_delegate.cc
blob: 25737ca4baf9f03cae7ac2e7ed68d2c2ccdeb6df (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
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
// 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/webui/web_dialog_web_contents_delegate.h"

#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_navigator.h"
#include "chrome/browser/ui/tab_contents/tab_contents.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "content/public/browser/web_contents.h"

using content::OpenURLParams;
using content::WebContents;

// 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.
WebDialogWebContentsDelegate::WebDialogWebContentsDelegate(Profile* profile)
    : profile_(profile) {
}

WebDialogWebContentsDelegate::~WebDialogWebContentsDelegate() {
}

Profile* WebDialogWebContentsDelegate::profile() const { return profile_; }

void WebDialogWebContentsDelegate::Detach() {
  profile_ = NULL;
}

WebContents* WebDialogWebContentsDelegate::OpenURLFromTab(
    WebContents* source, const OpenURLParams& params) {
  WebContents* new_contents = NULL;
  StaticOpenURLFromTab(profile_, source, params, &new_contents);
  return new_contents;
}

// static
Browser* WebDialogWebContentsDelegate::StaticOpenURLFromTab(
    Profile* profile, WebContents* source, const OpenURLParams& params,
    WebContents** out_new_contents) {
  if (!profile)
    return NULL;

  // Specify a NULL browser for navigation. This will cause Navigate()
  // to find a browser matching params.profile or create a new one.
  Browser* browser = NULL;
  browser::NavigateParams nav_params(browser, params.url, params.transition);
  nav_params.profile = profile;
  nav_params.referrer = params.referrer;
  if (source && source->IsCrashed() &&
      params.disposition == CURRENT_TAB &&
      params.transition == content::PAGE_TRANSITION_LINK) {
    nav_params.disposition = NEW_FOREGROUND_TAB;
  } else {
    nav_params.disposition = params.disposition;
  }
  nav_params.window_action = browser::NavigateParams::SHOW_WINDOW;
  nav_params.user_gesture = true;
  browser::Navigate(&nav_params);
  *out_new_contents = nav_params.target_contents ?
      nav_params.target_contents->web_contents() : NULL;
  return nav_params.browser;
}

void WebDialogWebContentsDelegate::AddNewContents(
    WebContents* source, WebContents* new_contents,
    WindowOpenDisposition disposition, const gfx::Rect& initial_pos,
    bool user_gesture) {
  StaticAddNewContents(profile_, source, new_contents, disposition,
                       initial_pos, user_gesture);
}

// static
Browser* WebDialogWebContentsDelegate::StaticAddNewContents(
    Profile* profile,
    WebContents* source,
    WebContents* new_contents,
    WindowOpenDisposition disposition,
    const gfx::Rect& initial_pos,
    bool user_gesture) {
  if (!profile)
    return NULL;

  // Specify a NULL browser for navigation. This will cause Navigate()
  // to find a browser matching params.profile or create a new one.
  Browser* browser = NULL;

  TabContents* tab_contents = new TabContents(new_contents);
  browser::NavigateParams params(browser, tab_contents);
  params.profile = profile;
  // TODO(pinkerton): no way to get a TabContents for this.
  // params.source_contents = source;
  params.disposition = disposition;
  params.window_bounds = initial_pos;
  params.window_action = browser::NavigateParams::SHOW_WINDOW;
  params.user_gesture = true;
  browser::Navigate(&params);

  return params.browser;
}

bool WebDialogWebContentsDelegate::IsPopupOrPanel(
    const WebContents* source) const {
  // This needs to return true so that we are allowed to be resized by our
  // contents.
  return true;
}

bool WebDialogWebContentsDelegate::ShouldAddNavigationToHistory(
    const history::HistoryAddPageArgs& add_page_args,
    content::NavigationType navigation_type) {
  return false;
}