chrome.action

Description

Utilisez l'API chrome.action pour contrôler l'icône de l'extension dans la barre d'outils Google Chrome.

Les icônes d'action s'affichent dans la barre d'outils du navigateur, à côté de l'omnibox. Une fois installées, elles apparaissent dans le menu des extensions (icône en forme de pièce de puzzle). Les utilisateurs peuvent épingler l'icône de votre extension à la barre d'outils.

Disponibilité

Chrome 88 et versions ultérieures MV3 et versions ultérieures

Fichier manifeste

Les clés suivantes doivent être déclarées dans le fichier manifeste pour utiliser cette API.

"action"

Pour utiliser l'API chrome.action, spécifiez un "manifest_version" de 3 et incluez la clé "action" dans votre fichier manifeste.

{
  "name": "Action Extension",
  ...
  "action": {
    "default_icon": {              // optional
      "16": "images/icon16.png",   // optional
      "24": "images/icon24.png",   // optional
      "32": "images/icon32.png"    // optional
    },
    "default_title": "Click Me",   // optional, shown in tooltip
    "default_popup": "popup.html"  // optional
  },
  ...
}

La clé "action" (ainsi que ses enfants) est facultative. Si elle n'est pas incluse, votre extension s'affiche toujours dans la barre d'outils pour permettre d'accéder à son menu. C'est pourquoi nous vous recommandons d'inclure au moins les clés "action" et "default_icon".

Concepts et utilisation

Éléments de l'interface utilisateur

Icône

L'icône est l'image principale de la barre d'outils de votre extension. Elle est définie par la clé "default_icon" dans la clé "action" de votre fichier manifeste. Les icônes doivent mesurer 16 pixels indépendants de la densité (DIP) de large et de haut.

La clé "default_icon" est un dictionnaire des tailles et des chemins d'accès aux images. Chrome utilise ces icônes pour choisir l'échelle d'image à utiliser. En l'absence de correspondance exacte, Chrome sélectionne la taille la plus proche et l'adapte à l'image, ce qui peut affecter la qualité de l'image.

Étant donné que les appareils avec des facteurs d'échelle moins courants, comme 1,5x ou 1,2x, sont de plus en plus répandus, nous vous encourageons à fournir plusieurs tailles pour vos icônes. Cela permet également de pérenniser votre extension face à d'éventuels changements de taille d'affichage des icônes. Toutefois, si vous ne fournissez qu'une seule taille, la clé "default_icon" peut également être définie sur une chaîne avec le chemin d'accès à une seule icône au lieu d'un dictionnaire.

Vous pouvez également appeler action.setIcon() pour définir l'icône de votre extension de manière programmatique en spécifiant un autre chemin d'image ou en fournissant une icône générée dynamiquement à l'aide de l'élément canvas HTML ou, si vous la définissez à partir d'un service worker d'extension, de l'API offscreen canvas.

const canvas = new OffscreenCanvas(16, 16);
const context = canvas.getContext('2d');
context.clearRect(0, 0, 16, 16);
context.fillStyle = '#00FF00';  // Green
context.fillRect(0, 0, 16, 16);
const imageData = context.getImageData(0, 0, 16, 16);
chrome.action.setIcon({imageData: imageData}, () => { /* ... */ });

