// Type definitions for blob-util 1.3 // Project: https://github.com/nolanlawson/blob-util#readme // Definitions by: Max Battcher // Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped // TypeScript Version: 2.1 /** * Shim for new Blob() to support older browsers that use the deprecated BlobBuilder API. * * @param parts content of the Blob * @param options usually just `{ type: mimeType }` */ export function createBlob(parts: any[], options?: { type: string }): Blob; /** * Shim for URL.createObjectURL() to support browsers that only have the prefixed webkitURL (e.g. Android <4.4). */ export function createObjectURL(blob: Blob): string; /** * Shim for URL.revokeObjectURL() to support browsers that only have the prefixed webkitURL (e.g. Android <4.4). */ export function revokeObjectURL(url: string): void; /** * Convert a Blob to a binary string. */ export function blobToBinaryString(blob: Blob): Promise; /** * Convert a binary string to a Blob. * @param type the content type */ export function binaryStringToBlob(binary: string, type?: string): Promise; /** * Convert a Blob to a base-64 string. */ export function blobToBase64String(blob: Blob): Promise; /** * Convert a base-64 string to a Blob. * @param type the content type */ export function base64StringToBlob(base64: string, type?: string): Promise; /** * Convert a data URL string (e.g. `'...'`) to a Blob. */ export function dataURLToBlob(dataURL: string): Promise; /** * Convert a Blob to a data URL string (e.g. `'...'`). */ export function blobToDataURL(blob: Blob): Promise; /** * Convert an image's src URL to a data URL by loading the image and painting it to a canvas. * * Note: this will coerce the image to the desired content type, and it will only paint the first frame of an animated GIF. * * @param type the content type (optional, defaults to 'image/png') * @param crossOrigin for CORS-enabled images, set this to 'Anonymous' to avoid "tainted canvas" errors * @param quality a number between 0 and 1 indicating image quality if the requested type is 'image/jpeg' or 'image/webp' */ export function imgSrcToDataURL(src: string, type?: string, crossOrigin?: string, quality?: number): Promise; /** * Convert a canvas to a Blob. * * @param type the content type (optional, defaults to 'image/png') * @param quality a number between 0 and 1 indicating image quality if the requested type is 'image/jpeg' or 'image/webp' */ export function canvasToBlob(canvas: HTMLCanvasElement, type?: string, quality?: number): Promise; /** * Convert an image's src URL to a Blob by loading the image and painting it to a canvas. * * Note: this will coerce the image to the desired content type, and it will only paint the first frame of an animated GIF. * * @param type the content type (optional, defaults to 'image/png') * @param crossOrigin for CORS-enabled images, set this to 'Anonymous' to avoid "tainted canvas" errors * @param quality a number between 0 and 1 indicating image quality if the requested type is 'image/jpeg' or 'image/webp' */ export function imgSrcToBlob(src: string, type?: string, crossOrigin?: string, quality?: number): Promise; /** * Convert an ArrayBuffer to a Blob. * * @param type the content type */ export function arrayBufferToBlob(arrayBuff: ArrayBuffer, type?: string): Promise; /** * Convert a Blob to an ArrayBuffer. */ export function blobToArrayBuffer(blob: Blob): Promise;