Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1194)

Unified Diff: chrome/browser/ui/views/select_file_dialog_extension.cc

Issue 10584026: Allow ChromeOS file selection dialog to be shown from shell windows. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Another rebase Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/ui/views/select_file_dialog_extension.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/views/select_file_dialog_extension.cc
diff --git a/chrome/browser/ui/views/select_file_dialog_extension.cc b/chrome/browser/ui/views/select_file_dialog_extension.cc
index b8e3d26aa968a48a2d43028f7f94d3a5cc4e28f2..af66c52b44e0195641f04cbc15162982fd362652 100644
--- a/chrome/browser/ui/views/select_file_dialog_extension.cc
+++ b/chrome/browser/ui/views/select_file_dialog_extension.cc
@@ -10,15 +10,20 @@
#include "base/memory/ref_counted.h"
#include "base/memory/singleton.h"
#include "base/message_loop.h"
+#include "chrome/browser/browser_process.h"
#include "chrome/browser/chromeos/extensions/file_browser_private_api.h"
#include "chrome/browser/chromeos/extensions/file_manager_util.h"
#include "chrome/browser/extensions/extension_host.h"
#include "chrome/browser/extensions/extension_service.h"
+#include "chrome/browser/extensions/shell_window_registry.h"
+#include "chrome/browser/profiles/profile_manager.h"
#include "chrome/browser/sessions/restore_tab_helper.h"
+#include "chrome/browser/ui/base_window.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_finder.h"
#include "chrome/browser/ui/browser_list.h"
#include "chrome/browser/ui/browser_window.h"
+#include "chrome/browser/ui/extensions/shell_window.h"
#include "chrome/browser/ui/tab_contents/tab_contents.h"
#include "chrome/browser/ui/views/extensions/extension_dialog.h"
#include "content/public/browser/browser_thread.h"
@@ -96,7 +101,7 @@ SelectFileDialogExtension::SelectFileDialogExtension(Listener* listener)
: SelectFileDialog(listener),
has_multiple_file_type_choices_(false),
tab_id_(0),
- owner_browser_(NULL),
+ profile_(NULL),
owner_window_(NULL),
selection_type_(CANCEL),
selection_index_(0),
@@ -121,7 +126,7 @@ void SelectFileDialogExtension::ListenerDestroyed() {
void SelectFileDialogExtension::ExtensionDialogClosing(
ExtensionDialog* dialog) {
- owner_browser_ = NULL;
+ profile_ = NULL;
owner_window_ = NULL;
// Release our reference to the dialog to allow it to close.
extension_dialog_ = NULL;
@@ -144,10 +149,10 @@ void SelectFileDialogExtension::ExtensionTerminated(
// time, the extension subsystem would automatically reload it for us. At
// this time though this is broken because of some faulty wiring in
// ExtensionProcessManager::CreateViewHost. Once that is fixed, remove this.
- if (owner_browser_) {
+ if (profile_) {
MessageLoop::current()->PostTask(FROM_HERE,
base::Bind(&ExtensionService::ReloadExtension,
- base::Unretained(owner_browser_->profile()->GetExtensionService()),
+ base::Unretained(profile_->GetExtensionService()),
extension_id));
}
@@ -246,19 +251,55 @@ void SelectFileDialogExtension::SelectFileImpl(
LOG(ERROR) << "File dialog already in use!";
return;
}
- // Extension background pages may not supply an owner_window.
- owner_browser_ = (owner_window ?
+
+ // The base window to associate the dialog with.
+ BaseWindow* base_window = NULL;
+
+ // The tab contents to associate the dialog with.
+ const TabContents* tab = NULL;
+
+ // First try to find a Browser using the supplied owner_window. If no owner
+ // window has been supplied, this is running from a background page and should
+ // be associated with the last active browser.
+ Browser* owner_browser = (owner_window ?
browser::FindBrowserWithWindow(owner_window) :
- BrowserList::GetLastActive());
- if (!owner_browser_) {
- NOTREACHED() << "Can't find owning browser";
- return;
+ BrowserList::GetLastActive());
+ if (owner_browser) {
+ base_window = owner_browser->window();
+ tab = owner_browser->GetActiveTabContents();
+ profile_ = tab->profile();
+ } else if (owner_window) {
+ // If an owner_window was supplied but we couldn't find a browser, this
+ // could be for a shell window.
+ // TODO(benwells): Find a better way to get a shell window from a native
+ // window.
+ std::vector<Profile*> profiles =
+ g_browser_process->profile_manager()->GetLoadedProfiles();
+ for (std::vector<Profile*>::const_iterator iter = profiles.begin();
+ iter < profiles.end(); iter++) {
+ ShellWindowRegistry* registry = ShellWindowRegistry::Get(*iter);
+ DCHECK(registry);
+ ShellWindow* shell_window = registry->GetShellWindowForNativeWindow(
+ owner_window);
+ if (shell_window) {
+ base_window = shell_window;
+ tab = shell_window->tab_contents();
+ profile_ = *iter;
+ break;
+ }
+ }
}
- TabContents* tab = owner_browser_->GetActiveTabContents();
+ if (!base_window) {
+ NOTREACHED() << "Can't find owning window.";
+ return;
+ }
+ DCHECK(profile_);
// Check if we have another dialog opened in the tab. It's unlikely, but
- // possible.
+ // possible. If there is no tab contents use a tab_id of 0. A dialog without
+ // an associated tab contents will be shown fully screen; only one at a time
+ // is allowed in this state.
int32 tab_id = tab ? tab->restore_tab_helper()->session_id().id() : 0;
if (PendingExists(tab_id)) {
DLOG(WARNING) << "Pending dialog exists with id " << tab_id;
@@ -267,7 +308,7 @@ void SelectFileDialogExtension::SelectFileImpl(
FilePath virtual_path;
if (!file_manager_util::ConvertFileToRelativeFileSystemPath(
- owner_browser_->profile(), default_path, &virtual_path)) {
+ profile_, default_path, &virtual_path)) {
virtual_path = default_path.BaseName();
}
@@ -278,8 +319,8 @@ void SelectFileDialogExtension::SelectFileImpl(
type, title, virtual_path, file_types, file_type_index,
default_extension);
- ExtensionDialog* dialog = ExtensionDialog::Show(file_browser_url,
- owner_browser_, tab->web_contents(),
+ExtensionDialog* dialog = ExtensionDialog::Show(file_browser_url,
+ base_window, profile_, tab->web_contents(),
kFileManagerWidth, kFileManagerHeight,
#if defined(USE_AURA)
file_manager_util::GetTitleFromType(type),
« no previous file with comments | « chrome/browser/ui/views/select_file_dialog_extension.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698