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 dica.

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

  • Nenhuma outra solicitação de permissão é necessária.
  • Elimina a necessidade de o usuário digitar manualmente o número de telefone.
  • Não é necessário ter uma Conta do Google
  • Não vinculado diretamente 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 seu arquivo de compilação 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 uma 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). Em seguida, o usuário pode selecionar um número de telefone que gostaria de usar ou cancelar o fluxo. O número de telefone selecionado será disponibilizado ao desenvolvedor para recuperar do Intent.

IU e configurações de dica para número de telefone.
Figura 1. IU e configurações da dica "Números 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 para iniciar o fluxo de dica sobre número de telefone.

Kotlin

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

Java

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

Solicitando dica de número de telefone

Chame SignInClient.getPhoneNumberHintIntent(), transmitindo o objeto GetPhoneNumberHintIntentRequest anterior, para recuperar o PendingIntent e iniciar o fluxo de dica sobre o 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);
              }
          }
  });