summaryrefslogtreecommitdiffstats
path: root/src/com/cyanogenmod/setupwizard/setup
diff options
context:
space:
mode:
authorcretin45 <cretin45@gmail.com>2016-04-26 13:43:22 -0700
committercretin45 <cretin45@gmail.com>2016-04-27 10:35:48 -0700
commit81092777554443484cd871756ea22dfe2b841e82 (patch)
treeef5781eab3cd1c64447315e229d1fccad4727016 /src/com/cyanogenmod/setupwizard/setup
parent941aa1e1e2459c83c19a27aac2de1bf0370a2717 (diff)
downloadpackages_apps_SetupWizard-81092777554443484cd871756ea22dfe2b841e82.zip
packages_apps_SetupWizard-81092777554443484cd871756ea22dfe2b841e82.tar.gz
packages_apps_SetupWizard-81092777554443484cd871756ea22dfe2b841e82.tar.bz2
SetupWizard: Ensure compliance with GMS TOS
* Launches GMS TOS per documentation * Filters out redundant location page if GMS present * Uses setupwizardlib for some helper functions * Hide notification icons Issue-id: CYNGNOS-2599 Change-Id: I4b59592f0b84d0eb0eafe365eab3bad77c1f76ff
Diffstat (limited to 'src/com/cyanogenmod/setupwizard/setup')
-rw-r--r--src/com/cyanogenmod/setupwizard/setup/CMSetupWizardData.java7
-rw-r--r--src/com/cyanogenmod/setupwizard/setup/GmsAccountPage.java32
-rw-r--r--src/com/cyanogenmod/setupwizard/setup/OtherSettingsPage.java96
3 files changed, 45 insertions, 90 deletions
diff --git a/src/com/cyanogenmod/setupwizard/setup/CMSetupWizardData.java b/src/com/cyanogenmod/setupwizard/setup/CMSetupWizardData.java
index ca0d9de..b4cba65 100644
--- a/src/com/cyanogenmod/setupwizard/setup/CMSetupWizardData.java
+++ b/src/com/cyanogenmod/setupwizard/setup/CMSetupWizardData.java
@@ -113,8 +113,13 @@ public class CMSetupWizardData extends AbstractSetupData {
boolean isConnected = SetupWizardUtils.isNetworkConnected(mContext);
GmsAccountPage gmsAccountPage =
(GmsAccountPage) getPage(GmsAccountPage.TAG);
+ OtherSettingsPage otherSettingsPage = (OtherSettingsPage) getPage(OtherSettingsPage.TAG);
if (gmsAccountPage != null) {
- gmsAccountPage.setHidden(!isConnected && gmsAccountPage.canSkip());
+ boolean hidden = !isConnected && gmsAccountPage.canSkip();
+ gmsAccountPage.setHidden(hidden);
+ if (otherSettingsPage != null) {
+ otherSettingsPage.setHidden(!hidden);
+ }
}
CyanogenServicesPage cyanogenServicesPage =
(CyanogenServicesPage) getPage(CyanogenServicesPage.TAG);
diff --git a/src/com/cyanogenmod/setupwizard/setup/GmsAccountPage.java b/src/com/cyanogenmod/setupwizard/setup/GmsAccountPage.java
index eebf3f5..2b4741a 100644
--- a/src/com/cyanogenmod/setupwizard/setup/GmsAccountPage.java
+++ b/src/com/cyanogenmod/setupwizard/setup/GmsAccountPage.java
@@ -32,6 +32,7 @@ import android.os.Bundle;
import android.service.persistentdata.PersistentDataBlockManager;
import android.util.Log;
+import com.android.setupwizardlib.util.ResultCodes;
import com.cyanogenmod.setupwizard.R;
import com.cyanogenmod.setupwizard.SetupWizardApp;
import com.cyanogenmod.setupwizard.cmstats.SetupStats;
@@ -46,6 +47,7 @@ public class GmsAccountPage extends SetupPage {
public static final String ACTION_RESTORE = "com.google.android.setupwizard.RESTORE";
public static final String ACTION_PROGRESS = "com.google.android.setupwizard.PROGRESS";
+ public static final String ACTION_VENDOR_SETUP = "com.google.android.setupwizard.VENDOR_SETUP";
public static final String RESTORE_ACTION_ID = "mfm_restore_start";
public static final String RESTORE_CHECK_ID = "restore_check";
public static final String FRAGMENT_START_RESTORE =
@@ -128,7 +130,10 @@ public class GmsAccountPage extends SetupPage {
}
}
}
- if (requestCode == SetupWizardApp.REQUEST_CODE_SETUP_GMS && data != null) {
+ if (requestCode == SetupWizardApp.REQUEST_CODE_SETUP_GMS &&
+ resultCode == ResultCodes.RESULT_SKIP) {
+ launchGmsVendorSetup();
+ } else if (requestCode == SetupWizardApp.REQUEST_CODE_SETUP_GMS && data != null) {
if (SetupWizardUtils.isOwner() && resultCode == Activity.RESULT_OK) {
// If we don't have a restore token and a restore account, then we need to
@@ -242,6 +247,31 @@ public class GmsAccountPage extends SetupPage {
}
}
+ private void launchGmsVendorSetup() {
+ if (SetupWizardApp.DEBUG) {
+ Log.d(TAG, "Launching gms vendor setup page");
+ }
+ try {
+ Intent intent = new Intent(ACTION_VENDOR_SETUP);
+ intent.setPackage(SetupWizardUtils.GOOGLE_SETUPWIZARD_PACKAGE);
+ intent.putExtra(SetupWizardApp.EXTRA_ALLOW_SKIP, true);
+ intent.putExtra(SetupWizardApp.EXTRA_USE_IMMERSIVE, true);
+ intent.putExtra(SetupWizardApp.EXTRA_FIRST_RUN, true);
+ intent.putExtra(SetupWizardApp.EXTRA_THEME, SetupWizardApp.EXTRA_MATERIAL_LIGHT);
+ ActivityOptions options =
+ ActivityOptions.makeCustomAnimation(mContext,
+ android.R.anim.fade_in,
+ android.R.anim.fade_out);
+ mFragment.startActivityForResult(
+ intent,
+ SetupWizardApp.REQUEST_CODE_VENDOR_SETUP_GMS, options.toBundle());
+ return;
+ } catch (Exception e) {
+ // Move on if the vendor setup activity is not found.
+ getCallbacks().onNextPage();
+ }
+ }
+
public boolean canSkip() {
final PersistentDataBlockManager pdbManager = (PersistentDataBlockManager)
mContext.getSystemService(Context.PERSISTENT_DATA_BLOCK_SERVICE);
diff --git a/src/com/cyanogenmod/setupwizard/setup/OtherSettingsPage.java b/src/com/cyanogenmod/setupwizard/setup/OtherSettingsPage.java
index 0ed17ff..7ed23dc 100644
--- a/src/com/cyanogenmod/setupwizard/setup/OtherSettingsPage.java
+++ b/src/com/cyanogenmod/setupwizard/setup/OtherSettingsPage.java
@@ -16,40 +16,27 @@
package com.cyanogenmod.setupwizard.setup;
+import com.cyanogenmod.setupwizard.R;
+import com.cyanogenmod.setupwizard.cmstats.SetupStats;
+import com.cyanogenmod.setupwizard.ui.SetupPageFragment;
+import com.cyanogenmod.setupwizard.util.SetupWizardUtils;
+
import android.app.Fragment;
import android.app.FragmentManager;
-import android.app.backup.IBackupManager;
import android.content.BroadcastReceiver;
import android.content.ContentResolver;
import android.content.Context;
import android.content.Intent;
-import android.location.LocationManager;
-import android.net.Uri;
import android.os.Bundle;
-import android.os.RemoteException;
-import android.os.ServiceManager;
import android.provider.Settings;
-import android.text.SpannableString;
-import android.text.Spanned;
-import android.text.method.LinkMovementMethod;
-import android.text.style.ClickableSpan;
import android.util.Log;
import android.view.View;
import android.widget.CheckBox;
import android.widget.TextView;
-import com.cyanogenmod.setupwizard.R;
-import com.cyanogenmod.setupwizard.SetupWizardApp;
-import com.cyanogenmod.setupwizard.cmstats.SetupStats;
-import com.cyanogenmod.setupwizard.ui.SetupPageFragment;
-import com.cyanogenmod.setupwizard.util.SetupWizardUtils;
-
public class OtherSettingsPage extends SetupPage {
- private static final String TAG = "OtherSettingsPage";
-
- private static final String PRIVACY_POLICY_URI =
- "https://www.google.com/intl/en/policies/privacy/?fg=1";
+ public static final String TAG = "OtherSettingsPage";
public OtherSettingsPage(Context context, SetupDataCallbacks callbacks) {
super(context, callbacks);
@@ -84,18 +71,15 @@ public class OtherSettingsPage extends SetupPage {
public static class OtherSettingsFragment extends SetupPageFragment {
- private View mBackupRow;
private View mLocationRow;
private View mBatteryRow;
private View mNetworkRow;
- private CheckBox mBackup;
private CheckBox mNetwork;
private CheckBox mBattery;
private CheckBox mLocationAccess;
private ContentResolver mContentResolver;
- private IBackupManager mBackupManager;
/** Broadcast intent action when the location mode is about to change. */
private static final String MODE_CHANGING_ACTION =
@@ -107,13 +91,6 @@ public class OtherSettingsPage extends SetupPage {
private BroadcastReceiver mReceiver;
- private View.OnClickListener mBackupClickListener = new View.OnClickListener() {
- @Override
- public void onClick(View view) {
- onToggleBackup(!mBackup.isChecked());
- }
- };
-
private View.OnClickListener mLocationClickListener = new View.OnClickListener() {
@Override
public void onClick(View view) {
@@ -137,42 +114,10 @@ public class OtherSettingsPage extends SetupPage {
@Override
protected void initializePage() {
- final boolean hasGms = SetupWizardUtils.hasGMS(getActivity());
final boolean hasTelephony = SetupWizardUtils.hasTelephony(getActivity());
mContentResolver = getActivity().getContentResolver();
- mBackupManager = IBackupManager.Stub.asInterface(
- ServiceManager.getService(Context.BACKUP_SERVICE));
TextView summaryView = (TextView) mRootView.findViewById(android.R.id.summary);
- if (hasGms) {
- String privacy_policy = getString(R.string.services_privacy_policy);
- String otherSummary = getString(R.string.other_services_summary, privacy_policy);
- SpannableString ss = new SpannableString(otherSummary);
- ClickableSpan clickableSpan = new ClickableSpan() {
- @Override
- public void onClick(View textView) {
- final Intent intent = new Intent(SetupWizardApp.ACTION_VIEW_LEGAL);
- intent.setData(Uri.parse(PRIVACY_POLICY_URI));
- try {
- getActivity().startActivity(intent);
- } catch (Exception e) {
- Log.e(TAG, "Unable to start activity " + intent.toString());
- }
- }
- };
- ss.setSpan(clickableSpan,
- otherSummary.length() - privacy_policy.length() - 1,
- otherSummary.length() - 1, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
- summaryView.setMovementMethod(LinkMovementMethod.getInstance());
- summaryView.setText(ss);
- } else {
- summaryView.setText(R.string.location_services_summary);
- }
- mBackupRow = mRootView.findViewById(R.id.backup);
- mBackupRow.setOnClickListener(mBackupClickListener);
- boolean backupVisible = hasGms &&
- SetupWizardUtils.accountExists(getActivity(), SetupWizardApp.ACCOUNT_TYPE_GMS);
- mBackupRow.setVisibility(backupVisible ? View.VISIBLE : View.GONE);
- mBackup = (CheckBox) mRootView.findViewById(R.id.backup_checkbox);
+ summaryView.setText(R.string.location_services_summary);
mLocationRow = mRootView.findViewById(R.id.location);
mLocationRow.setOnClickListener(mLocationClickListener);
mLocationAccess = (CheckBox) mRootView.findViewById(R.id.location_checkbox);
@@ -183,9 +128,7 @@ public class OtherSettingsPage extends SetupPage {
mNetworkRow.setOnClickListener(mNetworkClickListener);
mNetwork = (CheckBox) mRootView.findViewById(R.id.network_checkbox);
TextView networkSummary = (TextView) mRootView.findViewById(R.id.network_summary);
- if (hasGms) {
- networkSummary.setText(R.string.location_network_gms);
- } else if (hasTelephony) {
+ if (hasTelephony) {
networkSummary.setText(R.string.location_network_telephony);
} else {
networkSummary.setText(R.string.location_network);
@@ -201,7 +144,6 @@ public class OtherSettingsPage extends SetupPage {
public void onResume() {
super.onResume();
refreshLocationMode();
- updateBackupToggle();
}
@Override
@@ -218,28 +160,6 @@ public class OtherSettingsPage extends SetupPage {
};
}
- private boolean isBackupRestoreEnabled() {
- try {
- return mBackupManager.isBackupEnabled();
- } catch (Exception e) {
- return false;
- }
- }
-
- private void updateBackupToggle() {
- mBackup.setChecked(isBackupRestoreEnabled());
- }
-
- private void onToggleBackup(boolean checked) {
- try {
- mBackupManager.setBackupEnabled(checked);
- SetupStats.addEvent(SetupStats.Categories.SETTING_CHANGED,
- SetupStats.Action.ENABLE_BACKUP,
- SetupStats.Label.CHECKED, String.valueOf(checked));
- } catch (RemoteException e) {}
- updateBackupToggle();
- }
-
private void setLocationMode(int mode) {
Intent intent = new Intent(MODE_CHANGING_ACTION);
intent.putExtra(CURRENT_MODE_KEY, mCurrentMode);