Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

hops-pwa

Package Overview
Dependencies
Maintainers
8
Versions
170
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

hops-pwa

ServiceWorker and Web App Manifest support for Hops

  • 15.2.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
26
decreased by-87.74%
Maintainers
8
Weekly downloads
 
Created
Source

hops-pwa

npm

Please see the main Hops Readme for general information and a Getting Started Guide.

This is a preset for Hops that can be used to enable progressive web app features like a web app manifest and service worker usage in Hops.

Installation

Add this preset to your existing Hops React project:

npm install --save hops-pwa

If you don't already have an existing Hops project read this section on how to set up your first Hops project.

Usage

Web App Manifest

When you import / require a web app manifest in your application code you will get an URL to the web app manifet which you can, for example, render in a <link /> element via React Helmet Async.

import manifest from './manifest.webmanifest';
// inside a components render method
<Helmet>
  <link rel="manifest" href={manifest} />
</Helmet>;

Images that are referenced inside the web app manifest will be copied to the public directory and its references inside the webmanifest will be updated.

Service Worker

In order to use a service worker you need to configure the path to your worker file via the workerFile preset option and then import the installServiceWorker() function from hops-pwa.

import installServiceWorker from 'hops-pwa';

installServiceWorker();

Check out this integration test as an example for how to use this preset.

Consumer API
installServiceWorker(): Promise<ServiceWorkerRegistration>

This is the main export of hops-pwa which, when executed, will register the configured service worker and return a promise which resolves to the ServiceWorkerRegistration object.

Configuration

Preset Options
NameTypeDefaultRequiredDescription
workerPathString<basePath>/sw.jsnoThe path on which to serve the service worker
workerFileStringhops-pwa/worker.jsyesThe path to the service worker entry file
workerPath

This configures the path on which to serve the service worker.

workerFile

This is the path to the service worker source file which will be compiled via webpack and served on the workerPath.

The service worker is expected to export a function with the following signature: (config, assets): void.

The assets parameter is an array of asset urls that your build produced (referenced images, styles, scripts, etc) and might be used for precaching them.

export default (config, assets) => {
  // your worker code goes here. e.g.:
  self.addEventListener('install', (event) => {
    event.waitUntil(precache(assets));
  });
};
Render Options

This preset has no runtime options.

Keywords

FAQs

Package last updated on 20 Jun 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc