Saltar al contenido

Inicio

GitHub
ventana de terminal
bun add @capgo/capacitor-file-sharer
bunx cap sync
import { FileSharer } from '@capgo/capacitor-file-sharer';
import { FileSharer } from '@capgo/capacitor-file-sharer';
await FileSharer.share({
filename: 'report.pdf',
contentType: 'application/pdf',
base64Data: reportBase64,
title: 'Quarterly report',
text: 'Attached report',
});

base64Data puede ser una cadena base64 cruda o una URL de datos como data:application/pdf;base64,....

await FileSharer.share({
filename: 'export.zip',
contentType: 'application/zip',
path: fileUri,
});

Las implementaciones nativas aceptan rutas locales, file:// URLs, Android content:// URIs, y Capacitor _capacitor_file_ URLs.

const result = await FileSharer.save({
filename: 'backup.zip',
contentType: 'application/zip',
base64Data: zipBase64,
android: {
saveDirectory: 'downloads',
relativePath: 'Download/My App',
},
});
console.log(result.uri);

Las directorios de guardado de Android son downloads, pictures, movies, music, y documents. En Android 10 y posteriores, el plugin escribe a través de MediaStore. En Android 9 y debajo, los guardados públicos utilizan el manifiesto WRITE_EXTERNAL_STORAGE permiso con maxSdkVersion=28.

await FileSharer.share({
filename: 'photo.jpg',
contentType: 'image/jpeg',
path: photoUri,
title: 'Site photo',
subject: 'Photo export',
text: 'Captured during inspection.',
});

text se pasa como EXTRA_TEXT en Android y como un segundo elemento de actividad en iOS.

export interface ShareFileOptions {
filename: string;
base64Data?: string;
path?: string;
contentType?: string;
text?: string;
title?: string;
subject?: string;
android?: AndroidFileSharerOptions;
}
export interface AndroidFileSharerOptions {
chooserTitle?: string;
saveDirectory?: 'downloads' | 'pictures' | 'movies' | 'music' | 'documents';
relativePath?: string;
}
export interface SaveFileResult {
uri?: string;
}
  • ERR_PARAM_NO_FILENAME - filename falta o está en blanco.
  • ERR_PARAM_NO_DATA - ni base64Data ni path no se pudo descodificar la entrada base64.
  • ERR_PARAM_DATA_INVALID - no se pudo abrir la ruta de acceso local o la URI de contenido proporcionada.
  • ERR_LOCAL_FILE_NOT_FOUND - no se pudo escribir el archivo temporal nativo.
  • ERR_FILE_CACHING_FAILED - Android no pudo guardar el archivo en almacenamiento público.
  • ERR_FILE_SAVE_FAILED ni
  • ERR_ACTIVITY_NOT_FOUND - No se pudo abrir un objetivo de compartir en Android.
  • USER_CANCELLED - La hoja de compartir de iOS se despidió sin completar.

Esta página sigue el plugin’s src/definitions.tsRe-ejecutar la sincronización cuando los cambios públicos API cambien en la fuente.

Si estás utilizando Getting Started para planificar el almacenamiento y el manejo de archivos, conecta con Usando @capgo/capacitor-file-sharer para la capacidad nativa en Usando @capgo/capacitor-file-sharer, @capgo/capacitor-almacenamiento-de-datos-sqlite para el detalle de implementación en @capgo/capacitor-almacenamiento-de-datos-sqlite, Usando @capgo/capacitor-almacenamiento-de-datos-sqlite para la capacidad nativa en Usando @capgo/capacitor-almacenamiento-de-datos-sqlite, @capgo/capacitor-archivo para el detalle de implementación en @capgo/capacitor-archivo, y Usando @capgo/capacitor-archivo para la capacidad nativa en Usando @capgo/capacitor-archivo.