跳过内容

iOS 月度承诺计费计划

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提示

复制到剪贴板

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);
}

使用顶级 expirationDateisActive 用于资格决策。使用 commitmentInfo.expirationDate 向客户说明完整的承诺时间表。

  • 在购买之前显示重复计费价格和总承诺价格。
  • 在购买按钮附近明确承诺长度。
  • 使用 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 开始使用的实现细节 编辑页面