Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 52c75baa authored by Maurice Lam's avatar Maurice Lam
Browse files

[Setup] Theme ChooseLockGeneric for setup wizard

This is step one of theming the set-up lock screen flow to match the
setup wizard theme. This shows the general approach of creating a
subclass of both the activity and fragment and overriding methods to
achieve the desired behavior for setup.

ag/594000 is a much more comprehensive change for what the final
change will look like.

Bug: 18482708
Change-Id: Idff34937f39f46a0c488df2cae4c46155b80cab7
parent faf1dd20
Loading
Loading
Loading
Loading
+10 −0
Original line number Diff line number Diff line
@@ -1133,6 +1133,16 @@
            android:exported="false"
            android:windowSoftInputMode="stateVisible|adjustResize"/>

        <activity android:name="SetupChooseLockGeneric"
            android:taskAffinity="com.android.wizard"
            android:theme="@style/SetupWizardDisableAppStartingTheme"
            android:label="@string/lockpassword_choose_lock_generic_header">
            <intent-filter>
                <action android:name="com.android.settings.SETUP_LOCK_SCREEN" />
                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>

        <activity android:name="ChooseLockGeneric"
            android:label="@string/lockpassword_choose_lock_generic_header"
            android:excludeFromRecents="true" >
+2 −2
Original line number Diff line number Diff line
@@ -28,7 +28,7 @@
        <item name="android:windowBackground">@null</item>
    </style>

    <style name="SetupWizardWifiTheme" parent="android:Theme.Material.NoActionBar">
    <style name="SetupWizardTheme" parent="android:Theme.Material.NoActionBar">
        <item name="android:alertDialogTheme">@style/Theme.WifiDialog</item>
        <item name="android:colorAccent">@color/setup_wizard_color_accent_dark</item>
        <item name="android:listPreferredItemPaddingEnd">@dimen/setup_wizard_margin_sides</item>
@@ -45,7 +45,7 @@
        <item name="preferenceBackgroundColor">?android:attr/colorBackground</item>
    </style>

    <style name="SetupWizardWifiTheme.Light" parent="android:Theme.Material.Light.NoActionBar">
    <style name="SetupWizardTheme.Light" parent="android:Theme.Material.Light.NoActionBar">
        <item name="android:alertDialogTheme">@style/Theme.Light.WifiDialog</item>
        <item name="android:colorAccent">@color/setup_wizard_color_accent_light</item>
        <item name="android:listPreferredItemPaddingEnd">@dimen/setup_wizard_margin_sides</item>
+6 −1
Original line number Diff line number Diff line
@@ -19,6 +19,7 @@ package com.android.settings;
import android.accessibilityservice.AccessibilityServiceInfo;
import android.app.Activity;
import android.app.ActivityManagerNative;
import android.app.Fragment;
import android.app.PendingIntent;
import android.app.admin.DevicePolicyManager;
import android.content.Context;
@@ -50,7 +51,7 @@ public class ChooseLockGeneric extends SettingsActivity {
    @Override
    public Intent getIntent() {
        Intent modIntent = new Intent(super.getIntent());
        modIntent.putExtra(EXTRA_SHOW_FRAGMENT, ChooseLockGenericFragment.class.getName());
        modIntent.putExtra(EXTRA_SHOW_FRAGMENT, getFragmentClass().getName());
        return modIntent;
    }

@@ -60,6 +61,10 @@ public class ChooseLockGeneric extends SettingsActivity {
        return false;
    }

    /* package */ Class<? extends Fragment> getFragmentClass() {
        return ChooseLockGenericFragment.class;
    }

    public static class InternalActivity extends ChooseLockGeneric {
    }

+85 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2014 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;

import com.android.setupwizard.navigationbar.SetupWizardNavBar;


import android.content.res.Resources;
import android.os.Bundle;
import android.preference.PreferenceFragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ListView;

public class SetupChooseLockGeneric extends ChooseLockGeneric
        implements SetupWizardNavBar.NavigationBarListener {

    @Override
    protected boolean isValidFragment(String fragmentName) {
        return SetupChooseLockGenericFragment.class.getName().equals(fragmentName);
    }

    @Override
    /* package */ Class<? extends PreferenceFragment> getFragmentClass() {
        return SetupChooseLockGenericFragment.class;
    }

    @Override
    protected void onApplyThemeResource(Resources.Theme theme, int resid, boolean first) {
        resid = SetupWizardUtils.getTheme(getIntent(), resid);
        super.onApplyThemeResource(theme, resid, first);
    }

    @Override
    public void onNavigationBarCreated(SetupWizardNavBar bar) {
        SetupWizardUtils.setImmersiveMode(this, bar);
        bar.getNextButton().setEnabled(false);
    }

    @Override
    public void onNavigateBack() {
        onBackPressed();
    }

    @Override
    public void onNavigateNext() {
    }

    public static class SetupChooseLockGenericFragment extends ChooseLockGenericFragment {

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                Bundle savedInstanceState) {
            final View view = inflater.inflate(R.layout.setup_preference, container, false);
            ListView list = (ListView) view.findViewById(android.R.id.list);
            View title = view.findViewById(R.id.title);
            if (title == null) {
                final View header = inflater.inflate(R.layout.setup_wizard_header, list, false);
                list.addHeaderView(header, null, false);
            }
            return view;
        }

        @Override
        public void onViewCreated(View view, Bundle savedInstanceState) {
            super.onViewCreated(view, savedInstanceState);
            SetupWizardUtils.setHeaderText(getActivity(), getActivity().getTitle());
        }
    }
}
+106 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2014 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;

