Реализация Trial-периода для SaaS-приложения

Наша компания занимается разработкой, поддержкой и обслуживанием сайтов любой сложности. От простых одностраничных сайтов до масштабных кластерных систем построенных на микро сервисах. Опыт разработчиков подтвержден сертификатами от вендоров.
Разработка и обслуживание любых видов сайтов:
Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Реализация Trial-периода для SaaS-приложения
Средняя
~3-5 рабочих дней
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1214
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1161
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    852
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1041
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    823
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    815

SaaS триальный период

Триал — стандарт для SaaS. Пользователь пробует продукт без оплаты, затем конвертируется в платящего клиента. Задача — показать ценность до окончания триала и снизить трение при конверсии.

Stripe: триал при создании подписки

// Создание подписки с 14-дневным триалом
const subscription = await stripe.subscriptions.create({
  customer: customerId,
  items: [{ price: priceId }],
  trial_period_days: 14,
  // Требуем карту сразу (снижает churn после триала)
  payment_behavior: 'default_incomplete',
  expand: ['latest_invoice.payment_intent'],
});

// Или через Checkout с картой
const session = await stripe.checkout.sessions.create({
  mode: 'subscription',
  customer: customerId,
  line_items: [{ price: priceId, quantity: 1 }],
  subscription_data: {
    trial_period_days: 14,
  },
  payment_method_collection: 'always', // требуем карту
  success_url: `${APP_URL}/dashboard?trial=started`,
  cancel_url: `${APP_URL}/pricing`,
});

Триал без карты

// Вариант без Stripe: триал через дату в БД
export async function startFreeTrial(userId: string): Promise<void> {
  const trialEndsAt = new Date();
  trialEndsAt.setDate(trialEndsAt.getDate() + 14);

  await db.user.update({
    where: { id: userId },
    data: {
      trialEndsAt,
      trialUsed: true, // один триал на аккаунт
    }
  });

  // Отправляем onboarding письмо
  await sendTrialStartedEmail(userId, trialEndsAt);
}

// Middleware: проверка доступа
export async function checkTrialAccess(userId: string): Promise<boolean> {
  const user = await db.user.findUnique({
    where: { id: userId },
    select: {
      trialEndsAt: true,
      subscription: { select: { status: true } }
    }
  });

  // Активная подписка
  if (user?.subscription?.status === 'ACTIVE') return true;

  // Активный триал
  if (user?.trialEndsAt && user.trialEndsAt > new Date()) return true;

  return false;
}

Уведомления в течение триала

// Cron job / scheduler: напоминания о конце триала
// Запускается ежедневно

export async function sendTrialReminders() {
  const now = new Date();

  // Уведомление за 3 дня до конца триала
  const threeDaysLeft = new Date(now.getTime() + 3 * 24 * 60 * 60 * 1000);
  const trialEndingSoon = await db.user.findMany({
    where: {
      trialEndsAt: {
        gte: now,
        lte: threeDaysLeft,
      },
      subscription: null, // без активной подписки
      trialReminderSent: false,
    }
  });

  for (const user of trialEndingSoon) {
    await sendEmail({
      to: user.email,
      template: 'trial-ending-soon',
      variables: {
        daysLeft: Math.ceil((user.trialEndsAt!.getTime() - now.getTime()) / (1000 * 60 * 60 * 24)),
        upgradeUrl: `${APP_URL}/settings/billing`,
      }
    });

    await db.user.update({
      where: { id: user.id },
      data: { trialReminderSent: true }
    });
  }

  // Уведомление об истечении триала
  const expired = await db.user.findMany({
    where: {
      trialEndsAt: { lt: now },
      subscription: null,
      trialExpiredEmailSent: false,
    }
  });

  for (const user of expired) {
    await sendEmail({
      to: user.email,
      template: 'trial-expired',
      variables: { upgradeUrl: `${APP_URL}/settings/billing` }
    });

    await db.user.update({
      where: { id: user.id },
      data: { trialExpiredEmailSent: true }
    });
  }
}

UI: триальный баннер

// components/TrialBanner.tsx
export function TrialBanner({
  trialEndsAt,
  daysLeft,
}: {
  trialEndsAt: Date;
  daysLeft: number;
}) {
  const urgency = daysLeft <= 3;

  return (
    <div
      className={`flex items-center justify-between px-4 py-2 text-sm
        ${urgency
          ? 'bg-red-50 border-b border-red-200 text-red-800'
          : 'bg-blue-50 border-b border-blue-200 text-blue-800'
        }`}
    >
      <span>
        {urgency
          ? `Триал заканчивается через ${daysLeft} ${daysLeft === 1 ? 'день' : 'дня'}!`
          : `Пробный период активен ещё ${daysLeft} дней (до ${trialEndsAt.toLocaleDateString('ru-RU')})`
        }
      </span>
      <a
        href="/settings/billing"
        className={`ml-4 font-medium underline ${urgency ? 'text-red-900' : 'text-blue-900'}`}
      >
        Перейти на платный план
      </a>
    </div>
  );
}

Метрики триала

Ключевые показатели для мониторинга:

  • Trial-to-Paid Conversion Rate — цель 15–25% для B2B SaaS
  • Trial Activation Rate — процент триалов, где пользователь выполнил ключевое действие
  • Time to First Key Action — когда пользователь впервые ощутил ценность
  • Churn at Trial End — сколько уходит в день X
// Аналитика через PostHog
posthog.capture('trial_started', {
  distinct_id: userId,
  trial_days: 14,
  plan: 'pro',
  source: 'checkout',
});

posthog.capture('trial_converted', {
  distinct_id: userId,
  trial_day: daysFromTrialStart,
  plan: 'pro',
  billing_period: 'monthly',
});

Настройка триального периода с уведомлениями и Stripe интеграцией — 2–3 рабочих дня.