Planes de facturación mensual de iOS de Compromiso
Copie una solicitud de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
Apple admite suscripciones que facturan mensualmente mientras que el cliente se compromete con un plazo más largo de 12 meses. @capgo/native-purchases exposa los términos de precios, permite seleccionar el plan de facturación mensual durante la compra y devuelve metadatos de compromiso en transacciones y información de renovación.
Utilice esto para ofertas de suscripción anuales donde los usuarios prefieren pagos mensuales pero aún quiere la retención y la previsibilidad de un plazo anual comprometido.
Requisitos
Título de la sección “Requisitos”- Configure el plan de facturación mensual con un compromiso de 12 meses en App Store Connect o en StoreKit Testing en Xcode.
- Construya la aplicación iOS con un Xcode SDK que contenga StoreKit
pricingTermsybillingPlanType. - Ejecuta en una versión de iOS que admita planes de facturación de compromiso de StoreKit.
- Mantenga una opción de facturación estándar disponible para dispositivos o tiendas que no devuelvan términos de precios de compromiso.
Cargar y mostrar Términos de Precios
Sección titulada “Cargar y mostrar Términos de Precios”Llamar getProducts() como de costumbre. Para los productos de suscripción iOS admitidos, cada producto puede incluir 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',);Representar los valores proporcionados por la tienda en lugar de precios hardcodeados:
| Campo | Utilícelo para |
|---|---|
billingDisplayPrice | El monto de facturación recurrente mostrado al usuario, por ejemplo, el cargo mensual. |
billingPeriod | El patrón de facturación para el precio de facturación mostrado. |
commitmentInfo.priceString | El precio total de compromiso formateado para la tienda del usuario. |
commitmentInfo.period | El período de compromiso completo. |
subscriptionOffers | Ofertas promocionales o de introducción asociadas a la cláusula de precios. |
Ejemplo de copia de paywall:
function commitmentLabel(term: NonNullable<typeof monthlyCommitment>) { const total = term.commitmentInfo?.priceString; return total ? `${term.billingDisplayPrice} billed monthly, ${total} total commitment` : term.billingDisplayPrice;}Comprar el Plan de Compromiso Mensual
Sección titulada “Comprar el Plan de Compromiso Mensual”Cuando el usuario selecciona el plan de compromiso mensual, pasa billingPlanType: 'monthly'.
const transaction = await NativePurchases.purchaseProduct({ productIdentifier: 'com.example.app.premium.yearly', productType: PURCHASE_TYPE.SUBS, billingPlanType: 'monthly', appAccountToken: userStoreUuid,});Sólo cuando necesites seleccionar explícitamente el plan de facturación de pago inicial estándar. Si omites billingPlanType: 'upFront' StoreKit utiliza su comportamiento de compra predeterminado para el producto. billingPlanTypeUtiliza
Leer Metadatos de Compromiso
Sección titulada “Leer Metadatos de Compromiso”Las transacciones incluyen el plan de facturación y el progreso del compromiso cuando StoreKit lo proporciona:
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);}La información de renovación puede incluir el próximo estado de compromiso:
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);}Utiliza el nivel superior expirationDate y isActive campos para decisiones de acceso condicional. Utilice commitmentInfo.expirationDate para explicar el plazo de compromiso completo al cliente.
Notas de Revisión de la Tienda de Aplicaciones
Sección titulada “Notas de Revisión de la Tienda de Aplicaciones”- Muestre tanto el precio de facturación recurrente como el precio de compromiso total antes de la compra.
- Haga explícito el largo del compromiso cerca del botón de compra.
- Utilice
product.title,product.priceString,pricingTerms[].billingDisplayPrice, ypricingTerms[].commitmentInfo.priceStringde StoreKit en lugar de precios hardcoded. - Proporcione acciones de restaurar compras y administrar suscripciones en la pantalla de pago o pantalla de cuenta.
Guías Relacionadas
Sección titulada “Guías Relacionadas”- Crear suscripciones de iOS
- Configurar pruebas de sandbox de iOS
- Directrices de revisión de la Tienda de Aplicaciones de iOS
Sigue adelante desde los planes de facturación mensual de compromiso de iOS
Título de la sección “Sigue adelante desde los planes de facturación mensual de compromiso de iOS”Si estás utilizando Planes de facturación mensual de compromiso de iOS para planificar pagos y compras, conecta Usando @capgo/native-purchases para la capacidad nativa en Usando @capgo/native-purchases, Capgo Precios para el flujo de trabajo de producto en Capgo Precios Sistema de pago Para el detalle de implementación en Sistema de pago, @capgo/native-purchases Para el detalle de implementación en @capgo/native-purchases, y Getting Started Para el detalle de implementación en Getting Started.