mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
98 lines
3.6 KiB
TypeScript
98 lines
3.6 KiB
TypeScript
// Type definitions for blob-util 1.3
|
|
// Project: https://github.com/nolanlawson/blob-util#readme
|
|
// Definitions by: Max Battcher <https://github.com/WorldMaker>
|
|
// 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<string>;
|
|
|
|
/**
|
|
* Convert a binary string to a Blob.
|
|
* @param type the content type
|
|
*/
|
|
export function binaryStringToBlob(binary: string, type?: string): Promise<Blob>;
|
|
|
|
/**
|
|
* Convert a Blob to a base-64 string.
|
|
*/
|
|
export function blobToBase64String(blob: Blob): Promise<string>;
|
|
|
|
/**
|
|
* Convert a base-64 string to a Blob.
|
|
* @param type the content type
|
|
*/
|
|
export function base64StringToBlob(base64: string, type?: string): Promise<Blob>;
|
|
|
|
/**
|
|
* Convert a data URL string (e.g. `'...'`) to a Blob.
|
|
*/
|
|
export function dataURLToBlob(dataURL: string): Promise<Blob>;
|
|
|
|
/**
|
|
* Convert a Blob to a data URL string (e.g. `'...'`).
|
|
*/
|
|
export function blobToDataURL(blob: Blob): Promise<string>;
|
|
|
|
/**
|
|
* 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<string>;
|
|
|
|
/**
|
|
* 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<Blob>;
|
|
|
|
/**
|
|
* 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<Blob>;
|
|
|
|
/**
|
|
* Convert an ArrayBuffer to a Blob.
|
|
*
|
|
* @param type the content type
|
|
*/
|
|
export function arrayBufferToBlob(arrayBuff: ArrayBuffer, type?: string): Promise<Blob>;
|
|
|
|
/**
|
|
* Convert a Blob to an ArrayBuffer.
|
|
*/
|
|
export function blobToArrayBuffer(blob: Blob): Promise<ArrayBuffer>;
|