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
ash / shelf / shelf_menu_model_adapter.cc [blame]
// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ash/shelf/shelf_menu_model_adapter.h"
#include "ash/public/cpp/app_menu_constants.h"
#include "base/metrics/histogram_macros.h"
#include "ui/base/mojom/menu_source_type.mojom.h"
#include "ui/menus/simple_menu_model.h"
#include "ui/views/view.h"
namespace ash {
ShelfMenuModelAdapter::ShelfMenuModelAdapter(
const std::string& app_id,
std::unique_ptr<ui::SimpleMenuModel> model,
views::View* menu_owner,
ui::mojom::MenuSourceType source_type,
base::OnceClosure on_menu_closed_callback,
bool is_tablet_mode,
bool for_application_menu_items)
: AppMenuModelAdapter(app_id,
std::move(model),
menu_owner->GetWidget(),
source_type,
std::move(on_menu_closed_callback),
is_tablet_mode),
menu_owner_(menu_owner),
for_application_menu_items_(for_application_menu_items) {}
ShelfMenuModelAdapter::~ShelfMenuModelAdapter() = default;
int ShelfMenuModelAdapter::GetCommandIdForHistograms(int command_id) {
if (!for_application_menu_items_)
return command_id;
// Command IDs of shelf app menu items must be in the range
// [APP_MENU_ITEM_ID_FIRST : APP_MENU_ITEM_ID_LAST] to avoid conflicts with
// other IDs when reporting UMA.
command_id += APP_MENU_ITEM_ID_FIRST;
DCHECK_LE(command_id, APP_MENU_ITEM_ID_LAST);
return command_id;
}
void ShelfMenuModelAdapter::RecordHistogramOnMenuClosed() {
base::TimeDelta user_journey_time = base::TimeTicks::Now() - menu_open_time();
// If the menu is for a ShelfButton.
if (!app_id().empty()) {
UMA_HISTOGRAM_TIMES("Apps.ContextMenuUserJourneyTimeV2.ShelfButton",
user_journey_time);
UMA_HISTOGRAM_ENUMERATION("Apps.ContextMenuShowSourceV2.ShelfButton",
source_type());
if (is_tablet_mode()) {
UMA_HISTOGRAM_TIMES(
"Apps.ContextMenuUserJourneyTimeV2.ShelfButton.TabletMode",
user_journey_time);
UMA_HISTOGRAM_ENUMERATION(
"Apps.ContextMenuShowSourceV2.ShelfButton.TabletMode", source_type());
} else {
UMA_HISTOGRAM_TIMES(
"Apps.ContextMenuUserJourneyTimeV2.ShelfButton.ClamshellMode",
user_journey_time);
UMA_HISTOGRAM_ENUMERATION(
"Apps.ContextMenuShowSourceV2.ShelfButton.ClamshellMode",
source_type());
}
return;
}
UMA_HISTOGRAM_TIMES("Apps.ContextMenuUserJourneyTimeV2.Shelf",
user_journey_time);
UMA_HISTOGRAM_ENUMERATION("Apps.ContextMenuShowSourceV2.Shelf",
source_type());
if (is_tablet_mode()) {
UMA_HISTOGRAM_TIMES("Apps.ContextMenuUserJourneyTimeV2.Shelf.TabletMode",
user_journey_time);
UMA_HISTOGRAM_ENUMERATION("Apps.ContextMenuShowSourceV2.Shelf.TabletMode",
source_type());
} else {
UMA_HISTOGRAM_TIMES("Apps.ContextMenuUserJourneyTimeV2.Shelf.ClamshellMode",
user_journey_time);
UMA_HISTOGRAM_ENUMERATION(
"Apps.ContextMenuShowSourceV2.Shelf.ClamshellMode", source_type());
}
}
bool ShelfMenuModelAdapter::IsShowingMenuForView(
const views::View& view) const {
return IsShowingMenu() && menu_owner_ == &view;
}
} // namespace ash