Description
Utilisez l'API chrome.action
pour contrôler l'icône de l'extension dans la barre d'outils Google Chrome.
Disponibilité
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
() => { /* ... */ },
);
Fenêtre pop-up
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
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
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
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()
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()
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()
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
-
résultat
-
Renvoie
-
Promise<extensionTypes.ColorArray>
getBadgeText()
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()
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
-
résultat
-
Renvoie
-
Promise<extensionTypes.ColorArray>
getPopup()
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()
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()
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
-
userSettings
-
Renvoie
-
Promise<UserSettings>
isEnabled()
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()
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()
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()
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é. SitabId
est spécifié et quetext
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()
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()
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 taillescale
* 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 taillescale
* 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()
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()
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
-
tabulation
-
onUserSettingsChanged
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
-
callback
fonction
Le paramètre
callback
se présente comme suit :(change: UserSettingsChange) => void
-
modifier
-