Description
Utilise l'API chrome.fileBrowserHandler
pour étendre l'explorateur de fichiers Chrome OS. Par exemple, vous pouvez vous en servir pour autoriser les utilisateurs à importer des fichiers sur votre site Web.
Concepts et utilisation
Le navigateur de fichiers ChromeOS s'affiche lorsque l'utilisateur appuie sur Alt+Maj+M ou connecte un périphérique de stockage externe, comme une carte SD, une clé USB, un disque externe ou un appareil photo numérique. En plus d'afficher les fichiers sur des appareils externes, le navigateur de fichiers peut également afficher les fichiers que l'utilisateur a précédemment enregistrés sur le système.
Lorsque l'utilisateur sélectionne un ou plusieurs fichiers, le navigateur de fichiers ajoute des boutons représentant les gestionnaires valides de ces fichiers. Par exemple, dans la capture d'écran suivante, la sélection d'un fichier avec un suffixe ".png" affiche un bouton "Enregistrer dans la galerie" sur lequel l'utilisateur peut cliquer.
Autorisations
fileBrowserHandler
Vous devez déclarer l'autorisation "fileBrowserHandler"
dans le fichier manifeste de l'extension.
Disponibilité
Vous devez utiliser le champ "file_browser_handlers"
pour enregistrer l'extension en tant que gestionnaire d'au moins un type de fichier. Vous devez également fournir une icône de 16 x 16 pixels à afficher sur le bouton. Exemple :
{
"name": "My extension",
...
"file_browser_handlers": [
{
"id": "upload",
"default_title": "Save to Gallery", // What the button will display
"file_filters": [
"filesystem:*.jpg", // To match all files, use "filesystem:*.*"
"filesystem:*.jpeg",
"filesystem:*.png"
]
}
],
"permissions" : [
"fileBrowserHandler"
],
"icons": {
"16": "icon16.png",
"48": "icon48.png",
"128": "icon128.png"
},
...
}
Implémenter un gestionnaire d'explorateur de fichiers
Pour utiliser cette API, vous devez implémenter une fonction qui gère l'événement onExecute
de chrome.fileBrowserHandler
. Votre fonction est appelée chaque fois que l'utilisateur clique sur le bouton représentant votre gestionnaire de navigateur de fichiers. Dans votre fonction, utilisez l'API File System pour accéder au contenu du fichier. Voici un exemple :
chrome.fileBrowserHandler.onExecute.addListener(async (id, details) => {
if (id !== 'upload') {
return; // check if you have multiple file_browser_handlers
}
for (const entry of detail.entries) {
// the FileSystemFileEntry doesn't have a Promise API, wrap in one
const file = await new Promise((resolve, reject) => {
entry.file(resolve, reject);
});
const buffer = await file.arrayBuffer();
// do something with buffer
}
});
Votre gestionnaire d'événements reçoit deux arguments:
id
- Valeur
id
du fichier manifeste. Si votre extension implémente plusieurs gestionnaires, vous pouvez vérifier la valeur de l'ID pour voir quel gestionnaire a été déclenché. details
- Objet décrivant l'événement. Vous pouvez obtenir le ou les fichiers sélectionnés par l'utilisateur à partir du champ
entries
de cet objet, qui est un tableau d'objetsFileSystemFileEntry
.
Types
FileHandlerExecuteEventDetails
Charge utile des détails de l'événement pour l'événement fileBrowserHandler.onExecute.
Propriétés
-
entries
any[]
Tableau d'instances Entry représentant les fichiers cibles de cette action (sélectionnés dans le navigateur de fichiers ChromeOS).
-
tab_id
number facultatif
ID de l'onglet ayant déclenché cet événement. Les ID d'onglet sont uniques dans une session de navigateur.
Événements
onExecute
chrome.fileBrowserHandler.onExecute.addListener(
callback: function,
)
Déclenché lorsqu'une action de système de fichiers est exécutée à partir du navigateur de fichiers ChromeOS.
Paramètres
-
rappel
fonction
Le paramètre
callback
se présente comme suit :(id: string, details: FileHandlerExecuteEventDetails) => void
-
id
chaîne
-
détails
-