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 "ash/system/tray/system_tray.h" | 5 #include "ash/system/tray/system_tray.h" |
6 | 6 |
7 #include "ash/common/ash_switches.h" | 7 #include "ash/common/ash_switches.h" |
8 #include "ash/common/session/session_state_delegate.h" | 8 #include "ash/common/session/session_state_delegate.h" |
9 #include "ash/common/shelf/wm_shelf.h" | 9 #include "ash/common/shelf/wm_shelf.h" |
10 #include "ash/common/shelf/wm_shelf_util.h" | 10 #include "ash/common/shelf/wm_shelf_util.h" |
11 #include "ash/common/shell_window_ids.h" | 11 #include "ash/common/shell_window_ids.h" |
12 #include "ash/common/system/date/tray_date.h" | 12 #include "ash/common/system/date/tray_date.h" |
13 #include "ash/common/system/tray/system_tray_delegate.h" | 13 #include "ash/common/system/tray/system_tray_delegate.h" |
14 #include "ash/common/system/tray/system_tray_item.h" | 14 #include "ash/common/system/tray/system_tray_item.h" |
15 #include "ash/common/system/tray/tray_constants.h" | 15 #include "ash/common/system/tray/tray_constants.h" |
16 #include "ash/common/system/tray_accessibility.h" | 16 #include "ash/common/system/tray_accessibility.h" |
17 #include "ash/common/system/update/tray_update.h" | 17 #include "ash/common/system/update/tray_update.h" |
18 #include "ash/common/wm_lookup.h" | |
19 #include "ash/common/wm_root_window_controller.h" | |
18 #include "ash/common/wm_shell.h" | 20 #include "ash/common/wm_shell.h" |
21 #include "ash/common/wm_window.h" | |
19 #include "ash/metrics/user_metrics_recorder.h" | 22 #include "ash/metrics/user_metrics_recorder.h" |
20 #include "ash/shell.h" | 23 #include "ash/shell.h" |
21 #include "ash/system/audio/tray_audio.h" | 24 #include "ash/system/audio/tray_audio.h" |
22 #include "ash/system/cast/tray_cast.h" | 25 #include "ash/system/cast/tray_cast.h" |
23 #include "ash/system/status_area_widget.h" | 26 #include "ash/system/status_area_widget.h" |
24 #include "ash/system/tray/tray_bubble_wrapper.h" | 27 #include "ash/system/tray/tray_bubble_wrapper.h" |
25 #include "ash/system/user/login_status.h" | 28 #include "ash/system/user/login_status.h" |
26 #include "ash/system/user/tray_user.h" | 29 #include "ash/system/user/tray_user.h" |
27 #include "ash/system/user/tray_user_separator.h" | 30 #include "ash/system/user/tray_user_separator.h" |
28 #include "ash/system/web_notification/web_notification_tray.h" | 31 #include "ash/system/web_notification/web_notification_tray.h" |
(...skipping 627 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
656 DestroyNotificationBubble(); | 659 DestroyNotificationBubble(); |
657 } | 660 } |
658 } | 661 } |
659 | 662 |
660 void SystemTray::ClickedOutsideBubble() { | 663 void SystemTray::ClickedOutsideBubble() { |
661 if (!system_bubble_ || system_bubble_->is_persistent()) | 664 if (!system_bubble_ || system_bubble_->is_persistent()) |
662 return; | 665 return; |
663 HideBubbleWithView(system_bubble_->bubble_view()); | 666 HideBubbleWithView(system_bubble_->bubble_view()); |
664 } | 667 } |
665 | 668 |
669 // views::TrayBubbleView::Delegate overrides: | |
msw
2016/06/22 23:00:23
nit: I'm not a big fan unless the file is consiste
James Cook
2016/06/22 23:06:28
Removed.
| |
670 | |
666 void SystemTray::BubbleViewDestroyed() { | 671 void SystemTray::BubbleViewDestroyed() { |
667 if (system_bubble_) { | 672 if (system_bubble_) { |
668 system_bubble_->bubble()->DestroyItemViews(); | 673 system_bubble_->bubble()->DestroyItemViews(); |
669 system_bubble_->bubble()->BubbleViewDestroyed(); | 674 system_bubble_->bubble()->BubbleViewDestroyed(); |
670 } | 675 } |
671 } | 676 } |
672 | 677 |
673 void SystemTray::OnMouseEnteredView() { | 678 void SystemTray::OnMouseEnteredView() { |
674 if (system_bubble_) | 679 if (system_bubble_) |
675 system_bubble_->bubble()->StopAutoCloseTimer(); | 680 system_bubble_->bubble()->StopAutoCloseTimer(); |
676 } | 681 } |
677 | 682 |
678 void SystemTray::OnMouseExitedView() { | 683 void SystemTray::OnMouseExitedView() { |
679 if (system_bubble_) | 684 if (system_bubble_) |
680 system_bubble_->bubble()->RestartAutoCloseTimer(); | 685 system_bubble_->bubble()->RestartAutoCloseTimer(); |
681 } | 686 } |
682 | 687 |
683 base::string16 SystemTray::GetAccessibleNameForBubble() { | 688 base::string16 SystemTray::GetAccessibleNameForBubble() { |
684 return GetAccessibleNameForTray(); | 689 return GetAccessibleNameForTray(); |
685 } | 690 } |
686 | 691 |
687 gfx::Rect SystemTray::GetAnchorRect( | 692 gfx::Rect SystemTray::GetAnchorRect( |
688 views::Widget* anchor_widget, | 693 views::Widget* anchor_widget, |
689 TrayBubbleView::AnchorType anchor_type, | 694 TrayBubbleView::AnchorType anchor_type, |
690 TrayBubbleView::AnchorAlignment anchor_alignment) const { | 695 TrayBubbleView::AnchorAlignment anchor_alignment) const { |
691 return GetBubbleAnchorRect(anchor_widget, anchor_type, anchor_alignment); | 696 return GetBubbleAnchorRect(anchor_widget, anchor_type, anchor_alignment); |
692 } | 697 } |
693 | 698 |
699 void SystemTray::OnBeforeBubbleWidgetInit( | |
700 views::Widget* anchor_widget, | |
701 views::Widget* bubble_widget, | |
702 views::Widget::InitParams* params) const { | |
703 // Place the bubble in the same root window as |anchor_widget|. | |
704 WmLookup::Get() | |
705 ->GetWindowForWidget(anchor_widget) | |
706 ->GetRootWindowController() | |
707 ->ConfigureWidgetInitParamsForContainer( | |
708 bubble_widget, kShellWindowId_SettingBubbleContainer, params); | |
709 } | |
710 | |
694 void SystemTray::HideBubble(const TrayBubbleView* bubble_view) { | 711 void SystemTray::HideBubble(const TrayBubbleView* bubble_view) { |
695 HideBubbleWithView(bubble_view); | 712 HideBubbleWithView(bubble_view); |
696 } | 713 } |
697 | 714 |
698 views::View* SystemTray::GetTrayItemViewForTest(SystemTrayItem* item) { | 715 views::View* SystemTray::GetTrayItemViewForTest(SystemTrayItem* item) { |
699 std::map<SystemTrayItem*, views::View*>::iterator it = | 716 std::map<SystemTrayItem*, views::View*>::iterator it = |
700 tray_item_map_.find(item); | 717 tray_item_map_.find(item); |
701 return it == tray_item_map_.end() ? NULL : it->second; | 718 return it == tray_item_map_.end() ? NULL : it->second; |
702 } | 719 } |
703 | 720 |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
759 .work_area() | 776 .work_area() |
760 .height(); | 777 .height(); |
761 if (work_area_height > 0) { | 778 if (work_area_height > 0) { |
762 UMA_HISTOGRAM_CUSTOM_COUNTS( | 779 UMA_HISTOGRAM_CUSTOM_COUNTS( |
763 "Ash.SystemMenu.PercentageOfWorkAreaHeightCoveredByMenu", | 780 "Ash.SystemMenu.PercentageOfWorkAreaHeightCoveredByMenu", |
764 100 * bubble_view->height() / work_area_height, 1, 300, 100); | 781 100 * bubble_view->height() / work_area_height, 1, 300, 100); |
765 } | 782 } |
766 } | 783 } |
767 | 784 |
768 } // namespace ash | 785 } // namespace ash |
OLD | NEW |