Clean up settings_entity_header layout.

update layout view IDs, and controller variable names to be more
generic.

Fix: 36734470
Bug: 37669238
Test: make RunSettingsRoboTests
Change-Id: Ib80827ae3eae6d01a600068b4a8a44b239c32511
This commit is contained in:
Fan Zhang
2017-05-17 17:22:09 -07:00
parent dd6483461f
commit f5bd885a1d
17 changed files with 292 additions and 305 deletions

View File

@@ -15,102 +15,96 @@
limitations under the License. limitations under the License.
--> -->
<LinearLayout <!-- Entity header -->
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android" xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/entity_header"
style="@style/EntityHeader"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:orientation="vertical"> android:paddingStart="?android:attr/listPreferredItemPaddingStart"
android:paddingEnd="0dp"
android:paddingTop="24dp"
android:paddingBottom="24dp">
<!-- App snippet with buttons --> <ImageView
<RelativeLayout android:id="@+id/entity_header_icon"
android:id="@+id/app_snippet" android:layout_width="56dp"
style="@style/EntityHeader" android:layout_height="56dp"
android:scaleType="fitXY"
android:layout_gravity="center_horizontal"
android:antialias="true" />
<LinearLayout
android:id="@+id/entity_header_links"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_alignParentEnd="true"
android:orientation="vertical">
<ImageButton
android:id="@android:id/button1"
style="?android:attr/actionOverflowButtonStyle"
android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="0dp"
android:minWidth="@dimen/min_tap_target_size"
android:src="@drawable/ic_settings_24dp"
android:tint="?android:attr/colorAccent" />
<ImageButton
android:id="@android:id/button2"
style="?android:attr/actionOverflowButtonStyle"
android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="0dp"
android:minWidth="@dimen/min_tap_target_size"
android:src="@null"
android:tint="?android:attr/colorAccent" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:paddingStart="?android:attr/listPreferredItemPaddingStart" android:layout_toEndOf="@id/entity_header_icon"
android:paddingEnd="0dp" android:layout_toStartOf="@id/entity_header_links"
android:paddingTop="24dp" android:paddingStart="24dp"
android:paddingBottom="24dp"> android:paddingEnd="24dp"
<ImageView android:orientation="vertical">
android:id="@+id/app_detail_icon"
android:layout_width="56dp"
android:layout_height="56dp"
android:scaleType="fitXY"
android:layout_gravity="center_horizontal"
android:antialias="true"/>
<LinearLayout <TextView
android:id="@+id/app_detail_links" android:id="@+id/entity_header_title"
android:layout_width="wrap_content" style="@style/TextAppearance.EntityHeaderTitle"
android:layout_height="match_parent"
android:layout_alignParentEnd="true"
android:orientation="vertical">
<ImageButton
android:id="@+id/right_button"
style="?android:attr/actionOverflowButtonStyle"
android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="0dp"
android:minWidth="@dimen/min_tap_target_size"
android:src="@drawable/ic_settings_24dp"
android:tint="?android:attr/colorAccent"/>
<ImageButton
android:id="@+id/left_button"
style="?android:attr/actionOverflowButtonStyle"
android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="0dp"
android:minWidth="@dimen/min_tap_target_size"
android:src="@null"
android:tint="?android:attr/colorAccent"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_toEndOf="@id/app_detail_icon" android:singleLine="false"
android:layout_toStartOf="@id/app_detail_links" android:ellipsize="marquee"
android:paddingStart="24dp" android:gravity="start"
android:paddingEnd="24dp" android:textDirection="locale"
android:orientation="vertical"> android:paddingTop="8dp" />
<TextView <TextView
android:id="@+id/app_detail_title" android:id="@+id/install_type"
style="@style/TextAppearance.EntityHeaderTitle" android:visibility="gone"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:singleLine="false" android:gravity="start"
android:ellipsize="marquee" android:singleLine="true"
android:gravity="start" android:ellipsize="marquee"
android:textDirection="locale" android:textAppearance="@android:style/TextAppearance.Material.Body1"
android:paddingTop="8dp"/> android:textColor="?android:attr/textColorSecondary" />
<TextView <TextView
android:id="@+id/install_type" android:id="@+id/entity_header_summary"
android:visibility="gone" android:layout_width="match_parent"
android:layout_width="match_parent" android:layout_height="wrap_content"
android:layout_height="wrap_content" android:gravity="start"
android:gravity="start" android:singleLine="true"
android:singleLine="true" android:ellipsize="marquee"
android:ellipsize="marquee" android:textAppearance="@android:style/TextAppearance.Material.Body1"
android:textAppearance="@android:style/TextAppearance.Material.Body1" android:textColor="?android:attr/textColorSecondary" />
android:textColor="?android:attr/textColorSecondary"/>
<TextView </LinearLayout>
android:id="@+id/app_detail_summary"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="start"
android:singleLine="true"
android:ellipsize="marquee"
android:textAppearance="@android:style/TextAppearance.Material.Body1"
android:textColor="?android:attr/textColorSecondary"/>
</LinearLayout> </RelativeLayout>
</RelativeLayout>
</LinearLayout>

View File

@@ -412,12 +412,12 @@
android:entries="@array/app_process_limit_entries" android:entries="@array/app_process_limit_entries"
android:entryValues="@array/app_process_limit_values" /> android:entryValues="@array/app_process_limit_values" />
<!-- hiding for now.
<Preference <Preference
android:key="background_check" android:key="background_check"
android:fragment="com.android.settings.applications.BackgroundCheckSummary" android:fragment="com.android.settings.applications.BackgroundCheckSummary"
android:title="@string/background_check_pref" /> android:title="@string/background_check_pref" />
-->
<SwitchPreference <SwitchPreference
android:key="show_all_anrs" android:key="show_all_anrs"

View File

@@ -16,8 +16,6 @@
package com.android.settings.applications; package com.android.settings.applications;
import static com.android.settings.applications.AppHeaderController.ActionType;
import android.app.Activity; import android.app.Activity;
import android.os.Bundle; import android.os.Bundle;
import android.support.v7.preference.Preference; import android.support.v7.preference.Preference;
@@ -27,6 +25,8 @@ import android.util.Log;
import com.android.settings.overlay.FeatureFactory; import com.android.settings.overlay.FeatureFactory;
import com.android.settingslib.applications.AppUtils; import com.android.settingslib.applications.AppUtils;
import static com.android.settings.applications.EntityHeaderController.ActionType;
public abstract class AppInfoWithHeader extends AppInfoBase { public abstract class AppInfoWithHeader extends AppInfoBase {
private boolean mCreated; private boolean mCreated;

View File

@@ -28,6 +28,7 @@ import android.content.pm.PermissionInfo;
import android.content.res.Resources; import android.content.res.Resources;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.os.Bundle; import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log; import android.util.Log;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
@@ -64,7 +65,7 @@ public class AppOpsDetails extends InstrumentedPreferenceFragment {
final View appSnippet = mRootView.findViewById(R.id.app_snippet); final View appSnippet = mRootView.findViewById(R.id.app_snippet);
CharSequence label = mPm.getApplicationLabel(pkgInfo.applicationInfo); CharSequence label = mPm.getApplicationLabel(pkgInfo.applicationInfo);
Drawable icon = mPm.getApplicationIcon(pkgInfo.applicationInfo); Drawable icon = mPm.getApplicationIcon(pkgInfo.applicationInfo);
InstalledAppDetails.setupAppSnippet(appSnippet, label, icon, setupAppSnippet(appSnippet, label, icon,
pkgInfo != null ? pkgInfo.versionName : null); pkgInfo != null ? pkgInfo.versionName : null);
} }
@@ -191,4 +192,30 @@ public class AppOpsDetails extends InstrumentedPreferenceFragment {
setIntentAndFinish(true, true); setIntentAndFinish(true, true);
} }
} }
/**
* @deprecated app info pages should use {@link EntityHeaderController} to show the app header.
*/
void setupAppSnippet(View appSnippet, CharSequence label, Drawable icon,
CharSequence versionName) {
LayoutInflater.from(appSnippet.getContext()).inflate(R.layout.widget_text_views,
appSnippet.findViewById(android.R.id.widget_frame));
ImageView iconView = appSnippet.findViewById(android.R.id.icon);
iconView.setImageDrawable(icon);
// Set application name.
TextView labelView = appSnippet.findViewById(android.R.id.title);
labelView.setText(label);
// Version number of application
TextView appVersion = appSnippet.findViewById(R.id.widget_text1);
if (!TextUtils.isEmpty(versionName)) {
appVersion.setSelected(true);
appVersion.setVisibility(View.VISIBLE);
appVersion.setText(appSnippet.getContext().getString(R.string.version_text,
String.valueOf(versionName)));
} else {
appVersion.setVisibility(View.INVISIBLE);
}
}
} }

