📦 plugin-pwa
Plugin Docusaurus pour ajouter le support PWA en utilisant Workbox. Ce plugin génère un Service Worker uniquement en production et vous permet de créer un site de documentation entièrement conforme à la PWA avec support hors ligne et installation.
#
Installation- npm
- Yarn
npm install --save @docusaurus/plugin-pwa
yarn add @docusaurus/plugin-pwa
#
ConfigurationCréer un manifest PWA dans ./static/manifest.json
.
Modifiez docusaurus.config.js
avec une configuration PWA minimale, tel que :
module.exports = { plugins: [ [ '@docusaurus/plugin-pwa', { debug: true, offlineModeActivationStrategies: [ 'appInstalled', 'standalone', 'queryString', ], pwaHead: [ { tagName: 'link', rel: 'icon', href: '/img/docusaurus.png', }, { tagName: 'link', rel: 'manifest', href: '/manifest.json', // your PWA manifest }, { tagName: 'meta', name: 'theme-color', content: 'rgb(37, 194, 160)', }, ], }, ], ],};
#
Application Web progressiveL'installation d'un Service Worker ne suffit pas à faire de votre application une PWA. Vous devez inclure au moins un Manifest d'Application Web et avoir les tags corrects dans le <head>
(Options > pwaHead).
Après le déploiement, vous pouvez utiliser Lighthouse pour exécuter un audit sur votre site.
Pour une liste plus exhaustive de ce qu'il faut pour que votre site soit un PWA, reportez-vous à la Liste de contrôle PWA
#
Prise en charge de l'installation de l'applicationSi votre navigateur le supporte, vous devriez pouvoir installer un site Docusaurus en tant qu'application.
remarque
L'installation de l'application nécessite le protocole https et un manifeste valide.
#
Mode hors ligne (pré-cache)Nous permettons aux utilisateurs de naviguer sur un site Docusaurus hors ligne, en utilisant la mise en cache préalable du service-worker.
Qu'est-ce que le Pré-cache ?#
Une des caractéristiques des services workers est la possibilité d'enregistrer un ensemble de fichiers dans le cache lors de l'installation du service worker. On l'appelle souvent « pré-cache », puisque vous mettez en cache du contenu avant que le service ne soit utilisé.
La principale raison de ce choix est qu'il donne aux développeurs le contrôle du cache, ce qui signifie qu'ils peuvent déterminer quand et combien de temps un fichier est mis en cache et le servir au navigateur sans passer par le réseau, ce qui signifie qu'il peut être utilisé pour créer des applications web qui fonctionnent hors ligne.
Workbox se charge d'une grande partie de la mise en cache en simplifiant l'API et en garantissant un téléchargement efficace des ressources.
Par défaut, le mode hors ligne est activé lorsque le site est installé en tant qu'application. Voir l'option offlineModeActivationStrategies
pour plus de détails.
Une fois que le site a été mis en précache, le service worker servira des réponses en cache pour des visites ultérieures. Lorsqu'une nouvelle version est déployée avec un nouveau service worker, le nouveau commence à s'installer et passe ensuite à l'état d'attente. Pendant cet état d'attente, une popup de rechargement s'affichera et demandera à l'utilisateur de recharger la page pour un nouveau contenu. Tant que l'utilisateur n'aura pas vidé le cache de l'application ou cliqué sur le bouton reload
de la popup, le service worker continuera à servir l'ancien contenu.
caution
Le mode hors-ligne / pré-cache nécessite de télécharger tous les ressources statiques du site à l'avance, et peut consommer de la bande passante inutilement. Ce n'est peut-être pas une bonne idée de l'activer pour tous les types de sites.
#
Optionsdebug
#
- Type :
boolean
- Par défaut :
false
Permet d'activer le mode débogage :
- Logs de Workbox
- Logs additionnels de Docusaurus
- Sortie de fichier SW non optimisé
- Source maps
offlineModeActivationStrategies
#
- Type :
Array<'appInstalled' | 'mobile' | 'saveData'| 'queryString' | 'always'>
- Par défaut :
['appInstalled','queryString','standalone']
Stratégies utilisées pour activer le mode hors ligne :
appInstalled
: active pour les utilisateurs ayant installé le site comme une application (pas fiable à 100%)standalone
: active pour les utilisateurs exécutant l'application comme autonome (souvent le cas une fois qu'une PWA est installé)queryString
: active si queryString contientofflineMode=true
(pratique pour le débogage PWA)mobile
: active pour les utilisateurs mobiles (largeur <= 940px)saveData
: active pour les utilisateurs avecnavigator.connection.saveData === true
always
: active pour tous les utilisateurs
caution
Utilisez ceci avec précaution : certains utilisateurs n'aiment pas être forcés d'utiliser le mode hors ligne.
danger
Il n'est pas possible de détecter si c'est un PWA de manière très fiable.
L'événement appinstalled
a été supprimé de la spécification et l'API navigator.getInstalledRelatedApps()
n'est prise en charge que dans les versions récentes de Chrome et nécessite related_applications
déclarée dans le manifeste.
La stratégie standalone
est une belle solution de secours pour activer le mode hors ligne (au moins lors de l'exécution de l'application installée).
injectManifestConfig
#
Les options de Workbox à passer à workbox.injectManifest()
. Cela vous permet de contrôler les ressources qui seront mises en pré-cache et seront disponibles hors ligne.
- Type :
InjectManifestOptions
- Par défaut :
{}
module.exports = { plugins: [ [ '@docusaurus/plugin-pwa', { injectManifestConfig: { manifestTransforms: [ //... ], modifyURLPrefix: { //... }, // Nous ajoutons déjà des ressources statiques régulières (html, images...) pour qu'elles soient disponibles hors ligne. // Vous pouvez ajouter d'autres fichiers en fonction de vos besoins globPatterns: ['**/*.{pdf,docx,xlsx}'], // ... }, }, ], ],};
reloadPopup
#
- Type :
string | false
- Par défaut :
'@theme/PwaReloadPopup'
Chemin du module pour recharger le composant popup. Ce popup est rendu lorsqu'un nouveau service worker attend d'être installé, et que nous suggérons un rechargement à l'utilisateur.
Le passage à false
désactivera la popup, mais ce n'est pas recommandé : les utilisateurs n'auront pas de moyen d'obtenir un contenu à jour.
Un composant personnalisé peut être utilisé, à condition qu'il accepte onReload
en tant que prop. La fonction de rappel onReload
doit être appelée lorsque le bouton reload
est cliqué. Cela indiquera au service worker d'installer le service worker en attente et de recharger la page.
interface PwaReloadPopupProps { onReload: () => void;}
Le thème par défaut inclut une implémentation pour la popup de rechargement et utilise Infima Alerts.
pwaHead
#
- Type :
Array<{ tagName: string } & Record<string,string>>
- Par défaut :
[]
Tableau d'objets contenant tagName
et des paires clé-valeur pour les attributs à injecter dans la balise <head>
. Techniquement, vous pouvez injecter n'importe quelle balise head par ce biais, mais l'idéal est de l'utiliser pour les balises afin de rendre votre site conforme à la norme PWA. Voici une liste de tags pour rendre votre application entièrement compatible :
module.exports = { plugins: [ [ '@docusaurus/plugin-pwa', { pwaHead: [ { tagName: 'link', rel: 'icon', href: '/img/docusaurus.png', }, { tagName: 'link', rel: 'manifest', href: '/manifest.json', }, { tagName: 'meta', name: 'theme-color', content: 'rgb(37, 194, 160)', }, { tagName: 'meta', name: 'apple-mobile-web-app-capable', content: 'yes', }, { tagName: 'meta', name: 'apple-mobile-web-app-status-bar-style', content: '#000', }, { tagName: 'link', rel: 'apple-touch-icon', href: '/img/docusaurus.png', }, { tagName: 'link', rel: 'mask-icon', href: '/img/docusaurus.svg', color: 'rgb(37, 194, 160)', }, { tagName: 'meta', name: 'msapplication-TileImage', content: '/img/docusaurus.png', }, { tagName: 'meta', name: 'msapplication-TileColor', content: '#000', }, ], }, ], ],};
swCustom
#
- Type :
string | undefined
- Par défaut :
undefined
Utile pour des règles additionnelles de Workbox. Vous pouvez faire tout ce qu'un service worker peut faire ici, et utiliser toute la puissance des bibliothèques Workbox. Le code est transpilé, vous pouvez donc utiliser la syntaxe moderne ES6+ ici.
Par exemple, pour mettre en cache des fichiers depuis des chemins externes :
import {registerRoute} from 'workbox-routing';import {StaleWhileRevalidate} from 'workbox-strategies';
// default fn export reçoit quelques paramètres utilesexport default function swCustom(params) { const { debug, // :boolean offlineMode, // :boolean } = params;
// Mettre en cache les réponses des ressources externes registerRoute((context) => { return [ /graph\.facebook\.com\/.*\/picture/, /netlify\.com\/img/, /avatars1\.githubusercontent/, ].some((regex) => context.url.href.match(regex)); }, new StaleWhileRevalidate());}
Le module doit avoir une fonction d'exportation default
, et reçoit quelques paramètres.
swRegister
#
- Type :
string | false
- Par défaut :
'docusaurus-plugin-pwa/src/registerSW.js'
Ajoute une entrée avant l'application Docusaurus pour que l'enregistrement puisse se faire avant l'exécution de l'application. Le fichier registerSW.js
par défaut est suffisant pour un simple enregistrement.
Passer false
désactivera complètement l'inscription.
#
Exemple de manifesteLe manifeste du site Docusaurus peut servir d'inspiration :
{ "name": "Docusaurus v2", "short_name": "Docusaurus", "theme_color": "#2196f3", "background_color": "#424242", "display": "standalone", "scope": "./", "start_url": "./index.html", "related_applications": [ { "platform": "webapp", "url": "https://docusaurus.io/manifest.json" } ], "icons": [ { "src": "img/icons/icon-72x72.png", "sizes": "72x72", "type": "image/png" }, { "src": "img/icons/icon-96x96.png", "sizes": "96x96", "type": "image/png" }, { "src": "img/icons/icon-128x128.png", "sizes": "128x128", "type": "image/png" }, { "src": "img/icons/icon-144x144.png", "sizes": "144x144", "type": "image/png" }, { "src": "img/icons/icon-152x152.png", "sizes": "152x152", "type": "image/png" }, { "src": "img/icons/icon-192x192.png", "sizes": "192x192", "type": "image/png" }, { "src": "img/icons/icon-384x384.png", "sizes": "384x384", "type": "image/png" }, { "src": "img/icons/icon-512x512.png", "sizes": "512x512", "type": "image/png" } ]}