Merge changes Iaf92730e,I54eb30f2,Ib80827ae
* changes: Use entity header on AccountDetailDashboardFragment Move entity header controller out of application package. Clean up settings_entity_header layout.
This commit is contained in:
committed by
Android (Google) Code Review
commit
7aac5c5791
@@ -1,53 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
style="@style/EntityHeader"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:paddingStart="?android:attr/listPreferredItemPaddingStart"
|
|
||||||
android:paddingEnd="?android:attr/listPreferredItemPaddingEnd"
|
|
||||||
android:gravity="center_vertical"
|
|
||||||
android:paddingTop="24dip"
|
|
||||||
android:paddingBottom="24dip"
|
|
||||||
android:orientation="horizontal">
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:id="@+id/icon_container"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:minWidth="56dp"
|
|
||||||
android:orientation="horizontal"
|
|
||||||
android:paddingEnd="12dp"
|
|
||||||
android:paddingTop="12dp"
|
|
||||||
android:paddingBottom="12dp">
|
|
||||||
<ImageView
|
|
||||||
android:id="@android:id/icon"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:maxWidth="48dp"
|
|
||||||
android:maxHeight="48dp"/>
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@android:id/title"
|
|
||||||
style="@style/TextAppearance.EntityHeaderTitle"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:singleLine="true"/>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
@@ -15,15 +15,10 @@
|
|||||||
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:layout_width="match_parent"
|
android:id="@+id/entity_header"
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:orientation="vertical">
|
|
||||||
|
|
||||||
<!-- App snippet with buttons -->
|
|
||||||
<RelativeLayout
|
|
||||||
android:id="@+id/app_snippet"
|
|
||||||
style="@style/EntityHeader"
|
style="@style/EntityHeader"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
@@ -31,54 +26,55 @@
|
|||||||
android:paddingEnd="0dp"
|
android:paddingEnd="0dp"
|
||||||
android:paddingTop="24dp"
|
android:paddingTop="24dp"
|
||||||
android:paddingBottom="24dp">
|
android:paddingBottom="24dp">
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/app_detail_icon"
|
android:id="@+id/entity_header_icon"
|
||||||
android:layout_width="56dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="56dp"
|
android:layout_height="48dp"
|
||||||
android:scaleType="fitXY"
|
android:scaleType="fitXY"
|
||||||
android:layout_gravity="center_horizontal"
|
android:layout_gravity="center_horizontal"
|
||||||
android:antialias="true"/>
|
android:antialias="true" />
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:id="@+id/app_detail_links"
|
android:id="@+id/entity_header_links"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_alignParentEnd="true"
|
android:layout_alignParentEnd="true"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<ImageButton
|
<ImageButton
|
||||||
android:id="@+id/right_button"
|
android:id="@android:id/button1"
|
||||||
style="?android:attr/actionOverflowButtonStyle"
|
style="?android:attr/actionOverflowButtonStyle"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_weight="1"
|
android:layout_weight="1"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
android:minWidth="@dimen/min_tap_target_size"
|
android:minWidth="@dimen/min_tap_target_size"
|
||||||
android:src="@drawable/ic_settings_24dp"
|
android:src="@drawable/ic_settings_24dp"
|
||||||
android:tint="?android:attr/colorAccent"/>
|
android:tint="?android:attr/colorAccent" />
|
||||||
|
|
||||||
<ImageButton
|
<ImageButton
|
||||||
android:id="@+id/left_button"
|
android:id="@android:id/button2"
|
||||||
style="?android:attr/actionOverflowButtonStyle"
|
style="?android:attr/actionOverflowButtonStyle"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_weight="1"
|
android:layout_weight="1"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
android:minWidth="@dimen/min_tap_target_size"
|
android:minWidth="@dimen/min_tap_target_size"
|
||||||
android:src="@null"
|
android:src="@null"
|
||||||
android:tint="?android:attr/colorAccent"/>
|
android:tint="?android:attr/colorAccent" />
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<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:layout_toEndOf="@id/entity_header_icon"
|
||||||
android:layout_toStartOf="@id/app_detail_links"
|
android:layout_toStartOf="@id/entity_header_links"
|
||||||
android:paddingStart="24dp"
|
android:paddingStart="24dp"
|
||||||
android:paddingEnd="24dp"
|
android:paddingEnd="24dp"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/app_detail_title"
|
android:id="@+id/entity_header_title"
|
||||||
style="@style/TextAppearance.EntityHeaderTitle"
|
style="@style/TextAppearance.EntityHeaderTitle"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
@@ -86,7 +82,7 @@
|
|||||||
android:ellipsize="marquee"
|
android:ellipsize="marquee"
|
||||||
android:gravity="start"
|
android:gravity="start"
|
||||||
android:textDirection="locale"
|
android:textDirection="locale"
|
||||||
android:paddingTop="8dp"/>
|
android:paddingTop="8dp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/install_type"
|
android:id="@+id/install_type"
|
||||||
@@ -97,20 +93,18 @@
|
|||||||
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
|
<TextView
|
||||||
android:id="@+id/app_detail_summary"
|
android:id="@+id/entity_header_summary"
|
||||||
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" />
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
@@ -19,9 +19,9 @@
|
|||||||
android:title="@string/account_settings_title"
|
android:title="@string/account_settings_title"
|
||||||
settings:keywords="@string/keywords_accounts">
|
settings:keywords="@string/keywords_accounts">
|
||||||
|
|
||||||
<Preference
|
<com.android.settings.applications.LayoutPreference
|
||||||
android:key="account_header"
|
android:key="account_header"
|
||||||
android:layout="@layout/account_header"
|
android:layout="@layout/settings_entity_header"
|
||||||
android:selectable="false"
|
android:selectable="false"
|
||||||
android:order="-10000"/>
|
android:order="-10000"/>
|
||||||
|
|
||||||
|
@@ -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"
|
||||||
|
@@ -22,9 +22,8 @@ import android.os.Bundle;
|
|||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.support.annotation.VisibleForTesting;
|
import android.support.annotation.VisibleForTesting;
|
||||||
import android.support.v7.preference.Preference;
|
|
||||||
|
|
||||||
import android.support.v7.preference.PreferenceScreen;
|
import android.support.v7.preference.PreferenceScreen;
|
||||||
|
|
||||||
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.Utils;
|
import com.android.settings.Utils;
|
||||||
@@ -45,7 +44,6 @@ public class AccountDetailDashboardFragment extends DashboardFragment {
|
|||||||
public static final String KEY_ACCOUNT_TYPE = "account_type";
|
public static final String KEY_ACCOUNT_TYPE = "account_type";
|
||||||
public static final String KEY_ACCOUNT_LABEL = "account_label";
|
public static final String KEY_ACCOUNT_LABEL = "account_label";
|
||||||
public static final String KEY_ACCOUNT_TITLE_RES = "account_title_res";
|
public static final String KEY_ACCOUNT_TITLE_RES = "account_title_res";
|
||||||
public static final String KEY_ACCOUNT_HEADER = "account_header";
|
|
||||||
public static final String KEY_USER_HANDLE = "user_handle";
|
public static final String KEY_USER_HANDLE = "user_handle";
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
@@ -110,6 +108,8 @@ public class AccountDetailDashboardFragment extends DashboardFragment {
|
|||||||
controllers.add(mAccountSynController);
|
controllers.add(mAccountSynController);
|
||||||
mRemoveAccountController = new RemoveAccountPreferenceController(context, this);
|
mRemoveAccountController = new RemoveAccountPreferenceController(context, this);
|
||||||
controllers.add(mRemoveAccountController);
|
controllers.add(mRemoveAccountController);
|
||||||
|
controllers.add(new AccountHeaderPreferenceController(
|
||||||
|
context, getActivity(), this, getArguments()));
|
||||||
return controllers;
|
return controllers;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -127,8 +127,6 @@ public class AccountDetailDashboardFragment extends DashboardFragment {
|
|||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
void updateUi() {
|
void updateUi() {
|
||||||
final Preference headerPreference = findPreference(KEY_ACCOUNT_HEADER);
|
|
||||||
headerPreference.setTitle(mAccount.name);
|
|
||||||
final Context context = getContext();
|
final Context context = getContext();
|
||||||
UserHandle userHandle = null;
|
UserHandle userHandle = null;
|
||||||
Bundle args = getArguments();
|
Bundle args = getArguments();
|
||||||
@@ -136,14 +134,12 @@ public class AccountDetailDashboardFragment extends DashboardFragment {
|
|||||||
userHandle = args.getParcelable(KEY_USER_HANDLE);
|
userHandle = args.getParcelable(KEY_USER_HANDLE);
|
||||||
}
|
}
|
||||||
final AuthenticatorHelper helper = new AuthenticatorHelper(context, userHandle, null);
|
final AuthenticatorHelper helper = new AuthenticatorHelper(context, userHandle, null);
|
||||||
headerPreference.setIcon(helper.getDrawableForType(context, mAccountType));
|
|
||||||
final AccountTypePreferenceLoader accountTypePreferenceLoader =
|
final AccountTypePreferenceLoader accountTypePreferenceLoader =
|
||||||
new AccountTypePreferenceLoader(this, helper, userHandle);
|
new AccountTypePreferenceLoader(this, helper, userHandle);
|
||||||
PreferenceScreen prefs =
|
PreferenceScreen prefs = accountTypePreferenceLoader.addPreferencesForType(
|
||||||
accountTypePreferenceLoader.addPreferencesForType(mAccountType, getPreferenceScreen());
|
mAccountType, getPreferenceScreen());
|
||||||
if (prefs != null) {
|
if (prefs != null) {
|
||||||
accountTypePreferenceLoader.updatePreferenceIntents(prefs, mAccountType, mAccount);
|
accountTypePreferenceLoader.updatePreferenceIntents(prefs, mAccountType, mAccount);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@@ -0,0 +1,87 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2017 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.accounts;
|
||||||
|
|
||||||
|
import android.accounts.Account;
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.app.Fragment;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
import android.support.v7.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.applications.LayoutPreference;
|
||||||
|
import com.android.settings.core.PreferenceController;
|
||||||
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
|
import com.android.settingslib.accounts.AuthenticatorHelper;
|
||||||
|
|
||||||
|
import static com.android.settings.accounts.AccountDetailDashboardFragment.KEY_ACCOUNT;
|
||||||
|
import static com.android.settings.accounts.AccountDetailDashboardFragment.KEY_USER_HANDLE;
|
||||||
|
|
||||||
|
public class AccountHeaderPreferenceController extends PreferenceController {
|
||||||
|
|
||||||
|
private static final String KEY_ACCOUNT_HEADER = "account_header";
|
||||||
|
|
||||||
|
private final Activity mActivity;
|
||||||
|
private final Fragment mHost;
|
||||||
|
private final Account mAccount;
|
||||||
|
private final UserHandle mUserHandle;
|
||||||
|
|
||||||
|
public AccountHeaderPreferenceController(Context context, Activity activity, Fragment host,
|
||||||
|
Bundle args) {
|
||||||
|
super(context);
|
||||||
|
mActivity = activity;
|
||||||
|
mHost = host;
|
||||||
|
if (args != null && args.containsKey(KEY_ACCOUNT)) {
|
||||||
|
mAccount = args.getParcelable(KEY_ACCOUNT);
|
||||||
|
} else {
|
||||||
|
mAccount = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (args != null && args.containsKey(KEY_USER_HANDLE)) {
|
||||||
|
mUserHandle = args.getParcelable(KEY_USER_HANDLE);
|
||||||
|
} else {
|
||||||
|
mUserHandle = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAvailable() {
|
||||||
|
return mAccount != null && mUserHandle != null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPreferenceKey() {
|
||||||
|
return KEY_ACCOUNT_HEADER;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
final LayoutPreference headerPreference =
|
||||||
|
(LayoutPreference) screen.findPreference(KEY_ACCOUNT_HEADER);
|
||||||
|
|
||||||
|
final AuthenticatorHelper helper = new AuthenticatorHelper(mContext, mUserHandle, null);
|
||||||
|
|
||||||
|
EntityHeaderController
|
||||||
|
.newInstance(mActivity, mHost, headerPreference.findViewById(R.id.entity_header))
|
||||||
|
.setLabel(mAccount.name)
|
||||||
|
.setIcon(helper.getDrawableForType(mContext, mAccount.type))
|
||||||
|
.done(mActivity, true /* rebindButtons */);
|
||||||
|
}
|
||||||
|
}
|
@@ -16,17 +16,17 @@
|
|||||||
|
|
||||||
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;
|
||||||
import android.util.IconDrawableFactory;
|
import android.util.IconDrawableFactory;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.applications.AppUtils;
|
import com.android.settingslib.applications.AppUtils;
|
||||||
|
|
||||||
|
import static com.android.settings.widget.EntityHeaderController.ActionType;
|
||||||
|
|
||||||
public abstract class AppInfoWithHeader extends AppInfoBase {
|
public abstract class AppInfoWithHeader extends AppInfoBase {
|
||||||
|
|
||||||
private boolean mCreated;
|
private boolean mCreated;
|
||||||
@@ -41,9 +41,8 @@ public abstract class AppInfoWithHeader extends AppInfoBase {
|
|||||||
mCreated = true;
|
mCreated = true;
|
||||||
if (mPackageInfo == null) return;
|
if (mPackageInfo == null) return;
|
||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
final Preference pref = FeatureFactory.getFactory(activity)
|
final Preference pref = EntityHeaderController
|
||||||
.getApplicationFeatureProvider(activity)
|
.newInstance(activity, this, null /* header */)
|
||||||
.newAppHeaderController(this, null /* appHeader */)
|
|
||||||
.setIcon(IconDrawableFactory.newInstance(activity)
|
.setIcon(IconDrawableFactory.newInstance(activity)
|
||||||
.getBadgedIcon(mPackageInfo.applicationInfo))
|
.getBadgedIcon(mPackageInfo.applicationInfo))
|
||||||
.setLabel(mPackageInfo.applicationInfo.loadLabel(mPm))
|
.setLabel(mPackageInfo.applicationInfo.loadLabel(mPm))
|
||||||
|
@@ -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;
|
||||||
@@ -43,6 +44,7 @@ import com.android.settings.core.InstrumentedPreferenceFragment;
|
|||||||
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.widget.EntityHeaderController;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@@ -64,7 +66,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 +193,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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -28,12 +28,6 @@ import java.util.List;
|
|||||||
public interface ApplicationFeatureProvider {
|
public interface ApplicationFeatureProvider {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a new {@link AppHeaderController} instance to customize app header.
|
|
||||||
*/
|
|
||||||
AppHeaderController 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.
|
||||||
*/
|
*/
|
||||||
@@ -61,8 +55,8 @@ 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
|
||||||
*/
|
*/
|
||||||
@@ -73,8 +67,8 @@ 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);
|
||||||
@@ -86,9 +80,8 @@ public interface ApplicationFeatureProvider {
|
|||||||
* 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);
|
||||||
|
@@ -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;
|
||||||
@@ -53,11 +52,6 @@ public class ApplicationFeatureProviderImpl implements ApplicationFeatureProvide
|
|||||||
mUm = UserManager.get(mContext);
|
mUm = UserManager.get(mContext);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public AppHeaderController newAppHeaderController(Fragment fragment, View appHeader) {
|
|
||||||
return new AppHeaderController(mContext, fragment, appHeader);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public InstantAppButtonsController newInstantAppButtonsController(Fragment fragment,
|
public InstantAppButtonsController newInstantAppButtonsController(Fragment fragment,
|
||||||
View view, InstantAppButtonsController.ShowDialogDelegate showDialogDelegate) {
|
View view, InstantAppButtonsController.ShowDialogDelegate showDialogDelegate) {
|
||||||
|
@@ -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;
|
||||||
@@ -96,6 +91,7 @@ import com.android.settings.notification.AppNotificationSettings;
|
|||||||
import com.android.settings.notification.NotificationBackend;
|
import com.android.settings.notification.NotificationBackend;
|
||||||
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;
|
||||||
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.AppItem;
|
import com.android.settingslib.AppItem;
|
||||||
import com.android.settingslib.RestrictedLockUtils;
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
import com.android.settingslib.applications.AppUtils;
|
import com.android.settingslib.applications.AppUtils;
|
||||||
@@ -411,14 +407,12 @@ public class InstalledAppDetails extends AppInfoBase
|
|||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
mHeader = (LayoutPreference) findPreference(KEY_HEADER);
|
mHeader = (LayoutPreference) findPreference(KEY_HEADER);
|
||||||
mActionButtons = (LayoutPreference) findPreference(KEY_ACTION_BUTTONS);
|
mActionButtons = (LayoutPreference) findPreference(KEY_ACTION_BUTTONS);
|
||||||
FeatureFactory.getFactory(activity)
|
EntityHeaderController.newInstance(activity, this, mHeader.findViewById(R.id.entity_header))
|
||||||
.getApplicationFeatureProvider(activity)
|
|
||||||
.newAppHeaderController(this, mHeader.findViewById(R.id.app_snippet))
|
|
||||||
.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,15 +578,13 @@ 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);
|
||||||
final CharSequence summary =
|
final CharSequence summary =
|
||||||
isInstantApp ? null : getString(Utils.getInstallationStatus(mAppEntry.info));
|
isInstantApp ? null : getString(Utils.getInstallationStatus(mAppEntry.info));
|
||||||
FeatureFactory.getFactory(activity)
|
EntityHeaderController.newInstance(activity, this, appSnippet)
|
||||||
.getApplicationFeatureProvider(activity)
|
|
||||||
.newAppHeaderController(this, appSnippet)
|
|
||||||
.setLabel(mAppEntry)
|
.setLabel(mAppEntry)
|
||||||
.setIcon(mAppEntry)
|
.setIcon(mAppEntry)
|
||||||
.setSummary(summary)
|
.setSummary(summary)
|
||||||
@@ -1245,32 +1237,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();
|
||||||
|
@@ -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.app.ActivityManager;
|
import android.app.ActivityManager;
|
||||||
import android.app.ActivityManager.RunningServiceInfo;
|
import android.app.ActivityManager.RunningServiceInfo;
|
||||||
@@ -53,7 +51,7 @@ import com.android.settings.R;
|
|||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
import com.android.settings.SummaryPreference;
|
import com.android.settings.SummaryPreference;
|
||||||
import com.android.settings.applications.ProcStatsEntry.Service;
|
import com.android.settings.applications.ProcStatsEntry.Service;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@@ -61,6 +59,8 @@ import java.util.Comparator;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static com.android.settings.widget.EntityHeaderController.ActionType;
|
||||||
|
|
||||||
public class ProcessStatsDetail extends SettingsPreferenceFragment {
|
public class ProcessStatsDetail extends SettingsPreferenceFragment {
|
||||||
|
|
||||||
private static final String TAG = "ProcessStatsDetail";
|
private static final String TAG = "ProcessStatsDetail";
|
||||||
@@ -126,9 +126,8 @@ public class ProcessStatsDetail extends SettingsPreferenceFragment {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
final Preference pref = FeatureFactory.getFactory(activity)
|
final Preference pref = EntityHeaderController
|
||||||
.getApplicationFeatureProvider(activity)
|
.newInstance(activity, this, null /* appHeader */)
|
||||||
.newAppHeaderController(this, null /* appHeader */)
|
|
||||||
.setIcon(mApp.mUiTargetApp != null
|
.setIcon(mApp.mUiTargetApp != null
|
||||||
? IconDrawableFactory.newInstance(activity).getBadgedIcon(mApp.mUiTargetApp)
|
? IconDrawableFactory.newInstance(activity).getBadgedIcon(mApp.mUiTargetApp)
|
||||||
: new ColorDrawable(0))
|
: new ColorDrawable(0))
|
||||||
|
@@ -41,9 +41,8 @@ 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.AppInfoBase;
|
import com.android.settings.applications.AppInfoBase;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.AppItem;
|
import com.android.settingslib.AppItem;
|
||||||
import com.android.settingslib.net.ChartData;
|
import com.android.settingslib.net.ChartData;
|
||||||
import com.android.settingslib.net.ChartDataLoader;
|
import com.android.settingslib.net.ChartDataLoader;
|
||||||
@@ -326,13 +325,12 @@ public class AppDataUsage extends DataUsageBase implements Preference.OnPreferen
|
|||||||
final boolean showInfoButton = mAppItem.key > 0;
|
final boolean showInfoButton = mAppItem.key > 0;
|
||||||
|
|
||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
final Preference pref = FeatureFactory.getFactory(activity)
|
final Preference pref = EntityHeaderController
|
||||||
.getApplicationFeatureProvider(activity)
|
.newInstance(activity, this, null /* header */)
|
||||||
.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)
|
||||||
|
@@ -37,13 +37,12 @@ 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.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;
|
||||||
import com.android.settings.enterprise.DevicePolicyManagerWrapper;
|
import com.android.settings.enterprise.DevicePolicyManagerWrapper;
|
||||||
import com.android.settings.enterprise.DevicePolicyManagerWrapperImpl;
|
import com.android.settings.enterprise.DevicePolicyManagerWrapperImpl;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.applications.AppUtils;
|
import com.android.settingslib.applications.AppUtils;
|
||||||
import com.android.settingslib.applications.ApplicationsState;
|
import com.android.settingslib.applications.ApplicationsState;
|
||||||
|
|
||||||
@@ -180,14 +179,13 @@ 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 = EntityHeaderController
|
||||||
.getApplicationFeatureProvider(context)
|
.newInstance(context, this, appSnippet)
|
||||||
.newAppHeaderController(this, appSnippet)
|
.setButtonActions(EntityHeaderController.ActionType.ACTION_NONE,
|
||||||
.setButtonActions(AppHeaderController.ActionType.ACTION_NONE,
|
EntityHeaderController.ActionType.ACTION_NONE);
|
||||||
AppHeaderController.ActionType.ACTION_NONE);
|
|
||||||
|
|
||||||
if (mAppEntry == null) {
|
if (mAppEntry == null) {
|
||||||
controller.setLabel(bundle.getString(EXTRA_LABEL));
|
controller.setLabel(bundle.getString(EXTRA_LABEL));
|
||||||
|
@@ -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,22 +37,24 @@ 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.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.widget.EntityHeaderController;
|
||||||
import com.android.settings.widget.MasterSwitchPreference;
|
import com.android.settings.widget.MasterSwitchPreference;
|
||||||
import com.android.settings.widget.SwitchBar;
|
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";
|
||||||
@@ -128,19 +126,18 @@ public class AppNotificationSettings extends NotificationSettingsBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void addHeaderPref() {
|
private void addHeaderPref() {
|
||||||
ArrayMap<String, AppRow> rows = new ArrayMap<String, AppRow>();
|
ArrayMap<String, AppRow> rows = new ArrayMap<>();
|
||||||
rows.put(mAppRow.pkg, mAppRow);
|
rows.put(mAppRow.pkg, mAppRow);
|
||||||
collectConfigActivities(rows);
|
collectConfigActivities(rows);
|
||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
final Preference pref = FeatureFactory.getFactory(activity)
|
final Preference pref = EntityHeaderController
|
||||||
.getApplicationFeatureProvider(activity)
|
.newInstance(activity, this /* fragment */, null /* header */)
|
||||||
.newAppHeaderController(this /* fragment */, null /* appHeader */)
|
|
||||||
.setIcon(mAppRow.icon)
|
.setIcon(mAppRow.icon)
|
||||||
.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);
|
||||||
|
@@ -16,18 +16,12 @@
|
|||||||
|
|
||||||
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.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,19 +32,21 @@ 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.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.widget.EntityHeaderController;
|
||||||
import com.android.settings.widget.SwitchBar;
|
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 static android.app.NotificationManager.IMPORTANCE_LOW;
|
||||||
|
import static android.app.NotificationManager.IMPORTANCE_NONE;
|
||||||
|
import static android.app.NotificationManager.IMPORTANCE_UNSPECIFIED;
|
||||||
|
|
||||||
public class ChannelNotificationSettings extends NotificationSettingsBase {
|
public class ChannelNotificationSettings extends NotificationSettingsBase {
|
||||||
private static final String TAG = "ChannelSettings";
|
private static final String TAG = "ChannelSettings";
|
||||||
|
|
||||||
@@ -110,20 +106,19 @@ public class ChannelNotificationSettings extends NotificationSettingsBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void addHeaderPref() {
|
private void addHeaderPref() {
|
||||||
ArrayMap<String, NotificationBackend.AppRow> rows = new ArrayMap<String, NotificationBackend.AppRow>();
|
ArrayMap<String, NotificationBackend.AppRow> rows = new ArrayMap<>();
|
||||||
rows.put(mAppRow.pkg, mAppRow);
|
rows.put(mAppRow.pkg, mAppRow);
|
||||||
collectConfigActivities(rows);
|
collectConfigActivities(rows);
|
||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
final Preference pref = FeatureFactory.getFactory(activity)
|
final Preference pref = EntityHeaderController
|
||||||
.getApplicationFeatureProvider(activity)
|
.newInstance(activity, this /* fragment */, null /* header */)
|
||||||
.newAppHeaderController(this /* fragment */, null /* appHeader */)
|
|
||||||
.setIcon(mAppRow.icon)
|
.setIcon(mAppRow.icon)
|
||||||
.setLabel(mChannel.getName())
|
.setLabel(mChannel.getName())
|
||||||
.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);
|
||||||
}
|
}
|
||||||
|
@@ -30,8 +30,8 @@ import com.android.settings.enterprise.EnterprisePrivacyFeatureProvider;
|
|||||||
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;
|
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;
|
||||||
import com.android.settings.gestures.AssistGestureFeatureProvider;
|
import com.android.settings.gestures.AssistGestureFeatureProvider;
|
||||||
import com.android.settings.localepicker.LocaleFeatureProvider;
|
import com.android.settings.localepicker.LocaleFeatureProvider;
|
||||||
import com.android.settings.security.SecurityFeatureProvider;
|
|
||||||
import com.android.settings.search2.SearchFeatureProvider;
|
import com.android.settings.search2.SearchFeatureProvider;
|
||||||
|
import com.android.settings.security.SecurityFeatureProvider;
|
||||||
import com.android.settings.users.UserFeatureProvider;
|
import com.android.settings.users.UserFeatureProvider;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -14,7 +14,7 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.android.settings.applications;
|
package com.android.settings.widget;
|
||||||
|
|
||||||
import android.annotation.IdRes;
|
import android.annotation.IdRes;
|
||||||
import android.annotation.UserIdInt;
|
import android.annotation.UserIdInt;
|
||||||
@@ -41,13 +41,16 @@ import android.widget.TextView;
|
|||||||
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.AppInfoBase;
|
||||||
|
import com.android.settings.applications.InstalledAppDetails;
|
||||||
|
import com.android.settings.applications.LayoutPreference;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settingslib.applications.ApplicationsState;
|
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 +71,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,90 +81,101 @@ 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) {
|
/**
|
||||||
|
* Creates a new instance of the controller.
|
||||||
|
*
|
||||||
|
* @param fragment The fragment that header will be placed in.
|
||||||
|
* @param header Optional: header view if it's already created.
|
||||||
|
*/
|
||||||
|
public static EntityHeaderController newInstance(Context context, Fragment fragment,
|
||||||
|
View header) {
|
||||||
|
return new EntityHeaderController(context.getApplicationContext(), fragment, header);
|
||||||
|
}
|
||||||
|
|
||||||
|
private 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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Done mutating appheader, rebinds everything and return a new {@link LayoutPreference}.
|
* Done mutating entity header, rebinds everything and return a new {@link LayoutPreference}.
|
||||||
*/
|
*/
|
||||||
public LayoutPreference done(Activity activity, Context uiContext) {
|
public LayoutPreference done(Activity activity, Context uiContext) {
|
||||||
final LayoutPreference pref = new LayoutPreference(uiContext, done(activity));
|
final LayoutPreference pref = new LayoutPreference(uiContext, done(activity));
|
||||||
@@ -172,41 +186,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 entity 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 +238,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) {
|
||||||
@@ -245,9 +259,16 @@ public class AppHeaderController {
|
|||||||
button.setContentDescription(
|
button.setContentDescription(
|
||||||
mContext.getString(R.string.application_info_label));
|
mContext.getString(R.string.application_info_label));
|
||||||
button.setImageResource(com.android.settings.R.drawable.ic_info);
|
button.setImageResource(com.android.settings.R.drawable.ic_info);
|
||||||
button.setOnClickListener(v -> AppInfoBase.startAppInfoFragment(
|
button.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
AppInfoBase.startAppInfoFragment(
|
||||||
InstalledAppDetails.class, R.string.application_info_label,
|
InstalledAppDetails.class, R.string.application_info_label,
|
||||||
mPackageName, mUid, mFragment, 0 /* request */, mMetricsCategory));
|
mPackageName, mUid, mFragment, 0 /* request */,
|
||||||
|
mMetricsCategory);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
button.setVisibility(View.VISIBLE);
|
button.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
@@ -256,7 +277,12 @@ public class AppHeaderController {
|
|||||||
if (mAppNotifPrefIntent == null) {
|
if (mAppNotifPrefIntent == null) {
|
||||||
button.setVisibility(View.GONE);
|
button.setVisibility(View.GONE);
|
||||||
} else {
|
} else {
|
||||||
button.setOnClickListener(v -> mFragment.startActivity(mAppNotifPrefIntent));
|
button.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
mFragment.startActivity(mAppNotifPrefIntent);
|
||||||
|
}
|
||||||
|
});
|
||||||
button.setVisibility(View.VISIBLE);
|
button.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
@@ -268,7 +294,12 @@ public class AppHeaderController {
|
|||||||
button.setVisibility(View.GONE);
|
button.setVisibility(View.GONE);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
button.setOnClickListener(v -> mFragment.startActivity(intent));
|
button.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
mFragment.startActivity(intent);
|
||||||
|
}
|
||||||
|
});
|
||||||
button.setVisibility(View.VISIBLE);
|
button.setVisibility(View.VISIBLE);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -289,7 +320,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);
|
@@ -17,7 +17,6 @@ package com.android.settings.accounts;
|
|||||||
|
|
||||||
import android.accounts.Account;
|
import android.accounts.Account;
|
||||||
import android.accounts.AccountManager;
|
import android.accounts.AccountManager;
|
||||||
import android.accounts.AuthenticatorDescription;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
@@ -26,8 +25,6 @@ import android.support.v7.preference.PreferenceScreen;
|
|||||||
|
|
||||||
import com.android.settings.SettingsRobolectricTestRunner;
|
import com.android.settings.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
import com.android.settings.testutils.shadow.ShadowAccountManager;
|
|
||||||
import com.android.settings.testutils.shadow.ShadowContentResolver;
|
|
||||||
import com.android.settingslib.drawer.CategoryKey;
|
import com.android.settingslib.drawer.CategoryKey;
|
||||||
import com.android.settingslib.drawer.Tile;
|
import com.android.settingslib.drawer.Tile;
|
||||||
|
|
||||||
@@ -41,11 +38,7 @@ import org.robolectric.shadows.ShadowApplication;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static org.mockito.Answers.RETURNS_DEEP_STUBS;
|
import static org.mockito.Answers.RETURNS_DEEP_STUBS;
|
||||||
import static org.mockito.Matchers.anyInt;
|
|
||||||
import static org.mockito.Mockito.doReturn;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
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)
|
||||||
@@ -54,7 +47,6 @@ public class AccountDetailDashboardFragmentTest {
|
|||||||
private static final String METADATA_CATEGORY = "com.android.settings.category";
|
private static final String METADATA_CATEGORY = "com.android.settings.category";
|
||||||
private static final String METADATA_ACCOUNT_TYPE = "com.android.settings.ia.account";
|
private static final String METADATA_ACCOUNT_TYPE = "com.android.settings.ia.account";
|
||||||
private static final String METADATA_USER_HANDLE = "user_handle";
|
private static final String METADATA_USER_HANDLE = "user_handle";
|
||||||
private static final String PREF_ACCOUNT_HEADER = "account_header";
|
|
||||||
|
|
||||||
@Mock(answer = RETURNS_DEEP_STUBS)
|
@Mock(answer = RETURNS_DEEP_STUBS)
|
||||||
private AccountManager mAccountManager;
|
private AccountManager mAccountManager;
|
||||||
@@ -118,20 +110,4 @@ public class AccountDetailDashboardFragmentTest {
|
|||||||
|
|
||||||
assertThat(mFragment.displayTile(tile)).isFalse();
|
assertThat(mFragment.displayTile(tile)).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
@Config(shadows = {ShadowAccountManager.class, ShadowContentResolver.class})
|
|
||||||
public void updateAccountHeader_shouldShowAccountName() throws Exception {
|
|
||||||
when(mAccountManager.getAuthenticatorTypesAsUser(anyInt())).thenReturn(
|
|
||||||
new AuthenticatorDescription[0]);
|
|
||||||
when(mAccountManager.getAccountsAsUser(anyInt())).thenReturn(new Account[0]);
|
|
||||||
when(mFragment.getContext()).thenReturn(mContext);
|
|
||||||
doReturn(mScreen).when(mFragment).getPreferenceScreen();
|
|
||||||
doReturn(mPreference).when(mFragment).findPreference(PREF_ACCOUNT_HEADER);
|
|
||||||
|
|
||||||
mFragment.updateUi();
|
|
||||||
|
|
||||||
verify(mPreference).setTitle("name1@abc.com");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,114 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2017 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.accounts;
|
||||||
|
|
||||||
|
import android.accounts.Account;
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.app.Fragment;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
import android.support.v7.preference.PreferenceScreen;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.SettingsRobolectricTestRunner;
|
||||||
|
import com.android.settings.TestConfig;
|
||||||
|
import com.android.settings.applications.LayoutPreference;
|
||||||
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
import com.android.settingslib.accounts.AuthenticatorHelper;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Answers;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.annotation.Implementation;
|
||||||
|
import org.robolectric.annotation.Implements;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.Matchers.anyString;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
|
||||||
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
||||||
|
public class AccountHeaderPreferenceControllerTest {
|
||||||
|
|
||||||
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
|
private Context mContext;
|
||||||
|
@Mock
|
||||||
|
private Activity mActivity;
|
||||||
|
@Mock
|
||||||
|
private Fragment mFragment;
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
|
||||||
|
private LayoutPreference mHeaderPreference;
|
||||||
|
|
||||||
|
private AccountHeaderPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
FakeFeatureFactory.setupForTest(mContext);
|
||||||
|
mHeaderPreference = new LayoutPreference(
|
||||||
|
RuntimeEnvironment.application, R.layout.settings_entity_header);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void isAvailable_noArgs_shouldReturnNull() {
|
||||||
|
mController = new AccountHeaderPreferenceController(RuntimeEnvironment.application,
|
||||||
|
mActivity, mFragment, null /* args */);
|
||||||
|
|
||||||
|
assertThat(mController.isAvailable()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(shadows = ShadowAuthenticatorHelper.class)
|
||||||
|
public void displayPreference_shouldDisplayAccountInEntityHeader() {
|
||||||
|
final Account account = new Account("name1@abc.com", "com.abc");
|
||||||
|
Bundle args = new Bundle();
|
||||||
|
args.putParcelable(AccountDetailDashboardFragment.KEY_ACCOUNT, account);
|
||||||
|
args.putParcelable(AccountDetailDashboardFragment.KEY_USER_HANDLE, UserHandle.CURRENT);
|
||||||
|
mController = new AccountHeaderPreferenceController(RuntimeEnvironment.application,
|
||||||
|
mActivity, mFragment, args);
|
||||||
|
|
||||||
|
assertThat(mController.isAvailable()).isTrue();
|
||||||
|
|
||||||
|
when(mScreen.findPreference(anyString())).thenReturn(mHeaderPreference);
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
final CharSequence label =
|
||||||
|
((TextView) mHeaderPreference.findViewById(R.id.entity_header_title)).getText();
|
||||||
|
|
||||||
|
assertThat(label).isEqualTo(account.name);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Implements(AuthenticatorHelper.class)
|
||||||
|
public static class ShadowAuthenticatorHelper {
|
||||||
|
@Implementation
|
||||||
|
public void onAccountsUpdated(Account[] accounts) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -28,9 +28,12 @@ import com.android.internal.logging.nano.MetricsProto;
|
|||||||
import com.android.settings.SettingsRobolectricTestRunner;
|
import com.android.settings.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowEntityHeaderController;
|
||||||
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.applications.AppUtils;
|
import com.android.settingslib.applications.AppUtils;
|
||||||
import com.android.settingslib.applications.instantapps.InstantAppDataProvider;
|
import com.android.settingslib.applications.instantapps.InstantAppDataProvider;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -47,10 +50,13 @@ import static org.mockito.Mockito.verify;
|
|||||||
import static org.mockito.Mockito.when;
|
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,
|
||||||
|
shadows = ShadowEntityHeaderController.class)
|
||||||
public class AppInfoWithHeaderTest {
|
public class AppInfoWithHeaderTest {
|
||||||
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
|
private EntityHeaderController mHeaderController;
|
||||||
|
|
||||||
private FakeFeatureFactory mFactory;
|
private FakeFeatureFactory mFactory;
|
||||||
private TestFragment mAppInfoWithHeader;
|
private TestFragment mAppInfoWithHeader;
|
||||||
@@ -64,16 +70,16 @@ public class AppInfoWithHeaderTest {
|
|||||||
when(mFactory.metricsFeatureProvider.getMetricsCategory(any(Object.class)))
|
when(mFactory.metricsFeatureProvider.getMetricsCategory(any(Object.class)))
|
||||||
.thenReturn(MetricsProto.MetricsEvent.SETTINGS_APP_NOTIF_CATEGORY);
|
.thenReturn(MetricsProto.MetricsEvent.SETTINGS_APP_NOTIF_CATEGORY);
|
||||||
mAppInfoWithHeader = new TestFragment();
|
mAppInfoWithHeader = new TestFragment();
|
||||||
|
ShadowEntityHeaderController.setUseMock(mHeaderController);
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tearDown() {
|
||||||
|
ShadowEntityHeaderController.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testAppHeaderIsAdded() {
|
public void testAppHeaderIsAdded() {
|
||||||
final AppHeaderController appHeaderController = new AppHeaderController(
|
|
||||||
ShadowApplication.getInstance().getApplicationContext(),
|
|
||||||
mAppInfoWithHeader,
|
|
||||||
null);
|
|
||||||
when(mFactory.applicationFeatureProvider.newAppHeaderController(mAppInfoWithHeader, null))
|
|
||||||
.thenReturn(appHeaderController);
|
|
||||||
mAppInfoWithHeader.onActivityCreated(null);
|
mAppInfoWithHeader.onActivityCreated(null);
|
||||||
|
|
||||||
verify(mAppInfoWithHeader.mScreen).addPreference(any(LayoutPreference.class));
|
verify(mAppInfoWithHeader.mScreen).addPreference(any(LayoutPreference.class));
|
||||||
|
@@ -25,11 +25,13 @@ 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.AppHeaderController.ActionType;
|
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowEntityHeaderController;
|
||||||
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
|
import com.android.settings.widget.EntityHeaderController.ActionType;
|
||||||
import com.android.settingslib.AppItem;
|
import com.android.settingslib.AppItem;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -45,28 +47,33 @@ import static org.mockito.Mockito.doReturn;
|
|||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
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,
|
||||||
|
shadows = ShadowEntityHeaderController.class)
|
||||||
public class AppDataUsageTest {
|
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 AppDataUsage mFragment;
|
private AppDataUsage mFragment;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
FakeFeatureFactory.setupForTest(mContext);
|
FakeFeatureFactory.setupForTest(mContext);
|
||||||
mFeatureFactory = (FakeFeatureFactory) FakeFeatureFactory.getFactory(mContext);
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tearDown() {
|
||||||
|
ShadowEntityHeaderController.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void bindAppHeader_allWorkApps_shouldNotShowAppInfoLink() {
|
public void bindAppHeader_allWorkApps_shouldNotShowAppInfoLink() {
|
||||||
|
ShadowEntityHeaderController.setUseMock(mHeaderController);
|
||||||
mFragment = spy(new AppDataUsage());
|
mFragment = spy(new AppDataUsage());
|
||||||
|
|
||||||
doReturn(mock(PreferenceManager.class, RETURNS_DEEP_STUBS))
|
doReturn(mock(PreferenceManager.class, RETURNS_DEEP_STUBS))
|
||||||
@@ -74,8 +81,6 @@ public class AppDataUsageTest {
|
|||||||
.getPreferenceManager();
|
.getPreferenceManager();
|
||||||
doReturn(mock(PreferenceScreen.class)).when(mFragment).getPreferenceScreen();
|
doReturn(mock(PreferenceScreen.class)).when(mFragment).getPreferenceScreen();
|
||||||
ReflectionHelpers.setField(mFragment, "mAppItem", mock(AppItem.class));
|
ReflectionHelpers.setField(mFragment, "mAppItem", mock(AppItem.class));
|
||||||
when(mFeatureFactory.applicationFeatureProvider.newAppHeaderController(mFragment, null))
|
|
||||||
.thenReturn(mHeaderController);
|
|
||||||
|
|
||||||
mFragment.onViewCreated(new View(RuntimeEnvironment.application), new Bundle());
|
mFragment.onViewCreated(new View(RuntimeEnvironment.application), new Bundle());
|
||||||
|
|
||||||
|
@@ -16,41 +16,28 @@
|
|||||||
|
|
||||||
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.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.BatteryStats;
|
import android.os.BatteryStats;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.View;
|
|
||||||
|
|
||||||
import com.android.internal.os.BatterySipper;
|
import com.android.internal.os.BatterySipper;
|
||||||
import com.android.internal.os.BatteryStatsHelper;
|
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.LayoutPreference;
|
import com.android.settings.applications.LayoutPreference;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowEntityHeaderController;
|
||||||
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.applications.AppUtils;
|
import com.android.settingslib.applications.AppUtils;
|
||||||
import com.android.settingslib.applications.ApplicationsState;
|
import com.android.settingslib.applications.ApplicationsState;
|
||||||
import com.android.settingslib.applications.instantapps.InstantAppDataProvider;
|
import com.android.settingslib.applications.instantapps.InstantAppDataProvider;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -64,8 +51,21 @@ 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,
|
||||||
|
shadows = ShadowEntityHeaderController.class)
|
||||||
public class AdvancedPowerUsageDetailTest {
|
public class AdvancedPowerUsageDetailTest {
|
||||||
private static final String APP_LABEL = "app label";
|
private static final String APP_LABEL = "app label";
|
||||||
private static final String SUMMARY = "summary";
|
private static final String SUMMARY = "summary";
|
||||||
@@ -85,7 +85,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 +121,17 @@ 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)
|
ShadowEntityHeaderController.setUseMock(mEntityHeaderController);
|
||||||
.newAppHeaderController(any(Fragment.class), any(View.class));
|
doReturn(mEntityHeaderController).when(mEntityHeaderController)
|
||||||
doReturn(mAppHeaderController).when(mAppHeaderController).setButtonActions(anyInt(),
|
.setButtonActions(anyInt(), anyInt());
|
||||||
anyInt());
|
doReturn(mEntityHeaderController).when(mEntityHeaderController)
|
||||||
doReturn(mAppHeaderController).when(mAppHeaderController).setIcon(any(Drawable.class));
|
.setIcon(any(Drawable.class));
|
||||||
doReturn(mAppHeaderController).when(mAppHeaderController).setIcon(any(
|
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();
|
||||||
@@ -166,13 +165,18 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
captor.capture(), anyInt(), any(), any());
|
captor.capture(), anyInt(), any(), any());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void reset() {
|
||||||
|
ShadowEntityHeaderController.reset();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInitHeader_NoAppEntry_BuildByBundle() {
|
public void testInitHeader_NoAppEntry_BuildByBundle() {
|
||||||
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 +191,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 +208,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
|
||||||
|
@@ -16,15 +16,6 @@
|
|||||||
|
|
||||||
package com.android.settings.language;
|
package com.android.settings.language;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
import static org.mockito.Matchers.any;
|
|
||||||
import static org.mockito.Mockito.doReturn;
|
|
||||||
import static org.mockito.Mockito.mock;
|
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.mockito.Mockito.times;
|
|
||||||
import static org.mockito.Mockito.verify;
|
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.app.admin.DevicePolicyManager;
|
import android.app.admin.DevicePolicyManager;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
@@ -44,7 +35,6 @@ import com.android.settings.SettingsRobolectricTestRunner;
|
|||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
import com.android.settings.core.PreferenceController;
|
import com.android.settings.core.PreferenceController;
|
||||||
import com.android.settings.dashboard.SummaryLoader;
|
import com.android.settings.dashboard.SummaryLoader;
|
||||||
import com.android.settings.fuelgauge.PowerUsageSummary;
|
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
import com.android.settings.testutils.XmlTestUtils;
|
import com.android.settings.testutils.XmlTestUtils;
|
||||||
import com.android.settings.testutils.shadow.ShadowSecureSettings;
|
import com.android.settings.testutils.shadow.ShadowSecureSettings;
|
||||||
@@ -63,6 +53,15 @@ import org.robolectric.annotation.Config;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.Matchers.any;
|
||||||
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
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 LanguageAndInputSettingsTest {
|
public class LanguageAndInputSettingsTest {
|
||||||
|
@@ -28,14 +28,13 @@ import com.android.settings.gestures.AssistGestureFeatureProvider;
|
|||||||
import com.android.settings.localepicker.LocaleFeatureProvider;
|
import com.android.settings.localepicker.LocaleFeatureProvider;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settings.overlay.SupportFeatureProvider;
|
import com.android.settings.overlay.SupportFeatureProvider;
|
||||||
import com.android.settings.security.SecurityFeatureProvider;
|
|
||||||
import com.android.settings.search2.SearchFeatureProvider;
|
|
||||||
import com.android.settings.overlay.SurveyFeatureProvider;
|
import com.android.settings.overlay.SurveyFeatureProvider;
|
||||||
|
import com.android.settings.search2.SearchFeatureProvider;
|
||||||
|
import com.android.settings.security.SecurityFeatureProvider;
|
||||||
import com.android.settings.users.UserFeatureProvider;
|
import com.android.settings.users.UserFeatureProvider;
|
||||||
|
|
||||||
import static org.mockito.Matchers.anyString;
|
import static org.mockito.Matchers.anyString;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.mockingDetails;
|
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -64,7 +63,7 @@ public class FakeFeatureFactory extends FeatureFactory {
|
|||||||
*
|
*
|
||||||
* @param context The context must be a deep mock.
|
* @param context The context must be a deep mock.
|
||||||
*/
|
*/
|
||||||
public static void setupForTest(Context context) {
|
public static FakeFeatureFactory setupForTest(Context context) {
|
||||||
sFactory = null;
|
sFactory = null;
|
||||||
when(context.getString(com.android.settings.R.string.config_featureFactory))
|
when(context.getString(com.android.settings.R.string.config_featureFactory))
|
||||||
.thenReturn(FakeFeatureFactory.class.getName());
|
.thenReturn(FakeFeatureFactory.class.getName());
|
||||||
@@ -74,6 +73,7 @@ public class FakeFeatureFactory extends FeatureFactory {
|
|||||||
} catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
// Ignore.
|
// Ignore.
|
||||||
}
|
}
|
||||||
|
return (FakeFeatureFactory) FakeFeatureFactory.getFactory(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2017 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.testutils.shadow;
|
||||||
|
|
||||||
|
import android.app.Fragment;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
|
|
||||||
|
import org.robolectric.annotation.Implementation;
|
||||||
|
import org.robolectric.annotation.Implements;
|
||||||
|
import org.robolectric.annotation.Resetter;
|
||||||
|
|
||||||
|
@Implements(value = EntityHeaderController.class, callThroughByDefault = false)
|
||||||
|
public class ShadowEntityHeaderController {
|
||||||
|
|
||||||
|
private static EntityHeaderController sMockController;
|
||||||
|
|
||||||
|
public static void setUseMock(EntityHeaderController mockController) {
|
||||||
|
sMockController = mockController;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Resetter
|
||||||
|
public static void reset() {
|
||||||
|
sMockController = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Implementation
|
||||||
|
public static EntityHeaderController newInstance(Context context, Fragment fragment,
|
||||||
|
View header) {
|
||||||
|
return sMockController;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -14,17 +14,9 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.android.settings.applications;
|
package com.android.settings.widget;
|
||||||
|
|
||||||
|
|
||||||
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;
|
||||||
@@ -43,6 +35,8 @@ import android.widget.TextView;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
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.LayoutPreference;
|
||||||
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -53,9 +47,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;
|
||||||
@@ -64,16 +66,19 @@ public class AppHeaderControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private Fragment mFragment;
|
private Fragment mFragment;
|
||||||
|
|
||||||
|
private FakeFeatureFactory mFeatureFactory;
|
||||||
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
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
FakeFeatureFactory.setupForTest(mContext);
|
||||||
|
mFeatureFactory = (FakeFeatureFactory) FakeFeatureFactory.getFactory(mContext);
|
||||||
mShadowContext = RuntimeEnvironment.application;
|
mShadowContext = RuntimeEnvironment.application;
|
||||||
|
when(mContext.getApplicationContext()).thenReturn(mContext);
|
||||||
when(mFragment.getContext()).thenReturn(mShadowContext);
|
when(mFragment.getContext()).thenReturn(mShadowContext);
|
||||||
mLayoutInflater = LayoutInflater.from(mShadowContext);
|
mLayoutInflater = LayoutInflater.from(mShadowContext);
|
||||||
mInfo = new PackageInfo();
|
mInfo = new PackageInfo();
|
||||||
@@ -82,7 +87,7 @@ public class AppHeaderControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBuildView_constructedWithoutView_shouldCreateNewView() {
|
public void testBuildView_constructedWithoutView_shouldCreateNewView() {
|
||||||
mController = new AppHeaderController(mShadowContext, mFragment, null);
|
mController = EntityHeaderController.newInstance(mShadowContext, mFragment, null);
|
||||||
View view = mController.done(mActivity);
|
View view = mController.done(mActivity);
|
||||||
|
|
||||||
assertThat(view).isNotNull();
|
assertThat(view).isNotNull();
|
||||||
@@ -90,7 +95,7 @@ public class AppHeaderControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBuildView_withContext_shouldBuildPreference() {
|
public void testBuildView_withContext_shouldBuildPreference() {
|
||||||
mController = new AppHeaderController(mShadowContext, mFragment, null);
|
mController = EntityHeaderController.newInstance(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 +104,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 = EntityHeaderController.newInstance(mShadowContext, mFragment, inputView);
|
||||||
View view = mController.done(mActivity);
|
View view = mController.done(mActivity);
|
||||||
|
|
||||||
assertThat(view).isSameAs(inputView);
|
assertThat(view).isSameAs(inputView);
|
||||||
@@ -108,11 +113,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 = EntityHeaderController.newInstance(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 +139,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 = EntityHeaderController.newInstance(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 +164,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 = EntityHeaderController.newInstance(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 +181,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 = EntityHeaderController.newInstance(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 +200,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 = EntityHeaderController.newInstance(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 +221,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 = EntityHeaderController.newInstance(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 +238,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 = EntityHeaderController.newInstance(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 +255,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 = EntityHeaderController.newInstance(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 = EntityHeaderController.newInstance(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 = EntityHeaderController.newInstance(mShadowContext, mFragment, null);
|
||||||
mController.styleActionBar(null);
|
mController.styleActionBar(null);
|
||||||
|
|
||||||
when(mActivity.getActionBar()).thenReturn(null);
|
when(mActivity.getActionBar()).thenReturn(null);
|
||||||
@@ -286,7 +296,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 = EntityHeaderController.newInstance(mShadowContext, mFragment, null);
|
||||||
mController.styleActionBar(mActivity);
|
mController.styleActionBar(mActivity);
|
||||||
|
|
||||||
verify(actionBar).setElevation(0);
|
verify(actionBar).setElevation(0);
|
||||||
@@ -297,7 +307,7 @@ public class AppHeaderControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void initAppHeaderController_appHeaderNull_useFragmentContext() {
|
public void initAppHeaderController_appHeaderNull_useFragmentContext() {
|
||||||
mController = new AppHeaderController(mContext, mFragment, null);
|
mController = EntityHeaderController.newInstance(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();
|
Reference in New Issue
Block a user