View File

@@ -28,14 +28,13 @@ import java.util.List;
public interface ApplicationFeatureProvider { public interface ApplicationFeatureProvider {
/** /**
* Returns a new {@link AppHeaderController} instance to customize app header. * Returns a new {@link EntityHeaderController} instance to customize app header.
*/ */
AppHeaderController newAppHeaderController(Fragment fragment, View appHeader); EntityHeaderController newAppHeaderController(Fragment fragment, View appHeader);
/** /**
* * Returns a new {@link InstantAppButtonsController} instance for showing buttons
* Returns a new {@link InstantAppButtonsController} instance for showing buttons * only relevant to instant apps.
* only relevant to instant apps.
*/ */
InstantAppButtonsController newInstantAppButtonsController(Fragment fragment, InstantAppButtonsController newInstantAppButtonsController(Fragment fragment,
View view, InstantAppButtonsController.ShowDialogDelegate showDialogDelegate); View view, InstantAppButtonsController.ShowDialogDelegate showDialogDelegate);
@@ -44,7 +43,7 @@ public interface ApplicationFeatureProvider {
* Calculates the total number of apps installed on the device via policy in the current user * Calculates the total number of apps installed on the device via policy in the current user
* and all its managed profiles. * and all its managed profiles.
* *
* @param async Whether to count asynchronously in a background thread * @param async Whether to count asynchronously in a background thread
* @param callback The callback to invoke with the result * @param callback The callback to invoke with the result
*/ */
void calculateNumberOfPolicyInstalledApps(boolean async, NumberOfAppsCallback callback); void calculateNumberOfPolicyInstalledApps(boolean async, NumberOfAppsCallback callback);
@@ -61,10 +60,10 @@ public interface ApplicationFeatureProvider {
* Asynchronously calculates the total number of apps installed in the current user and all its * Asynchronously calculates the total number of apps installed in the current user and all its
* managed profiles that have been granted one or more of the given permissions by the admin. * managed profiles that have been granted one or more of the given permissions by the admin.
* *
* @param permissions Only consider apps that have been granted one or more of these permissions * @param permissions Only consider apps that have been granted one or more of these
* by the admin, either at run-time or install-time * permissions by the admin, either at run-time or install-time
* @param async Whether to count asynchronously in a background thread * @param async Whether to count asynchronously in a background thread
* @param callback The callback to invoke with the result * @param callback The callback to invoke with the result
*/ */
void calculateNumberOfAppsWithAdminGrantedPermissions(String[] permissions, boolean async, void calculateNumberOfAppsWithAdminGrantedPermissions(String[] permissions, boolean async,
NumberOfAppsCallback callback); NumberOfAppsCallback callback);
@@ -73,9 +72,9 @@ public interface ApplicationFeatureProvider {
* Asynchronously builds the list of apps installed in the current user and all its * Asynchronously builds the list of apps installed in the current user and all its
* managed profiles that have been granted one or more of the given permissions by the admin. * managed profiles that have been granted one or more of the given permissions by the admin.
* *
* @param permissions Only consider apps that have been granted one or more of these permissions * @param permissions Only consider apps that have been granted one or more of these
* by the admin, either at run-time or install-time * permissions by the admin, either at run-time or install-time
* @param callback The callback to invoke with the result * @param callback The callback to invoke with the result
*/ */
void listAppsWithAdminGrantedPermissions(String[] permissions, ListOfAppsCallback callback); void listAppsWithAdminGrantedPermissions(String[] permissions, ListOfAppsCallback callback);
@@ -85,10 +84,9 @@ public interface ApplicationFeatureProvider {
* given intent (e.g. open browser), even if the user has other apps installed that would also * given intent (e.g. open browser), even if the user has other apps installed that would also
* be able to handle the intent. * be able to handle the intent.
* *
* @param userId ID of the user for which to find persistent preferred activities * @param userId ID of the user for which to find persistent preferred activities
* @param intent The intents for which to find persistent preferred activities * @param intents The intents for which to find persistent preferred activities
* * @return the persistent preferred activities for the given intents, ordered first by user id,
* @return the persistent preferred activites for the given intents, ordered first by user id,
* then by package name * then by package name
*/ */
List<UserAppInfo> findPersistentPreferredActivities(@UserIdInt int userId, Intent[] intents); List<UserAppInfo> findPersistentPreferredActivities(@UserIdInt int userId, Intent[] intents);

View File

@@ -24,7 +24,6 @@ import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo; import android.content.pm.ResolveInfo;
import android.content.pm.UserInfo; import android.content.pm.UserInfo;
import android.os.RemoteException; import android.os.RemoteException;
import android.os.UserHandle;
import android.os.UserManager; import android.os.UserManager;
import android.util.ArraySet; import android.util.ArraySet;
import android.view.View; import android.view.View;
@@ -54,8 +53,8 @@ public class ApplicationFeatureProviderImpl implements ApplicationFeatureProvide
} }
@Override @Override
public AppHeaderController newAppHeaderController(Fragment fragment, View appHeader) { public EntityHeaderController newAppHeaderController(Fragment fragment, View appHeader) {
return new AppHeaderController(mContext, fragment, appHeader); return new EntityHeaderController(mContext, fragment, appHeader);
} }
@Override @Override

View File

@@ -47,7 +47,7 @@ import com.android.settingslib.applications.ApplicationsState;
import java.lang.annotation.Retention; import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy; import java.lang.annotation.RetentionPolicy;
public class AppHeaderController { public class EntityHeaderController {
@IntDef({ActionType.ACTION_NONE, @IntDef({ActionType.ACTION_NONE,
ActionType.ACTION_APP_INFO, ActionType.ACTION_APP_INFO,
@@ -68,7 +68,7 @@ public class AppHeaderController {
private final Context mContext; private final Context mContext;
private final Fragment mFragment; private final Fragment mFragment;
private final int mMetricsCategory; private final int mMetricsCategory;
private final View mAppHeader; private final View mHeader;
private Drawable mIcon; private Drawable mIcon;
private CharSequence mLabel; private CharSequence mLabel;
@@ -78,84 +78,84 @@ public class AppHeaderController {
@UserIdInt @UserIdInt
private int mUid = UserHandle.USER_NULL; private int mUid = UserHandle.USER_NULL;
@ActionType @ActionType
private int mLeftAction; private int mAction1;
@ActionType @ActionType
private int mRightAction; private int mAction2;
private boolean mIsInstantApp; private boolean mIsInstantApp;
public AppHeaderController(Context context, Fragment fragment, View appHeader) { public EntityHeaderController(Context context, Fragment fragment, View header) {
mContext = context; mContext = context;
mFragment = fragment; mFragment = fragment;
mMetricsCategory = FeatureFactory.getFactory(context).getMetricsFeatureProvider() mMetricsCategory = FeatureFactory.getFactory(context).getMetricsFeatureProvider()
.getMetricsCategory(fragment); .getMetricsCategory(fragment);
if (appHeader != null) { if (header != null) {
mAppHeader = appHeader; mHeader = header;
} else { } else {
mAppHeader = LayoutInflater.from(fragment.getContext()) mHeader = LayoutInflater.from(fragment.getContext())
.inflate(R.layout.settings_entity_header, null /* root */); .inflate(R.layout.settings_entity_header, null /* root */);
} }
} }
public AppHeaderController setIcon(Drawable icon) { public EntityHeaderController setIcon(Drawable icon) {
if (icon != null) { if (icon != null) {
mIcon = icon.getConstantState().newDrawable(mContext.getResources()); mIcon = icon.getConstantState().newDrawable(mContext.getResources());
} }
return this; return this;
} }
public AppHeaderController setIcon(ApplicationsState.AppEntry appEntry) { public EntityHeaderController setIcon(ApplicationsState.AppEntry appEntry) {
if (appEntry.icon != null) { if (appEntry.icon != null) {
mIcon = appEntry.icon.getConstantState().newDrawable(mContext.getResources()); mIcon = appEntry.icon.getConstantState().newDrawable(mContext.getResources());
} }
return this; return this;
} }
public AppHeaderController setLabel(CharSequence label) { public EntityHeaderController setLabel(CharSequence label) {
mLabel = label; mLabel = label;
return this; return this;
} }
public AppHeaderController setLabel(ApplicationsState.AppEntry appEntry) { public EntityHeaderController setLabel(ApplicationsState.AppEntry appEntry) {
mLabel = appEntry.label; mLabel = appEntry.label;
return this; return this;
} }
public AppHeaderController setSummary(CharSequence summary) { public EntityHeaderController setSummary(CharSequence summary) {
mSummary = summary; mSummary = summary;
return this; return this;
} }
public AppHeaderController setSummary(PackageInfo packageInfo) { public EntityHeaderController setSummary(PackageInfo packageInfo) {
if (packageInfo != null) { if (packageInfo != null) {
mSummary = packageInfo.versionName; mSummary = packageInfo.versionName;
} }
return this; return this;
} }
public AppHeaderController setButtonActions(@ActionType int leftAction, public EntityHeaderController setButtonActions(@ActionType int action1,
@ActionType int rightAction) { @ActionType int action2) {
mLeftAction = leftAction; mAction1 = action1;
mRightAction = rightAction; mAction2 = action2;
return this; return this;
} }
public AppHeaderController setPackageName(String packageName) { public EntityHeaderController setPackageName(String packageName) {
mPackageName = packageName; mPackageName = packageName;
return this; return this;
} }
public AppHeaderController setUid(int uid) { public EntityHeaderController setUid(int uid) {
mUid = uid; mUid = uid;
return this; return this;
} }
public AppHeaderController setAppNotifPrefIntent(Intent appNotifPrefIntent) { public EntityHeaderController setAppNotifPrefIntent(Intent appNotifPrefIntent) {
mAppNotifPrefIntent = appNotifPrefIntent; mAppNotifPrefIntent = appNotifPrefIntent;
return this; return this;
} }
public AppHeaderController setIsInstantApp(boolean isInstantApp) { public EntityHeaderController setIsInstantApp(boolean isInstantApp) {
this.mIsInstantApp = isInstantApp; this.mIsInstantApp = isInstantApp;
return this; return this;
} }
@@ -172,41 +172,41 @@ public class AppHeaderController {
} }
/** /**
* Done mutating appheader, rebinds everything (optionally skip rebinding buttons). * Done mutating entity header, rebinds everything (optionally skip rebinding buttons).
*/ */
public View done(Activity activity, boolean rebindActions) { public View done(Activity activity, boolean rebindActions) {
styleActionBar(activity); styleActionBar(activity);
ImageView iconView = mAppHeader.findViewById(R.id.app_detail_icon); ImageView iconView = mHeader.findViewById(R.id.entity_header_icon);
if (iconView != null) { if (iconView != null) {
iconView.setImageDrawable(mIcon); iconView.setImageDrawable(mIcon);
} }
setText(R.id.app_detail_title, mLabel); setText(R.id.entity_header_title, mLabel);
setText(R.id.app_detail_summary, mSummary); setText(R.id.entity_header_summary, mSummary);
if (mIsInstantApp) { if (mIsInstantApp) {
setText(R.id.install_type, setText(R.id.install_type,
mAppHeader.getResources().getString(R.string.install_type_instant)); mHeader.getResources().getString(R.string.install_type_instant));
} }
if (rebindActions) { if (rebindActions) {
bindAppHeaderButtons(); bindHeaderButtons();
} }
return mAppHeader; return mHeader;
} }
/** /**
* Only binds app header with button actions. * Only binds app header with button actions.
*/ */
public AppHeaderController bindAppHeaderButtons() { public EntityHeaderController bindHeaderButtons() {
ImageButton leftButton = mAppHeader.findViewById(R.id.left_button); ImageButton button1 = mHeader.findViewById(android.R.id.button1);
ImageButton rightButton = mAppHeader.findViewById(R.id.right_button); ImageButton button2 = mHeader.findViewById(android.R.id.button2);
bindButton(leftButton, mLeftAction); bindButton(button1, mAction1);
bindButton(rightButton, mRightAction); bindButton(button2, mAction2);
return this; return this;
} }
public AppHeaderController styleActionBar(Activity activity) { public EntityHeaderController styleActionBar(Activity activity) {
if (activity == null) { if (activity == null) {
Log.w(TAG, "No activity, cannot style actionbar."); Log.w(TAG, "No activity, cannot style actionbar.");
return this; return this;
@@ -224,7 +224,7 @@ public class AppHeaderController {
} }
/** /**
* Done mutating appheader, rebinds everything. * Done mutating entity header, rebinds everything.
*/ */
@VisibleForTesting @VisibleForTesting
View done(Activity activity) { View done(Activity activity) {
@@ -289,7 +289,7 @@ public class AppHeaderController {
} }
private void setText(@IdRes int id, CharSequence text) { private void setText(@IdRes int id, CharSequence text) {
TextView textView = mAppHeader.findViewById(id); TextView textView = mHeader.findViewById(id);
if (textView != null) { if (textView != null) {
textView.setText(text); textView.setText(text);
textView.setVisibility(TextUtils.isEmpty(text) ? View.GONE : View.VISIBLE); textView.setVisibility(TextUtils.isEmpty(text) ? View.GONE : View.VISIBLE);

View File

@@ -37,7 +37,6 @@ import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.ResolveInfo; import android.content.pm.ResolveInfo;
import android.content.pm.UserInfo; import android.content.pm.UserInfo;
import android.content.res.Resources; import android.content.res.Resources;
import android.graphics.drawable.Drawable;
import android.icu.text.ListFormatter; import android.icu.text.ListFormatter;
import android.net.INetworkStatsService; import android.net.INetworkStatsService;
import android.net.INetworkStatsSession; import android.net.INetworkStatsSession;
@@ -60,16 +59,12 @@ import android.text.TextUtils;
import android.text.format.DateUtils; import android.text.format.DateUtils;
import android.text.format.Formatter; import android.text.format.Formatter;
import android.util.Log; import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu; import android.view.Menu;
import android.view.MenuInflater; import android.view.MenuInflater;
import android.view.MenuItem; import android.view.MenuItem;
import android.view.View; import android.view.View;
import android.view.ViewGroup;
import android.webkit.IWebViewUpdateService; import android.webkit.IWebViewUpdateService;
import android.widget.Button; import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import com.android.internal.logging.nano.MetricsProto.MetricsEvent; import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
import com.android.internal.os.BatterySipper; import com.android.internal.os.BatterySipper;
@@ -413,12 +408,12 @@ public class InstalledAppDetails extends AppInfoBase
mActionButtons = (LayoutPreference) findPreference(KEY_ACTION_BUTTONS); mActionButtons = (LayoutPreference) findPreference(KEY_ACTION_BUTTONS);
FeatureFactory.getFactory(activity) FeatureFactory.getFactory(activity)
.getApplicationFeatureProvider(activity) .getApplicationFeatureProvider(activity)
.newAppHeaderController(this, mHeader.findViewById(R.id.app_snippet)) .newAppHeaderController(this, mHeader.findViewById(R.id.entity_header))
.setPackageName(mPackageName) .setPackageName(mPackageName)
.setButtonActions(AppHeaderController.ActionType.ACTION_APP_PREFERENCE, .setButtonActions(EntityHeaderController.ActionType.ACTION_APP_PREFERENCE,
AppHeaderController.ActionType.ACTION_NONE) EntityHeaderController.ActionType.ACTION_NONE)
.styleActionBar(activity) .styleActionBar(activity)
.bindAppHeaderButtons(); .bindHeaderButtons();
prepareUninstallAndStop(); prepareUninstallAndStop();
mNotificationPreference = findPreference(KEY_NOTIFICATION); mNotificationPreference = findPreference(KEY_NOTIFICATION);
@@ -584,7 +579,7 @@ public class InstalledAppDetails extends AppInfoBase
// Utility method to set application label and icon. // Utility method to set application label and icon.
private void setAppLabelAndIcon(PackageInfo pkgInfo) { private void setAppLabelAndIcon(PackageInfo pkgInfo) {
final View appSnippet = mHeader.findViewById(R.id.app_snippet); final View appSnippet = mHeader.findViewById(R.id.entity_header);
mState.ensureIcon(mAppEntry); mState.ensureIcon(mAppEntry);
final Activity activity = getActivity(); final Activity activity = getActivity();
final boolean isInstantApp = AppUtils.isInstant(mPackageInfo.applicationInfo); final boolean isInstantApp = AppUtils.isInstant(mPackageInfo.applicationInfo);
@@ -1245,32 +1240,6 @@ public class InstalledAppDetails extends AppInfoBase
} }
} }
/**
* @deprecated app info pages should use {@link AppHeaderController} to show the app header.
*/
public static void setupAppSnippet(View appSnippet, CharSequence label, Drawable icon,
CharSequence versionName) {
LayoutInflater.from(appSnippet.getContext()).inflate(R.layout.widget_text_views,
(ViewGroup) appSnippet.findViewById(android.R.id.widget_frame));
ImageView iconView = (ImageView) appSnippet.findViewById(R.id.app_detail_icon);
iconView.setImageDrawable(icon);
// Set application name.
TextView labelView = (TextView) appSnippet.findViewById(R.id.app_detail_title);
labelView.setText(label);
// Version number of application
TextView appVersion = (TextView) appSnippet.findViewById(R.id.widget_text1);
if (!TextUtils.isEmpty(versionName)) {
appVersion.setSelected(true);
appVersion.setVisibility(View.VISIBLE);
appVersion.setText(appSnippet.getContext().getString(R.string.version_text,
String.valueOf(versionName)));
} else {
appVersion.setVisibility(View.INVISIBLE);
}
}
public static NetworkTemplate getTemplate(Context context) { public static NetworkTemplate getTemplate(Context context) {
if (DataUsageList.hasReadyMobileRadio(context)) { if (DataUsageList.hasReadyMobileRadio(context)) {
return NetworkTemplate.buildTemplateMobileWildcard(); return NetworkTemplate.buildTemplateMobileWildcard();

View File

@@ -16,7 +16,7 @@
package com.android.settings.applications; package com.android.settings.applications;
import static com.android.settings.applications.AppHeaderController.ActionType; import static com.android.settings.applications.EntityHeaderController.ActionType;
import android.app.Activity; import android.app.Activity;
import android.app.ActivityManager; import android.app.ActivityManager;

View File

@@ -41,7 +41,7 @@ import android.widget.AdapterView;
import com.android.internal.logging.nano.MetricsProto.MetricsEvent; import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.applications.AppHeaderController; import com.android.settings.applications.EntityHeaderController;
import com.android.settings.applications.AppInfoBase; import com.android.settings.applications.AppInfoBase;
import com.android.settings.overlay.FeatureFactory; import com.android.settings.overlay.FeatureFactory;
import com.android.settingslib.AppItem; import com.android.settingslib.AppItem;
@@ -330,9 +330,9 @@ public class AppDataUsage extends DataUsageBase implements Preference.OnPreferen
.getApplicationFeatureProvider(activity) .getApplicationFeatureProvider(activity)
.newAppHeaderController(this, null /* appHeader */) .newAppHeaderController(this, null /* appHeader */)
.setButtonActions(showInfoButton .setButtonActions(showInfoButton
? AppHeaderController.ActionType.ACTION_APP_INFO ? EntityHeaderController.ActionType.ACTION_APP_INFO
: AppHeaderController.ActionType.ACTION_NONE, : EntityHeaderController.ActionType.ACTION_NONE,
AppHeaderController.ActionType.ACTION_NONE) EntityHeaderController.ActionType.ACTION_NONE)
.setIcon(mIcon) .setIcon(mIcon)
.setLabel(mLabel) .setLabel(mLabel)
.setPackageName(pkg) .setPackageName(pkg)

View File

@@ -37,7 +37,7 @@ 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.Utils; import com.android.settings.Utils;
import com.android.settings.applications.AppHeaderController; import com.android.settings.applications.EntityHeaderController;
import com.android.settings.applications.LayoutPreference; import com.android.settings.applications.LayoutPreference;
import com.android.settings.core.PreferenceController; import com.android.settings.core.PreferenceController;
import com.android.settings.dashboard.DashboardFragment; import com.android.settings.dashboard.DashboardFragment;
@@ -180,14 +180,14 @@ public class AdvancedPowerUsageDetail extends DashboardFragment implements
@VisibleForTesting @VisibleForTesting
void initHeader() { void initHeader() {
final View appSnippet = mHeaderPreference.findViewById(R.id.app_snippet); final View appSnippet = mHeaderPreference.findViewById(R.id.entity_header);
final Activity context = getActivity(); final Activity context = getActivity();
final Bundle bundle = getArguments(); final Bundle bundle = getArguments();
AppHeaderController controller = FeatureFactory.getFactory(context) EntityHeaderController controller = FeatureFactory.getFactory(context)
.getApplicationFeatureProvider(context) .getApplicationFeatureProvider(context)
.newAppHeaderController(this, appSnippet) .newAppHeaderController(this, appSnippet)
.setButtonActions(AppHeaderController.ActionType.ACTION_NONE, .setButtonActions(EntityHeaderController.ActionType.ACTION_NONE,
AppHeaderController.ActionType.ACTION_NONE); EntityHeaderController.ActionType.ACTION_NONE);
if (mAppEntry == null) { if (mAppEntry == null) {
controller.setLabel(bundle.getString(EXTRA_LABEL)); controller.setLabel(bundle.getString(EXTRA_LABEL));

View File

@@ -16,10 +16,6 @@
package com.android.settings.notification; package com.android.settings.notification;
import static android.app.NotificationManager.IMPORTANCE_LOW;
import static android.app.NotificationManager.IMPORTANCE_NONE;
import static android.app.NotificationManager.IMPORTANCE_UNSPECIFIED;
import android.app.Activity; import android.app.Activity;
import android.app.NotificationChannel; import android.app.NotificationChannel;
import android.app.NotificationChannelGroup; import android.app.NotificationChannelGroup;
@@ -41,8 +37,8 @@ import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
import com.android.settings.AppHeader; import com.android.settings.AppHeader;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.Utils; import com.android.settings.Utils;
import com.android.settings.applications.AppHeaderController;
import com.android.settings.applications.AppInfoBase; import com.android.settings.applications.AppInfoBase;
import com.android.settings.applications.EntityHeaderController;
import com.android.settings.applications.LayoutPreference; import com.android.settings.applications.LayoutPreference;
import com.android.settings.notification.NotificationBackend.AppRow; import com.android.settings.notification.NotificationBackend.AppRow;
import com.android.settings.overlay.FeatureFactory; import com.android.settings.overlay.FeatureFactory;
@@ -51,12 +47,15 @@ import com.android.settings.widget.SwitchBar;
import com.android.settingslib.RestrictedSwitchPreference; import com.android.settingslib.RestrictedSwitchPreference;
import com.android.settingslib.widget.FooterPreference; import com.android.settingslib.widget.FooterPreference;
import java.text.Collator;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
import java.util.List; import java.util.List;
import static android.app.NotificationManager.IMPORTANCE_LOW;
import static android.app.NotificationManager.IMPORTANCE_NONE;
import static android.app.NotificationManager.IMPORTANCE_UNSPECIFIED;
/** These settings are per app, so should not be returned in global search results. */ /** These settings are per app, so should not be returned in global search results. */
public class AppNotificationSettings extends NotificationSettingsBase { public class AppNotificationSettings extends NotificationSettingsBase {
private static final String TAG = "AppNotificationSettings"; private static final String TAG = "AppNotificationSettings";
@@ -139,8 +138,8 @@ public class AppNotificationSettings extends NotificationSettingsBase {
.setLabel(mAppRow.label) .setLabel(mAppRow.label)
.setPackageName(mAppRow.pkg) .setPackageName(mAppRow.pkg)
.setUid(mAppRow.uid) .setUid(mAppRow.uid)
.setButtonActions(AppHeaderController.ActionType.ACTION_APP_INFO, .setButtonActions(EntityHeaderController.ActionType.ACTION_APP_INFO,
AppHeaderController.ActionType.ACTION_NOTIF_PREFERENCE) EntityHeaderController.ActionType.ACTION_NOTIF_PREFERENCE)
.done(activity, getPrefContext()); .done(activity, getPrefContext());
pref.setKey(KEY_HEADER); pref.setKey(KEY_HEADER);
getPreferenceScreen().addPreference(pref); getPreferenceScreen().addPreference(pref);

View File

@@ -24,10 +24,8 @@ import android.app.Activity;
import android.app.NotificationChannel; import android.app.NotificationChannel;
import android.app.NotificationManager; import android.app.NotificationManager;
import android.content.Intent; import android.content.Intent;
import android.content.pm.UserInfo;
import android.net.Uri; import android.net.Uri;
import android.os.Bundle; import android.os.Bundle;
import android.os.UserHandle;
import android.provider.Settings; import android.provider.Settings;
import android.support.v7.preference.Preference; import android.support.v7.preference.Preference;
import android.text.TextUtils; import android.text.TextUtils;
@@ -38,12 +36,11 @@ import android.view.View;
import android.widget.Switch; import android.widget.Switch;
import com.android.internal.logging.nano.MetricsProto.MetricsEvent; import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
import com.android.internal.widget.LockPatternUtils;
import com.android.settings.AppHeader; import com.android.settings.AppHeader;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.RingtonePreference; import com.android.settings.RingtonePreference;
import com.android.settings.Utils; import com.android.settings.Utils;
import com.android.settings.applications.AppHeaderController; import com.android.settings.applications.EntityHeaderController;
import com.android.settings.applications.AppInfoBase; import com.android.settings.applications.AppInfoBase;
import com.android.settings.applications.LayoutPreference; import com.android.settings.applications.LayoutPreference;
import com.android.settings.overlay.FeatureFactory; import com.android.settings.overlay.FeatureFactory;
@@ -122,8 +119,8 @@ public class ChannelNotificationSettings extends NotificationSettingsBase {
.setSummary(mAppRow.label) .setSummary(mAppRow.label)
.setPackageName(mAppRow.pkg) .setPackageName(mAppRow.pkg)
.setUid(mAppRow.uid) .setUid(mAppRow.uid)
.setButtonActions(AppHeaderController.ActionType.ACTION_APP_INFO, .setButtonActions(EntityHeaderController.ActionType.ACTION_APP_INFO,
AppHeaderController.ActionType.ACTION_NOTIF_PREFERENCE) EntityHeaderController.ActionType.ACTION_NOTIF_PREFERENCE)
.done(activity, getPrefContext()); .done(activity, getPrefContext());
getPreferenceScreen().addPreference(pref); getPreferenceScreen().addPreference(pref);
} }

View File

@@ -68,12 +68,12 @@ public class AppInfoWithHeaderTest {
@Test @Test
public void testAppHeaderIsAdded() { public void testAppHeaderIsAdded() {
final AppHeaderController appHeaderController = new AppHeaderController( final EntityHeaderController entityHeaderController = new EntityHeaderController(
ShadowApplication.getInstance().getApplicationContext(), ShadowApplication.getInstance().getApplicationContext(),
mAppInfoWithHeader, mAppInfoWithHeader,
null); null);
when(mFactory.applicationFeatureProvider.newAppHeaderController(mAppInfoWithHeader, null)) when(mFactory.applicationFeatureProvider.newAppHeaderController(mAppInfoWithHeader, null))
.thenReturn(appHeaderController); .thenReturn(entityHeaderController);
mAppInfoWithHeader.onActivityCreated(null); mAppInfoWithHeader.onActivityCreated(null);
verify(mAppInfoWithHeader.mScreen).addPreference(any(LayoutPreference.class)); verify(mAppInfoWithHeader.mScreen).addPreference(any(LayoutPreference.class));

View File

@@ -17,14 +17,6 @@
package com.android.settings.applications; package com.android.settings.applications;
import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Matchers.any;
import static org.mockito.Matchers.anyInt;
import static org.mockito.Matchers.eq;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import android.app.ActionBar; import android.app.ActionBar;
import android.app.Activity; import android.app.Activity;
import android.app.Fragment; import android.app.Fragment;
@@ -53,9 +45,17 @@ import org.mockito.MockitoAnnotations;
import org.robolectric.RuntimeEnvironment; import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Config; import org.robolectric.annotation.Config;
import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Matchers.any;
import static org.mockito.Matchers.anyInt;
import static org.mockito.Matchers.eq;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
@RunWith(SettingsRobolectricTestRunner.class) @RunWith(SettingsRobolectricTestRunner.class)
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION) @Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
public class AppHeaderControllerTest { public class EntityHeaderControllerTest {
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
private Context mContext; private Context mContext;
@@ -67,7 +67,7 @@ public class AppHeaderControllerTest {
private Context mShadowContext; private Context mShadowContext;
private LayoutInflater mLayoutInflater; private LayoutInflater mLayoutInflater;
private PackageInfo mInfo; private PackageInfo mInfo;
private AppHeaderController mController; private EntityHeaderController mController;
@Before @Before
@@ -82,7 +82,7 @@ public class AppHeaderControllerTest {
@Test @Test
public void testBuildView_constructedWithoutView_shouldCreateNewView() { public void testBuildView_constructedWithoutView_shouldCreateNewView() {
mController = new AppHeaderController(mShadowContext, mFragment, null); mController = new EntityHeaderController(mShadowContext, mFragment, null);
View view = mController.done(mActivity); View view = mController.done(mActivity);
assertThat(view).isNotNull(); assertThat(view).isNotNull();
@@ -90,7 +90,7 @@ public class AppHeaderControllerTest {
@Test @Test
public void testBuildView_withContext_shouldBuildPreference() { public void testBuildView_withContext_shouldBuildPreference() {
mController = new AppHeaderController(mShadowContext, mFragment, null); mController = new EntityHeaderController(mShadowContext, mFragment, null);
Preference preference = mController.done(mActivity, mShadowContext); Preference preference = mController.done(mActivity, mShadowContext);
assertThat(preference instanceof LayoutPreference).isTrue(); assertThat(preference instanceof LayoutPreference).isTrue();
@@ -99,7 +99,7 @@ public class AppHeaderControllerTest {
@Test @Test
public void testBuildView_constructedWithView_shouldReturnSameView() { public void testBuildView_constructedWithView_shouldReturnSameView() {
View inputView = mLayoutInflater.inflate(R.layout.settings_entity_header, null /* root */); View inputView = mLayoutInflater.inflate(R.layout.settings_entity_header, null /* root */);
mController = new AppHeaderController(mShadowContext, mFragment, inputView); mController = new EntityHeaderController(mShadowContext, mFragment, inputView);
View view = mController.done(mActivity); View view = mController.done(mActivity);
assertThat(view).isSameAs(inputView); assertThat(view).isSameAs(inputView);
@@ -108,11 +108,12 @@ public class AppHeaderControllerTest {
@Test @Test
public void bindViews_shouldBindAllData() { public void bindViews_shouldBindAllData() {
final String testString = "test"; final String testString = "test";
final View appHeader = mLayoutInflater.inflate(R.layout.settings_entity_header, null /* root */); final View header = mLayoutInflater.inflate(
final TextView label = appHeader.findViewById(R.id.app_detail_title); R.layout.settings_entity_header, null /* root */);
final TextView version = appHeader.findViewById(R.id.app_detail_summary); final TextView label = header.findViewById(R.id.entity_header_title);
final TextView version = header.findViewById(R.id.entity_header_summary);
mController = new AppHeaderController(mShadowContext, mFragment, appHeader); mController = new EntityHeaderController(mShadowContext, mFragment, header);
mController.setLabel(testString); mController.setLabel(testString);
mController.setSummary(testString); mController.setSummary(testString);
mController.setIcon(mShadowContext.getDrawable(R.drawable.ic_add)); mController.setIcon(mShadowContext.getDrawable(R.drawable.ic_add));
@@ -133,18 +134,18 @@ public class AppHeaderControllerTest {
when(mContext.getPackageManager().resolveActivity(any(Intent.class), anyInt())) when(mContext.getPackageManager().resolveActivity(any(Intent.class), anyInt()))
.thenReturn(info); .thenReturn(info);
mController = new AppHeaderController(mContext, mFragment, appLinks); mController = new EntityHeaderController(mContext, mFragment, appLinks);
mController.setButtonActions( mController.setButtonActions(
AppHeaderController.ActionType.ACTION_APP_PREFERENCE, EntityHeaderController.ActionType.ACTION_APP_PREFERENCE,
AppHeaderController.ActionType.ACTION_NONE); EntityHeaderController.ActionType.ACTION_NONE);
mController.done(mActivity); mController.done(mActivity);
assertThat(appLinks.findViewById(R.id.left_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button1).getVisibility())
.isEqualTo(View.VISIBLE); .isEqualTo(View.VISIBLE);
assertThat(appLinks.findViewById(R.id.right_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button2).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
try { try {
appLinks.findViewById(R.id.left_button).performClick(); appLinks.findViewById(android.R.id.button1).performClick();
} catch (Exception e) { } catch (Exception e) {
// Ignore exception because the launching intent is fake. // Ignore exception because the launching intent is fake.
} }
@@ -158,15 +159,15 @@ public class AppHeaderControllerTest {
when(mContext.getPackageManager().resolveActivity(any(Intent.class), anyInt())) when(mContext.getPackageManager().resolveActivity(any(Intent.class), anyInt()))
.thenReturn(null); .thenReturn(null);
mController = new AppHeaderController(mContext, mFragment, appLinks); mController = new EntityHeaderController(mContext, mFragment, appLinks);
mController.setButtonActions( mController.setButtonActions(
AppHeaderController.ActionType.ACTION_APP_PREFERENCE, EntityHeaderController.ActionType.ACTION_APP_PREFERENCE,
AppHeaderController.ActionType.ACTION_NONE); EntityHeaderController.ActionType.ACTION_NONE);
mController.done(mActivity); mController.done(mActivity);
assertThat(appLinks.findViewById(R.id.left_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button1).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
assertThat(appLinks.findViewById(R.id.right_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button2).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
} }
@@ -175,16 +176,16 @@ public class AppHeaderControllerTest {
final View appLinks = mLayoutInflater final View appLinks = mLayoutInflater
.inflate(R.layout.settings_entity_header, null /* root */); .inflate(R.layout.settings_entity_header, null /* root */);
mController = new AppHeaderController(mContext, mFragment, appLinks); mController = new EntityHeaderController(mContext, mFragment, appLinks);
mController.setPackageName(null) mController.setPackageName(null)
.setButtonActions( .setButtonActions(
AppHeaderController.ActionType.ACTION_APP_INFO, EntityHeaderController.ActionType.ACTION_APP_INFO,
AppHeaderController.ActionType.ACTION_NONE); EntityHeaderController.ActionType.ACTION_NONE);
mController.done(mActivity); mController.done(mActivity);
assertThat(appLinks.findViewById(R.id.left_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button1).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
assertThat(appLinks.findViewById(R.id.right_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button2).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
} }
@@ -194,17 +195,17 @@ public class AppHeaderControllerTest {
.inflate(R.layout.settings_entity_header, null /* root */); .inflate(R.layout.settings_entity_header, null /* root */);
when(mFragment.getActivity()).thenReturn(mock(Activity.class)); when(mFragment.getActivity()).thenReturn(mock(Activity.class));
mController = new AppHeaderController(mContext, mFragment, appLinks); mController = new EntityHeaderController(mContext, mFragment, appLinks);
mController.setPackageName("123") mController.setPackageName("123")
.setUid(UserHandle.USER_SYSTEM) .setUid(UserHandle.USER_SYSTEM)
.setButtonActions( .setButtonActions(
AppHeaderController.ActionType.ACTION_APP_INFO, EntityHeaderController.ActionType.ACTION_APP_INFO,
AppHeaderController.ActionType.ACTION_NOTIF_PREFERENCE); EntityHeaderController.ActionType.ACTION_NOTIF_PREFERENCE);
mController.done(mActivity); mController.done(mActivity);
assertThat(appLinks.findViewById(R.id.left_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button1).getVisibility())
.isEqualTo(View.VISIBLE); .isEqualTo(View.VISIBLE);
assertThat(appLinks.findViewById(R.id.right_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button2).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
} }
@@ -215,15 +216,15 @@ public class AppHeaderControllerTest {
when(mFragment.getActivity()).thenReturn(mock(Activity.class)); when(mFragment.getActivity()).thenReturn(mock(Activity.class));
when(mContext.getString(eq(R.string.application_info_label))).thenReturn("App Info"); when(mContext.getString(eq(R.string.application_info_label))).thenReturn("App Info");
mController = new AppHeaderController(mContext, mFragment, appLinks); mController = new EntityHeaderController(mContext, mFragment, appLinks);
mController.setPackageName("123") mController.setPackageName("123")
.setUid(UserHandle.USER_SYSTEM) .setUid(UserHandle.USER_SYSTEM)
.setButtonActions( .setButtonActions(
AppHeaderController.ActionType.ACTION_APP_INFO, EntityHeaderController.ActionType.ACTION_APP_INFO,
AppHeaderController.ActionType.ACTION_NOTIF_PREFERENCE); EntityHeaderController.ActionType.ACTION_NOTIF_PREFERENCE);
mController.done(mActivity); mController.done(mActivity);
assertThat(appLinks.findViewById(R.id.left_button).getContentDescription()) assertThat(appLinks.findViewById(android.R.id.button1).getContentDescription())
.isEqualTo("App Info"); .isEqualTo("App Info");
} }
@@ -232,16 +233,16 @@ public class AppHeaderControllerTest {
final View appLinks = mLayoutInflater final View appLinks = mLayoutInflater
.inflate(R.layout.settings_entity_header, null /* root */); .inflate(R.layout.settings_entity_header, null /* root */);
mController = new AppHeaderController(mContext, mFragment, appLinks); mController = new EntityHeaderController(mContext, mFragment, appLinks);
mController.setAppNotifPrefIntent(new Intent()) mController.setAppNotifPrefIntent(new Intent())
.setButtonActions( .setButtonActions(
AppHeaderController.ActionType.ACTION_NOTIF_PREFERENCE, EntityHeaderController.ActionType.ACTION_NOTIF_PREFERENCE,
AppHeaderController.ActionType.ACTION_NONE); EntityHeaderController.ActionType.ACTION_NONE);
mController.done(mActivity); mController.done(mActivity);
assertThat(appLinks.findViewById(R.id.left_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button1).getVisibility())
.isEqualTo(View.VISIBLE); .isEqualTo(View.VISIBLE);
assertThat(appLinks.findViewById(R.id.right_button).getVisibility()) assertThat(appLinks.findViewById(android.R.id.button2).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
} }
@@ -249,31 +250,35 @@ public class AppHeaderControllerTest {
// app is instant. // app is instant.
@Test @Test
public void instantApps_normalAppsDontGetLabel() { public void instantApps_normalAppsDontGetLabel() {
final View appHeader = mLayoutInflater.inflate(R.layout.settings_entity_header, null /* root */); final View header = mLayoutInflater.inflate(
mController = new AppHeaderController(mContext, mFragment, appHeader); R.layout.settings_entity_header, null /* root */);
mController = new EntityHeaderController(mContext, mFragment, header);
mController.done(mActivity); mController.done(mActivity);
assertThat(appHeader.findViewById(R.id.install_type).getVisibility())
assertThat(header.findViewById(R.id.install_type).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
} }
// Test that the "instant apps" label is present in the header when we have an instant app. // Test that the "instant apps" label is present in the header when we have an instant app.
@Test @Test
public void instantApps_expectedHeaderItem() { public void instantApps_expectedHeaderItem() {
final View appHeader = mLayoutInflater.inflate(R.layout.settings_entity_header, null /* root */); final View header = mLayoutInflater.inflate(
mController = new AppHeaderController(mContext, mFragment, appHeader); R.layout.settings_entity_header, null /* root */);
mController = new EntityHeaderController(mContext, mFragment, header);
mController.setIsInstantApp(true); mController.setIsInstantApp(true);
mController.done(mActivity); mController.done(mActivity);
TextView label = appHeader.findViewById(R.id.install_type); TextView label = header.findViewById(R.id.install_type);
assertThat(label.getVisibility()).isEqualTo(View.VISIBLE); assertThat(label.getVisibility()).isEqualTo(View.VISIBLE);
assertThat(label.getText()).isEqualTo( assertThat(label.getText()).isEqualTo(
appHeader.getResources().getString(R.string.install_type_instant)); header.getResources().getString(R.string.install_type_instant));
assertThat(appHeader.findViewById(R.id.app_detail_summary).getVisibility()) assertThat(header.findViewById(R.id.entity_header_summary).getVisibility())
.isEqualTo(View.GONE); .isEqualTo(View.GONE);
} }
@Test @Test
public void styleActionBar_invalidObjects_shouldNotCrash() { public void styleActionBar_invalidObjects_shouldNotCrash() {
mController = new AppHeaderController(mShadowContext, mFragment, null); mController = new EntityHeaderController(mShadowContext, mFragment, null);
mController.styleActionBar(null); mController.styleActionBar(null);
when(mActivity.getActionBar()).thenReturn(null); when(mActivity.getActionBar()).thenReturn(null);
@@ -286,7 +291,7 @@ public class AppHeaderControllerTest {
public void styleActionBar_setElevationAndBackground() { public void styleActionBar_setElevationAndBackground() {
final ActionBar actionBar = mActivity.getActionBar(); final ActionBar actionBar = mActivity.getActionBar();
mController = new AppHeaderController(mShadowContext, mFragment, null); mController = new EntityHeaderController(mShadowContext, mFragment, null);
mController.styleActionBar(mActivity); mController.styleActionBar(mActivity);
verify(actionBar).setElevation(0); verify(actionBar).setElevation(0);
@@ -297,7 +302,7 @@ public class AppHeaderControllerTest {
@Test @Test
public void initAppHeaderController_appHeaderNull_useFragmentContext() { public void initAppHeaderController_appHeaderNull_useFragmentContext() {
mController = new AppHeaderController(mContext, mFragment, null); mController = new EntityHeaderController(mContext, mFragment, null);
// Fragment.getContext() is invoked to inflate the view // Fragment.getContext() is invoked to inflate the view
verify(mFragment).getContext(); verify(mFragment).getContext();

View File

@@ -25,8 +25,8 @@ import android.view.View;
import com.android.settings.SettingsRobolectricTestRunner; import com.android.settings.SettingsRobolectricTestRunner;
import com.android.settings.TestConfig; import com.android.settings.TestConfig;
import com.android.settings.applications.AppHeaderController; import com.android.settings.applications.EntityHeaderController;
import com.android.settings.applications.AppHeaderController.ActionType; import com.android.settings.applications.EntityHeaderController.ActionType;
import com.android.settings.testutils.FakeFeatureFactory; import com.android.settings.testutils.FakeFeatureFactory;
import com.android.settingslib.AppItem; import com.android.settingslib.AppItem;
@@ -54,7 +54,7 @@ public class AppDataUsageTest {
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
private Context mContext; private Context mContext;
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
private AppHeaderController mHeaderController; private EntityHeaderController mHeaderController;
private FakeFeatureFactory mFeatureFactory; private FakeFeatureFactory mFeatureFactory;
private AppDataUsage mFragment; private AppDataUsage mFragment;

View File

@@ -16,19 +16,6 @@
package com.android.settings.fuelgauge; package com.android.settings.fuelgauge;
import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Matchers.any;
import static org.mockito.Matchers.anyInt;
import static org.mockito.Matchers.anyLong;
import static org.mockito.Matchers.anyString;
import static org.mockito.Matchers.eq;
import static org.mockito.Mockito.doAnswer;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import android.app.Activity; import android.app.Activity;
import android.app.Fragment; import android.app.Fragment;
import android.content.Context; import android.content.Context;
@@ -44,7 +31,7 @@ import com.android.internal.os.BatteryStatsHelper;
import com.android.settings.SettingsActivity; import com.android.settings.SettingsActivity;
import com.android.settings.SettingsRobolectricTestRunner; import com.android.settings.SettingsRobolectricTestRunner;
import com.android.settings.TestConfig; import com.android.settings.TestConfig;
import com.android.settings.applications.AppHeaderController; import com.android.settings.applications.EntityHeaderController;
import com.android.settings.applications.LayoutPreference; import com.android.settings.applications.LayoutPreference;
import com.android.settings.testutils.FakeFeatureFactory; import com.android.settings.testutils.FakeFeatureFactory;
import com.android.settingslib.applications.AppUtils; import com.android.settingslib.applications.AppUtils;
@@ -64,6 +51,18 @@ import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Config; import org.robolectric.annotation.Config;
import org.robolectric.util.ReflectionHelpers; import org.robolectric.util.ReflectionHelpers;
import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Matchers.any;
import static org.mockito.Matchers.anyInt;
import static org.mockito.Matchers.anyLong;
import static org.mockito.Matchers.anyString;
import static org.mockito.Matchers.eq;
import static org.mockito.Mockito.doAnswer;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
@RunWith(SettingsRobolectricTestRunner.class) @RunWith(SettingsRobolectricTestRunner.class)
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION) @Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
public class AdvancedPowerUsageDetailTest { public class AdvancedPowerUsageDetailTest {
@@ -85,7 +84,7 @@ public class AdvancedPowerUsageDetailTest {
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
private Activity mActivity; private Activity mActivity;
@Mock @Mock
private AppHeaderController mAppHeaderController; private EntityHeaderController mEntityHeaderController;
@Mock @Mock
private LayoutPreference mHeaderPreference; private LayoutPreference mHeaderPreference;
@Mock @Mock
@@ -121,18 +120,18 @@ public class AdvancedPowerUsageDetailTest {
doReturn(APP_LABEL).when(mBundle).getString(anyString()); doReturn(APP_LABEL).when(mBundle).getString(anyString());
doReturn(mBundle).when(mFragment).getArguments(); doReturn(mBundle).when(mFragment).getArguments();
doReturn(mAppHeaderController).when(mFeatureFactory.applicationFeatureProvider) doReturn(mEntityHeaderController).when(mFeatureFactory.applicationFeatureProvider)
.newAppHeaderController(any(Fragment.class), any(View.class)); .newAppHeaderController(any(Fragment.class), any(View.class));
doReturn(mAppHeaderController).when(mAppHeaderController).setButtonActions(anyInt(), doReturn(mEntityHeaderController).when(mEntityHeaderController)
anyInt()); .setButtonActions(anyInt(), anyInt());
doReturn(mAppHeaderController).when(mAppHeaderController).setIcon(any(Drawable.class)); doReturn(mEntityHeaderController).when(mEntityHeaderController)
doReturn(mAppHeaderController).when(mAppHeaderController).setIcon(any( .setIcon(any(Drawable.class));
doReturn(mEntityHeaderController).when(mEntityHeaderController).setIcon(any(
ApplicationsState.AppEntry.class)); ApplicationsState.AppEntry.class));
doReturn(mAppHeaderController).when(mAppHeaderController).setLabel(anyString()); doReturn(mEntityHeaderController).when(mEntityHeaderController).setLabel(anyString());
doReturn(mAppHeaderController).when(mAppHeaderController).setLabel(any( doReturn(mEntityHeaderController).when(mEntityHeaderController)
ApplicationsState.AppEntry.class)); .setLabel(any(ApplicationsState.AppEntry.class));
doReturn(mAppHeaderController).when(mAppHeaderController).setSummary(anyString()); doReturn(mEntityHeaderController).when(mEntityHeaderController).setSummary(anyString());
doReturn(UID).when(mBatterySipper).getUid(); doReturn(UID).when(mBatterySipper).getUid();
doReturn(APP_LABEL).when(mBatteryEntry).getLabel(); doReturn(APP_LABEL).when(mBatteryEntry).getLabel();
@@ -171,8 +170,8 @@ public class AdvancedPowerUsageDetailTest {
mFragment.mAppEntry = null; mFragment.mAppEntry = null;
mFragment.initHeader(); mFragment.initHeader();
verify(mAppHeaderController).setIcon(any(Drawable.class)); verify(mEntityHeaderController).setIcon(any(Drawable.class));
verify(mAppHeaderController).setLabel(APP_LABEL); verify(mEntityHeaderController).setLabel(APP_LABEL);
} }
@Test @Test
@@ -187,9 +186,9 @@ public class AdvancedPowerUsageDetailTest {
mFragment.mAppEntry = mAppEntry; mFragment.mAppEntry = mAppEntry;
mFragment.initHeader(); mFragment.initHeader();
verify(mAppHeaderController).setIcon(mAppEntry); verify(mEntityHeaderController).setIcon(mAppEntry);
verify(mAppHeaderController).setLabel(mAppEntry); verify(mEntityHeaderController).setLabel(mAppEntry);
verify(mAppHeaderController).setIsInstantApp(false); verify(mEntityHeaderController).setIsInstantApp(false);
} }
@Test @Test
@@ -204,10 +203,10 @@ public class AdvancedPowerUsageDetailTest {
mFragment.mAppEntry = mAppEntry; mFragment.mAppEntry = mAppEntry;
mFragment.initHeader(); mFragment.initHeader();
verify(mAppHeaderController).setIcon(mAppEntry); verify(mEntityHeaderController).setIcon(mAppEntry);
verify(mAppHeaderController).setLabel(mAppEntry); verify(mEntityHeaderController).setLabel(mAppEntry);
verify(mAppHeaderController).setIsInstantApp(true); verify(mEntityHeaderController).setIsInstantApp(true);
verify(mAppHeaderController).setSummary((CharSequence) null); verify(mEntityHeaderController).setSummary((CharSequence) null);
} }
@Test @Test