Style action bar during onResume instead of onCreate

am: e156d9a59f

Change-Id: Iee729bda63cb9cf007754d1003fa02d755d5a771
This commit is contained in:
Fan Zhang
2017-08-02 20:50:24 +00:00
committed by android-build-merger
3 changed files with 27 additions and 18 deletions

View File

@@ -114,7 +114,7 @@ public class AccountDetailDashboardFragment extends DashboardFragment {
mRemoveAccountController = new RemoveAccountPreferenceController(context, this);
controllers.add(mRemoveAccountController);
controllers.add(new AccountHeaderPreferenceController(
context, getLifecycle(), getActivity(), this, getArguments()));
context, getLifecycle(), getActivity(), this /* host */, getArguments()));
return controllers;
}

View File

@@ -16,6 +16,9 @@
package com.android.settings.accounts;
import static com.android.settings.accounts.AccountDetailDashboardFragment.KEY_ACCOUNT;
import static com.android.settings.accounts.AccountDetailDashboardFragment.KEY_USER_HANDLE;
import android.accounts.Account;
import android.app.Activity;
import android.content.Context;
@@ -30,11 +33,11 @@ import com.android.settings.core.PreferenceController;
import com.android.settings.widget.EntityHeaderController;
import com.android.settingslib.accounts.AuthenticatorHelper;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.core.lifecycle.LifecycleObserver;
import com.android.settingslib.core.lifecycle.events.OnResume;
import static com.android.settings.accounts.AccountDetailDashboardFragment.KEY_ACCOUNT;
import static com.android.settings.accounts.AccountDetailDashboardFragment.KEY_USER_HANDLE;
public class AccountHeaderPreferenceController extends PreferenceController {
public class AccountHeaderPreferenceController extends PreferenceController
implements LifecycleObserver, OnResume {
private static final String KEY_ACCOUNT_HEADER = "account_header";
@@ -42,14 +45,14 @@ public class AccountHeaderPreferenceController extends PreferenceController {
private final PreferenceFragment mHost;
private final Account mAccount;
private final UserHandle mUserHandle;
private final Lifecycle mLifecycle;
private LayoutPreference mHeaderPreference;
public AccountHeaderPreferenceController(Context context, Lifecycle lifecycle,
Activity activity, PreferenceFragment host, Bundle args) {
super(context);
mActivity = activity;
mHost = host;
mLifecycle = lifecycle;
if (args != null && args.containsKey(KEY_ACCOUNT)) {
mAccount = args.getParcelable(KEY_ACCOUNT);
} else {
@@ -61,6 +64,9 @@ public class AccountHeaderPreferenceController extends PreferenceController {
} else {
mUserHandle = null;
}
if (lifecycle != null) {
lifecycle.addObserver(this);
}
}
@Override
@@ -76,14 +82,15 @@ public class AccountHeaderPreferenceController extends PreferenceController {
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
final LayoutPreference headerPreference =
(LayoutPreference) screen.findPreference(KEY_ACCOUNT_HEADER);
mHeaderPreference = (LayoutPreference) screen.findPreference(KEY_ACCOUNT_HEADER);
}
@Override
public void onResume() {
final AuthenticatorHelper helper = new AuthenticatorHelper(mContext, mUserHandle, null);
EntityHeaderController
.newInstance(mActivity, mHost, headerPreference.findViewById(R.id.entity_header))
.setRecyclerView(mHost.getListView(), mLifecycle)
.newInstance(mActivity, mHost, mHeaderPreference.findViewById(R.id.entity_header))
.setLabel(mAccount.name)
.setIcon(helper.getDrawableForType(mContext, mAccount.type))
.done(mActivity, true /* rebindButtons */);