| OLD | NEW |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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/frame/browser_view.h" | 5 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <algorithm> | 9 #include <algorithm> |
| 10 #include <memory> | 10 #include <memory> |
| 11 #include <utility> | 11 #include <utility> |
| 12 | 12 |
| 13 #include "base/auto_reset.h" | 13 #include "base/auto_reset.h" |
| 14 #include "base/command_line.h" | 14 #include "base/command_line.h" |
| 15 #include "base/i18n/rtl.h" | 15 #include "base/i18n/rtl.h" |
| 16 #include "base/location.h" | 16 #include "base/location.h" |
| 17 #include "base/macros.h" | 17 #include "base/macros.h" |
| 18 #include "base/metrics/histogram_macros.h" | 18 #include "base/metrics/histogram_macros.h" |
| 19 #include "base/metrics/user_metrics.h" |
| 19 #include "base/profiler/scoped_tracker.h" | 20 #include "base/profiler/scoped_tracker.h" |
| 20 #include "base/single_thread_task_runner.h" | 21 #include "base/single_thread_task_runner.h" |
| 21 #include "base/strings/string_number_conversions.h" | 22 #include "base/strings/string_number_conversions.h" |
| 22 #include "base/threading/thread_task_runner_handle.h" | 23 #include "base/threading/thread_task_runner_handle.h" |
| 23 #include "build/build_config.h" | 24 #include "build/build_config.h" |
| 24 #include "chrome/app/chrome_command_ids.h" | 25 #include "chrome/app/chrome_command_ids.h" |
| 25 #include "chrome/browser/app_mode/app_mode_utils.h" | 26 #include "chrome/browser/app_mode/app_mode_utils.h" |
| 26 #include "chrome/browser/bookmarks/bookmark_stats.h" | 27 #include "chrome/browser/bookmarks/bookmark_stats.h" |
| 27 #include "chrome/browser/browser_process.h" | 28 #include "chrome/browser/browser_process.h" |
| 28 #include "chrome/browser/chrome_notification_types.h" | 29 #include "chrome/browser/chrome_notification_types.h" |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 111 #include "components/prefs/pref_service.h" | 112 #include "components/prefs/pref_service.h" |
| 112 #include "components/sessions/core/tab_restore_service.h" | 113 #include "components/sessions/core/tab_restore_service.h" |
| 113 #include "components/signin/core/common/profile_management_switches.h" | 114 #include "components/signin/core/common/profile_management_switches.h" |
| 114 #include "components/translate/core/browser/language_state.h" | 115 #include "components/translate/core/browser/language_state.h" |
| 115 #include "content/public/browser/download_manager.h" | 116 #include "content/public/browser/download_manager.h" |
| 116 #include "content/public/browser/keyboard_event_processing_result.h" | 117 #include "content/public/browser/keyboard_event_processing_result.h" |
| 117 #include "content/public/browser/notification_service.h" | 118 #include "content/public/browser/notification_service.h" |
| 118 #include "content/public/browser/render_frame_host.h" | 119 #include "content/public/browser/render_frame_host.h" |
| 119 #include "content/public/browser/render_view_host.h" | 120 #include "content/public/browser/render_view_host.h" |
| 120 #include "content/public/browser/render_widget_host_view.h" | 121 #include "content/public/browser/render_widget_host_view.h" |
| 121 #include "content/public/browser/user_metrics.h" | |
| 122 #include "content/public/browser/web_contents.h" | 122 #include "content/public/browser/web_contents.h" |
| 123 #include "content/public/common/content_switches.h" | 123 #include "content/public/common/content_switches.h" |
| 124 #include "ui/accessibility/ax_node_data.h" | 124 #include "ui/accessibility/ax_node_data.h" |
| 125 #include "ui/base/accelerators/accelerator.h" | 125 #include "ui/base/accelerators/accelerator.h" |
| 126 #include "ui/base/hit_test.h" | 126 #include "ui/base/hit_test.h" |
| 127 #include "ui/base/l10n/l10n_util.h" | 127 #include "ui/base/l10n/l10n_util.h" |
| 128 #include "ui/base/resource/resource_bundle.h" | 128 #include "ui/base/resource/resource_bundle.h" |
| 129 #include "ui/base/theme_provider.h" | 129 #include "ui/base/theme_provider.h" |
| 130 #include "ui/content_accelerators/accelerator_util.h" | 130 #include "ui/content_accelerators/accelerator_util.h" |
| 131 #include "ui/display/screen.h" | 131 #include "ui/display/screen.h" |
| (...skipping 2324 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2456 #else | 2456 #else |
| 2457 // App commands are Windows-specific so there's nothing to do here. | 2457 // App commands are Windows-specific so there's nothing to do here. |
| 2458 return -1; | 2458 return -1; |
| 2459 #endif | 2459 #endif |
| 2460 } | 2460 } |
| 2461 | 2461 |
| 2462 void BrowserView::UpdateAcceleratorMetrics(const ui::Accelerator& accelerator, | 2462 void BrowserView::UpdateAcceleratorMetrics(const ui::Accelerator& accelerator, |
| 2463 int command_id) { | 2463 int command_id) { |
| 2464 const ui::KeyboardCode key_code = accelerator.key_code(); | 2464 const ui::KeyboardCode key_code = accelerator.key_code(); |
| 2465 if (command_id == IDC_HELP_PAGE_VIA_KEYBOARD && key_code == ui::VKEY_F1) | 2465 if (command_id == IDC_HELP_PAGE_VIA_KEYBOARD && key_code == ui::VKEY_F1) |
| 2466 content::RecordAction(UserMetricsAction("ShowHelpTabViaF1")); | 2466 base::RecordAction(UserMetricsAction("ShowHelpTabViaF1")); |
| 2467 | 2467 |
| 2468 if (command_id == IDC_BOOKMARK_PAGE) | 2468 if (command_id == IDC_BOOKMARK_PAGE) |
| 2469 UMA_HISTOGRAM_ENUMERATION("Bookmarks.EntryPoint", | 2469 UMA_HISTOGRAM_ENUMERATION("Bookmarks.EntryPoint", |
| 2470 BOOKMARK_ENTRY_POINT_ACCELERATOR, | 2470 BOOKMARK_ENTRY_POINT_ACCELERATOR, |
| 2471 BOOKMARK_ENTRY_POINT_LIMIT); | 2471 BOOKMARK_ENTRY_POINT_LIMIT); |
| 2472 | 2472 |
| 2473 #if defined(OS_CHROMEOS) | 2473 #if defined(OS_CHROMEOS) |
| 2474 // Collect information about the relative popularity of various accelerators | 2474 // Collect information about the relative popularity of various accelerators |
| 2475 // on Chrome OS. | 2475 // on Chrome OS. |
| 2476 switch (command_id) { | 2476 switch (command_id) { |
| 2477 case IDC_BACK: | 2477 case IDC_BACK: |
| 2478 if (key_code == ui::VKEY_BROWSER_BACK) | 2478 if (key_code == ui::VKEY_BROWSER_BACK) |
| 2479 content::RecordAction(UserMetricsAction("Accel_Back_F1")); | 2479 base::RecordAction(UserMetricsAction("Accel_Back_F1")); |
| 2480 else if (key_code == ui::VKEY_LEFT) | 2480 else if (key_code == ui::VKEY_LEFT) |
| 2481 content::RecordAction(UserMetricsAction("Accel_Back_Left")); | 2481 base::RecordAction(UserMetricsAction("Accel_Back_Left")); |
| 2482 break; | 2482 break; |
| 2483 case IDC_FORWARD: | 2483 case IDC_FORWARD: |
| 2484 if (key_code == ui::VKEY_BROWSER_FORWARD) | 2484 if (key_code == ui::VKEY_BROWSER_FORWARD) |
| 2485 content::RecordAction(UserMetricsAction("Accel_Forward_F2")); | 2485 base::RecordAction(UserMetricsAction("Accel_Forward_F2")); |
| 2486 else if (key_code == ui::VKEY_RIGHT) | 2486 else if (key_code == ui::VKEY_RIGHT) |
| 2487 content::RecordAction(UserMetricsAction("Accel_Forward_Right")); | 2487 base::RecordAction(UserMetricsAction("Accel_Forward_Right")); |
| 2488 break; | 2488 break; |
| 2489 case IDC_RELOAD: | 2489 case IDC_RELOAD: |
| 2490 case IDC_RELOAD_BYPASSING_CACHE: | 2490 case IDC_RELOAD_BYPASSING_CACHE: |
| 2491 if (key_code == ui::VKEY_R) | 2491 if (key_code == ui::VKEY_R) |
| 2492 content::RecordAction(UserMetricsAction("Accel_Reload_R")); | 2492 base::RecordAction(UserMetricsAction("Accel_Reload_R")); |
| 2493 else if (key_code == ui::VKEY_BROWSER_REFRESH) | 2493 else if (key_code == ui::VKEY_BROWSER_REFRESH) |
| 2494 content::RecordAction(UserMetricsAction("Accel_Reload_F3")); | 2494 base::RecordAction(UserMetricsAction("Accel_Reload_F3")); |
| 2495 break; | 2495 break; |
| 2496 case IDC_FOCUS_LOCATION: | 2496 case IDC_FOCUS_LOCATION: |
| 2497 if (key_code == ui::VKEY_D) | 2497 if (key_code == ui::VKEY_D) |
| 2498 content::RecordAction(UserMetricsAction("Accel_FocusLocation_D")); | 2498 base::RecordAction(UserMetricsAction("Accel_FocusLocation_D")); |
| 2499 else if (key_code == ui::VKEY_L) | 2499 else if (key_code == ui::VKEY_L) |
| 2500 content::RecordAction(UserMetricsAction("Accel_FocusLocation_L")); | 2500 base::RecordAction(UserMetricsAction("Accel_FocusLocation_L")); |
| 2501 break; | 2501 break; |
| 2502 case IDC_FOCUS_SEARCH: | 2502 case IDC_FOCUS_SEARCH: |
| 2503 if (key_code == ui::VKEY_E) | 2503 if (key_code == ui::VKEY_E) |
| 2504 content::RecordAction(UserMetricsAction("Accel_FocusSearch_E")); | 2504 base::RecordAction(UserMetricsAction("Accel_FocusSearch_E")); |
| 2505 else if (key_code == ui::VKEY_K) | 2505 else if (key_code == ui::VKEY_K) |
| 2506 content::RecordAction(UserMetricsAction("Accel_FocusSearch_K")); | 2506 base::RecordAction(UserMetricsAction("Accel_FocusSearch_K")); |
| 2507 break; | 2507 break; |
| 2508 default: | 2508 default: |
| 2509 // Do nothing. | 2509 // Do nothing. |
| 2510 break; | 2510 break; |
| 2511 } | 2511 } |
| 2512 #endif | 2512 #endif |
| 2513 } | 2513 } |
| 2514 | 2514 |
| 2515 void BrowserView::ShowAvatarBubbleFromAvatarButton( | 2515 void BrowserView::ShowAvatarBubbleFromAvatarButton( |
| 2516 AvatarBubbleMode mode, | 2516 AvatarBubbleMode mode, |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2684 } | 2684 } |
| 2685 | 2685 |
| 2686 extensions::ActiveTabPermissionGranter* | 2686 extensions::ActiveTabPermissionGranter* |
| 2687 BrowserView::GetActiveTabPermissionGranter() { | 2687 BrowserView::GetActiveTabPermissionGranter() { |
| 2688 content::WebContents* web_contents = GetActiveWebContents(); | 2688 content::WebContents* web_contents = GetActiveWebContents(); |
| 2689 if (!web_contents) | 2689 if (!web_contents) |
| 2690 return nullptr; | 2690 return nullptr; |
| 2691 return extensions::TabHelper::FromWebContents(web_contents) | 2691 return extensions::TabHelper::FromWebContents(web_contents) |
| 2692 ->active_tab_permission_granter(); | 2692 ->active_tab_permission_granter(); |
| 2693 } | 2693 } |
| OLD | NEW |