Pour les extensions compressées (installées à partir d'un fichier .crx), les images peuvent être dans la plupart des formats que le moteur de rendu Blink peut afficher, y compris PNG, JPEG, BMP, ICO, etc. Le format SVG n'est pas accepté. Les extensions décompressées doivent utiliser des images PNG.

Info-bulle (titre)

L'info-bulle ou le titre s'affichent lorsque l'utilisateur pointe sur l'icône de l'extension dans la barre d'outils. Il est également inclus dans le texte accessible lu par les lecteurs d'écran lorsque le bouton est sélectionné.

L'info-bulle par défaut est définie à l'aide du champ "default_title" de la clé "action" dans manifest.json. Vous pouvez également le définir par programmation en appelant action.setTitle().

Badge

Les actions peuvent éventuellement afficher un "badge", c'est-à-dire un petit texte superposé à l'icône. Cela vous permet de mettre à jour l'action pour afficher une petite quantité d'informations sur l'état de l'extension, comme un compteur. Le badge comporte un composant de texte et une couleur d'arrière-plan. L'espace étant limité, nous vous recommandons d'utiliser quatre caractères ou moins pour le texte du badge.

Pour créer un badge, définissez-le par programmation en appelant action.setBadgeBackgroundColor() et action.setBadgeText(). Il n'existe pas de paramètre de badge par défaut dans le fichier manifeste. Les valeurs de couleur des badges peuvent être un tableau de quatre entiers compris entre 0 et 255 qui composent la couleur RVBA du badge, ou une chaîne avec une valeur de couleur CSS.

chrome.action.setBadgeBackgroundColor(
  {color: [0, 255, 0, 0]},  // Green
  () => { /* ... */ },
);

chrome.action.setBadgeBackgroundColor(
  {color: '#00FF00'},  // Also green
  () => { /* ... */ },
);

chrome.action.setBadgeBackgroundColor(
  {color: 'green'},  // Also, also green
  () => { /* ... */ },
);

Le pop-up d'une action s'affiche lorsque l'utilisateur clique sur le bouton d'action de l'extension dans la barre d'outils. Le pop-up peut contenir n'importe quel contenu HTML et sa taille sera automatiquement ajustée à son contenu. La taille du pop-up doit être comprise entre 25 x 25 et 800 x 600 pixels.

Le pop-up est initialement défini par la propriété "default_popup" dans la clé "action" du fichier manifest.json. Si elle est présente, cette propriété doit pointer vers un chemin d'accès relatif dans le répertoire de l'extension. Il peut également être mis à jour de manière dynamique pour pointer vers un autre chemin d'accès relatif à l'aide de la méthode action.setPopup().

Cas d'utilisation

État par onglet

Les actions d'extension peuvent avoir différents états pour chaque onglet. Pour définir une valeur pour un onglet individuel, utilisez la propriété tabId dans les méthodes de paramètre de l'API action. Par exemple, pour définir le texte du badge d'un onglet spécifique, procédez comme suit :

function getTabId() { /* ... */}
function getTabBadge() { /* ... */}

chrome.action.setBadgeText(
  {
    text: getTabBadge(tabId),
    tabId: getTabId(),
  },
  () => { ... }
);

Si la propriété tabId est omise, le paramètre est considéré comme global. Les paramètres spécifiques à un onglet sont prioritaires par rapport aux paramètres généraux.

État activé

Par défaut, les actions de la barre d'outils sont activées (cliquables) dans chaque onglet. Vous pouvez modifier cette valeur par défaut en définissant la propriété default_state dans la clé action du fichier manifeste. Si default_state est défini sur "disabled", l'action est désactivée par défaut et doit être activée de manière programmatique pour être cliquable. Si default_state est défini sur "enabled" (valeur par défaut), l'action est activée et cliquable par défaut.

Vous pouvez contrôler l'état de manière programmatique à l'aide des méthodes action.enable() et action.disable(). Cela n'a d'incidence que sur l'envoi ou non du pop-up (le cas échéant) ou de l'événement action.onClicked à votre extension. Cela n'a aucune incidence sur la présence de l'action dans la barre d'outils.

Exemples

Les exemples suivants illustrent certaines utilisations courantes des actions dans les extensions. Pour essayer cette API, installez l'exemple d'API Actions à partir du dépôt chrome-extension-samples.

Afficher un pop-up

Il est courant qu'une extension affiche un pop-up lorsque l'utilisateur clique sur l'action de l'extension. Pour implémenter cela dans votre propre extension, déclarez le pop-up dans votre manifest.json et spécifiez le contenu que Chrome doit afficher dans le pop-up.

// manifest.json
{
  "name": "Action popup demo",
  "version": "1.0",
  "manifest_version": 3,
  "action": {
    "default_title": "Click to view a popup",
    "default_popup": "popup.html"
  }
}
<!-- popup.html -->
<!DOCTYPE html>
<html>
<head>
  <style>
    html {
      min-height: 5em;
      min-width: 10em;
      background: salmon;
    }
  </style>
</head>
<body>
  <p>Hello, world!</p>
</body>
</html>

Injecter un script de contenu au clic

Un modèle courant pour les extensions consiste à exposer leur fonctionnalité principale à l'aide de l'action de l'extension. L'exemple suivant illustre ce modèle. Lorsque l'utilisateur clique sur l'action, l'extension injecte un script de contenu dans la page actuelle. Le script de contenu affiche ensuite une alerte pour vérifier que tout a fonctionné comme prévu.

// manifest.json
{
  "name": "Action script injection demo",
  "version": "1.0",
  "manifest_version": 3,
  "action": {
    "default_title": "Click to show an alert"
  },
  "permissions": ["activeTab", "scripting"],
  "background": {
    "service_worker": "background.js"
  }
}
// background.js
chrome.action.onClicked.addListener((tab) => {
  chrome.scripting.executeScript({
    target: {tabId: tab.id},
    files: ['content.js']
  });
});
// content.js
alert('Hello, world!');

Émuler des actions avec declarativeContent

Cet exemple montre comment la logique d'arrière-plan d'une extension peut (a) désactiver une action par défaut et (b) utiliser declarativeContent pour activer l'action sur des sites spécifiques.

// service-worker.js

// Wrap in an onInstalled callback to avoid unnecessary work
// every time the service worker is run
chrome.runtime.onInstalled.addListener(() => {
  // Page actions are disabled by default and enabled on select tabs
  chrome.action.disable();

  // Clear all rules to ensure only our expected rules are set
  chrome.declarativeContent.onPageChanged.removeRules(undefined, () => {
    // Declare a rule to enable the action on example.com pages
    let exampleRule = {
      conditions: [
        new chrome.declarativeContent.PageStateMatcher({
          pageUrl: {hostSuffix: '.example.com'},
        })
      ],
      actions: [new chrome.declarativeContent.ShowAction()],
    };

    // Finally, apply our new array of rules
    let rules = [exampleRule];
    chrome.declarativeContent.onPageChanged.addRules(rules);
  });
});

Types

OpenPopupOptions

Chrome 99 et versions ultérieures

Propriétés

  • windowId

    number facultatif

    ID de la fenêtre dans laquelle ouvrir le pop-up d'action. Si aucune valeur n'est spécifiée, la fenêtre active est utilisée par défaut.

TabDetails

Propriétés

  • tabId

    number facultatif

    ID de l'onglet dont l'état doit être interrogé. Si aucun onglet n'est spécifié, l'état non spécifique à un onglet est renvoyé.

UserSettings

Chrome 91 et versions ultérieures

Ensemble de paramètres spécifiés par l'utilisateur et liés à l'action d'une extension.

Propriétés

  • isOnToolbar

    booléen

    Indique si l'icône d'action de l'extension est visible dans la barre d'outils de premier niveau des fenêtres du navigateur (c'est-à-dire si l'extension a été "épinglée" par l'utilisateur).

UserSettingsChange

Chrome 130 et versions ultérieures

Propriétés

  • isOnToolbar

    booléen facultatif

    Indique si l'icône d'action de l'extension est visible dans la barre d'outils de premier niveau des fenêtres du navigateur (c'est-à-dire si l'extension a été "épinglée" par l'utilisateur).

Méthodes

disable()

Promise
chrome.action.disable(
  tabId?: number,
  callback?: function,
)
: Promise<void>

Désactive l'action pour un onglet.

Paramètres

  • tabId

    number facultatif

    ID de l'onglet pour lequel vous souhaitez modifier l'action.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

enable()

Promise
chrome.action.enable(
  tabId?: number,
  callback?: function,
)
: Promise<void>

Active l'action pour un onglet. Par défaut, les actions sont activées.

Paramètres

  • tabId

    number facultatif

    ID de l'onglet pour lequel vous souhaitez modifier l'action.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

getBadgeBackgroundColor()

Promise
chrome.action.getBadgeBackgroundColor(
  details: TabDetails,
  callback?: function,
)
: Promise<extensionTypes.ColorArray>

Récupère la couleur d'arrière-plan de l'action.

Paramètres

  • détails
  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (result: ColorArray) => void

Renvoie

getBadgeText()

Promise
chrome.action.getBadgeText(
  details: TabDetails,
  callback?: function,
)
: Promise<string>

Récupère le texte du badge de l'action. Si aucun onglet n'est spécifié, le texte du badge non spécifique à un onglet est renvoyé. Si displayActionCountAsBadgeText est activé, un texte d'espace réservé sera renvoyé, sauf si l'autorisation declarativeNetRequestFeedback est présente ou si un texte de badge spécifique à l'onglet a été fourni.

Paramètres

  • détails
  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (result: string) => void

    • résultat

      chaîne

Renvoie

  • Promise<string>

getBadgeTextColor()

Promise Chrome 110 et versions ultérieures
chrome.action.getBadgeTextColor(
  details: TabDetails,
  callback?: function,
)
: Promise<extensionTypes.ColorArray>

Récupère la couleur du texte de l'action.

Paramètres

  • détails
  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (result: ColorArray) => void

Renvoie

getPopup()

Promise
chrome.action.getPopup(
  details: TabDetails,
  callback?: function,
)
: Promise<string>

Récupère le document HTML défini comme pop-up pour cette action.

Paramètres

  • détails
  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (result: string) => void

    • résultat

      chaîne

Renvoie

  • Promise<string>

getTitle()

Promise
chrome.action.getTitle(
  details: TabDetails,
  callback?: function,
)
: Promise<string>

Récupère le titre de l'action.

Paramètres

  • détails
  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (result: string) => void

    • résultat

      chaîne

Renvoie

  • Promise<string>

getUserSettings()

Promise Chrome 91 et versions ultérieures
chrome.action.getUserSettings(
  callback?: function,
)
: Promise<UserSettings>

Renvoie les paramètres spécifiés par l'utilisateur concernant l'action d'une extension.

Paramètres

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (userSettings: UserSettings) => void

Renvoie

isEnabled()

Promise Chrome 110 et versions ultérieures
chrome.action.isEnabled(
  tabId?: number,
  callback?: function,
)
: Promise<boolean>

Indique si l'action d'extension est activée pour un onglet (ou globalement si aucun tabId n'est fourni). Les actions activées à l'aide de declarativeContent renvoient toujours la valeur "false".

Paramètres

  • tabId

    number facultatif

    ID de l'onglet dont vous souhaitez vérifier l'état d'activation.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (isEnabled: boolean) => void

    • isEnabled

      booléen

      "True" si l'action d'extension est activée.

Renvoie

  • Promise<boolean>

openPopup()

Promise Chrome 127 et versions ultérieures
chrome.action.openPopup(
  options?: OpenPopupOptions,
  callback?: function,
)
: Promise<void>

Ouvre le pop-up de l'extension. Entre Chrome 118 et Chrome 126, cette fonctionnalité n'est disponible que pour les extensions installées par le biais de règles.

Paramètres

  • options

    OpenPopupOptions facultatif

    Spécifie les options d'ouverture du pop-up.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

setBadgeBackgroundColor()

Promise
chrome.action.setBadgeBackgroundColor(
  details: object,
  callback?: function,
)
: Promise<void>

Définit la couleur d'arrière-plan du badge.

Paramètres

  • détails

    objet

    • couleur

      string | ColorArray

      Tableau de quatre entiers compris dans la plage [0,255] qui composent la couleur RVBA du badge. Par exemple, le rouge opaque est [255, 0, 0, 255]. Il peut également s'agir d'une chaîne avec une valeur CSS, le rouge opaque étant #FF0000 ou #F00.

    • tabId

      number facultatif

      Limite la modification à l'onglet sélectionné. Elle est automatiquement réinitialisée lorsque l'onglet est fermé.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

setBadgeText()

Promise
chrome.action.setBadgeText(
  details: object,
  callback?: function,
)
: Promise<void>

Définit le texte du badge pour l'action. Le badge s'affiche au-dessus de l'icône.

Paramètres

  • détails

    objet

    • tabId

      number facultatif

      Limite la modification à l'onglet sélectionné. Elle est automatiquement réinitialisée lorsque l'onglet est fermé.

    • texte

      chaîne facultative

      Vous pouvez transmettre n'importe quel nombre de caractères, mais seuls quatre environ peuvent tenir dans l'espace. Si une chaîne vide ('') est transmise, le texte du badge est effacé. Si tabId est spécifié et que text est nul, le texte de l'onglet spécifié est effacé et reprend le texte global du badge par défaut.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

setBadgeTextColor()

Promise Chrome 110 et versions ultérieures
chrome.action.setBadgeTextColor(
  details: object,
  callback?: function,
)
: Promise<void>

Définit la couleur du texte du badge.

Paramètres

  • détails

    objet

    • couleur

      string | ColorArray

      Tableau de quatre entiers compris dans la plage [0,255] qui composent la couleur RVBA du badge. Par exemple, le rouge opaque est [255, 0, 0, 255]. Il peut également s'agir d'une chaîne avec une valeur CSS, le rouge opaque étant #FF0000 ou #F00. Si vous ne définissez pas cette valeur, une couleur sera automatiquement choisie pour contraster avec la couleur d'arrière-plan du badge afin que le texte soit visible. Les couleurs dont la valeur alpha est égale à 0 ne seront pas définies et renverront une erreur.

    • tabId

      number facultatif

      Limite la modification à l'onglet sélectionné. Elle est automatiquement réinitialisée lorsque l'onglet est fermé.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

setIcon()

Promise
chrome.action.setIcon(
  details: object,
  callback?: function,
)
: Promise<void>

Définit l'icône de l'action. L'icône peut être spécifiée sous la forme du chemin d'accès à un fichier image, des données en pixels d'un élément canvas ou d'un dictionnaire de l'un ou l'autre. Vous devez spécifier la propriété path ou imageData.

Paramètres

  • détails

    objet

    • imageData

      ImageData | objet facultatif

      Objet ImageData ou dictionnaire {size -> ImageData} représentant l'icône à définir. Si l'icône est spécifiée sous forme de dictionnaire, l'image à utiliser est choisie en fonction de la densité de pixels de l'écran. Si le nombre de pixels d'image qui tiennent dans une unité d'espace d'écran est égal à scale, l'image de taille scale * n sera sélectionnée, où n correspond à la taille de l'icône dans l'UI. Vous devez spécifier au moins une image. Notez que "details.imageData = foo" équivaut à "details.imageData = {'16': foo}".

    • chemin d'accès

      string | object facultatif

      Chemin d'accès relatif à l'image ou dictionnaire {taille -> chemin d'accès relatif à l'image} pointant vers l'icône à définir. Si l'icône est spécifiée sous forme de dictionnaire, l'image à utiliser est choisie en fonction de la densité de pixels de l'écran. Si le nombre de pixels d'image qui tiennent dans une unité d'espace d'écran est égal à scale, l'image de taille scale * n sera sélectionnée, où n correspond à la taille de l'icône dans l'UI. Vous devez spécifier au moins une image. Notez que "details.path = foo" équivaut à "details.path = {'16': foo}".

    • tabId

      number facultatif

      Limite la modification à l'onglet sélectionné. Elle est automatiquement réinitialisée lorsque l'onglet est fermé.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

    Chrome 96 et versions ultérieures

setPopup()

Promise
chrome.action.setPopup(
  details: object,
  callback?: function,
)
: Promise<void>

Définit le document HTML à ouvrir sous forme de pop-up lorsque l'utilisateur clique sur l'icône de l'action.

Paramètres

  • détails

    objet

    • pop-up

      chaîne

      Chemin d'accès relatif au fichier HTML à afficher dans un pop-up. Si elle est définie sur la chaîne vide (''), aucun pop-up ne s'affiche.

    • tabId

      number facultatif

      Limite la modification à l'onglet sélectionné. Elle est automatiquement réinitialisée lorsque l'onglet est fermé.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

setTitle()

Promise
chrome.action.setTitle(
  details: object,
  callback?: function,
)
: Promise<void>

Définit le titre de l'action. Il s'affiche dans l'info-bulle.

Paramètres

  • détails

    objet

    • tabId

      number facultatif

      Limite la modification à l'onglet sélectionné. Elle est automatiquement réinitialisée lorsque l'onglet est fermé.

    • titre

      chaîne

      Chaîne que l'action doit afficher lorsque la souris est pointée dessus.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

Renvoie

  • Promise<void>

Événements

onClicked

chrome.action.onClicked.addListener(
  callback: function,
)

Déclenché lorsqu'un utilisateur clique sur une icône d'action. Cet événement ne se déclenche pas si l'action comporte un pop-up.

Paramètres

  • callback

    fonction

    Le paramètre callback se présente comme suit :

    (tab: tabs.Tab) => void

onUserSettingsChanged

Chrome 130 et versions ultérieures
chrome.action.onUserSettingsChanged.addListener(
  callback: function,
)

Déclenché lorsque les paramètres spécifiés par l'utilisateur concernant l'action d'une extension changent.

Paramètres