iOS 月度承诺计费计划
复制一个包含安装步骤和本插件的完整Markdown指南的设置提示。
Apple 支持每月付款的订阅,同时要求客户承诺 12 个月的期限。当 StoreKit 和运行的 OS 支持此付款计划时, @capgo/native-purchases 暴露了定价条款,允许您在购买时选择每月付款计划,并在交易和续订信息中返回承诺元数据。
使用此选项提供年付订阅,用户偏好每月付款,但您仍然希望保留和预测 1 年期限的承诺。
要求
标题:要求- 在 App Store Connect 或 Xcode 中的 StoreKit Testing 中配置每月付款的 12 个月承诺计划。
- 使用包含 StoreKit 的 Xcode SDK 构建 iOS 应用程序。
pricingTerms在支持 StoreKit 承诺付款计划的 iOS 版本上运行。billingPlanType. - __CAPGO_KEEP_0__
- 保持标准计费选项可供不返回承诺价格条款的设备或商店使用。
加载和显示价格条款
标题:加载和显示价格条款调用 getProducts() 如常。对于支持的 iOS 订阅产品,每个产品都可以包含 pricingTerms.
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
const { products } = await NativePurchases.getProducts({ productIdentifiers: ['com.example.app.premium.yearly'], productType: PURCHASE_TYPE.SUBS,});
const premiumYearly = products.find( (product) => product.identifier === 'com.example.app.premium.yearly',);const monthlyCommitment = premiumYearly?.pricingTerms?.find( (term) => term.billingPlanType === 'monthly',);渲染商店提供的值而不是硬编码的价格:
| 字段 | 使用它 |
|---|---|
billingDisplayPrice | 用户看到的定期计费金额,例如月度费用 |
billingPeriod | 显示的计费价格的计费频率 |
commitmentInfo.priceString | 为用户商店格式化的总承诺价格 |
commitmentInfo.period | 全程承诺期 |
subscriptionOffers | 附加到定价条款的推广或促销活动 |
示例付费墙复制:
function commitmentLabel(term: NonNullable<typeof monthlyCommitment>) { const total = term.commitmentInfo?.priceString; return total ? `${term.billingDisplayPrice} billed monthly, ${total} total commitment` : term.billingDisplayPrice;}购买月度承诺计划
标题为“购买月度承诺计划”的部分当用户选择月度承诺计划时,传递 billingPlanType: 'monthly'.
const transaction = await NativePurchases.purchaseProduct({ productIdentifier: 'com.example.app.premium.yearly', productType: PURCHASE_TYPE.SUBS, billingPlanType: 'monthly', appAccountToken: userStoreUuid,});仅在您需要明确选择标准预付费计费计划时使用。如果您省略 billingPlanType: 'upFront' StoreKit将使用其默认购买行为处理产品。 billingPlanType提示
标题为“阅读承诺元数据”
交易包括StoreKit提供的计费计划和承诺进度:复制到剪贴板
if (transaction.billingPlanType === 'monthly') { console.log('Current billing period:', transaction.commitmentInfo?.billingPeriodNumber); console.log('Total billing periods:', transaction.commitmentInfo?.totalBillingPeriods); console.log('Commitment ends:', transaction.commitmentInfo?.expirationDate); console.log('Commitment total:', transaction.commitmentInfo?.price);}__CAPGO_KEEP_0__
const { purchases } = await NativePurchases.getPurchases({ productType: PURCHASE_TYPE.SUBS, onlyCurrentEntitlements: true,});
for (const purchase of purchases) { const commitment = purchase.renewalInfo?.commitmentInfo; if (!commitment) continue;
console.log('Renews into another commitment:', commitment.willAutoRenew); console.log('Next billing plan:', commitment.renewalBillingPlanType); console.log('Next renewal date:', commitment.renewalDate);}使用顶级 expirationDate 和 isActive 用于资格决策。使用 commitmentInfo.expirationDate 向客户说明完整的承诺时间表。
App Store Review Notes
标题为“App Store Review Notes”- 在购买之前显示重复计费价格和总承诺价格。
- 在购买按钮附近明确承诺长度。
- 使用
product.title,product.priceString,pricingTerms[].billingDisplayPrice、和pricingTerms[].commitmentInfo.priceString从 StoreKit 中取代硬编码价格。 - 提供恢复购买和管理订阅操作于付款墙或账户屏幕。
相关指南
标题:相关指南继续使用iOS月度承诺付款计划
标题:继续使用iOS月度承诺付款计划如果您正在使用 iOS月度承诺付款计划 来规划付款和购买,连接它与 使用@capgo/native-purchases 使用 @capgo/native-purchases 的原生能力 Capgo 价格 使用 Capgo 价格 的产品工作流程 支付系统 支付系统的实现细节 @capgo/native-purchases 的实现细节 for the implementation detail in @capgo/native-purchases, and 开始使用的实现细节 编辑页面