Реализация экрана управления подпиской в мобильном приложении

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.

Разработка и поддержка любых видов мобильных приложений:

Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Услуги, которые мы предлагаем
Показано 1 из 1Все 1735 услуг
Реализация экрана управления подпиской в мобильном приложении
Простой
~2-3 дня
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    792
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    671
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1097
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    969
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    914
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    495

Реализация экрана управления подпиской в мобильном приложении

Экран управления подпиской — это не просто страница с кнопкой «Отменить». Это точка, где пользователь принимает решение остаться или уйти. Неправильно реализованный экран ускоряет отмены: пользователь не понимает, что именно он теряет, когда истечёт доступ и можно ли получить скидку.

Данные, которые нужно показать

Минимальный набор:

  • Текущий тариф (название, цена, период)
  • Дата следующего списания или дата истечения при отмене
  • Статус: активна / отменена (но доступ до) / grace period / billing retry
  • Кнопка перехода на другой тариф (upgrade/downgrade)
  • Ссылка на системный экран Apple/Google для отмены

Чтение текущего состояния (StoreKit 2)

import StoreKit

struct SubscriptionInfo {
    let productID: String
    let displayName: String
    let price: String
    let renewalDate: Date?
    let expirationDate: Date?
    let willAutoRenew: Bool
    let state: Product.SubscriptionInfo.RenewalState
    let isInGracePeriod: Bool
}

func loadSubscriptionInfo(productIds: [String]) async -> SubscriptionInfo? {
    guard let product = try? await Product.products(for: productIds).first,
          let status = try? await product.subscription?.status.first else {
        return nil
    }

    let renewalInfo = try? status.renewalInfo.payloadValue
    let transaction = try? status.transaction.payloadValue

    return SubscriptionInfo(
        productID: product.id,
        displayName: product.displayName,
        price: product.displayPrice,
        renewalDate: renewalInfo?.renewalDate,
        expirationDate: transaction?.expirationDate,
        willAutoRenew: renewalInfo?.willAutoRenew ?? false,
        state: status.state,
        isInGracePeriod: status.state == .inGracePeriod
    )
}

renewalInfo.willAutoRenew — показывает, включено ли автопродление. Если пользователь отменил подписку, это поле будет false, но доступ активен до expirationDate.

SwiftUI-компонент экрана

struct SubscriptionManagementView: View {
    @StateObject private var viewModel = SubscriptionManagementViewModel()

    var body: some View {
        ScrollView {
            VStack(alignment: .leading, spacing: 24) {
                if let info = viewModel.subscriptionInfo {
                    CurrentPlanCard(info: info)

                    if info.state == .inGracePeriod {
                        GracePeriodWarning()
                    }

                    if info.willAutoRenew, let date = info.renewalDate {
                        Text("Следующее списание: \(date.formatted(.dateTime.day().month().year()))")
                            .foregroundStyle(.secondary)
                    } else if let date = info.expirationDate {
                        Text("Доступ активен до: \(date.formatted(.dateTime.day().month().year()))")
                            .foregroundStyle(.secondary)
                    }

                    PlanPickerSection(currentPlan: info.productID)
                }

                ManageButton()
            }
            .padding()
        }
        .task { await viewModel.load() }
    }
}

Системная кнопка управления подпиской (обязательна)

Apple требует, чтобы в приложении был доступ к системному экрану управления подписками. Без этого — rejection по guideline 3.1.2:

Button("Управление подпиской в App Store") {
    Task {
        try? await AppStore.showManageSubscriptions(in: windowScene)
    }
}

На Android — deeplink в Google Play:

val intent = Intent(Intent.ACTION_VIEW).apply {
    data = Uri.parse("https://play.google.com/store/account/subscriptions?sku=premium_monthly&package=${packageName}")
}
startActivity(intent)

Cancellation flow — не просто кнопка

Лучшие практики удержания при попытке отменить:

  1. Перед уходом на системный экран — показать что теряет пользователь (список фич)
  2. Если подписка активна давно — предложить паузу вместо отмены (Google Play поддерживает нативно)
  3. Для пользователей с давней историей — предложить Promotional Offer со скидкой

Это не dark pattern — это честное напоминание о ценности. Важно не злоупотреблять: один экран подтверждения максимум.

Что входит в работу

  • Чтение статуса через StoreKit 2 / Google Play Billing Library
  • Компонент отображения: тариф, дата, статус, grace period
  • Переключатель тарифов (upgrade/downgrade) с описанием условий
  • Интеграция AppStore.showManageSubscriptions / Play Store deeplink
  • Опциональный cancellation flow с retention-оффером

Сроки

2–3 дня для базового экрана с актуальным статусом. Со сложным cancellation flow и retention-офферами — до 5 дней. Стоимость рассчитывается индивидуально.