Merge "Merge Tap & Pay settings entries with NFC"

This commit is contained in:
Robert Luo
2020-02-06 05:03:39 +00:00
committed by Android (Google) Code Review
12 changed files with 536 additions and 23 deletions

View File

@@ -21,11 +21,23 @@ import android.content.pm.PackageManager;
import android.nfc.NfcAdapter;
import android.os.UserManager;
import com.android.settings.core.BasePreferenceController;
import androidx.preference.Preference;
import androidx.preference.PreferenceScreen;
public class DefaultPaymentSettingsPreferenceController extends BasePreferenceController {
import com.android.settings.core.BasePreferenceController;
import com.android.settingslib.core.lifecycle.LifecycleObserver;
import com.android.settingslib.core.lifecycle.events.OnPause;
import com.android.settingslib.core.lifecycle.events.OnResume;
/**
* This Controller works with PaymentSettingsEnabler to control payment features availability
* based on NFC status
*/
public class DefaultPaymentSettingsPreferenceController extends BasePreferenceController
implements LifecycleObserver, OnResume, OnPause {
private final NfcAdapter mNfcAdapter;
private PaymentSettingsEnabler mPaymentSettingsEnabler;
private final PackageManager mPackageManager;
private final UserManager mUserManager;
@@ -37,6 +49,32 @@ public class DefaultPaymentSettingsPreferenceController extends BasePreferenceCo
mNfcAdapter = NfcAdapter.getDefaultAdapter(mContext);
}
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
if (!isAvailable()) {
mPaymentSettingsEnabler = null;
return;
}
final Preference preference = screen.findPreference(getPreferenceKey());
mPaymentSettingsEnabler = new PaymentSettingsEnabler(mContext, preference);
}
@Override
public void onResume() {
if (mPaymentSettingsEnabler != null) {
mPaymentSettingsEnabler.resume();
}
}
@Override
public void onPause() {
if (mPaymentSettingsEnabler != null) {
mPaymentSettingsEnabler.pause();
}
}
@Override
public int getAvailabilityStatus() {
if (!mPackageManager.hasSystemFeature(PackageManager.FEATURE_NFC)
@@ -47,9 +85,12 @@ public class DefaultPaymentSettingsPreferenceController extends BasePreferenceCo
if (!mUserManager.isAdminUser()) {
return DISABLED_FOR_USER;
}
if (mNfcAdapter == null || !mNfcAdapter.isEnabled()) {
if (mNfcAdapter == null) {
return CONDITIONALLY_UNAVAILABLE;
}
if (!mNfcAdapter.isEnabled()) {
return DISABLED_DEPENDENT_SETTING;
}
return AVAILABLE;
}
}

View File

@@ -0,0 +1,54 @@
/*
* Copyright (C) 2020 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.applications.specialaccess;
import android.content.Context;
import android.nfc.NfcAdapter;
import androidx.preference.Preference;
import com.android.settings.R;
import com.android.settings.nfc.BaseNfcEnabler;
/**
* PaymentSettingsEnabler is a helper to manage the payment feature enable / disable state.
* It enables / disables payment features based on NFC state, and ensures the summary of the
* preference is updated.
*/
public class PaymentSettingsEnabler extends BaseNfcEnabler {
private final Preference mPreference;
public PaymentSettingsEnabler(Context context, Preference preference) {
super(context);
mPreference = preference;
}
@Override
protected void handleNfcStateChanged(int newState) {
switch (newState) {
case NfcAdapter.STATE_OFF:
mPreference.setSummary(
R.string.nfc_and_payment_settings_payment_off_nfc_off_summary);
mPreference.setEnabled(false);
break;
case NfcAdapter.STATE_ON:
mPreference.setSummary(null);
mPreference.setEnabled(true);
break;
}
}
}

View File

@@ -0,0 +1,58 @@
/*
* Copyright (C) 2020 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.connecteddevice;
import android.app.settings.SettingsEnums;
import com.android.settings.R;
import com.android.settings.dashboard.DashboardFragment;
import com.android.settings.search.BaseSearchIndexProvider;
import com.android.settingslib.search.SearchIndexable;
/**
* This fragment contains NFC and payment specific settings.
*/
@SearchIndexable(forTarget = SearchIndexable.ALL & ~SearchIndexable.ARC)
public class NfcAndPaymentFragment extends DashboardFragment {
private static final String TAG = "NfcAndPaymentFragment";
@Override
protected int getPreferenceScreenResId() {
return R.xml.nfc_and_payment_settings;
}
@Override
protected String getLogTag() {
return TAG;
}
@Override
public int getMetricsCategory() {
return SettingsEnums.CONNECTION_DEVICE_ADVANCED_NFC;
}
@Override
public int getHelpResource() {
return R.string.help_uri_nfc_and_payment_settings;
}
/**
* For Search.
*/
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
new BaseSearchIndexProvider(R.xml.nfc_and_payment_settings);
}

View File

@@ -0,0 +1,67 @@
/*
* Copyright (C) 2020 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.connecteddevice;
import android.content.Context;
import android.content.pm.PackageManager;
import android.nfc.NfcAdapter;
import android.os.UserManager;
import com.android.settings.R;
import com.android.settings.core.BasePreferenceController;
/**
* Controller that used to show NFC and payment features
*/
public class NfcAndPaymentFragmentController extends BasePreferenceController {
private final NfcAdapter mNfcAdapter;
private final PackageManager mPackageManager;
private final UserManager mUserManager;
public NfcAndPaymentFragmentController(Context context, String preferenceKey) {
super(context, preferenceKey);
mPackageManager = context.getPackageManager();
mUserManager = context.getSystemService(UserManager.class);
mNfcAdapter = NfcAdapter.getDefaultAdapter(context);
}
@Override
public int getAvailabilityStatus() {
if (!mPackageManager.hasSystemFeature(PackageManager.FEATURE_NFC)
|| !mPackageManager.hasSystemFeature(
PackageManager.FEATURE_NFC_HOST_CARD_EMULATION)) {
return UNSUPPORTED_ON_DEVICE;
}
if (!mUserManager.isAdminUser()) {
return DISABLED_FOR_USER;
}
return AVAILABLE;
}
@Override
public CharSequence getSummary() {
if (mNfcAdapter != null) {
if (mNfcAdapter.isEnabled()) {
return mContext.getText(R.string.switch_on_text);
} else {
return mContext.getText(R.string.switch_off_text);
}
}
return null;
}
}