Descripción
Usa la API de chrome.fileBrowserHandler
para extender el navegador de archivos de ChromeOS. Por ejemplo, puedes usar esta API para permitir que los usuarios suban archivos a tu sitio web.
Conceptos y uso
El navegador de archivos de ChromeOS aparece cuando el usuario presiona Alt + Mayúsculas + M o conecta un dispositivo de almacenamiento externo, como una tarjeta SD, una llave USB, una unidad externa o una cámara digital. Además de mostrar los archivos en dispositivos externos, el navegador de archivos también puede mostrar los archivos que el usuario guardó anteriormente en el sistema.
Cuando el usuario selecciona uno o más archivos, el navegador de archivos agrega botones que representan los controladores válidos para esos archivos. Por ejemplo, en la siguiente captura de pantalla, si se selecciona un archivo con el sufijo ".png", aparece el botón "Guardar en la galería" en el que puede hacer clic el usuario.
Permisos
fileBrowserHandler
Debes declarar el permiso "fileBrowserHandler"
en el manifiesto de la extensión.
Disponibilidad
Debes usar el campo "file_browser_handlers"
para registrar la extensión como controlador de al menos un tipo de archivo. También debes proporcionar un ícono de 16 por 16 que se mostrará en el botón. Por ejemplo:
{
"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"
},
...
}
Implementa un controlador de navegador de archivos
Para usar esta API, debes implementar una función que controle el evento onExecute
de chrome.fileBrowserHandler
. Se llamará a tu función cada vez que el usuario haga clic en el botón que representa el controlador del navegador de archivos. En tu función, usa la API de File System para obtener acceso al contenido del archivo. A continuación, se muestra un ejemplo:
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
}
});
Se pasan dos argumentos al controlador de eventos:
id
- El valor
id
del archivo de manifiesto. Si tu extensión implementa varios controladores, puedes verificar el valor del ID para ver qué controlador se activó. details
- Un objeto que describe el evento. Puedes obtener el archivo o los archivos que el usuario seleccionó en el campo
entries
de este objeto, que es un array de objetosFileSystemFileEntry
.
Tipos
FileHandlerExecuteEventDetails
Carga útil de detalles del evento para el evento fileBrowserHandler.onExecute.
Propiedades
-
entradas
cualquier[]
Es un array de instancias de Entry que representan los archivos que son objetivos de esta acción (seleccionados en el navegador de archivos de ChromeOS).
-
tab_id
número opcional
Es el ID de la pestaña que generó este evento. Los IDs de pestaña son únicos dentro de una sesión del navegador.
Eventos
onExecute
chrome.fileBrowserHandler.onExecute.addListener(
callback: function,
)
Se activa cuando se ejecuta la acción del sistema de archivos desde el navegador de archivos de ChromeOS.
Parámetros
-
callback
función
El parámetro
callback
se ve de la siguiente manera:(id: string, details: FileHandlerExecuteEventDetails) => void
-
id
string
-
detalles
-