- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
在我的应用程序中,我需要使用用户的电话号码(而不是用户的联系人姓名)发送付款。因此,如果联系人中的用户有 2 个电话号码,则用户必须选择其中一个号码(如电话调用意图)。
在函数 func resolvePayee(forSendPayment intent: INSendPaymentIntent, with completion: @escaping (INPersonResolutionResult) -> Void)
中,我只看到用户的姓名,但没有电话号码。甚至 intent.payee.personHandle 总是 == nil
最佳答案
我使用了这个解决方法(当我显示他们时,只需在联系人姓名中添加数字)。以下是 resolvePayee 函数的完整代码:
func resolvePayee(forSendPayment intent: INSendPaymentIntent, with completion: @escaping (INPersonResolutionResult) -> Void) {
print("start resolving payee")
if let payee = intent.payee, payee.displayName.length > 0 {
// search proper phone number if we chose between these numbers before
var foundPhoneNumberInBuferNumbers: String? = nil
if let arrayOfSavedPhones = PaymentIntentHandler.resolvePayeeHelp_offeredPhoneNumbersFor1Contact {
for phone in arrayOfSavedPhones {
if payee.displayName.hasSuffix(phone) {
foundPhoneNumberInBuferNumbers = phone
break
}
}
if foundPhoneNumberInBuferNumbers == nil { // if we didn't manage to find this number that means that we have a new request for a new contact, so we don't need to remember number in buffer anymore
print("can't find phone number for \(payee.displayName), so we remove all buffer numbers = \(PaymentIntentHandler.resolvePayeeHelp_offeredPhoneNumbersFor1Contact)")
PaymentIntentHandler.resolvePayeeHelp_offeredPhoneNumbersFor1Contact = nil
}
}
let searchName = foundPhoneNumberInBuferNumbers != nil ? payee.displayName.replacingOccurrences(of: " " + foundPhoneNumberInBuferNumbers!, with: "") : payee.displayName
Singleton.sharedInstance.contactsService_getPhoneContacts(contactIdentifiresToFetch: nil, matchingName: searchName, showAlert: false, completionBlock: { (havePermission, customContactsMatchingName) in
if !havePermission { // user didn't grant permissions
print("unsupported because don't have permissions")
completion(INPersonResolutionResult.unsupported())
return
}
switch customContactsMatchingName.count {
case 2 ... Int.max: // user has to choose
let arrayOfPersons = customContactsMatchingName.map({ (phoneBookContact) -> INPerson in
return phoneBookContact.inSiriPerson()
})
print("disambiguation between several contacts")
completion(INPersonResolutionResult.disambiguation(with: arrayOfPersons))
case 1:
let contactCustom = customContactsMatchingName[0]
switch contactCustom.phoneNumbers.count {
case 0:
print("unsupported because don't have phone numbers")
completion(INPersonResolutionResult.unsupported())
case 1:
print("success")
completion(INPersonResolutionResult.success(with: contactCustom.inSiriPerson()))
case 2 ... Int.max:
print("now we have a uniq contact, but several phone numbers")
if foundPhoneNumberInBuferNumbers == nil { // we need user to choose between several phone numbers
var arrayOfStringNumbers = [String]()
var arrayOfPersonsToChoose = [INPerson]()
for phoneNumber in contactCustom.phoneNumbers {
let numberOnlyDigits = Singleton.sharedInstance.phone_getPhoneOnlyDigits(phoneNumber.number)
let formattedNumber = Singleton.sharedInstance.phone_getFormattedPhone("+" + numberOnlyDigits, allowLetters: false)
arrayOfStringNumbers.append(formattedNumber)
let personHandler = INPersonHandle(value: formattedNumber, type: .phoneNumber)
let person = INPerson(personHandle: personHandler, nameComponents: nil, displayName: payee.displayName + " " + formattedNumber, image: nil, contactIdentifier: contactCustom.id, customIdentifier: formattedNumber)
arrayOfPersonsToChoose.append(person)
}
PaymentIntentHandler.resolvePayeeHelp_offeredPhoneNumbersFor1Contact = arrayOfStringNumbers
print("disambiguation in one contact between several phones")
completion(INPersonResolutionResult.disambiguation(with: arrayOfPersonsToChoose))
}
else {
// found proper phone number
print("success after choosing bufer number")
let personHandle = INPersonHandle(value: foundPhoneNumberInBuferNumbers!, type: .phoneNumber)
let displayName = payee.displayName.replacingOccurrences(of: " " + foundPhoneNumberInBuferNumbers!, with: "")
completion(INPersonResolutionResult.success(with: INPerson(personHandle: personHandle, nameComponents: nil, displayName: displayName, image: nil, contactIdentifier: nil, customIdentifier: personHandle.value)))
}
default:
print("unsupported: can't happen")
completion(INPersonResolutionResult.unsupported())
}
case 0:
print("unsupported because can't find this contact in phonebook = \(searchName), contacts in buffer = \(PaymentIntentHandler.resolvePayeeHelp_offeredPhoneNumbersFor1Contact)")
completion(INPersonResolutionResult.unsupported())
default:
print("unsupported: can't happen")
completion(INPersonResolutionResult.unsupported())
}
})
}
else {
print("needsValue")
PaymentIntentHandler.resolvePayeeHelp_offeredPhoneNumbersFor1Contact = nil
completion(INPersonResolutionResult.needsValue())
}
}
关于ios - 如何在 INSendPaymentIntent 中选择电话号码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40205898/
以下是场景:我有一个可通过移动浏览器访问的网络应用程序。每当用户单击通过网络浏览器访问的应用程序页面中的链接时,我需要检测移动设备 IMEI 和 sim IMSI。这是为了跟踪具有相同 SIM 卡的同
场景如下:我有一个可通过移动浏览器访问的 Web 应用程序。每当用户单击可通过网络浏览器访问的我的应用程序页面中的链接时,我都需要检测移动设备的 IMEI 和 sim IMSI。这是为了跟踪具有相同
我需要在 Phonegap 为 Android 构建 HTML 移动 Web 应用程序中获取 IMEI 号码、手机号码、SIM 号码 最佳答案 你不能直接得到它们。 选项 1) 寻找一些插件,我不确定
我有一个输入框。它可能包含名称或数字。 如果输入至少有一个字母,我们将其作为名称处理,并且其长度应为 11 或更短。因此有效输入可能是 Bob、12Bob 或 Bob23。不允许有空格或其他字符,因此
我有这个要求:从客户表中 - 返回电话号码的前缀。我尝试使用字符串,将全名拆分为名字/姓氏,但它仅适用于数字。完整的nb格式为(258)1231456 最佳答案 SELECT '(258) 12314
我正在开发一个应用程序,用户必须使用手机键盘调用电话并输入验证号码。 我希望能够检测他们输入的数字是否正确。电话系统无法访问有效号码列表,但它会根据算法(如信用卡号码)验证号码。 以下是一些要求: 一
我有一张城市交通卡。我需要知道卡的援助(应用程序标识符)号码是多少。根据 EMV Book 1,我必须使用 List of AIDs 方法(第 141 页)。但是如何呢? 我还有一个 ACR122U
我想使用 javascript 分解数组中的 VIN,可能使用正则表达式,然后使用某种循环... 以下是读取 VIN 的方法: http://forum.cardekho.com/topic/600-
Here我找到了一个非常有用的答案,展示了如何使用 Whatsapp 从网站发送预填充的消息。 我们可以对 Telegram 做同样的事情吗? 最佳答案 您可以尝试使用以下方式打开 Telegram
我需要帮助完成这段代码,以便应用程序在收到推送通知时显示角标(Badge)编号,我可以收到推送通知,但应用程序上没有角标(Badge),这是代码 func application(_ applica
我正在使用 Twilio 进行入站调用,用户可以通过 Twilio-Number(从 Twilio 获得)调用应用程序并将被重定向到管理员。 现在,我们希望管理员使用相同的 Twilio 号码调用用户
C#/.NET 2.0 我需要解析一个字符串,其中包含街道名称和房屋编号的两个独立值。 in: "Streetname 1a" out: "streetname" "1a"
正如你们可能建议的那样,我正在创建一个带有语音命令的 SIRI。现在我确实想添加一个调用功能。例如我有这段代码: Intent call = new Intent(Intent.ACTION_DIAL
我想构建一个 android 应用程序,当设备第一次启动时,它会检测 IMEI 和其他设备信息,并检查是否有 SIM 卡。如果有 SIM 卡,它会发送短信包含特定号码的 IMEI 和其他设备信息。 我
我有这个对象: a = {"formData": { "total": "60.00", "tr0_RTN": "PZH", "tr0_amount": "10.00",
我正在制作一个测试工具,我有 imei 号码,但是否可以简单地或通过 NDK 更改 imei 号码。 谢谢 最佳答案 如何更改 IMEI 取决于硬件/系统,并且它是 - 至少在世界的(大部分)部分 -
我有一个表,其中有子项和父项,父项的 pid 为 0,子项的 pid 为父项的 id。我想选择父级及其子级数。 我的模型: function parent_child() {
抱歉,因为我从 android 开发跳到 IOS 开发,我想知道收到通知时是否有任何函数会触发?或者我应该如何处理通知? 这是我应用中的应用委托(delegate)。问题是每当收到消息时,如果应用程序
我正在开发应用程序,当它收到未接来电或来自手机的消息时自动发送消息。我的问题是当我从私有(private)号码收到未接来电或从私有(private)号码或服务器收到消息时(way2sms,160/2,
我想检查从联系人那里得到的电话号码是手机号码还是固定电话号码。我试过使用正则表达式,但一切都是徒劳的..任何帮助都将非常感激 最佳答案 要按手机号码和固定电话过滤联系人,您需要在数据库中有标准代码列表
我是一名优秀的程序员,十分优秀!