फ़ोन नंबर का संकेत

Phone Number Hint API, Google Play services की मदद से काम करने वाली एक लाइब्रेरी है. यह उपयोगकर्ता के (सिम के आधार पर) फ़ोन नंबरों को हिंट के तौर पर दिखाने का आसान तरीका उपलब्ध कराती है.

फ़ोन नंबर के कुछ अंक दिखाने की सुविधा इस्तेमाल करने के ये फ़ायदे हैं:

  • अनुमति के लिए कोई और अनुरोध करने की ज़रूरत नहीं है
  • इससे उपयोगकर्ता को फ़ोन नंबर मैन्युअल तरीके से टाइप करने की ज़रूरत नहीं पड़ती
  • इसके लिए Google खाते की ज़रूरत नहीं है
  • यह सीधे तौर पर साइन-इन या साइन-अप वर्कफ़्लो से नहीं जुड़ा होता
  • ऑटोमैटिक भरने की सुविधा की तुलना में, Android के ज़्यादा वर्शन पर काम करती है

यह कैसे काम करता है

Phone Number Hint API, फ़्लो शुरू करने के लिए PendingIntent का इस्तेमाल करता है. PendingIntent लॉन्च होने के बाद, उपयोगकर्ता को एक यूज़र इंटरफ़ेस (यूआई) दिखेगा. इसमें सभी (सिम के आधार पर) फ़ोन नंबर की सूची होगी. इसके बाद, उपयोगकर्ता के पास यह विकल्प होता है कि वह उस फ़ोन नंबर को चुने जिसका उसे इस्तेमाल करना है या इस प्रोसेस को रद्द कर दे. इसके बाद, चुना गया फ़ोन नंबर डेवलपर को उपलब्ध कराया जाएगा, ताकि वह Intent से इसे वापस पा सके.

फ़ोन नंबर के बारे में जानकारी देने वाला यूज़र इंटरफ़ेस (यूआई) और सेटिंग.
पहली इमेज. फ़ोन नंबर का हिंट दिखाने वाला यूज़र इंटरफ़ेस (यूआई) और सेटिंग

अपने ऐप्लिकेशन को तैयार करने के लिए, यहां दिए गए सेक्शन में बताया गया तरीका अपनाएं.

अपने ऐप्लिकेशन को कॉन्फ़िगर करना

फ़ोन नंबर का सुझाव देने वाले एपीआई के लिए, Google Play services की डिपेंडेंसी को अपनी मॉड्यूल की Gradle बिल्ड फ़ाइल में जोड़ें. यह फ़ाइल आम तौर पर app/build.gradle होती है:

  apply plugin: 'com.android.application'

  ...

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

GetPhoneNumbeHintIntentRequest ऑब्जेक्ट बनाना

दिए गए GetPhoneNumberHintIntentRequest.Builder() तरीके का इस्तेमाल करके, GetPhoneNumberHintIntentRequest ऑब्जेक्ट बनाएं. इसके बाद, इस अनुरोध ऑब्जेक्ट का इस्तेमाल करके, Intent पाया जा सकता है. इससे फ़ोन नंबर का हिंट देने वाला फ़्लो शुरू किया जा सकता है.

Kotlin

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

Java

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

फ़ोन नंबर के बारे में जानकारी पाने का अनुरोध करना

फ़ोन नंबर का सुझाव देने की सुविधा शुरू करने के लिए, SignInClient.getPhoneNumberHintIntent() को कॉल करें. इसके लिए, पिछले GetPhoneNumberHintIntentRequest ऑब्जेक्ट को पास करें, ताकि PendingIntent को वापस पाया जा सके.

Kotlin

val phoneNumberHintIntentResultLauncher = ...

Identity.getSignInClient(activity)
.getPhoneNumberHintIntent(request)
.addOnSuccessListener { result: PendingIntent ->
  try {
    phoneNumberHintIntentResultLauncher.launch(
      IntentSenderRequest.Builder(result).build()
    )
  } 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);
  });

फ़ोन नंबर वापस पाया जा रहा है

फ़ोन नंबर वापस पाने के लिए, SignInClient.getPhoneNumberFromIntent में Intent पास करें.

Kotlin

val phoneNumberHintIntentResultLauncher =
registerForActivityResult(ActivityResultContracts.StartIntentSenderForResult()) { result ->
      try {
          val phoneNumber = Identity.getSignInClient(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);
              }
          }
  });