Capacitor SDK: Руководство по базовой интеграции
В этом разделе содержится информация о том, как интегрировать Pushwoosh Capacitor SDK в ваше приложение.
Предварительные требования
Anchor link toДля интеграции Pushwoosh Capacitor SDK в ваше приложение вам понадобится следующее:
Шаги интеграции
Anchor link to1. Добавьте зависимость Pushwoosh Capacitor SDK
Anchor link toДобавьте зависимость Pushwoosh Capacitor SDK в ваш проект:
npm install pushwoosh-capacitor-pluginСинхронизируйте конфигурацию Capacitor:
npx cap sync2. Инициализация Capacitor SDK
Anchor link toВ вашем основном JavaScript-файле импортируйте и инициализируйте Pushwoosh SDK:
import { Pushwoosh } from 'pushwoosh-capacitor-plugin';
// Инициализируем SDKPushwoosh.onDeviceReady({ appid: "__YOUR_APP_CODE__"});
// Регистрируемся для получения push-уведомленийPushwoosh.registerDevice() .then(result => { console.log("Push token:", result.pushToken); // Обрабатываем успешную регистрацию }) .catch(error => { console.error("Failed to register device:", error); // Обрабатываем ошибку регистрации });Где:
__YOUR_APP_CODE__— это код приложения из Панели управления Pushwoosh.
3. Нативная настройка для iOS
Anchor link to3.1 Capabilities
Anchor link toЧтобы включить Push-уведомления в вашем проекте, необходимо добавить определенные capabilities.
В разделе Signing & Capabilities добавьте следующие capabilities:
Push NotificationsBackground Modes. После добавления этой capability отметьте флажокRemote notifications.
Если вы планируете использовать Time Sensitive Notifications (iOS 15+), также добавьте capability Time Sensitive Notifications.
3.2 Info.plist
Anchor link toВ вашем Runner/Info.plist установите ключ __PUSHWOOSH_DEVICE_API_TOKEN__ в значение Pushwoosh Device API Token:
<key>Pushwoosh_API_TOKEN</key><string>__PUSHWOOSH_DEVICE_API_TOKEN__</string>3.3 Отслеживание доставки сообщений
Anchor link toВы должны добавить таргет Notification Service Extension в ваш проект. Это необходимо для точного отслеживания доставки и таких функций, как Rich Media на iOS.
Следуйте шагам из руководства по нативной интеграции, чтобы добавить таргет расширения и необходимый код Pushwoosh в него.
4. Нативная настройка для Android
Anchor link to4.1 Установка зависимостей
Anchor link toУбедитесь, что необходимые зависимости и плагины добавлены в ваши скрипты Gradle:
Добавьте плагин Google Services Gradle в зависимости вашего build.gradle на уровне проекта:
buildscript { dependencies { classpath 'com.google.gms:google-services:4.3.15' }}Примените плагин в вашем файле build.gradle на уровне приложения:
apply plugin: 'com.google.gms.google-services'4.2 Добавьте конфигурационный файл Firebase
Anchor link toПоместите файл google-services.json в папку android/app в директории вашего проекта.
4.3 Добавьте метаданные Pushwoosh
Anchor link toВ вашем main/AndroidManifest.xml добавьте Pushwoosh Device API Token внутрь тега <application>:
<meta-data android:name="com.pushwoosh.apitoken" android:value="__YOUR_DEVICE_API_TOKEN__" />Важно: Убедитесь, что токену предоставлен доступ к нужному приложению в вашей Панели управления Pushwoosh. Узнать больше
5. Запустите проект
Anchor link to- Соберите и запустите проект.
- Перейдите в Панель управления Pushwoosh и отправьте push-уведомление.
- Вы должны увидеть уведомление в приложении.
Расширенная интеграция
Anchor link toНа этом этапе вы уже интегрировали SDK и можете отправлять и получать push-уведомления. Теперь давайте рассмотрим основной функционал.
Слушатели событий push-уведомлений
Anchor link toВ Pushwoosh Capacitor SDK есть два callback-метода для обработки push-уведомлений:
pushReceivedCallbackсрабатывает при получении push-уведомленияpushOpenedCallbackсрабатывает, когда пользователь открывает уведомление
Вам следует настроить эти колбэки сразу после инициализации SDK:
import { Pushwoosh } from 'pushwoosh-capacitor-plugin';
// Настраиваем колбэк получения push-уведомленияawait Pushwoosh.pushReceivedCallback((notification, err) => { if (err) { console.error("Failed to process received notification:", err); } else { console.log("Push received:", JSON.stringify(notification)); // Обрабатываем полученное уведомление }});
// Настраиваем колбэк открытия push-уведомленияawait Pushwoosh.pushOpenedCallback((notification, err) => { if (err) { console.error("Failed to process opened notification:", err); } else { console.log("Push opened:", JSON.stringify(notification)); // Обрабатываем открытое уведомление }});Конфигурация пользователя
Anchor link toФокусируясь на поведении и предпочтениях отдельных пользователей, вы можете доставлять персонализированный контент, что приводит к повышению удовлетворенности и лояльности пользователей.
import { Pushwoosh } from 'pushwoosh-capacitor-plugin';
class Registration { async afterUserLogin(user) {
// Устанавливаем User ID Pushwoosh.setUserId(user.getId);
// Устанавливаем дополнительную информацию о пользователе в виде тегов для Pushwoosh await Pushwoosh.setTags({ "age": user.getAge(), "name": user.getName(), "last_login": user.getLastLoginDate() }); }}Теги
Anchor link toТеги — это пары «ключ-значение», присваиваемые пользователям или устройствам, которые позволяют сегментировать аудиторию на основе таких атрибутов, как предпочтения или поведение, что делает возможным таргетированный обмен сообщениями.
import { Pushwoosh } from 'pushwoosh-capacitor-plugin';
class UpdateUser { async afterUserUpdateProfile(user) {
// Устанавливаем список избранных категорий await Pushwoosh.setTags({ "favorite_categories": user.getFavoriteCategoriesList() });
// Устанавливаем платежную информацию await Pushwoosh.setTags({ "is_subscribed": user.isSubscribed(), "payment_status": user.getPaymentStatus(), "billing_address": user.getBillingAddress() }); }}События
Anchor link toСобытия — это определенные действия или происшествия пользователя в приложении, которые можно отслеживать для анализа поведения и запуска соответствующих сообщений или действий.
import { Pushwoosh } from 'pushwoosh-capacitor-plugin';
class Registration {
// Отслеживаем событие входа afterUserLogin(user) { Pushwoosh.postEvent("login", { "name": user.getName(), "last_login": user.getLastLoginDate() }); }
// Отслеживаем событие покупки afterUserPurchase(product) { Pushwoosh.postEvent("purchase", { "product_id": product.getId(), "product_name": product.getName(), "price": product.getPrice(), "quantity": product.getQuantity() }); }}Устранение неполадок
Anchor link toЕсли у вас возникнут какие-либо проблемы в процессе интеграции, обратитесь к разделу поддержки и сообщества.