import com.android.setupwizard.navigationbar.SetupWizardNavBar;


import android.app.Activity;
import android.content.Intent;
import android.graphics.Color;
import android.view.Window;
import android.widget.TextView;

public class SetupWizardUtils {
    private static final String TAG = "SetupWizardUtils";

    // Extra containing the resource name of the theme to be used
    public static final String EXTRA_THEME = "theme";
    public static final String THEME_HOLO = "holo";
    public static final String THEME_HOLO_LIGHT = "holo_light";
    public static final String THEME_MATERIAL = "material";
    public static final String THEME_MATERIAL_LIGHT = "material_light";

    public static final String EXTRA_USE_IMMERSIVE_MODE = "useImmersiveMode";

    // From WizardManager (must match constants maintained there)
    public static final String ACTION_NEXT = "com.android.wizard.NEXT";
    public static final String EXTRA_SCRIPT_URI = "scriptUri";
    public static final String EXTRA_ACTION_ID = "actionId";
    public static final String EXTRA_RESULT_CODE = "com.android.setupwizard.ResultCode";
    public static final int NEXT_REQUEST = 10000;

    public static boolean isUsingWizardManager(Activity activity) {
        return activity.getIntent().hasExtra(EXTRA_SCRIPT_URI);
    }

    /**
     * Send the results of this activity to WizardManager, which will then send out the next
     * scripted activity. WizardManager does not actually return an activity result, but if we
     * invoke WizardManager without requesting a result, the framework will choose not to issue a
     * call to onActivityResult with RESULT_CANCELED when navigating backward.
     */
    public static void sendResultsToSetupWizard(Activity activity, int resultCode) {
        final Intent intent = activity.getIntent();
        final Intent nextIntent = new Intent(ACTION_NEXT);
        nextIntent.putExtra(EXTRA_SCRIPT_URI, intent.getStringExtra(EXTRA_SCRIPT_URI));
        nextIntent.putExtra(EXTRA_ACTION_ID, intent.getStringExtra(EXTRA_ACTION_ID));
        nextIntent.putExtra(EXTRA_THEME, intent.getStringExtra(EXTRA_THEME));
        nextIntent.putExtra(EXTRA_RESULT_CODE, resultCode);
        activity.startActivityForResult(nextIntent, NEXT_REQUEST);
    }

    public static int getTheme(Intent intent, int defaultResId) {
        final String themeName = intent.getStringExtra(EXTRA_THEME);
        int resid = defaultResId;
        if (THEME_HOLO_LIGHT.equalsIgnoreCase(themeName) ||
                THEME_MATERIAL_LIGHT.equalsIgnoreCase(themeName)) {
            resid = R.style.SetupWizardTheme_Light;
        } else if (THEME_HOLO.equalsIgnoreCase(themeName) ||
                THEME_MATERIAL.equalsIgnoreCase(themeName)) {
            resid = R.style.SetupWizardTheme;
        }
        return resid;
    }

    /**
     * Sets the immersive mode related flags based on the extra in the intent which started the
     * activity.
     */
    public static void setImmersiveMode(Activity activity, SetupWizardNavBar navBar) {
        final boolean useImmersiveMode =
                activity.getIntent().getBooleanExtra(EXTRA_USE_IMMERSIVE_MODE, false);
        navBar.setUseImmersiveMode(useImmersiveMode);
        if (useImmersiveMode) {
            final Window window = activity.getWindow();
            window.setNavigationBarColor(Color.TRANSPARENT);
            window.setStatusBarColor(Color.TRANSPARENT);
        }
    }

    public static TextView getHeader(Activity activity) {
        return (TextView) activity.findViewById(R.id.title);
    }

    public static void setHeaderText(Activity activity, int text) {
        getHeader(activity).setText(text);
    }

    public static void setHeaderText(Activity activity, CharSequence text) {
        getHeader(activity).setText(text);
    }
}
Loading