Skip to content

smokeballdev/localnotificationsplugin

 
 

Repository files navigation

Local Notifications Plugin for Xamarin and Windows

Build status

A consistent and easy way to show local notifications in Xamarin and Windows apps.

Setup

Platform Support

Platform Version
Xamarin.iOS 7.0+
Xamarin.Android 3.0+ (API 11+)

API Usage

Call CrossLocalNotifications.Current from any project or PCL to gain access to APIs.

Display a local notification immediately

CrossLocalNotifications.Current
  .New(1)
  .WithTitle("title")
  .WithBody("body")
  .Show();

Display a local notification at a scheduled date/time

CrossLocalNotifications.Current
  .New(1)
  .WithTitle("title")
  .WithBody("body")
  .Show(DateTime.Now.AddSeconds(5));

Display a local notification with action(s)

CrossLocalNotifications.Current
  .RegisterActionSet("ReminderActions")
    .WithActionHandler("Dismiss", OnDismiss)
    .WithActionHandler("Snooze", OnSnooze)
    .WithDismissActionHandler(OnDismiss)
    .Register();

CrossLocalNotifications.Current
  .New(1)
  .WithTitle("title")
  .WithBody("body")
  .WithActionSet("ReminderActions", "Parameter")
  .Show(DateTime.Now.AddSeconds(5));

Note: Action set identifier must be unique, the identifier may then be used accross different notifications.

Cancel a local notification

CrossLocalNotifications.Current.Cancel(101);

Platform Specific Notes

Some platforms require certain permissions or settings before it will display notifications.

iOS 8.0+

You must get permission from the user to allow the app to show local notifications.

To do so, include the following code in the FinishedLaunching() method of AppDelegate:

if (UIDevice.CurrentDevice.CheckSystemVersion(10, 0))
{
        // Ask the user for permission to get notifications on iOS 10.0+
        UNUserNotificationCenter.Current.RequestAuthorization(
                UNAuthorizationOptions.Alert | UNAuthorizationOptions.Badge | UNAuthorizationOptions.Sound,
                (approved, error) => { });
}
else if (UIDevice.CurrentDevice.CheckSystemVersion(8, 0))
{
        // Ask the user for permission to get notifications on iOS 8.0+
        var settings = UIUserNotificationSettings.GetSettingsForTypes(
                UIUserNotificationType.Alert | UIUserNotificationType.Badge | UIUserNotificationType.Sound,
                new NSSet());

        UIApplication.SharedApplication.RegisterUserNotificationSettings(settings);
}

On iOS 10.0+ in order to specify how notifications are handled when the app is active you must create a delegate class that subclasses UNUserNotificationCenterDelegate and assign it to the UNUserNotificationCenter.

For more details see the sample included in this repository and check out Xamarin's iOS 10 UserNotifications framework documentation.

Android

Currently, if the phone is re-booted then the pending notifications are not sent, you should save them out to settings and re-send on re-boot.

Contributors

License

Licensed under MIT see License file

About

Local Notifications Plugin for Xamarin and Windows

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C# 100.0%