Skip to content

ahmedjamshed/react-native-pusher-push-notifications

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

65 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

react-native-pusher-push-notifications

Manage pusher interest subscriptions from within React Native JS

IMPORTANT!!! This module is intended to complement the default Pusher setup. This module simply allows that implementation to be accessed directly from React Native JS.

npm version

Getting started

$ npm install react-native-pusher-push-notifications --save

Mostly automatic installation

$ react-native link react-native-pusher-push-notifications

Manual installation

iOS

  1. In XCode, in the project navigator, right click LibrariesAdd Files to [your project's name]
  2. Go to node_modulesreact-native-pusher-push-notifications and add RNPusherPushNotifications.xcodeproj
  3. In XCode, in the project navigator, select your project. Add libRNPusherPushNotifications.a to your project's Build PhasesLink Binary With Libraries
  4. Run your project (Cmd+R)<

Android

  1. Open up android/app/src/main/java/[...]/MainActivity.java
  • Add import com.reactlibrary.RNPusherPushNotificationsPackage; to the imports at the top of the file
  • Add new RNPusherPushNotificationsPackage() to the list returned by the getPackages() method
  1. Append the following lines to android/settings.gradle:
    include ':react-native-pusher-push-notifications'
    project(':react-native-pusher-push-notifications').projectDir = new File(rootProject.projectDir, 	'../node_modules/react-native-react-native-pusher-push-notifications/android')
    
  2. Insert the following lines inside the dependencies block in android/app/build.gradle:
      compile project(':react-native-pusher-push-notifications')
    

All installations

iOS

** DO NOT follow the pusher.com push notification docs that detail modifying the AppDelegate.h/m files! - this package takes care of most of the steps for you**

  1. After package installation open AppDelegate.h and add:
    #import <RNPusherPushNotifications.h>
    // ..after @implements and before @end
    @property (nonatomic, strong) RNPusherPushNotifications *RNPusher;
  1. Open AppDelegate.m and add:
    // Inside didFinishLaunchingWithOptions, near the bottom (after rootView has been initialised)
    self.RNPusher = [((RCTRootView *) self.window.rootViewController.view).bridge moduleForName:@"RNPusherPushNotifications"];

    // Add the following as a new methods to AppDelegate.m
    - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
      [[((RCTRootView *) self.window.rootViewController.view).bridge moduleForName:@"RNPusherPushNotifications"] setDeviceToken:deviceToken];
    }

    - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)notification {
      [[((RCTRootView *) self.window.rootViewController.view).bridge moduleForName:@"RNPusherPushNotifications"] handleNotification:notification];
    }

Usage

  // Import module
  import RNPusherPushNotifications from 'react-native-pusher-push-notifications';

  // Get your interest
  const donutsInterest = "donuts";

  // Set your app key and register for push
  RNPusherPushNotifications.setAppKey(CONSTANTS.PUSHER_APP_KEY);

  // Init interests after registration
  RNPusherPushNotifications.on('registered', subscribe(donutsInterest));

  // Setup notification listeners
  RNPusherPushNotifications.on('notification', handleNotification);

  // Handle notifications received
  const handleNotification = (notification) => {
    console.log(notification);
  };

  // Subscribe to an interest
  const subscribe = (interest) => {
    // Note that only Android devices will respond to success/error callbacks
    RNPusherPushNotifications.subscribe(
        interest,
        (statusCode, response) => {
            console.error(statusCode, response);
        },
        () => {
            console.log("Success");
        }
    );
  };

  // Unsubscribe an interest
  const unsubscribe = (interest) => {
    // Note that only Android devices will respond to success/error callbacks
    RNPusherPushNotifications.unsubscribe(
        interest,
        (statusCode, response) => {
            console.error(statusCode, response);
        },
        () => {
            console.log("Success");
        }
    );
  };

About

Manage pusher interest subscriptions and notification events in Javascript.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 68.5%
  • Objective-C 19.9%
  • JavaScript 11.6%