Dica sobre o número de telefone

A API Phone Number Hint, uma biblioteca com a tecnologia do Google Play Services, oferece uma maneira simples de mostrar os números de telefone de um usuário (baseados em chip) como uma dica.

Os benefícios de usar a dica de número de telefone incluem:

  • Nenhuma outra solicitação de permissão é necessária
  • Elimina a necessidade do usuário digitar o número de telefone manualmente.
  • Não é necessário ter uma Conta do Google
  • Não diretamente vinculado a fluxos de trabalho de login/inscrição
  • Maior compatibilidade com versões do Android em comparação com o preenchimento automático

Antes de começar

Para preparar o app, siga as etapas nas seções a seguir.

Configurar o app

No arquivo build.gradle do projeto, inclua o repositório Maven do Google nas seções buildscript e allprojects:

buildscript {
  repositories {
    google()
    mavenCentral()
  }
}

allprojects {
  repositories {
    google()
    mavenCentral()
  }
}

Adicione a dependência do Google Play Services para a API Phone Number Hint ao arquivo de build do Gradle do módulo, que geralmente é app/build.gradle:

  dependencies {
    implementation 'com.google.android.gms:play-services-auth:20.2.0'
  }

Como funciona

A API Phone Number Hint usa um PendingIntent para iniciar o fluxo. Depois que a PendingIntent for iniciada, o usuário verá uma IU, listando todos os números de telefone (baseados em chip). O usuário pode escolher um número de telefone que quer usar ou cancelar o fluxo. O número de telefone selecionado será disponibilizado para o desenvolvedor para recuperar do Intent.

IU e configurações de dica de número de telefone.
Figura 1. IU e configurações de dica de número de telefone

Criar um objeto GetPhoneNumbeHintIntentRequest

Comece criando um objeto GetPhoneNumberHintIntentRequest usando o método GetPhoneNumberHintIntentRequest.Builder() fornecido. Esse objeto de solicitação pode ser usado para receber um Intent e iniciar o fluxo de dica sobre o número de telefone.

Kotlin

val request: GetPhoneNumberHintIntentRequest = GetPhoneNumberHintIntentRequest.builder().build()

Java

GetPhoneNumberHintIntentRequest request = GetPhoneNumberHintIntentRequest.builder().build();

Dica de número de telefone solicitante

Chame SignInClient.getPhoneNumberHintIntent(), transmitindo o objeto GetPhoneNumberHintIntentRequest anterior, para recuperar o PendingIntent para iniciar o fluxo de dica de número de telefone.

Kotlin

val phoneNumberHintIntentResultLauncher: ActivityResultLauncher = ...

Identity.signInClient(activity)
  .getPhoneNumberHintIntent(request)
  .addOnSuccessListener(
      try {
          phoneNumberHintIntentResultLauncher.launch(request.getIntentSender())
      } catch(e: Exception) {
          Log.e(TAG, “Launching the PendingIntent failed”)
      })
  .addOnFailureListener(
      Log.e(TAG, “Phone Number Hint failed”)
  )

Java

ActivityResultLauncher phoneNumberHintIntentResultLauncher = ...

Identity.getSignInClient(activity)
  .getPhoneNumberHintIntent(request)
  .addOnSuccessListener( result -> {
      try {
          phoneNumberHintIntentResultLauncher.launch(result.getIntentSender());
      } catch(Exception e) {
          Log.e(TAG, “Launching the PendingIntent failed”, e);
      }
  })
  .addOnFailureListener(e -> {
      Log.e(TAG, “Phone Number Hint failed”, e);
  });

Como recuperar o número de telefone

Transmita o Intent para SignInClient.getPhoneNumberFromIntent para recuperar o número de telefone.

Kotlin

val phoneNumberHintIntentResultLauncher: ActivityResultLauncher =
  registerForActivityResult(StartActivityForResult()) { result ->
      try {
          val phoneNumber = Identity.signInClient(activity).getPhoneNumberFromIntent(result.data)
      } catch(e: Exception) {
          Log.e(TAG, "Phone Number Hint failed")
      }
  }

Java

ActivityResultLauncher phoneNumberHintIntentResultLauncher =
  registerForActivityResult(
      new ActivityResultContracts.StartActivityForResult(),
      new ActivityResultCallback() {
          @Override
          public void onActivityResult(ActivityResult result) {
              try {
                  String phoneNumber = Identity.getSignInClient(activity).getPhoneNumberFromIntent(result.getData());
              } catch {
                  Log.e(TAG, “Phone Number Hint failed”, e);
              }
          }
  });