Merge "[Network Connection] Call NetworkRequestUserSelectionCallback#reject() if user quit activity without selection" into qt-qpr1-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
17cbea0112
@@ -340,6 +340,7 @@ public class NetworkRequestDialogFragment extends InstrumentedDialogFragment imp
|
||||
// Throws error dialog.
|
||||
final NetworkRequestErrorDialogFragment fragment = NetworkRequestErrorDialogFragment
|
||||
.newInstance();
|
||||
fragment.setRejectCallback(mUserSelectionCallback);
|
||||
final Bundle bundle = new Bundle();
|
||||
bundle.putSerializable(NetworkRequestErrorDialogFragment.DIALOG_TYPE, type);
|
||||
fragment.setArguments(bundle);
|
||||
|
@@ -20,8 +20,10 @@ import android.app.Dialog;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.DialogInterface;
|
||||
import android.os.Bundle;
|
||||
import android.net.wifi.WifiManager.NetworkRequestUserSelectionCallback;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
|
||||
import com.android.settings.R;
|
||||
@@ -36,6 +38,8 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
||||
public static final String DIALOG_TYPE = "DIALOG_ERROR_TYPE";
|
||||
|
||||
public enum ERROR_DIALOG_TYPE {TIME_OUT, ABORT}
|
||||
@Nullable
|
||||
private NetworkRequestUserSelectionCallback mRejectCallback;
|
||||
|
||||
public static NetworkRequestErrorDialogFragment newInstance() {
|
||||
return new NetworkRequestErrorDialogFragment();
|
||||
@@ -49,7 +53,7 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
||||
public void onCancel(@NonNull DialogInterface dialog) {
|
||||
super.onCancel(dialog);
|
||||
// Wants to finish the activity when user clicks back key or outside of the dialog.
|
||||
getActivity().finish();
|
||||
rejectNetworkRequestAndFinish();
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -65,10 +69,12 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
||||
builder.setMessage(R.string.network_connection_timeout_dialog_message)
|
||||
.setPositiveButton(R.string.network_connection_timeout_dialog_ok,
|
||||
(dialog, which) -> startScanningDialog())
|
||||
.setNegativeButton(R.string.cancel, (dialog, which) -> getActivity().finish());
|
||||
.setNegativeButton(R.string.cancel,
|
||||
(dialog, which) -> rejectNetworkRequestAndFinish());
|
||||
} else {
|
||||
builder.setMessage(R.string.network_connection_errorstate_dialog_message)
|
||||
.setPositiveButton(R.string.okay, (dialog, which) -> getActivity().finish());
|
||||
.setPositiveButton(R.string.okay,
|
||||
(dialog, which) -> rejectNetworkRequestAndFinish());
|
||||
}
|
||||
return builder.create();
|
||||
}
|
||||
@@ -78,9 +84,23 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
||||
return SettingsEnums.WIFI_SCANNING_NEEDED_DIALOG;
|
||||
}
|
||||
|
||||
// Sets the callback for fragment to reject this request.
|
||||
public void setRejectCallback(NetworkRequestUserSelectionCallback rejectCallback) {
|
||||
mRejectCallback = rejectCallback;
|
||||
}
|
||||
|
||||
protected void startScanningDialog() {
|
||||
final NetworkRequestDialogFragment fragment = NetworkRequestDialogFragment.newInstance();
|
||||
fragment.show(getActivity().getSupportFragmentManager(),
|
||||
NetworkRequestErrorDialogFragment.class.getSimpleName());
|
||||
}
|
||||
|
||||
private void rejectNetworkRequestAndFinish() {
|
||||
if (getActivity() != null) {
|
||||
if (mRejectCallback != null) {
|
||||
mRejectCallback.reject();
|
||||
}
|
||||
getActivity().finish();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user