Move styleActionBar to onStart()
Change-Id: I002c266acc0e1095269e92eb7988b1ab505e48ff Fixes: 72097389 Test: robotest
This commit is contained in:
@@ -1199,7 +1199,6 @@
|
|||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name="Settings$NotificationStationActivity"
|
<activity android:name="Settings$NotificationStationActivity"
|
||||||
android:theme="@style/Theme.NotificationStation"
|
|
||||||
android:label="@string/notification_log_title"
|
android:label="@string/notification_log_title"
|
||||||
android:taskAffinity="">
|
android:taskAffinity="">
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
|
@@ -267,14 +267,6 @@
|
|||||||
<item name="android:actionBarStyle">@style/Theme.ActionBar</item>
|
<item name="android:actionBarStyle">@style/Theme.ActionBar</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Theme.NotificationStation" parent="@style/Theme.Settings">
|
|
||||||
<!-- Redefine the ActionBar style for contentInsetStart -->
|
|
||||||
<item name="android:actionBarStyle">@style/Theme.ActionBar.SubSettings</item>
|
|
||||||
<item name="*android:actionBarSize">@dimen/actionbar_size</item>
|
|
||||||
|
|
||||||
<item name="preferenceBackgroundColor">@android:color/transparent</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style name="Theme.ConfirmDeviceCredentials" parent="Theme.SubSettings">
|
<style name="Theme.ConfirmDeviceCredentials" parent="Theme.SubSettings">
|
||||||
<item name="confirmDeviceCredentialsSideMargin">@dimen/confirm_credentials_side_margin</item>
|
<item name="confirmDeviceCredentialsSideMargin">@dimen/confirm_credentials_side_margin</item>
|
||||||
<item name="confirmDeviceCredentialsTopMargin">@dimen/confirm_credentials_top_margin</item>
|
<item name="confirmDeviceCredentialsTopMargin">@dimen/confirm_credentials_top_margin</item>
|
||||||
|
@@ -29,9 +29,11 @@ import com.android.settings.widget.EntityHeaderController;
|
|||||||
import com.android.settingslib.applications.AppUtils;
|
import com.android.settingslib.applications.AppUtils;
|
||||||
import com.android.settingslib.applications.ApplicationsState.AppEntry;
|
import com.android.settingslib.applications.ApplicationsState.AppEntry;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStart;
|
||||||
|
|
||||||
public class AppHeaderViewPreferenceController extends BasePreferenceController
|
public class AppHeaderViewPreferenceController extends BasePreferenceController
|
||||||
implements AppInfoDashboardFragment.Callback {
|
implements AppInfoDashboardFragment.Callback, LifecycleObserver, OnStart {
|
||||||
|
|
||||||
private static final String KEY_HEADER = "header_view";
|
private static final String KEY_HEADER = "header_view";
|
||||||
|
|
||||||
@@ -40,12 +42,17 @@ public class AppHeaderViewPreferenceController extends BasePreferenceController
|
|||||||
private final String mPackageName;
|
private final String mPackageName;
|
||||||
private final Lifecycle mLifecycle;
|
private final Lifecycle mLifecycle;
|
||||||
|
|
||||||
|
private EntityHeaderController mEntityHeaderController;
|
||||||
|
|
||||||
public AppHeaderViewPreferenceController(Context context, AppInfoDashboardFragment parent,
|
public AppHeaderViewPreferenceController(Context context, AppInfoDashboardFragment parent,
|
||||||
String packageName, Lifecycle lifecycle) {
|
String packageName, Lifecycle lifecycle) {
|
||||||
super(context, KEY_HEADER);
|
super(context, KEY_HEADER);
|
||||||
mParent = parent;
|
mParent = parent;
|
||||||
mPackageName = packageName;
|
mPackageName = packageName;
|
||||||
mLifecycle = lifecycle;
|
mLifecycle = lifecycle;
|
||||||
|
if (mLifecycle != null) {
|
||||||
|
mLifecycle.addObserver(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -58,17 +65,21 @@ public class AppHeaderViewPreferenceController extends BasePreferenceController
|
|||||||
super.displayPreference(screen);
|
super.displayPreference(screen);
|
||||||
mHeader = (LayoutPreference) screen.findPreference(KEY_HEADER);
|
mHeader = (LayoutPreference) screen.findPreference(KEY_HEADER);
|
||||||
final Activity activity = mParent.getActivity();
|
final Activity activity = mParent.getActivity();
|
||||||
EntityHeaderController
|
mEntityHeaderController = EntityHeaderController
|
||||||
.newInstance(activity, mParent, mHeader.findViewById(R.id.entity_header))
|
.newInstance(activity, mParent, mHeader.findViewById(R.id.entity_header))
|
||||||
.setRecyclerView(mParent.getListView(), mLifecycle)
|
|
||||||
.setPackageName(mPackageName)
|
.setPackageName(mPackageName)
|
||||||
.setHasAppInfoLink(false)
|
|
||||||
.setButtonActions(EntityHeaderController.ActionType.ACTION_APP_PREFERENCE,
|
.setButtonActions(EntityHeaderController.ActionType.ACTION_APP_PREFERENCE,
|
||||||
EntityHeaderController.ActionType.ACTION_NONE)
|
EntityHeaderController.ActionType.ACTION_NONE)
|
||||||
.styleActionBar(activity)
|
|
||||||
.bindHeaderButtons();
|
.bindHeaderButtons();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStart() {
|
||||||
|
mEntityHeaderController
|
||||||
|
.setRecyclerView(mParent.getListView(), mLifecycle)
|
||||||
|
.styleActionBar(mParent.getActivity());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void refreshUi() {
|
public void refreshUi() {
|
||||||
setAppLabelAndIcon(mParent.getPackageInfo(), mParent.getAppEntry());
|
setAppLabelAndIcon(mParent.getPackageInfo(), mParent.getAppEntry());
|
||||||
@@ -80,13 +91,11 @@ public class AppHeaderViewPreferenceController extends BasePreferenceController
|
|||||||
final boolean isInstantApp = AppUtils.isInstant(pkgInfo.applicationInfo);
|
final boolean isInstantApp = AppUtils.isInstant(pkgInfo.applicationInfo);
|
||||||
final CharSequence summary = isInstantApp
|
final CharSequence summary = isInstantApp
|
||||||
? null : mContext.getString(Utils.getInstallationStatus(appEntry.info));
|
? null : mContext.getString(Utils.getInstallationStatus(appEntry.info));
|
||||||
EntityHeaderController
|
mEntityHeaderController
|
||||||
.newInstance(activity, mParent, mHeader.findViewById(R.id.entity_header))
|
|
||||||
.setLabel(appEntry)
|
.setLabel(appEntry)
|
||||||
.setIcon(appEntry)
|
.setIcon(appEntry)
|
||||||
.setSummary(summary)
|
.setSummary(summary)
|
||||||
.setIsInstantApp(isInstantApp)
|
.setIsInstantApp(isInstantApp)
|
||||||
.done(activity, false /* rebindActions */);
|
.done(activity, false /* rebindActions */);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,10 @@
|
|||||||
|
|
||||||
package com.android.settings.widget;
|
package com.android.settings.widget;
|
||||||
|
|
||||||
|
import static com.android.internal.logging.nano.MetricsProto.MetricsEvent
|
||||||
|
.ACTION_OPEN_APP_NOTIFICATION_SETTING;
|
||||||
|
import static com.android.internal.logging.nano.MetricsProto.MetricsEvent.ACTION_OPEN_APP_SETTING;
|
||||||
|
|
||||||
import android.annotation.IdRes;
|
import android.annotation.IdRes;
|
||||||
import android.annotation.UserIdInt;
|
import android.annotation.UserIdInt;
|
||||||
import android.app.ActionBar;
|
import android.app.ActionBar;
|
||||||
@@ -27,6 +31,7 @@ import android.content.pm.PackageInfo;
|
|||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
import android.graphics.drawable.ColorDrawable;
|
import android.graphics.drawable.ColorDrawable;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.os.Bundle;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.support.annotation.IntDef;
|
import android.support.annotation.IntDef;
|
||||||
import android.support.annotation.VisibleForTesting;
|
import android.support.annotation.VisibleForTesting;
|
||||||
@@ -54,10 +59,6 @@ import com.android.settingslib.core.lifecycle.Lifecycle;
|
|||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.lang.annotation.RetentionPolicy;
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
|
||||||
import static com.android.internal.logging.nano.MetricsProto.MetricsEvent
|
|
||||||
.ACTION_OPEN_APP_NOTIFICATION_SETTING;
|
|
||||||
import static com.android.internal.logging.nano.MetricsProto.MetricsEvent.ACTION_OPEN_APP_SETTING;
|
|
||||||
|
|
||||||
public class EntityHeaderController {
|
public class EntityHeaderController {
|
||||||
|
|
||||||
@IntDef({ActionType.ACTION_NONE,
|
@IntDef({ActionType.ACTION_NONE,
|
||||||
@@ -291,6 +292,11 @@ public class EntityHeaderController {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Styles the action bar (elevation, scrolling behaviors, color, etc).
|
||||||
|
* <p/>
|
||||||
|
* This method must be called after {@link Fragment#onCreate(Bundle)}.
|
||||||
|
*/
|
||||||
public EntityHeaderController 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.");
|
||||||
|
@@ -16,15 +16,25 @@
|
|||||||
|
|
||||||
package com.android.settings.applications.appinfo;
|
package com.android.settings.applications.appinfo;
|
||||||
|
|
||||||
|
import static android.arch.lifecycle.Lifecycle.Event.ON_START;
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.ActionBar;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
|
import android.arch.lifecycle.LifecycleOwner;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
import android.support.v7.preference.PreferenceScreen;
|
import android.support.v7.preference.PreferenceScreen;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
@@ -33,12 +43,14 @@ import com.android.settings.TestConfig;
|
|||||||
import com.android.settings.applications.LayoutPreference;
|
import com.android.settings.applications.LayoutPreference;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settingslib.applications.ApplicationsState;
|
import com.android.settingslib.applications.ApplicationsState;
|
||||||
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
|
||||||
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;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.Robolectric;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
@@ -48,19 +60,34 @@ public class AppHeaderViewPreferenceControllerTest {
|
|||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private AppInfoDashboardFragment mFragment;
|
private AppInfoDashboardFragment mFragment;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private Activity mActivity;
|
private PreferenceScreen mScreen;
|
||||||
|
@Mock
|
||||||
|
private LayoutPreference mPreference;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
private Activity mActivity;
|
||||||
|
private LifecycleOwner mLifecycleOwner;
|
||||||
|
private Lifecycle mLifecycle;
|
||||||
|
private View mHeader;
|
||||||
private AppHeaderViewPreferenceController mController;
|
private AppHeaderViewPreferenceController mController;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
|
mActivity = spy(Robolectric.buildActivity(Activity.class).get());
|
||||||
|
mLifecycleOwner = () -> mLifecycle;
|
||||||
|
mLifecycle = new Lifecycle(mLifecycleOwner);
|
||||||
|
mHeader = LayoutInflater.from(mContext).inflate(R.layout.settings_entity_header, null);
|
||||||
|
|
||||||
when(mFragment.getActivity()).thenReturn(mActivity);
|
when(mFragment.getActivity()).thenReturn(mActivity);
|
||||||
when(mActivity.getApplicationContext()).thenReturn(mContext);
|
when(mScreen.findPreference(anyString())).thenReturn(mPreference);
|
||||||
mController = new AppHeaderViewPreferenceController(mContext, mFragment, "Package1", null);
|
when(mPreference.findViewById(R.id.entity_header)).thenReturn(mHeader);
|
||||||
|
|
||||||
|
mController = new AppHeaderViewPreferenceController(mContext, mFragment, "Package1",
|
||||||
|
mLifecycle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -77,21 +104,29 @@ public class AppHeaderViewPreferenceControllerTest {
|
|||||||
when(mFragment.getAppEntry()).thenReturn(appEntry);
|
when(mFragment.getAppEntry()).thenReturn(appEntry);
|
||||||
when(mFragment.getPackageInfo()).thenReturn(packageInfo);
|
when(mFragment.getPackageInfo()).thenReturn(packageInfo);
|
||||||
|
|
||||||
final PreferenceScreen screen = mock(PreferenceScreen.class);
|
|
||||||
final LayoutPreference preference = mock(LayoutPreference.class);
|
|
||||||
when(screen.findPreference(mController.getPreferenceKey())).thenReturn(preference);
|
|
||||||
final View header = mock(View.class);
|
|
||||||
when(preference.findViewById(R.id.entity_header)).thenReturn(header);
|
|
||||||
final TextView title = mock(TextView.class);
|
|
||||||
when(header.findViewById(R.id.entity_header_title)).thenReturn(title);
|
|
||||||
final TextView summary = mock(TextView.class);
|
|
||||||
when(header.findViewById(R.id.entity_header_summary)).thenReturn(summary);
|
|
||||||
mController.displayPreference(screen);
|
|
||||||
|
|
||||||
|
final TextView title = mHeader.findViewById(R.id.entity_header_title);
|
||||||
|
final TextView summary = mHeader.findViewById(R.id.entity_header_summary);
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
mController.refreshUi();
|
mController.refreshUi();
|
||||||
|
|
||||||
verify(title).setText(appLabel);
|
assertThat(title.getText()).isEqualTo(appLabel);
|
||||||
verify(summary).setText(mContext.getString(R.string.installed));
|
assertThat(summary.getText()).isEqualTo(mContext.getString(R.string.installed));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStart_shouldStyleActionBar() {
|
||||||
|
final ActionBar actionBar = mock(ActionBar.class);
|
||||||
|
when(mActivity.getActionBar()).thenReturn(actionBar);
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
verifyZeroInteractions(actionBar);
|
||||||
|
|
||||||
|
mLifecycle.handleLifecycleEvent(ON_START);
|
||||||
|
|
||||||
|
verify(actionBar).setBackgroundDrawable(any(Drawable.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user