Javascript Desktop Notifications

I'm not gonna write massive paragraphs about his one, but simply provide a nice example of how to implement desktop notifications for browsers running webkit in JavaScript. Who knows maybe Internet Explorer will support it some time soon?

Here's my useful function that should let you easily post notifications to the user, it includes an onclick handler and auto focuses the window on click too.

var Site = {};
Site.Notifications = {
    GainAccess: function (callback) {
        if (Notification.permission !== "granted") { 
            Notification.requestPermission(callback);
        }
    },
    Notify: function (title, message, imageAddress, onclick) {
        var notification = {};

        // Let's check if the browser supports notifications
        if (!("Notification" in window)) {
            //alert("This browser does not support system notifications");
            return;
        }

        // Let's check whether notification permissions have already been granted
        else if (Notification.permission === "granted") {
        // If it's okay let's create a notification
            notification = new Notification(title,
            {
                icon: imageAddress,
                body: message,
            });
        }

        // Otherwise, we need to ask the user for permission
        else if (Notification.permission !== 'denied') {
            Notification.requestPermission(function (permission) {
                // If the user accepts, let's create a notification
                if (permission === "granted") {
                    notification = new Notification(title,
                    {
                        icon: imageAddress,
                        body: message,
                    });
                }
            });
        }

        // Add callback when notification is clicked.
        notification.onclick = function () {
            // Show user the screen.
            window.focus();

            // Close notification.
            notification.close();

            // Perform requested action.
            if (onclick != undefined && onclick != null) {
                onclick();
            }
        };
    }
}

Then you simply call it using the code below:

Site.Notifications.Notify("Hello world", "How you doin?", "http://linktomyimages.com/image.png", function () { alert ("You clicked my notification!") });

That's it.


Published at

Tags: JavaScript

Luke Alderton

Comments

Post a comment
Sit tight...
We're adding your comment.
Thank you.
Your comment has been added.
There's been a problem.
Please try again later.
Share with
Tags
Latest Comments
By DavidassuG on MVC forms in Umbraco
12 Jul 2018, 10:54 AM
By Luke on Setting up tables in SQLite with a primary key on a Xamarin Forms app
11 Jul 2018, 09:18 AM
By Travis on Setting up tables in SQLite with a primary key on a Xamarin Forms app
7 Jul 2018, 15:44 PM
By Luke on Auto/Custom height on Xamarin Forms WebView for Android and iOS
15 Jun 2018, 09:43 AM
By vikki on Auto/Custom height on Xamarin Forms WebView for Android and iOS
14 Jun 2018, 13:35 PM
By jimbo on JQuery Unobtrusive Validation for dynamically created elements
13 Jun 2018, 17:13 PM
By ScottKem on MVC forms in Umbraco
8 Jun 2018, 10:29 AM
By Alaa on java.lang.UnsatisfiedLinkError: no rxtxSerial in java.library.path
3 Jun 2018, 20:16 PM
Categories
App Development
Event
Game Development
Mapping
Modelling
Programming
Review
Robotics
Tutorial
Web Development