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

Commit 7b0b26ec authored by josephpv's avatar josephpv
Browse files

Add waiting screen before PS setup completion

At the end of PS setup just before showing the final sucess screen this
change adds a new screen with loading layout which enables profile quiet
mode.
After enabling quiet mode checks if user is stopped before removing the
loading layout screen. Until user is stopped loading screen will be
shown.

Bug: 329042236
Bug: 328393532
Test: Manual verify new delay screen is shown
Change-Id: Iac3fd2f0f5c75a64719fbce32ff4dbfb533322d5
parent 4230ad4b
Loading
Loading
Loading
Loading
+29 −0
Original line number Diff line number Diff line
<?xml version="1.0" encoding="utf-8"?>
<!--
  ~ Copyright (C) 2024 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.
  -->

<com.google.android.setupdesign.GlifLoadingLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/private_space_pre_finish"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:icon="@drawable/ic_private_space_icon"
    app:sudUsePartnerHeavyTheme="true"
    app:sudIllustrationType="default"
    app:sucHeaderText="@string/private_space_pre_finish_title">
</com.google.android.setupdesign.GlifLoadingLayout>
 No newline at end of file
+10 −3
Original line number Diff line number Diff line
@@ -46,6 +46,13 @@
            android:id="@+id/action_retry_profile_creation"
            app:destination="@id/ps_auto_advance_fragment"/>
    </fragment>
    <fragment android:id="@+id/ps_pre_finish_delay_fragment"
              android:name="com.android.settings.privatespace.SetupPreFinishDelayFragment"
              android:label="fragment_ps_pre_finish">
        <action
            android:id="@+id/action_success_fragment"
            app:destination="@id/ps_profile_success_fragment"/>
    </fragment>
    <fragment android:id="@+id/ps_profile_success_fragment"
              android:name="com.android.settings.privatespace.SetupSuccessFragment"
              android:label="fragment_ps_success"/>
@@ -64,7 +71,7 @@
              android:label="fragment_ps_lock">
        <action
            android:id="@+id/action_lock_success_fragment"
            app:destination="@id/ps_profile_success_fragment"/>
            app:destination="@id/ps_pre_finish_delay_fragment"/>
    </fragment>
    <fragment android:id="@+id/ps_account_intro_fragment"
              android:name="com.android.settings.privatespace.PrivateSpaceGaiaEducationFragment"
@@ -76,6 +83,6 @@
            android:id="@+id/action_advance_login_error"
            app:destination="@id/ps_account_error_fragment"/>
    </fragment>
    <action android:id="@+id/action_success_fragment"
            app:destination="@id/ps_profile_success_fragment"/>
    <action android:id="@+id/action_pre_finish_delay_fragment"
            app:destination="@id/ps_pre_finish_delay_fragment"/>
</navigation>
+2 −0
Original line number Diff line number Diff line
@@ -1343,6 +1343,8 @@
    <string name="private_space_use_screenlock_label">Use screen lock</string>
    <!-- Label for private space lock setup button to choose a new lock. [CHAR LIMIT=50] -->
    <string name="private_space_set_lock_label">Choose new lock</string>
    <!-- Title for private space setup pre completion screen to add a delay. [CHAR LIMIT=30] -->
    <string name="private_space_pre_finish_title">Just a sec\u2026</string>
    <!-- Title for private space setup success screen. [CHAR LIMIT=30] -->
    <string name="private_space_success_title">All set!</string>
    <!-- Summary for the private space setup success screen. [CHAR LIMIT=NONE] -->
+9 −7
Original line number Diff line number Diff line
@@ -59,7 +59,7 @@ public class AutoAdvanceSetupFragment extends InstrumentedFragment {
    private static final int ANIMATION_DURATION_MILLIS = 500;
    private static final int HEADER_TEXT_MAX_LINES = 4;
    private GlifLayout mRootView;
    private Handler mHandler;
    private static final Handler sHandler = new Handler(Looper.getMainLooper());
    private int mScreenTitleIndex;
    private static final List<Pair<Integer, Integer>> HEADER_ILLUSTRATION_PAIRS =
            ImmutableList.of(
@@ -77,7 +77,7 @@ public class AutoAdvanceSetupFragment extends InstrumentedFragment {
                    if (getActivity() != null) {
                        if (++mScreenTitleIndex < HEADER_ILLUSTRATION_PAIRS.size()) {
                            startFadeOutAnimation();
                            mHandler.postDelayed(mUpdateScreenResources, DELAY_BETWEEN_SCREENS);
                            sHandler.postDelayed(mUpdateScreenResources, DELAY_BETWEEN_SCREENS);
                        } else if (PrivateSpaceMaintainer.getInstance(getActivity())
                                .doesPrivateSpaceExist()) {
                            mMetricsFeatureProvider.action(
@@ -131,8 +131,6 @@ public class AutoAdvanceSetupFragment extends InstrumentedFragment {
        mRootView.getHeaderTextView().setMaxLines(HEADER_TEXT_MAX_LINES);
        mRootView.getHeaderTextView().setBreakStrategy(BREAK_STRATEGY_SIMPLE);
        updateHeaderAndIllustration();
        mHandler = new Handler(Looper.getMainLooper());
        mHandler.postDelayed(mUpdateScreenResources, DELAY_BETWEEN_SCREENS);
        OnBackPressedCallback callback =
                new OnBackPressedCallback(true /* enabled by default */) {
                    @Override
@@ -153,12 +151,16 @@ public class AutoAdvanceSetupFragment extends InstrumentedFragment {

    @Override
    public void onDestroy() {
        if (mHandler != null) {
            mHandler.removeCallbacks(mUpdateScreenResources);
        }
        sHandler.removeCallbacks(mUpdateScreenResources);
        super.onDestroy();
    }

    @Override
    public void onResume() {
        sHandler.postDelayed(mUpdateScreenResources, DELAY_BETWEEN_SCREENS);
        super.onResume();
    }

    @Override
    public int getMetricsCategory() {
        return SettingsEnums.PRIVATE_SPACE_SETUP_SPACE_CREATION;
+1 −1
Original line number Diff line number Diff line
@@ -97,7 +97,7 @@ public class PrivateSpaceSetLockFragment extends InstrumentedFragment {
                    getContext(), SettingsEnums.ACTION_PRIVATE_SPACE_SETUP_USE_SCREEN_LOCK);
            // Simply Use default screen lock. No need to handle
            NavHostFragment.findNavController(PrivateSpaceSetLockFragment.this)
                    .navigate(R.id.action_lock_success_fragment);
                    .navigate(R.id.action_pre_finish_delay_fragment);
        };
    }

Loading