Skip to content

Instantly share code, notes, and snippets.

@Antoinebr
Last active January 7, 2020 19:58
Show Gist options
  • Save Antoinebr/de670e61d80c4121d45b53de1ac07b4a to your computer and use it in GitHub Desktop.
Save Antoinebr/de670e61d80c4121d45b53de1ac07b4a to your computer and use it in GitHub Desktop.
pwa-event-paris

Install workbox

npm install workbox-cli.

List your assets that will only change at build time

// workbox-config.js 

module.exports = {
    globDirectory: './',
    globPatterns: [
      'img/logo*.png',
      '{js,css}/*.{js,css}'
    ],

    swDest: './sw.js',
    clientsClaim: true,
    skipWaiting: true
  };

Generate the precache

workbox generateSW

Add custom logic


/*
| --------------------------------------------------------------------------
| Caching the home page 
| --------------------------------------------------------------------------
*/

workbox.routing.registerRoute( "/" , (args) => {

  return workbox.strategies.networkFirst()
        .handle(args).then((response) => (!response) ? caches.match('/offline.php') : response);

});



workbox.routing.registerRoute( '/index.php', (args) => {

  return workbox.strategies.networkFirst()
        .handle(args).then((response) => (!response) ? caches.match('/offline.php') : response);

});


/*
| --------------------------------------------------------------------------
|  Caching of the listing
| -------------------------------------------------------------------------- 
*/ 
const productsNetworkFirstHandler = workbox.strategies.networkFirst({
  cacheName: 'list',
  
  plugins: [
    new workbox.expiration.Plugin({
      maxEntries: 30,
      maxAgeSeconds: 2 * 30 * 24 * 60 * 60,
    }),
    new workbox.cacheableResponse.Plugin({
      statuses: [200]
    }),

  ]

});
  
    
workbox.routing.registerRoute(/list.php/, (args) => {

  return productsNetworkFirstHandler.handle(args).then((response) => (!response) ? caches.match('/offline.php') : response);

});
  


/*
| --------------------------------------------------------------------------
|  Caching the details
| -------------------------------------------------------------------------- 
*/ 

const catsNetworkFirstHandler = workbox.strategies.networkFirst({
  cacheName: 'detail-page',
  
  plugins: [
    new workbox.expiration.Plugin({
      maxEntries: 10,
      maxAgeSeconds: 2 * 30 * 24 * 60 * 60,
    }),
    new workbox.cacheableResponse.Plugin({
      statuses: [200]
    }),

  ]

});
  
    
workbox.routing.registerRoute(/detail-page.php/, (args) => {

  return catsNetworkFirstHandler.handle(args).then((response) => (!response) ? caches.match('/offline.php') : response);

});

Register the service worker

<script>
        if ("serviceWorker" in navigator) {
          navigator.serviceWorker.register("./sw.js").then(function(registration){
          
            console.log("Service Worker registered with scope:", registration.scope );
        
          }).catch(function(err) {
            
            console.log("Service worker registration failed:", err);
        
          });
        
        }
</script>

Onesignal

Install the SDK

<script src="https://cdn.onesignal.com/sdks/OneSignalSDK.js" async=""></script>
<script>
  var OneSignal = window.OneSignal || [];
  OneSignal.push(function() {
    OneSignal.init({
      appId: "26e25b26-86b2-4234-bd44-3b7f9365c735", // replace your id 
      autoRegister: false,
      notifyButton: {
        enable: false,
      },
    });
  });
</script>

Next, you'll need to add the OneSignal SDK files to your site. To do so,

Download the files here Unzip the OneSignal SDK files. There should be three files:

Upload the OneSignal SDK files to the top-level root of your site directory, making them publicly accessible.

A custom notification button

<a href="#" id="subscribe-link" style="display: none;">Subscribe to Notifications</a>

    <script>
        function subscribe() {
            OneSignal.push(["registerForPushNotifications"]);
            event.preventDefault();
        }

        var OneSignal = OneSignal || [];
        /* This example assumes you've already initialized OneSignal */
        OneSignal.push(function() {
            // If we're on an unsupported browser, do nothing
            if (!OneSignal.isPushNotificationsSupported()) return;
            OneSignal.isPushNotificationsEnabled(function(isEnabled) {
              
                if (isEnabled) {
                    // The user is subscribed to notifications
                    // Don't show anything
                } else {
                    document.getElementById("subscribe-link").addEventListener('click', subscribe);
                    document.getElementById("subscribe-link").style.display = '';
                }
            });
        });
    </script>
    

Basic offline page

The service worker

// sw.js 


/*
| --------------------------------------------------------------------------
|  Fetch return a promise : so we can catch if something goes wrong
| --------------------------------------------------------------------------
|  
|  In this example : if the request can't be made we reply with a text response
| 
*/

var responseContent = 
`
<!DOCTYPE html>
<html class="no-js">
<head>
	<meta charset="utf-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
	<title></title>
	<meta name="description" content="">
	<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
    <body>
        <style>
          
          body{
            background-color: #292929;
            font-family : sans-serif;
            text-align: center;
            color: #d4d4d4;
          }
          
           img{
               display:block;
               margin:auto;
           }
          
          a{
            display:block;
            margin:auto;
            width: 200px;
            max-width: 100%;
            background-color: #FFF;
            height : 40px; 
            line-height: 40px;
            color: black;
            text-decoration:none;
            
            margin-top: 30px; 
          }
          
        </style>
        <img src="" style="">
        
        <h1>Your seems to be offline :x </h1>
       
        <p>A question ? Send us an email ...</p>
      
        <a href="mailto:[email protected]"> send an email </a>
    </body>
</html>
`;


self.addEventListener("fetch", function(event) {

    event.respondWith(
        fetch(event.request).catch(function() {
            return new Response(responseContent, { headers: { "Content-Type": "text/html; charset=utf-8" }}
            );
        })
    );

});

Register the service worker

<script>
        if ("serviceWorker" in navigator) {
          navigator.serviceWorker.register("./sw.js").then(function(registration){
          
            console.log("Service Worker registered with scope:", registration.scope );
        
          }).catch(function(err) {
            
            console.log("Service worker registration failed:", err);
        
          });
        
        }
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment