Ajouter une interface utilisateur d'installation enrichie

Les plates-formes de téléchargement d'applications permettent aux développeurs de présenter leurs applications avant l'installation, avec des captures d'écran et des informations textuelles qui aident l'utilisateur à choisir d'installer l'application. L'UI d'installation enrichie offre un espace similaire aux développeurs d'applications Web pour inviter leurs utilisateurs à installer leur application directement depuis le navigateur. Cette interface utilisateur améliorée est disponible dans Chrome pour Android et les environnements de bureau.

Requête par défaut

Consultez l'exemple ci-dessous pour voir l'expérience par défaut, qui ne fournit pas suffisamment de contexte.

Boîte de dialogue d'installation par défaut du navigateur pour ordinateur.
Boîte de dialogue d'installation par défaut sur ordinateur


Boîte de dialogue d'installation par défaut du navigateur pour mobile.
Boîte de dialogue d'installation par défaut sur mobile

Interface utilisateur d'installation plus riche

Pour obtenir la boîte de dialogue de l'interface utilisateur d'installation enrichie au lieu de l'invite par défaut plus petite, ajoutez les champs screenshots et description à votre fichier manifeste Web. Consultez l'exemple Squoosh.app ci-dessous :

Interface utilisateur d'installation enrichie sur ordinateur et mobile
Interface utilisateur d'installation enrichie sur ordinateur et mobile.

La boîte de dialogue "Interface utilisateur d'installation enrichie" est composée du contenu des champs description et screenshots du fichier manifeste Web.

Pour déclencher la boîte de dialogue, il vous suffit d'ajouter au moins une capture d'écran pour le facteur de forme correspondant, mais il est recommandé d'ajouter également la description. Consultez les spécificités de ces champs ci-dessous.

Captures d'écran

Les captures d'écran ajoutent vraiment la partie "plus riche" à la nouvelle UI d'installation, et nous vous recommandons vivement de les utiliser. Dans votre fichier manifeste, vous ajoutez le membre screenshots, qui accepte un tableau nécessitant au moins une image (Chrome peut en afficher jusqu'à huit). Un exemple est présenté ci-dessous.

 "screenshots": [
    {
     "src": "source/image1.png",
      "sizes": "640x320",
      "type": "image/png",
      "form_factor": "wide",
      "label": "Wonder Widgets"
    }
]

Les captures d'écran doivent respecter les critères suivants :

  • La largeur et la hauteur doivent être comprises entre 320 et 3 840 pixels.
  • La dimension maximale ne peut pas être plus de 2,3 fois plus grande que la dimension minimale.
  • Toutes les captures d'écran ayant la même valeur form_factor doivent avoir le même format.
  • Seuls les formats d'image JPEG et PNG sont acceptés.
  • Seules huit captures d'écran seront affichées. Si d'autres sont ajoutés, l'user-agent les ignore simplement.

Vous devez également inclure la taille et le type de l'image pour qu'elle s'affiche correctement.

form_factor indique au navigateur si la capture d'écran doit s'afficher sur un ordinateur (wide) ou sur un appareil mobile (narrow).

Description

Le membre description décrit l'application dans l'invite d'installation, afin d'inviter l'utilisateur à conserver l'application.

La boîte de dialogue s'affiche même sans description, mais il est recommandé de l'utiliser. Une limite est appliquée après sept lignes de texte (environ 324 caractères). Les descriptions plus longues sont tronquées et des points de suspension sont ajoutés.

{

"description": "Compress and compare images with different codecs
right in your browser."
}
Description ajoutée
Description ajoutée.
Description plus longue qui a été tronquée.
Les descriptions plus longues sont tronquées.

La description s'affiche en haut de l'invite d'installation.

Comme vous l'avez peut-être remarqué sur les captures d'écran, les boîtes de dialogue d'installation indiquent également l'origine de l'application. Les origines trop longues pour tenir dans l'UI sont tronquées. Cette opération, également appelée "élision", est utilisée comme mesure de sécurité pour protéger les utilisateurs.

Documentation complémentaire

Démo

HTML

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <meta name="color-scheme" content="dark light" />
    <link rel="manifest" href="manifest.json" />
    <title>How to add Richer Install UI to your web app</title>
    <!-- TODO: Devsite - Removed inline handlers -->
    <!-- <script>
      if ('serviceWorker' in navigator) {
        window.addEventListener('load', () => {
          navigator.serviceWorker.register('sw.js');
        });
      }
    </script>
    <script type="module" src="script.js"></script> -->
  </head>
  <body>
    <h1>How to add Richer Install UI to your web app</h1>
    <ol>
      <li>
        Install the app by clicking the button below. After the installation,
        the button is disabled.
        <p>
          <button disabled type="button">Install</button>
        </p>
      </li>
      <li>
        When you click on install a dialog similar to the ones from app stores
        will be displayed.
      </li>
      <li>
        The dialog includes the `description` and `screenshots` set in the app
        manifest.
      </li>
      <li>
        Screenshots should be different depending if the app is being installed
        on a mobile or desktop device, according to the `form_factor` value set
        for the screenshots on the manifest
      </li>
    </ol>
  </body>
</html>

JS


        // The install button.
const installButton = document.querySelector('button');

// Only relevant for browsers that support installation.
if ('BeforeInstallPromptEvent' in window) {
  // Variable to stash the `BeforeInstallPromptEvent`.
  let installEvent = null;

  // Function that will be run when the app is installed.
  const onInstall = () => {
    // Disable the install button.
    installButton.disabled = true;
    // No longer needed.
    installEvent = null;
  };

  window.addEventListener('beforeinstallprompt', (event) => {
    // Do not show the install prompt quite yet.
    event.preventDefault();
    // Stash the `BeforeInstallPromptEvent` for later.
    installEvent = event;
    // Enable the install button.
    installButton.disabled = false;
  });

  installButton.addEventListener('click', async () => {
    // If there is no stashed `BeforeInstallPromptEvent`, return.
    if (!installEvent) {
      return;
    }
    // Use the stashed `BeforeInstallPromptEvent` to prompt the user.
    installEvent.prompt();
    const result = await installEvent.userChoice;
    // If the user installs the app, run `onInstall()`.
    if (result.outcome === 'accepted') {
      onInstall();
    }
  });

  // The user can decide to ignore the install button
  // and just use the browser prompt directly. In this case
  // likewise run `onInstall()`.
  window.addEventListener('appinstalled', () => {
    onInstall();
  });
}