Обработка событий онбординга в Capacitor SDK
Онбординги, настроенные в конструкторе, генерируют события, на которые ваше приложение может реагировать. Используйте метод setEventHandlers для обработки этих событий при самостоятельном отображении экранов.
Перед началом убедитесь, что:
- Вы создали онбординг.
- Вы добавили онбординг в плейсмент.
Настройка обработчиков событий
Для обработки событий онбордингов используйте метод view.setEventHandlers:
try {
const view = await createOnboardingView(onboarding);
view.setEventHandlers({
onAnalytics(event, meta) {
console.log('Analytics event:', event);
},
onClose(actionId, meta) {
console.log('Onboarding closed:', actionId);
return true; // Allow the onboarding to close
},
onCustom(actionId, meta) {
console.log('Custom action:', actionId);
return false; // Don't close the onboarding
},
onPaywall(actionId, meta) {
console.log('Paywall action:', actionId);
view.dismiss().then(() => {
openPaywall(actionId);
});
},
onStateUpdated(action, meta) {
console.log('State updated:', action);
},
onFinishedLoading(meta) {
console.log('Onboarding finished loading');
},
onError(error) {
console.error('Onboarding error:', error);
},
});
await view.present();
} catch (error) {
console.error('Failed to present onboarding:', error);
}
Типы событий
В следующих разделах описаны различные типы событий, которые можно обрабатывать.
Обработка пользовательских действий
В конструкторе можно добавить к кнопке действие custom и назначить ему идентификатор.
Затем вы можете использовать этот ID в коде и обрабатывать его как пользовательское действие. Например, если пользователь нажимает на кастомную кнопку — Login или Allow notifications — обработчик события будет вызван с параметром actionId, соответствующим Action ID из билдера. Вы можете задавать собственные ID, например "allowNotifications".
view.setEventHandlers({
onCustom(actionId, meta) {
switch (actionId) {
case 'login':
console.log('Login action triggered');
break;
case 'allow_notifications':
console.log('Allow notifications action triggered');
break;
}
return false; // Don't close the onboarding
},
});
Пример события (нажмите, чтобы раскрыть)
{
"actionId": "allow_notifications",
"meta": {
"onboardingId": "onboarding_123",
"screenClientId": "profile_screen",
"screenIndex": 0,
"screensTotal": 3
}
}Завершение загрузки онбординга
Когда онбординг завершает загрузку, срабатывает следующее событие:
view.setEventHandlers({
onFinishedLoading(meta) {
console.log('Onboarding loaded:', meta.onboardingId);
},
});
Пример события (нажмите, чтобы развернуть)
{
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "welcome_screen",
"screen_index": 0,
"total_screens": 4
}
}Закрытие онбординга
Онбординг считается закрытым, когда пользователь нажимает кнопку с назначенным действием Close.
Обратите внимание, что вам нужно самостоятельно обработать закрытие онбординга. Например, необходимо прекратить отображение самого онбординга.
view.setEventHandlers({
onClose(actionId, meta) {
console.log('Онбординг закрыт:', actionId);
return true; // Разрешить закрытие онбординга
},
});
Пример события (нажмите, чтобы развернуть)
{
"action_id": "close_button",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "final_screen",
"screen_index": 3,
"total_screens": 4
}
}Открытие пейвола
Обрабатывайте это событие, если хотите открыть пейвол внутри онбординга. Если нужно открыть пейвол после его закрытия, есть более простой способ — обработайте действие закрытия и откройте пейвол, не опираясь на данные события.
Самый удобный подход при работе с пейволами в онбордингах — сделать ID действия равным ID плейсмента пейвола.
Обратите внимание: на iOS одновременно может отображаться только один экран (пейвол или онбординг). Если вы показываете пейвол поверх онбординга, вы не можете программно управлять онбордингом в фоне. Попытка закрыть онбординг приведёт к закрытию пейвола, а онбординг останется видимым. Чтобы этого избежать, всегда закрывайте экран онбординга перед показом пейвола.
view.setEventHandlers({
onPaywall(actionId, meta) {
// Скрыть онбординг перед показом пейвола
view.dismiss().then(() => {
openPaywall(actionId);
});
},
});
async function openPaywall(placementId: string) {
// Реализуйте здесь логику открытия пейвола
}
Пример события (нажмите, чтобы развернуть)
{
"action_id": "premium_offer_1",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "pricing_screen",
"screen_index": 2,
"total_screens": 4
}
}Отслеживание навигации
Аналитическое событие поступает при возникновении различных событий навигации в процессе онбординга:
view.setEventHandlers({
onAnalytics(event, meta) {
console.log('Analytics event:', event.type, meta.onboardingId);
},
});
Объект event может быть одного из следующих типов:
| Тип | Описание |
|---|---|
onboardingStarted | Когда онбординг загружен |
screenPresented | Когда показывается любой экран |
screenCompleted | Когда экран завершён. Включает опциональный elementId (идентификатор завершённого элемента) и опциональный reply (ответ пользователя). Срабатывает, когда пользователь выполняет любое действие для выхода с экрана. |
secondScreenPresented | Когда показывается второй экран |
userEmailCollected | Срабатывает, когда email пользователя собирается через поле ввода |
onboardingCompleted | Срабатывает, когда пользователь достигает экрана с ID final. Если вам нужно это событие, присвойте ID final последнему экрану. |
unknown | Для любого нераспознанного типа события. Включает name (название неизвестного события) и meta (дополнительные метаданные) |
Каждое событие содержит информацию meta со следующими полями: |
| Поле | Описание |
|---|---|
onboardingId | Уникальный идентификатор флоу онбординга |
screenClientId | Идентификатор текущего экрана |
screenIndex | Позиция текущего экрана в флоу |
screensTotal | Общее количество экранов в флоу |
Примеры событий (нажмите, чтобы развернуть)
// onboardingStarted
{
"name": "onboarding_started",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "welcome_screen",
"screen_index": 0,
"total_screens": 4
}
}
// screenPresented
{
"name": "screen_presented",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "interests_screen",
"screen_index": 2,
"total_screens": 4
}
}
// screenCompleted
{
"name": "screen_completed",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "profile_screen",
"screen_index": 1,
"total_screens": 4
},
"params": {
"element_id": "profile_form",
"reply": "success"
}
}
// secondScreenPresented
{
"name": "second_screen_presented",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "profile_screen",
"screen_index": 1,
"total_screens": 4
}
}
// userEmailCollected
{
"name": "user_email_collected",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "profile_screen",
"screen_index": 1,
"total_screens": 4
}
}
// onboardingCompleted
{
"name": "onboarding_completed",
"meta": {
"onboarding_id": "onboarding_123",
"screen_cid": "final_screen",
"screen_index": 3,
"total_screens": 4
}
}