pushwoosh-cordova-plugin
v8.3.69
Published
This plugin allows you to send and receive push notifications. Powered by Pushwoosh (www.pushwoosh.com).
Downloads
7,446
Readme
Table of Contents
- Documentation
- Features
- Installation
- AI-Assisted Integration
- Quick Start
- API Reference
- Plugin Preferences
- Support
- License
Documentation
- Integration Guide — step-by-step setup
- API Reference — full API documentation
Features
- Push Notifications — register, receive, and handle push notifications on iOS and Android
- In-App Messages — trigger and display in-app messages based on events
- Tags & Segmentation — set and get user tags for targeted messaging
- User Identification — associate devices with user IDs for cross-device tracking
- Message Inbox — built-in UI for message inbox with customization options
- Badge Management — set, get, and increment app icon badge numbers
- Local Notifications — schedule and manage local notifications
- VoIP Calls — CallKit (iOS) and ConnectionService (Android) integration for VoIP push calls
- Huawei Push — HMS push notification support
- TypeScript Support — full TypeScript definitions included
Installation
Using npm:
cordova plugin add [email protected]Using git:
cordova plugin add https://github.com/Pushwoosh/pushwoosh-phonegap-plugin.git#8.3.69AI-Assisted Integration
Integrate the Pushwoosh Cordova plugin using AI coding assistants (Claude Code, Cursor, GitHub Copilot, etc.).
Requirement: Your AI assistant must have access to Context7 MCP server or web search capabilities.
Quick Start Prompts
Choose the prompt that matches your task:
1. Basic Plugin Integration
Integrate Pushwoosh Cordova plugin into my Cordova project.
Requirements:
- Install pushwoosh-cordova-plugin via npm
- Initialize Pushwoosh with my App ID in deviceready event
- Register for push notifications and handle push-receive and push-notification events
Use Context7 MCP to fetch Pushwoosh Cordova plugin documentation.2. Tags and User Segmentation
Show me how to use Pushwoosh tags in a Cordova app for user segmentation.
I need to set tags, get tags, and set user ID for cross-device tracking.
Use Context7 MCP to fetch Pushwoosh Cordova plugin documentation for setTags and getTags.3. Message Inbox Integration
Integrate Pushwoosh Message Inbox into my Cordova app. Show me how to:
- Display the inbox UI with custom styling
- Load messages programmatically
- Track unread message count
Use Context7 MCP to fetch Pushwoosh Cordova plugin documentation for presentInboxUI.Quick Start
Initialization
document.addEventListener('deviceready', function() {
var pushwoosh = cordova.require("pushwoosh-cordova-plugin.PushNotification");
// 1. Register notification callbacks before initialization
document.addEventListener('push-receive', function(event) {
var notification = event.notification;
console.log("Push received: " + JSON.stringify(notification));
});
document.addEventListener('push-notification', function(event) {
var notification = event.notification;
console.log("Push opened: " + JSON.stringify(notification));
});
// 2. Initialize Pushwoosh
pushwoosh.onDeviceReady({
appid: "XXXXX-XXXXX" // Pushwoosh Application ID
});
// 3. Register the device to receive push notifications
pushwoosh.registerDevice(
function(status) {
console.log("Registered with push token: " + status.pushToken);
},
function(error) {
console.error("Failed to register: " + error);
}
);
}, false);User ID and Events
var pushwoosh = cordova.require("pushwoosh-cordova-plugin.PushNotification");
pushwoosh.setUserId("user_123");
pushwoosh.postEvent("purchase", {
product: "Premium Plan",
price: "9.99"
});Tags
var pushwoosh = cordova.require("pushwoosh-cordova-plugin.PushNotification");
// Set tags
pushwoosh.setTags(
{ age: 25, name: "John", favorite_categories: ["sports", "news"] },
function() { console.log("Tags set successfully"); },
function(error) { console.error("Failed to set tags: " + error); }
);
// Get tags
pushwoosh.getTags(
function(tags) { console.log("Tags: " + JSON.stringify(tags)); },
function(error) { console.error("Failed to get tags: " + error); }
);API Reference
Initialization & Registration
| Method | Description |
|--------|-------------|
| onDeviceReady(config) | Initialize the plugin. Call on every app launch |
| registerDevice(success, fail) | Register for push notifications |
| unregisterDevice(success, fail) | Unregister from push notifications |
| getPushToken(success) | Get the push token |
| getPushwooshHWID(success) | Get Pushwoosh Hardware ID |
Tags & User Data
| Method | Description |
|--------|-------------|
| setTags(tags, success, fail) | Set device tags |
| getTags(success, fail) | Get device tags |
| setUserId(userId) | Set user identifier for cross-device tracking |
| setLanguage(language) | Set custom language for localized pushes |
| setEmail(email, success, fail) | Register email for the user |
| setEmails(emails, success, fail) | Register multiple emails |
Notifications
| Method | Description |
|--------|-------------|
| getRemoteNotificationStatus(success, fail) | Get push notification permission status |
| getLaunchNotification(success) | Get notification that launched the app |
| createLocalNotification(config, success, fail) | Schedule a local notification |
| clearLocalNotification() | Clear all pending local notifications (Android) |
| clearNotificationCenter() | Clear all notifications from notification center (Android) |
Badge Management
| Method | Description |
|--------|-------------|
| setApplicationIconBadgeNumber(badge) | Set badge number |
| getApplicationIconBadgeNumber(success) | Get current badge number |
| addToApplicationIconBadgeNumber(badge) | Increment/decrement badge |
In-App Messages & Events
| Method | Description |
|--------|-------------|
| postEvent(event, attributes) | Post event to trigger In-App Messages |
| addJavaScriptInterface(name) | Add JS interface for Rich Media communication |
Message Inbox
| Method | Description |
|--------|-------------|
| presentInboxUI(params) | Open inbox UI with optional style customization |
| loadMessages(success, fail) | Load inbox messages programmatically |
| unreadMessagesCount(success) | Get unread message count |
| messagesCount(success) | Get total message count |
| readMessage(id) | Mark message as read |
| deleteMessage(id) | Delete a message |
| performAction(id) | Perform the action associated with a message |
Communication Control
| Method | Description |
|--------|-------------|
| setCommunicationEnabled(enable, success, fail) | Enable/disable all Pushwoosh communication |
| isCommunicationEnabled(success) | Check if communication is enabled |
Events
| Event | Description |
|-------|-------------|
| push-receive | Fired when a notification is received while the app is active |
| push-notification | Fired when a notification is opened by the user |
Plugin Preferences
Configure these in your config.xml:
<plugin name="pushwoosh-cordova-plugin">
<variable name="LOG_LEVEL" value="DEBUG" />
<variable name="IOS_FOREGROUND_ALERT_TYPE" value="ALERT" />
<variable name="ANDROID_FOREGROUND_PUSH" value="true" />
<variable name="PW_VOIP_IOS_ENABLED" value="false" />
<variable name="PW_VOIP_ANDROID_ENABLED" value="false" />
</plugin>| Preference | Default | Description |
|-----------|---------|-------------|
| LOG_LEVEL | DEBUG | Logging level |
| IOS_FOREGROUND_ALERT_TYPE | ALERT | iOS foreground notification display type |
| ANDROID_FOREGROUND_PUSH | true | Show notifications when app is in foreground (Android) |
| PW_VOIP_IOS_ENABLED | false | Enable VoIP calling features on iOS |
| PW_VOIP_ANDROID_ENABLED | false | Enable VoIP calling features on Android |
VoIP in Capacitor
This plugin works in Capacitor apps. Capacitor does not execute Cordova hooks, so VoIP dependencies must be added manually to your native projects.
iOS
Add the VoIP pod to ios/App/Podfile:
pod 'PushwooshXCFramework/PushwooshVoIP'Then run pod install in the ios/App/ directory.
Android
Add the property to android/gradle.properties:
PW_VOIP_ANDROID_ENABLED=trueThese changes persist across cap sync since Capacitor does not regenerate native projects.
Support
License
Pushwoosh Cordova Plugin is available under the MIT license. See LICENSE for details.
Made with ❤️ by Pushwoosh
