Merge "Allow disojoint datasets for inline suggestions." into rvc-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
28a5ed1cfb
@@ -47,6 +47,7 @@ import android.view.autofill.AutofillManager;
|
||||
import android.view.autofill.AutofillValue;
|
||||
import android.view.autofill.IAutoFillManagerClient;
|
||||
import android.view.inputmethod.InlineSuggestionsRequest;
|
||||
import android.view.inputmethod.InlineSuggestionsResponse;
|
||||
|
||||
import com.android.internal.infra.AbstractRemoteService;
|
||||
import com.android.internal.infra.AndroidFuture;
|
||||
@@ -243,20 +244,27 @@ final class RemoteAugmentedAutofillService
|
||||
}
|
||||
mCallbacks.setLastResponse(sessionId);
|
||||
|
||||
final InlineSuggestionsResponse inlineSuggestionsResponse =
|
||||
InlineSuggestionFactory.createAugmentedInlineSuggestionsResponse(
|
||||
request, inlineSuggestionsData, focusedId, mContext,
|
||||
dataset -> {
|
||||
mCallbacks.logAugmentedAutofillSelected(sessionId,
|
||||
dataset.getId());
|
||||
try {
|
||||
client.autofill(sessionId, dataset.getFieldIds(),
|
||||
dataset.getFieldValues());
|
||||
} catch (RemoteException e) {
|
||||
Slog.w(TAG, "Encounter exception autofilling the values");
|
||||
}
|
||||
}, onErrorCallback, remoteRenderService);
|
||||
|
||||
if (inlineSuggestionsResponse == null) {
|
||||
Slog.w(TAG, "InlineSuggestionFactory created null response");
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
inlineSuggestionsCallback.onInlineSuggestionsResponse(
|
||||
InlineSuggestionFactory.createAugmentedInlineSuggestionsResponse(
|
||||
request, inlineSuggestionsData, focusedId, mContext,
|
||||
dataset -> {
|
||||
mCallbacks.logAugmentedAutofillSelected(sessionId,
|
||||
dataset.getId());
|
||||
try {
|
||||
client.autofill(sessionId, dataset.getFieldIds(),
|
||||
dataset.getFieldValues());
|
||||
} catch (RemoteException e) {
|
||||
Slog.w(TAG, "Encounter exception autofilling the values");
|
||||
}
|
||||
}, onErrorCallback, remoteRenderService));
|
||||
inlineSuggestionsCallback.onInlineSuggestionsResponse(inlineSuggestionsResponse);
|
||||
} catch (RemoteException e) {
|
||||
Slog.w(TAG, "Exception sending inline suggestions response back to IME.");
|
||||
}
|
||||
|
||||
@@ -2686,6 +2686,12 @@ final class Session implements RemoteFillService.FillServiceCallbacks, ViewState
|
||||
requestHideFillUi(mCurrentViewId);
|
||||
}
|
||||
}, mService.getRemoteInlineSuggestionRenderServiceLocked());
|
||||
|
||||
if (inlineSuggestionsResponse == null) {
|
||||
Slog.w(TAG, "InlineSuggestionFactory created null response");
|
||||
return false;
|
||||
}
|
||||
|
||||
try {
|
||||
imeResponse.getCallback().onInlineSuggestionsResponse(inlineSuggestionsResponse);
|
||||
} catch (RemoteException e) {
|
||||
|
||||
@@ -150,13 +150,13 @@ public final class InlineSuggestionFactory {
|
||||
final int fieldIndex = dataset.getFieldIds().indexOf(autofillId);
|
||||
if (fieldIndex < 0) {
|
||||
Slog.w(TAG, "AutofillId=" + autofillId + " not found in dataset");
|
||||
return null;
|
||||
continue;
|
||||
}
|
||||
final InlinePresentation inlinePresentation = dataset.getFieldInlinePresentation(
|
||||
fieldIndex);
|
||||
if (inlinePresentation == null) {
|
||||
Slog.w(TAG, "InlinePresentation not found in dataset");
|
||||
return null;
|
||||
continue;
|
||||
}
|
||||
if (!includeDataset(dataset, fieldIndex, filterText)) {
|
||||
continue;
|
||||
|
||||
Reference in New Issue
Block a user