chore: update readme

This commit is contained in:
Ayo Ayco 2024-08-03 10:40:29 +02:00
parent fb8a4699cb
commit d44c39ce59

View file

@ -1,9 +1,21 @@
> **>>> TL;DR:** Simple Astro integration to use your own authored service-worker; by default, devs retain full control as opposed to getting generated sw code
> **>>> TL;DR:** Simple Astro integration to use your own authored service worker; by default, devs retain full control as opposed to getting generated sw code
# Astro SW
The integration `serviceWorker` accepts configuration with service worker path and automatically injects needed dynamic variables such as `assets` generated by Astro for caching
## Installation
In your [Astro](https://astro.build) project:
```bash
# npm
$ npm i -D @ayco/astro-sw
# pnpm
$ pnpm add -D @ayco/astro-sw
```
## Usage
Example `astro.config.mjs`
@ -34,5 +46,9 @@ The integration accepts a configuration object of type `ServiceWorkerConfig` wit
| property | type | required? | notes |
| --- | --- | --- | --- |
| path | string | required | path to your *own* service worker script; no surprises & easy debugging |
| assetCachePrefix | string | optional | cache storage name prefix; useful for debugging & invalidation |
| assetCacheVersionID | string | optional | cache storage name versioning; by default, a random UUID is used but you can provide your own for easy debugging |
| assetCachePrefix | string | optional | cache storage name prefix; useful for debugging |
| assetCacheVersionID | string | optional | cache storage name versioning; by default, a random UUID is used but you can provide your own for easy debugging & invalidation |
## Example sw.js
You can find an example service worker (`example_sw.js`) in the [repository](https://ayco.io/gh/astro-sw), and here's the [raw file](https://raw.githubusercontent.com/ayoayco/astro-sw/main/example_sw.js) too.