Use MetricsFeatureProvider for condition/suggestion/search.
Bug: 31664539 Test: make RunSettingsRoboTests This allows different metric clients to listen to these events. Change-Id: Ib19c8099b16ff78d9aa4901278e0ff33eeefd4a8
This commit is contained in:
@@ -33,11 +33,11 @@ import android.view.ViewGroup;
|
|||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import com.android.internal.logging.MetricsLogger;
|
|
||||||
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
||||||
import com.android.internal.util.ArrayUtils;
|
import com.android.internal.util.ArrayUtils;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsActivity;
|
import com.android.settings.SettingsActivity;
|
||||||
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
import com.android.settings.dashboard.conditional.Condition;
|
import com.android.settings.dashboard.conditional.Condition;
|
||||||
import com.android.settings.dashboard.conditional.ConditionAdapterUtils;
|
import com.android.settings.dashboard.conditional.ConditionAdapterUtils;
|
||||||
import com.android.settingslib.SuggestionParser;
|
import com.android.settingslib.SuggestionParser;
|
||||||
@@ -71,6 +71,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
private final IconCache mCache;
|
private final IconCache mCache;
|
||||||
|
|
||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
|
private final MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
|
|
||||||
private List<DashboardCategory> mCategories;
|
private List<DashboardCategory> mCategories;
|
||||||
private List<Condition> mConditions;
|
private List<Condition> mConditions;
|
||||||
@@ -85,9 +86,11 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
private Condition mExpandedCondition = null;
|
private Condition mExpandedCondition = null;
|
||||||
private SuggestionParser mSuggestionParser;
|
private SuggestionParser mSuggestionParser;
|
||||||
|
|
||||||
public DashboardAdapter(Context context, SuggestionParser parser, Bundle savedInstanceState,
|
public DashboardAdapter(Context context, SuggestionParser parser,
|
||||||
List<Condition> conditions) {
|
MetricsFeatureProvider metricsFeatureProvider, Bundle savedInstanceState,
|
||||||
|
List<Condition> conditions) {
|
||||||
mContext = context;
|
mContext = context;
|
||||||
|
mMetricsFeatureProvider = metricsFeatureProvider;
|
||||||
mCache = new IconCache(context);
|
mCache = new IconCache(context);
|
||||||
mSuggestionParser = parser;
|
mSuggestionParser = parser;
|
||||||
mConditions = conditions;
|
mConditions = conditions;
|
||||||
@@ -240,7 +243,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
holder.itemView.setOnClickListener(new View.OnClickListener() {
|
holder.itemView.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
MetricsLogger.action(mContext, MetricsEvent.ACTION_SETTINGS_SUGGESTION,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
|
MetricsEvent.ACTION_SETTINGS_SUGGESTION,
|
||||||
DashboardAdapter.getSuggestionIdentifier(mContext, suggestion));
|
DashboardAdapter.getSuggestionIdentifier(mContext, suggestion));
|
||||||
((SettingsActivity) mContext).startSuggestion(suggestion.intent);
|
((SettingsActivity) mContext).startSuggestion(suggestion.intent);
|
||||||
}
|
}
|
||||||
@@ -276,7 +280,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
new MenuItem.OnMenuItemClickListener() {
|
new MenuItem.OnMenuItemClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public boolean onMenuItemClick(MenuItem item) {
|
public boolean onMenuItemClick(MenuItem item) {
|
||||||
MetricsLogger.action(mContext, MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION,
|
mMetricsFeatureProvider.action(
|
||||||
|
mContext, MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION,
|
||||||
DashboardAdapter.getSuggestionIdentifier(mContext, suggestion));
|
DashboardAdapter.getSuggestionIdentifier(mContext, suggestion));
|
||||||
disableSuggestion(suggestion);
|
disableSuggestion(suggestion);
|
||||||
mSuggestions.remove(suggestion);
|
mSuggestions.remove(suggestion);
|
||||||
@@ -379,12 +384,12 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (v.getTag() == mExpandedCondition) {
|
if (v.getTag() == mExpandedCondition) {
|
||||||
MetricsLogger.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_CLICK,
|
mMetricsFeatureProvider.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_CLICK,
|
||||||
mExpandedCondition.getMetricsConstant());
|
mExpandedCondition.getMetricsConstant());
|
||||||
mExpandedCondition.onPrimaryClick();
|
mExpandedCondition.onPrimaryClick();
|
||||||
} else {
|
} else {
|
||||||
mExpandedCondition = (Condition) v.getTag();
|
mExpandedCondition = (Condition) v.getTag();
|
||||||
MetricsLogger.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND,
|
mMetricsFeatureProvider.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND,
|
||||||
mExpandedCondition.getMetricsConstant());
|
mExpandedCondition.getMetricsConstant());
|
||||||
notifyDataSetChanged();
|
notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
@@ -392,12 +397,13 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
|
|
||||||
public void onExpandClick(View v) {
|
public void onExpandClick(View v) {
|
||||||
if (v.getTag() == mExpandedCondition) {
|
if (v.getTag() == mExpandedCondition) {
|
||||||
MetricsLogger.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_COLLAPSE,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
|
MetricsEvent.ACTION_SETTINGS_CONDITION_COLLAPSE,
|
||||||
mExpandedCondition.getMetricsConstant());
|
mExpandedCondition.getMetricsConstant());
|
||||||
mExpandedCondition = null;
|
mExpandedCondition = null;
|
||||||
} else {
|
} else {
|
||||||
mExpandedCondition = (Condition) v.getTag();
|
mExpandedCondition = (Condition) v.getTag();
|
||||||
MetricsLogger.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND,
|
mMetricsFeatureProvider.action(mContext, MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND,
|
||||||
mExpandedCondition.getMetricsConstant());
|
mExpandedCondition.getMetricsConstant());
|
||||||
}
|
}
|
||||||
notifyDataSetChanged();
|
notifyDataSetChanged();
|
||||||
|
@@ -26,16 +26,17 @@ import android.view.LayoutInflater;
|
|||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.android.internal.logging.MetricsLogger;
|
|
||||||
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.core.InstrumentedFragment;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.Settings;
|
import com.android.settings.Settings;
|
||||||
import com.android.settings.SettingsActivity;
|
import com.android.settings.SettingsActivity;
|
||||||
|
import com.android.settings.core.InstrumentedFragment;
|
||||||
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
import com.android.settings.dashboard.conditional.Condition;
|
import com.android.settings.dashboard.conditional.Condition;
|
||||||
import com.android.settings.dashboard.conditional.ConditionAdapterUtils;
|
import com.android.settings.dashboard.conditional.ConditionAdapterUtils;
|
||||||
import com.android.settings.dashboard.conditional.ConditionManager;
|
import com.android.settings.dashboard.conditional.ConditionManager;
|
||||||
import com.android.settings.dashboard.conditional.FocusRecyclerView;
|
import com.android.settings.dashboard.conditional.FocusRecyclerView;
|
||||||
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settingslib.SuggestionParser;
|
import com.android.settingslib.SuggestionParser;
|
||||||
import com.android.settingslib.drawer.DashboardCategory;
|
import com.android.settingslib.drawer.DashboardCategory;
|
||||||
import com.android.settingslib.drawer.SettingsDrawerActivity;
|
import com.android.settingslib.drawer.SettingsDrawerActivity;
|
||||||
@@ -122,7 +123,7 @@ public class DashboardSummary extends InstrumentedFragment
|
|||||||
mSummaryLoader.setListening(true);
|
mSummaryLoader.setListening(true);
|
||||||
for (Condition c : mConditionManager.getConditions()) {
|
for (Condition c : mConditionManager.getConditions()) {
|
||||||
if (c.shouldShow()) {
|
if (c.shouldShow()) {
|
||||||
MetricsLogger.visible(getContext(), c.getMetricsConstant());
|
mMetricsFeatureProvider.visible(getContext(), c.getMetricsConstant());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (DEBUG_TIMING) Log.d(TAG, "onResume took " + (System.currentTimeMillis() - startTime)
|
if (DEBUG_TIMING) Log.d(TAG, "onResume took " + (System.currentTimeMillis() - startTime)
|
||||||
@@ -137,7 +138,7 @@ public class DashboardSummary extends InstrumentedFragment
|
|||||||
mSummaryLoader.setListening(false);
|
mSummaryLoader.setListening(false);
|
||||||
for (Condition c : mConditionManager.getConditions()) {
|
for (Condition c : mConditionManager.getConditions()) {
|
||||||
if (c.shouldShow()) {
|
if (c.shouldShow()) {
|
||||||
MetricsLogger.hidden(getContext(), c.getMetricsConstant());
|
mMetricsFeatureProvider.hidden(getContext(), c.getMetricsConstant());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (mAdapter.getSuggestions() == null) {
|
if (mAdapter.getSuggestions() == null) {
|
||||||
@@ -148,7 +149,7 @@ public class DashboardSummary extends InstrumentedFragment
|
|||||||
String id = DashboardAdapter.getSuggestionIdentifier(getContext(), suggestion);
|
String id = DashboardAdapter.getSuggestionIdentifier(getContext(), suggestion);
|
||||||
if (!mSuggestionsHiddenLogged.contains(id)) {
|
if (!mSuggestionsHiddenLogged.contains(id)) {
|
||||||
mSuggestionsHiddenLogged.add(id);
|
mSuggestionsHiddenLogged.add(id);
|
||||||
MetricsLogger.action(getContext(),
|
mMetricsFeatureProvider.action(getContext(),
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION, id);
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION, id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -200,8 +201,8 @@ public class DashboardSummary extends InstrumentedFragment
|
|||||||
mDashboard.setHasFixedSize(true);
|
mDashboard.setHasFixedSize(true);
|
||||||
mDashboard.addItemDecoration(new DashboardDecorator(getContext()));
|
mDashboard.addItemDecoration(new DashboardDecorator(getContext()));
|
||||||
mDashboard.setListener(this);
|
mDashboard.setListener(this);
|
||||||
mAdapter = new DashboardAdapter(getContext(), mSuggestionParser, bundle,
|
mAdapter = new DashboardAdapter(getContext(), mSuggestionParser, mMetricsFeatureProvider,
|
||||||
mConditionManager.getConditions());
|
bundle, mConditionManager.getConditions());
|
||||||
mDashboard.setAdapter(mAdapter);
|
mDashboard.setAdapter(mAdapter);
|
||||||
mSummaryLoader.setAdapter(mAdapter);
|
mSummaryLoader.setAdapter(mAdapter);
|
||||||
ConditionAdapterUtils.addDismiss(mDashboard);
|
ConditionAdapterUtils.addDismiss(mDashboard);
|
||||||
@@ -246,7 +247,7 @@ public class DashboardSummary extends InstrumentedFragment
|
|||||||
String id = DashboardAdapter.getSuggestionIdentifier(context, suggestion);
|
String id = DashboardAdapter.getSuggestionIdentifier(context, suggestion);
|
||||||
if (!mSuggestionsShownLogged.contains(id)) {
|
if (!mSuggestionsShownLogged.contains(id)) {
|
||||||
mSuggestionsShownLogged.add(id);
|
mSuggestionsShownLogged.add(id);
|
||||||
MetricsLogger.action(context,
|
mMetricsFeatureProvider.action(context,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, id);
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -37,12 +37,11 @@ import android.widget.ListView;
|
|||||||
import android.widget.SearchView;
|
import android.widget.SearchView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import com.android.internal.logging.MetricsLogger;
|
|
||||||
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.core.InstrumentedFragment;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsActivity;
|
import com.android.settings.SettingsActivity;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
|
import com.android.settings.core.InstrumentedFragment;
|
||||||
import com.android.settings.search.Index;
|
import com.android.settings.search.Index;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@@ -85,8 +84,8 @@ public class SearchResultsSummary extends InstrumentedFragment {
|
|||||||
@Override
|
@Override
|
||||||
protected void onPostExecute(Cursor cursor) {
|
protected void onPostExecute(Cursor cursor) {
|
||||||
if (!isCancelled()) {
|
if (!isCancelled()) {
|
||||||
MetricsLogger.action(getContext(), MetricsEvent.ACTION_SEARCH_RESULTS,
|
mMetricsFeatureProvider.action(getContext(),
|
||||||
cursor.getCount());
|
MetricsEvent.ACTION_SEARCH_RESULTS, cursor.getCount());
|
||||||
setResultsCursor(cursor);
|
setResultsCursor(cursor);
|
||||||
setResultsVisibility(cursor.getCount() > 0);
|
setResultsVisibility(cursor.getCount() > 0);
|
||||||
} else if (cursor != null) {
|
} else if (cursor != null) {
|
||||||
|
@@ -36,8 +36,8 @@ import android.view.View;
|
|||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.android.internal.logging.MetricsProto;
|
import com.android.internal.logging.MetricsProto;
|
||||||
import com.android.settings.core.InstrumentedFragment;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.InstrumentedFragment;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settings.overlay.SupportFeatureProvider;
|
import com.android.settings.overlay.SupportFeatureProvider;
|
||||||
|
|
||||||
@@ -89,7 +89,7 @@ public final class SupportFragment extends InstrumentedFragment implements View.
|
|||||||
mSupportFeatureProvider =
|
mSupportFeatureProvider =
|
||||||
FeatureFactory.getFactory(mActivity).getSupportFeatureProvider(mActivity);
|
FeatureFactory.getFactory(mActivity).getSupportFeatureProvider(mActivity);
|
||||||
mSupportItemAdapter = new SupportItemAdapter(mActivity, savedInstanceState,
|
mSupportItemAdapter = new SupportItemAdapter(mActivity, savedInstanceState,
|
||||||
mSupportFeatureProvider, this /* itemClickListener */);
|
mSupportFeatureProvider, mMetricsFeatureProvider, this /* itemClickListener */);
|
||||||
mConnectivityManager =
|
mConnectivityManager =
|
||||||
(ConnectivityManager) mActivity.getSystemService(Context.CONNECTIVITY_SERVICE);
|
(ConnectivityManager) mActivity.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
}
|
}
|
||||||
|
@@ -37,9 +37,9 @@ import android.widget.ImageView;
|
|||||||
import android.widget.Spinner;
|
import android.widget.Spinner;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import com.android.internal.logging.MetricsLogger;
|
|
||||||
import com.android.internal.logging.MetricsProto;
|
import com.android.internal.logging.MetricsProto;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
import com.android.settings.overlay.SupportFeatureProvider;
|
import com.android.settings.overlay.SupportFeatureProvider;
|
||||||
import com.android.settings.support.SupportDisclaimerDialogFragment;
|
import com.android.settings.support.SupportDisclaimerDialogFragment;
|
||||||
import com.android.settings.support.SupportPhone;
|
import com.android.settings.support.SupportPhone;
|
||||||
@@ -69,6 +69,7 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
private final EscalationClickListener mEscalationClickListener;
|
private final EscalationClickListener mEscalationClickListener;
|
||||||
private final SpinnerItemSelectListener mSpinnerItemSelectListener;
|
private final SpinnerItemSelectListener mSpinnerItemSelectListener;
|
||||||
private final SupportFeatureProvider mSupportFeatureProvider;
|
private final SupportFeatureProvider mSupportFeatureProvider;
|
||||||
|
private final MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
private final View.OnClickListener mItemClickListener;
|
private final View.OnClickListener mItemClickListener;
|
||||||
private final List<SupportData> mSupportData;
|
private final List<SupportData> mSupportData;
|
||||||
|
|
||||||
@@ -77,9 +78,12 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
private Account mAccount;
|
private Account mAccount;
|
||||||
|
|
||||||
public SupportItemAdapter(Activity activity, Bundle savedInstanceState,
|
public SupportItemAdapter(Activity activity, Bundle savedInstanceState,
|
||||||
SupportFeatureProvider supportFeatureProvider, View.OnClickListener itemClickListener) {
|
SupportFeatureProvider supportFeatureProvider,
|
||||||
|
MetricsFeatureProvider metricsFeatureProvider,
|
||||||
|
View.OnClickListener itemClickListener) {
|
||||||
mActivity = activity;
|
mActivity = activity;
|
||||||
mSupportFeatureProvider = supportFeatureProvider;
|
mSupportFeatureProvider = supportFeatureProvider;
|
||||||
|
mMetricsFeatureProvider = metricsFeatureProvider;
|
||||||
mItemClickListener = itemClickListener;
|
mItemClickListener = itemClickListener;
|
||||||
mEscalationClickListener = new EscalationClickListener();
|
mEscalationClickListener = new EscalationClickListener();
|
||||||
mSpinnerItemSelectListener = new SpinnerItemSelectListener();
|
mSpinnerItemSelectListener = new SpinnerItemSelectListener();
|
||||||
@@ -141,7 +145,7 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
if (data.intent != null &&
|
if (data.intent != null &&
|
||||||
mActivity.getPackageManager().resolveActivity(data.intent, 0) != null) {
|
mActivity.getPackageManager().resolveActivity(data.intent, 0) != null) {
|
||||||
if (data.metricsEvent >= 0) {
|
if (data.metricsEvent >= 0) {
|
||||||
MetricsLogger.action(mActivity, data.metricsEvent);
|
mMetricsFeatureProvider.action(mActivity, data.metricsEvent);
|
||||||
}
|
}
|
||||||
mActivity.startActivityForResult(data.intent, 0);
|
mActivity.startActivityForResult(data.intent, 0);
|
||||||
}
|
}
|
||||||
@@ -427,7 +431,7 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
if (mAccount == null) {
|
if (mAccount == null) {
|
||||||
switch (v.getId()) {
|
switch (v.getId()) {
|
||||||
case android.R.id.text1:
|
case android.R.id.text1:
|
||||||
MetricsLogger.action(mActivity,
|
mMetricsFeatureProvider.action(mActivity,
|
||||||
MetricsProto.MetricsEvent.ACTION_SUPPORT_SIGN_IN);
|
MetricsProto.MetricsEvent.ACTION_SUPPORT_SIGN_IN);
|
||||||
mActivity.startActivityForResult(
|
mActivity.startActivityForResult(
|
||||||
mSupportFeatureProvider.getAccountLoginIntent(),
|
mSupportFeatureProvider.getAccountLoginIntent(),
|
||||||
@@ -442,12 +446,12 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
} else if (mHasInternet) {
|
} else if (mHasInternet) {
|
||||||
switch (v.getId()) {
|
switch (v.getId()) {
|
||||||
case android.R.id.text1:
|
case android.R.id.text1:
|
||||||
MetricsLogger.action(mActivity,
|
mMetricsFeatureProvider.action(mActivity,
|
||||||
MetricsProto.MetricsEvent.ACTION_SUPPORT_PHONE);
|
MetricsProto.MetricsEvent.ACTION_SUPPORT_PHONE);
|
||||||
tryStartDisclaimerAndSupport(PHONE);
|
tryStartDisclaimerAndSupport(PHONE);
|
||||||
break;
|
break;
|
||||||
case android.R.id.text2:
|
case android.R.id.text2:
|
||||||
MetricsLogger.action(mActivity,
|
mMetricsFeatureProvider.action(mActivity,
|
||||||
MetricsProto.MetricsEvent.ACTION_SUPPORT_CHAT);
|
MetricsProto.MetricsEvent.ACTION_SUPPORT_CHAT);
|
||||||
tryStartDisclaimerAndSupport(CHAT);
|
tryStartDisclaimerAndSupport(CHAT);
|
||||||
break;
|
break;
|
||||||
@@ -463,7 +467,7 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
.queryIntentActivities(intent, 0)
|
.queryIntentActivities(intent, 0)
|
||||||
.isEmpty();
|
.isEmpty();
|
||||||
if (canDial) {
|
if (canDial) {
|
||||||
MetricsLogger.action(mActivity,
|
mMetricsFeatureProvider.action(mActivity,
|
||||||
MetricsProto.MetricsEvent.ACTION_SUPPORT_DAIL_TOLLFREE);
|
MetricsProto.MetricsEvent.ACTION_SUPPORT_DAIL_TOLLFREE);
|
||||||
mActivity.startActivity(intent);
|
mActivity.startActivity(intent);
|
||||||
}
|
}
|
||||||
@@ -475,7 +479,7 @@ public final class SupportItemAdapter extends RecyclerView.Adapter<SupportItemAd
|
|||||||
.getSupportPhones(mSelectedCountry, false /* isTollFree */);
|
.getSupportPhones(mSelectedCountry, false /* isTollFree */);
|
||||||
final SupportPhoneDialogFragment fragment =
|
final SupportPhoneDialogFragment fragment =
|
||||||
SupportPhoneDialogFragment.newInstance(phone);
|
SupportPhoneDialogFragment.newInstance(phone);
|
||||||
MetricsLogger.action(mActivity,
|
mMetricsFeatureProvider.action(mActivity,
|
||||||
MetricsProto.MetricsEvent.ACTION_SUPPORT_VIEW_TRAVEL_ABROAD_DIALOG);
|
MetricsProto.MetricsEvent.ACTION_SUPPORT_VIEW_TRAVEL_ABROAD_DIALOG);
|
||||||
fragment.show(mActivity.getFragmentManager(),
|
fragment.show(mActivity.getFragmentManager(),
|
||||||
SupportPhoneDialogFragment.TAG);
|
SupportPhoneDialogFragment.TAG);
|
||||||
|
@@ -17,11 +17,14 @@
|
|||||||
package com.android.settings.dashboard.conditional;
|
package com.android.settings.dashboard.conditional;
|
||||||
|
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.graphics.drawable.Icon;
|
import android.graphics.drawable.Icon;
|
||||||
import android.os.PersistableBundle;
|
import android.os.PersistableBundle;
|
||||||
import com.android.internal.logging.MetricsLogger;
|
|
||||||
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
||||||
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
import static android.content.pm.PackageManager.DONT_KILL_APP;
|
import static android.content.pm.PackageManager.DONT_KILL_APP;
|
||||||
|
|
||||||
@@ -32,6 +35,7 @@ public abstract class Condition {
|
|||||||
private static final String KEY_LAST_STATE = "last_state";
|
private static final String KEY_LAST_STATE = "last_state";
|
||||||
|
|
||||||
protected final ConditionManager mManager;
|
protected final ConditionManager mManager;
|
||||||
|
protected final MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
|
|
||||||
private boolean mIsSilenced;
|
private boolean mIsSilenced;
|
||||||
private boolean mIsActive;
|
private boolean mIsActive;
|
||||||
@@ -39,7 +43,12 @@ public abstract class Condition {
|
|||||||
|
|
||||||
// All conditions must live in this package.
|
// All conditions must live in this package.
|
||||||
Condition(ConditionManager manager) {
|
Condition(ConditionManager manager) {
|
||||||
|
this(manager, FeatureFactory.getFactory(manager.getContext()).getMetricsFeatureProvider());
|
||||||
|
}
|
||||||
|
|
||||||
|
Condition(ConditionManager manager, MetricsFeatureProvider metricsFeatureProvider) {
|
||||||
mManager = manager;
|
mManager = manager;
|
||||||
|
mMetricsFeatureProvider = metricsFeatureProvider;
|
||||||
Class<?> receiverClass = getReceiverClass();
|
Class<?> receiverClass = getReceiverClass();
|
||||||
if (receiverClass != null && shouldAlwaysListenToBroadcast()) {
|
if (receiverClass != null && shouldAlwaysListenToBroadcast()) {
|
||||||
PackageManager pm = mManager.getContext().getPackageManager();
|
PackageManager pm = mManager.getContext().getPackageManager();
|
||||||
@@ -93,8 +102,9 @@ public abstract class Condition {
|
|||||||
public void silence() {
|
public void silence() {
|
||||||
if (!mIsSilenced) {
|
if (!mIsSilenced) {
|
||||||
mIsSilenced = true;
|
mIsSilenced = true;
|
||||||
MetricsLogger.action(mManager.getContext(),
|
Context context = mManager.getContext();
|
||||||
MetricsEvent.ACTION_SETTINGS_CONDITION_DISMISS, getMetricsConstant());
|
mMetricsFeatureProvider.action(context, MetricsEvent.ACTION_SETTINGS_CONDITION_DISMISS,
|
||||||
|
getMetricsConstant());
|
||||||
onSilenceChanged(mIsSilenced);
|
onSilenceChanged(mIsSilenced);
|
||||||
notifyChanged();
|
notifyChanged();
|
||||||
}
|
}
|
||||||
|
@@ -18,6 +18,7 @@ package com.android.settings.dashboard.conditional;
|
|||||||
import android.animation.Animator;
|
import android.animation.Animator;
|
||||||
import android.animation.AnimatorListenerAdapter;
|
import android.animation.AnimatorListenerAdapter;
|
||||||
import android.animation.ObjectAnimator;
|
import android.animation.ObjectAnimator;
|
||||||
|
import android.content.Context;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.support.v7.widget.helper.ItemTouchHelper;
|
import android.support.v7.widget.helper.ItemTouchHelper;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
@@ -25,10 +26,11 @@ import android.view.View.OnLayoutChangeListener;
|
|||||||
import android.view.ViewGroup.LayoutParams;
|
import android.view.ViewGroup.LayoutParams;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import com.android.internal.logging.MetricsLogger;
|
|
||||||
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.dashboard.DashboardAdapter;
|
import com.android.settings.dashboard.DashboardAdapter;
|
||||||
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
public class ConditionAdapterUtils {
|
public class ConditionAdapterUtils {
|
||||||
|
|
||||||
@@ -94,9 +96,10 @@ public class ConditionAdapterUtils {
|
|||||||
button.setOnClickListener(new View.OnClickListener() {
|
button.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
MetricsLogger.action(v.getContext(),
|
Context context = v.getContext();
|
||||||
MetricsEvent.ACTION_SETTINGS_CONDITION_BUTTON,
|
FeatureFactory.getFactory(context).getMetricsFeatureProvider()
|
||||||
condition.getMetricsConstant());
|
.action(context, MetricsEvent.ACTION_SETTINGS_CONDITION_BUTTON,
|
||||||
|
condition.getMetricsConstant());
|
||||||
condition.onActionClick(index);
|
condition.onActionClick(index);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@@ -0,0 +1,27 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2016 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License
|
||||||
|
*/
|
||||||
|
package com.android.internal.app;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fake controller to make robolectric test compile. Should be removed when Robolectric supports
|
||||||
|
* API 25.
|
||||||
|
*/
|
||||||
|
public class NightDisplayController {
|
||||||
|
|
||||||
|
public interface Callback {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,120 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2016 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License
|
||||||
|
*/
|
||||||
|
package com.android.settings.dashboard.conditional;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.graphics.drawable.Icon;
|
||||||
|
|
||||||
|
import com.android.internal.logging.MetricsProto;
|
||||||
|
import com.android.settings.TestConfig;
|
||||||
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.Matchers.any;
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
||||||
|
public class ConditionTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private ConditionManager mConditionManager;
|
||||||
|
@Mock
|
||||||
|
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
|
|
||||||
|
private TestCondition mCondition;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mCondition = new TestCondition(mConditionManager, mMetricsFeatureProvider);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void initialize_shouldNotBeSilenced() {
|
||||||
|
assertThat(mCondition.isSilenced()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void silence_shouldNotifyDataChangeAndLog() {
|
||||||
|
mCondition.silence();
|
||||||
|
|
||||||
|
assertThat(mCondition.isSilenced()).isTrue();
|
||||||
|
verify(mConditionManager).notifyChanged(mCondition);
|
||||||
|
verify(mMetricsFeatureProvider).action(any(Context.class),
|
||||||
|
eq(MetricsProto.MetricsEvent.ACTION_SETTINGS_CONDITION_DISMISS),
|
||||||
|
eq(TestCondition.TEST_METRIC_CONSTANT));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final class TestCondition extends Condition {
|
||||||
|
|
||||||
|
private static final int TEST_METRIC_CONSTANT = 1234;
|
||||||
|
|
||||||
|
TestCondition(ConditionManager manager,
|
||||||
|
MetricsFeatureProvider metricsFeatureProvider) {
|
||||||
|
super(manager, metricsFeatureProvider);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void refreshState() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMetricsConstant() {
|
||||||
|
return TEST_METRIC_CONSTANT;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Icon getIcon() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CharSequence getTitle() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CharSequence getSummary() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CharSequence[] getActions() {
|
||||||
|
return new CharSequence[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPrimaryClick() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onActionClick(int index) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user