OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/ui/views/tabs/browser_tab_strip_controller.h" | 5 #include "chrome/browser/ui/views/tabs/browser_tab_strip_controller.h" |
6 | 6 |
7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/task_runner_util.h" | 9 #include "base/task_runner_util.h" |
10 #include "base/threading/sequenced_worker_pool.h" | 10 #include "base/threading/sequenced_worker_pool.h" |
(...skipping 16 matching lines...) Expand all Loading... | |
27 #include "chrome/browser/ui/views/tabs/tab_renderer_data.h" | 27 #include "chrome/browser/ui/views/tabs/tab_renderer_data.h" |
28 #include "chrome/browser/ui/views/tabs/tab_strip.h" | 28 #include "chrome/browser/ui/views/tabs/tab_strip.h" |
29 #include "chrome/common/pref_names.h" | 29 #include "chrome/common/pref_names.h" |
30 #include "chrome/common/url_constants.h" | 30 #include "chrome/common/url_constants.h" |
31 #include "components/metrics/proto/omnibox_event.pb.h" | 31 #include "components/metrics/proto/omnibox_event.pb.h" |
32 #include "components/mime_util/mime_util.h" | 32 #include "components/mime_util/mime_util.h" |
33 #include "components/omnibox/browser/autocomplete_classifier.h" | 33 #include "components/omnibox/browser/autocomplete_classifier.h" |
34 #include "components/omnibox/browser/autocomplete_match.h" | 34 #include "components/omnibox/browser/autocomplete_match.h" |
35 #include "components/prefs/pref_service.h" | 35 #include "components/prefs/pref_service.h" |
36 #include "content/public/browser/browser_thread.h" | 36 #include "content/public/browser/browser_thread.h" |
37 #include "content/public/browser/navigation_controller.h" | |
38 #include "content/public/browser/navigation_entry.h" | |
39 #include "content/public/browser/navigation_handle.h" | |
37 #include "content/public/browser/notification_service.h" | 40 #include "content/public/browser/notification_service.h" |
38 #include "content/public/browser/plugin_service.h" | 41 #include "content/public/browser/plugin_service.h" |
39 #include "content/public/browser/user_metrics.h" | 42 #include "content/public/browser/user_metrics.h" |
40 #include "content/public/browser/web_contents.h" | 43 #include "content/public/browser/web_contents.h" |
41 #include "content/public/common/webplugininfo.h" | 44 #include "content/public/common/webplugininfo.h" |
42 #include "ipc/ipc_message.h" | 45 #include "ipc/ipc_message.h" |
43 #include "net/base/filename_util.h" | 46 #include "net/base/filename_util.h" |
44 #include "ui/base/models/list_selection_model.h" | 47 #include "ui/base/models/list_selection_model.h" |
45 #include "ui/gfx/image/image.h" | 48 #include "ui/gfx/image/image.h" |
46 #include "ui/views/controls/menu/menu_runner.h" | 49 #include "ui/views/controls/menu/menu_runner.h" |
47 #include "ui/views/widget/widget.h" | 50 #include "ui/views/widget/widget.h" |
48 #include "url/origin.h" | 51 #include "url/origin.h" |
49 | 52 |
50 using base::UserMetricsAction; | 53 using base::UserMetricsAction; |
51 using content::WebContents; | 54 using content::WebContents; |
52 | 55 |
53 namespace { | 56 namespace { |
54 | 57 |
55 TabRendererData::NetworkState TabContentsNetworkState( | 58 TabRendererData::NetworkState TabContentsNetworkState( |
56 WebContents* contents) { | 59 WebContents* contents) { |
57 if (!contents || !contents->IsLoadingToDifferentDocument()) | 60 if (!contents) |
58 return TabRendererData::NETWORK_STATE_NONE; | 61 return TabRendererData::NETWORK_STATE_NONE; |
62 | |
63 if (!contents->IsLoadingToDifferentDocument()) { | |
64 content::NavigationEntry* entry = | |
65 contents->GetController().GetLastCommittedEntry(); | |
66 if (entry && (entry->GetPageType() == content::PAGE_TYPE_ERROR)) | |
67 return TabRendererData::NETWORK_STATE_ERROR; | |
68 return TabRendererData::NETWORK_STATE_NONE; | |
69 } | |
70 | |
59 if (contents->IsWaitingForResponse()) | 71 if (contents->IsWaitingForResponse()) |
60 return TabRendererData::NETWORK_STATE_WAITING; | 72 return TabRendererData::NETWORK_STATE_WAITING; |
61 return TabRendererData::NETWORK_STATE_LOADING; | 73 return TabRendererData::NETWORK_STATE_LOADING; |
62 } | 74 } |
63 | 75 |
64 bool DetermineTabStripLayoutStacked(PrefService* prefs, bool* adjust_layout) { | 76 bool DetermineTabStripLayoutStacked(PrefService* prefs, bool* adjust_layout) { |
65 *adjust_layout = false; | 77 *adjust_layout = false; |
66 // For ash, always allow entering stacked mode. | 78 // For ash, always allow entering stacked mode. |
67 #if defined(USE_ASH) | 79 #if defined(USE_ASH) |
68 *adjust_layout = true; | 80 *adjust_layout = true; |
(...skipping 344 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
413 base::Bind(&BrowserTabStripController::OnFindURLMimeTypeCompleted, | 425 base::Bind(&BrowserTabStripController::OnFindURLMimeTypeCompleted, |
414 weak_ptr_factory_.GetWeakPtr(), | 426 weak_ptr_factory_.GetWeakPtr(), |
415 url)); | 427 url)); |
416 } | 428 } |
417 | 429 |
418 SkColor BrowserTabStripController::GetToolbarTopSeparatorColor() const { | 430 SkColor BrowserTabStripController::GetToolbarTopSeparatorColor() const { |
419 return BrowserView::GetBrowserViewForBrowser(browser_)->frame() | 431 return BrowserView::GetBrowserViewForBrowser(browser_)->frame() |
420 ->GetFrameView()->GetToolbarTopSeparatorColor(); | 432 ->GetFrameView()->GetToolbarTopSeparatorColor(); |
421 } | 433 } |
422 | 434 |
435 base::string16 BrowserTabStripController::GetAccessibleTabName() const { | |
436 return BrowserView::GetBrowserViewForBrowser(browser_) | |
sky
2016/12/16 00:52:51
Can you change BrowserTabStripController to take a
edwardjung
2016/12/19 12:59:25
Good point, fixed.
| |
437 ->GetAccessibleWindowTitle(); | |
438 } | |
439 | |
423 //////////////////////////////////////////////////////////////////////////////// | 440 //////////////////////////////////////////////////////////////////////////////// |
424 // BrowserTabStripController, TabStripModelObserver implementation: | 441 // BrowserTabStripController, TabStripModelObserver implementation: |
425 | 442 |
426 void BrowserTabStripController::TabInsertedAt(TabStripModel* tab_strip_model, | 443 void BrowserTabStripController::TabInsertedAt(TabStripModel* tab_strip_model, |
427 WebContents* contents, | 444 WebContents* contents, |
428 int model_index, | 445 int model_index, |
429 bool is_active) { | 446 bool is_active) { |
430 DCHECK(contents); | 447 DCHECK(contents); |
431 DCHECK(model_->ContainsIndex(model_index)); | 448 DCHECK(model_->ContainsIndex(model_index)); |
432 AddTab(contents, model_index, is_active); | 449 AddTab(contents, model_index, is_active); |
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
571 content::WebPluginInfo plugin; | 588 content::WebPluginInfo plugin; |
572 tabstrip_->FileSupported( | 589 tabstrip_->FileSupported( |
573 url, | 590 url, |
574 mime_type.empty() || mime_util::IsSupportedMimeType(mime_type) || | 591 mime_type.empty() || mime_util::IsSupportedMimeType(mime_type) || |
575 content::PluginService::GetInstance()->GetPluginInfo( | 592 content::PluginService::GetInstance()->GetPluginInfo( |
576 -1, // process ID | 593 -1, // process ID |
577 MSG_ROUTING_NONE, // routing ID | 594 MSG_ROUTING_NONE, // routing ID |
578 model_->profile()->GetResourceContext(), url, url::Origin(), | 595 model_->profile()->GetResourceContext(), url, url::Origin(), |
579 mime_type, false, NULL, &plugin, NULL)); | 596 mime_type, false, NULL, &plugin, NULL)); |
580 } | 597 } |
OLD | NEW |