mirror of
https://github.com/nolanlawson/blob-util.git
synced 2025-12-08 19:46:19 +00:00
continue on typescript
This commit is contained in:
parent
da31976065
commit
e76eed3c6c
@ -4,6 +4,7 @@
|
|||||||
"description": "Utilities for working with Blob objects in the browser",
|
"description": "Utilities for working with Blob objects in the browser",
|
||||||
"main": "dist/blob-util.cjs.js",
|
"main": "dist/blob-util.cjs.js",
|
||||||
"module": "dist/blob-util.es.js",
|
"module": "dist/blob-util.es.js",
|
||||||
|
"types": "./dist/blob-util.d.ts",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git://github.com/nolanlawson/blob-util.git"
|
"url": "git://github.com/nolanlawson/blob-util.git"
|
||||||
@ -21,13 +22,13 @@
|
|||||||
"url": "https://github.com/nolanlawson/blob-util/issues"
|
"url": "https://github.com/nolanlawson/blob-util/issues"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": "standard test/*js && tslint -c .tslint.json src/*ts",
|
"lint": "standard test/*js && tslint src/*ts",
|
||||||
"test": "npm run build && npm run lint && zuul --no-coverage ./test/test.js",
|
"test": "npm run build && npm run lint && zuul --no-coverage ./test/test.js",
|
||||||
"test-local": "npm run build && zuul ./test/test.js --local 9000 --no-coverage",
|
"test-local": "npm run build && zuul ./test/test.js --local 9000 --no-coverage",
|
||||||
"clean": "rimraf dist lib && mkdirp dist lib",
|
"clean": "rimraf dist lib && mkdirp dist lib",
|
||||||
"build": "run-s clean build-ts build-js min",
|
"build": "run-s clean build-ts build-js min",
|
||||||
"build-ts": "tsc src/blob-util.ts --target ES6 --module es2015 --outDir lib -d && cp lib/blob-util.d.ts dist/",
|
"build-ts": "tsc src/blob-util.ts --target ES6 --module es2015 --outDir lib -d && cpy lib/blob-util.d.ts dist/",
|
||||||
"build-js": "run-p build-es build-cjs build-umd",
|
"build-js": "run-p build-es build-cjs build-umd && rimraf lib",
|
||||||
"build-es": "rollup -i lib/blob-util.js -f es -o dist/blob-util.es.js",
|
"build-es": "rollup -i lib/blob-util.js -f es -o dist/blob-util.es.js",
|
||||||
"build-cjs": "rollup -i lib/blob-util.js -f cjs -o dist/blob-util.cjs.js",
|
"build-cjs": "rollup -i lib/blob-util.js -f cjs -o dist/blob-util.cjs.js",
|
||||||
"build-umd": "rollup -i lib/blob-util.js -f umd -n blobUtil -o dist/blob-util.js",
|
"build-umd": "rollup -i lib/blob-util.js -f umd -n blobUtil -o dist/blob-util.js",
|
||||||
@ -37,6 +38,7 @@
|
|||||||
"bundle-collapser": "^1.1.4",
|
"bundle-collapser": "^1.1.4",
|
||||||
"chai": "~1.8.1",
|
"chai": "~1.8.1",
|
||||||
"chai-as-promised": "~4.1.0",
|
"chai-as-promised": "~4.1.0",
|
||||||
|
"cpy-cli": "^1.0.1",
|
||||||
"istanbul": "^0.2.7",
|
"istanbul": "^0.2.7",
|
||||||
"mkdirp": "^0.5.0",
|
"mkdirp": "^0.5.0",
|
||||||
"mocha": "~1.18",
|
"mocha": "~1.18",
|
||||||
|
|||||||
142
src/blob-util.ts
142
src/blob-util.ts
@ -1,7 +1,14 @@
|
|||||||
/* global Promise, Image, Blob, FileReader, atob, btoa */
|
/* global Promise, Image, Blob, FileReader, atob, btoa,
|
||||||
|
BlobBuilder, MSBlobBuilder, MozBlobBuilder, WebKitBlobBuilder, webkitURL */
|
||||||
/* exported createObjectURL, revokeObjectURL, binaryStringToBlob, blobToDataURL,
|
/* exported createObjectURL, revokeObjectURL, binaryStringToBlob, blobToDataURL,
|
||||||
imgSrcToDataURL, imgSrcToBlob, arrayBufferToBlob, blobToArrayBuffer */
|
imgSrcToDataURL, imgSrcToBlob, arrayBufferToBlob, blobToArrayBuffer */
|
||||||
|
|
||||||
|
declare var BlobBuilder: any
|
||||||
|
declare var MozBlobBuilder: any
|
||||||
|
declare var MSBlobBuilder: any
|
||||||
|
declare var WebKitBlobBuilder: any
|
||||||
|
declare var webkitURL: any
|
||||||
|
|
||||||
function loadImage (src, crossOrigin) {
|
function loadImage (src, crossOrigin) {
|
||||||
return new Promise(function (resolve, reject) {
|
return new Promise(function (resolve, reject) {
|
||||||
var img = new Image()
|
var img = new Image()
|
||||||
@ -36,10 +43,10 @@ function imgToCanvas (img) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a binary string to an <code>ArrayBuffer</code>.
|
* Convert a binary string to an <code>ArrayBuffer</code>.
|
||||||
* @param {string} binary - binary string
|
* @param binary - binary string
|
||||||
* @returns {ArrayBuffer}
|
* @returns array buffer
|
||||||
*/
|
*/
|
||||||
export function binaryStringToArrayBuffer (binary) {
|
export function binaryStringToArrayBuffer (binary: string): ArrayBuffer {
|
||||||
var length = binary.length
|
var length = binary.length
|
||||||
var buf = new ArrayBuffer(length)
|
var buf = new ArrayBuffer(length)
|
||||||
var arr = new Uint8Array(buf)
|
var arr = new Uint8Array(buf)
|
||||||
@ -52,10 +59,10 @@ export function binaryStringToArrayBuffer (binary) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert an <code>ArrayBuffer</code> to a binary string.
|
* Convert an <code>ArrayBuffer</code> to a binary string.
|
||||||
* @param {ArrayBuffer} buffer - array buffer
|
* @param buffer - array buffer
|
||||||
* @returns {string}
|
* @returns binary string
|
||||||
*/
|
*/
|
||||||
export function arrayBufferToBinaryString (buffer) {
|
export function arrayBufferToBinaryString (buffer: ArrayBuffer): string {
|
||||||
var binary = ''
|
var binary = ''
|
||||||
var bytes = new Uint8Array(buffer)
|
var bytes = new Uint8Array(buffer)
|
||||||
var length = bytes.byteLength
|
var length = bytes.byteLength
|
||||||
@ -68,17 +75,16 @@ export function arrayBufferToBinaryString (buffer) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Shim for
|
* Shim for
|
||||||
* [new Blob()]{@link https://developer.mozilla.org/en-US/docs/Web/API/Blob.Blob}
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/Blob.Blob | <code>new Blob()</code>}
|
||||||
* to support
|
* to support
|
||||||
* [older browsers that use the deprecated <code>BlobBuilder</code> API]{@link http://caniuse.com/blob}.
|
* {@link http://caniuse.com/blob | older browsers that use the deprecated <code>BlobBuilder</code> API}.
|
||||||
*
|
*
|
||||||
* @param {Array} parts - content of the <code>Blob</code>
|
* @param parts - content of the <code>Blob</code>
|
||||||
* @param {Object} options - usually <code>{type: myContentType}</code>,
|
* @param properties - usually <code>{type: myContentType}</code>,
|
||||||
* you can also pass a string for the content type
|
* you can also pass a string for the content type
|
||||||
* @returns {Blob}
|
* @returns Blob
|
||||||
*/
|
*/
|
||||||
export function createBlob (parts, properties) {
|
export function createBlob (parts: Array<any>, properties?: BlobPropertyBag | string): Blob {
|
||||||
/* global BlobBuilder,MSBlobBuilder,MozBlobBuilder,WebKitBlobBuilder */
|
|
||||||
parts = parts || []
|
parts = parts || []
|
||||||
properties = properties || {}
|
properties = properties || {}
|
||||||
if (typeof properties === 'string') {
|
if (typeof properties === 'string') {
|
||||||
@ -92,8 +98,8 @@ export function createBlob (parts, properties) {
|
|||||||
}
|
}
|
||||||
var Builder = typeof BlobBuilder !== 'undefined'
|
var Builder = typeof BlobBuilder !== 'undefined'
|
||||||
? BlobBuilder : typeof MSBlobBuilder !== 'undefined'
|
? BlobBuilder : typeof MSBlobBuilder !== 'undefined'
|
||||||
? MSBlobBuilder : typeof MozBlobBuilder !== 'undefined'
|
? MSBlobBuilder : typeof MozBlobBuilder !== 'undefined'
|
||||||
? MozBlobBuilder : WebKitBlobBuilder
|
? MozBlobBuilder : WebKitBlobBuilder
|
||||||
var builder = new Builder()
|
var builder = new Builder()
|
||||||
for (var i = 0; i < parts.length; i += 1) {
|
for (var i = 0; i < parts.length; i += 1) {
|
||||||
builder.append(parts[i])
|
builder.append(parts[i])
|
||||||
@ -104,36 +110,34 @@ export function createBlob (parts, properties) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Shim for
|
* Shim for
|
||||||
* [URL.createObjectURL()]{@link https://developer.mozilla.org/en-US/docs/Web/API/URL.createObjectURL}
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/URL.createObjectURL | <code>URL.createObjectURL()</code>}
|
||||||
* to support browsers that only have the prefixed
|
* to support browsers that only have the prefixed
|
||||||
* <code>webkitURL</code> (e.g. Android <4.4).
|
* <code>webkitURL</code> (e.g. Android <4.4).
|
||||||
* @param {Blob} blob
|
* @param blob
|
||||||
* @returns {string} url
|
* @returns url
|
||||||
*/
|
*/
|
||||||
export function createObjectURL (blob) {
|
export function createObjectURL (blob: Blob): string {
|
||||||
/* global webkitURL */
|
|
||||||
return (typeof URL !== 'undefined' ? URL : webkitURL).createObjectURL(blob)
|
return (typeof URL !== 'undefined' ? URL : webkitURL).createObjectURL(blob)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shim for
|
* Shim for
|
||||||
* [URL.revokeObjectURL()]{@link https://developer.mozilla.org/en-US/docs/Web/API/URL.revokeObjectURL}
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/URL.revokeObjectURL | <code>URL.revokeObjectURL()</code>}
|
||||||
* to support browsers that only have the prefixed
|
* to support browsers that only have the prefixed
|
||||||
* <code>webkitURL</code> (e.g. Android <4.4).
|
* <code>webkitURL</code> (e.g. Android <4.4).
|
||||||
* @param {string} url
|
* @param url
|
||||||
*/
|
*/
|
||||||
export function revokeObjectURL (url) {
|
export function revokeObjectURL (url: string): void {
|
||||||
/* global webkitURL */
|
|
||||||
return (typeof URL !== 'undefined' ? URL : webkitURL).revokeObjectURL(url)
|
return (typeof URL !== 'undefined' ? URL : webkitURL).revokeObjectURL(url)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to a binary string.
|
* Convert a <code>Blob</code> to a binary string.
|
||||||
*
|
*
|
||||||
* @param {Blob} blob
|
* @param blob
|
||||||
* @returns {Promise} Promise that resolves with the binary string
|
* @returns Promise that resolves with the binary string
|
||||||
*/
|
*/
|
||||||
export function blobToBinaryString (blob) {
|
export function blobToBinaryString (blob: Blob): Promise<string> {
|
||||||
return new Promise(function (resolve, reject) {
|
return new Promise(function (resolve, reject) {
|
||||||
var reader = new FileReader()
|
var reader = new FileReader()
|
||||||
var hasBinaryString = typeof reader.readAsBinaryString === 'function'
|
var hasBinaryString = typeof reader.readAsBinaryString === 'function'
|
||||||
@ -155,31 +159,31 @@ export function blobToBinaryString (blob) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a base64-encoded string to a <code>Blob</code>.
|
* Convert a base64-encoded string to a <code>Blob</code>.
|
||||||
* @param {string} base64
|
* @param base64 - base64-encoded string
|
||||||
* @param {string|undefined} type - the content type (optional)
|
* @param type - the content type (optional)
|
||||||
* @returns {Blob}
|
* @returns Blob
|
||||||
*/
|
*/
|
||||||
export function base64StringToBlob (base64, type) {
|
export function base64StringToBlob (base64: string, type?: string): Blob {
|
||||||
var parts = [binaryStringToArrayBuffer(atob(base64))]
|
var parts = [binaryStringToArrayBuffer(atob(base64))]
|
||||||
return type ? createBlob(parts, { type: type }) : createBlob(parts)
|
return type ? createBlob(parts, { type: type }) : createBlob(parts)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a binary string to a <code>Blob</code>.
|
* Convert a binary string to a <code>Blob</code>.
|
||||||
* @param {string} binary
|
* @param binary - binary string
|
||||||
* @param {string|undefined} type - the content type (optional)
|
* @param type - the content type (optional)
|
||||||
* @returns {Blob}
|
* @returns Blob
|
||||||
*/
|
*/
|
||||||
export function binaryStringToBlob (binary, type) {
|
export function binaryStringToBlob (binary: string, type?: string): Blob {
|
||||||
return base64StringToBlob(btoa(binary), type)
|
return base64StringToBlob(btoa(binary), type)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to a binary string.
|
* Convert a <code>Blob</code> to a binary string.
|
||||||
* @param {Blob} blob
|
* @param blob
|
||||||
* @returns {Promise} Promise that resolves with the binary string
|
* @returns Promise that resolves with the binary string
|
||||||
*/
|
*/
|
||||||
export function blobToBase64String (blob) {
|
export function blobToBase64String (blob: Blob): Promise<string> {
|
||||||
return blobToBinaryString(blob).then(btoa)
|
return blobToBinaryString(blob).then(btoa)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -187,10 +191,10 @@ export function blobToBase64String (blob) {
|
|||||||
* Convert a data URL string
|
* Convert a data URL string
|
||||||
* (e.g. <code>'...'</code>)
|
* (e.g. <code>'...'</code>)
|
||||||
* to a <code>Blob</code>.
|
* to a <code>Blob</code>.
|
||||||
* @param {string} dataURL
|
* @param dataURL - dataURL-encoded string
|
||||||
* @returns {Blob}
|
* @returns Blob
|
||||||
*/
|
*/
|
||||||
export function dataURLToBlob (dataURL) {
|
export function dataURLToBlob (dataURL: string): Blob {
|
||||||
var type = dataURL.match(/data:([^;]+)/)[1]
|
var type = dataURL.match(/data:([^;]+)/)[1]
|
||||||
var base64 = dataURL.replace(/^[^,]+,/, '')
|
var base64 = dataURL.replace(/^[^,]+,/, '')
|
||||||
|
|
||||||
@ -201,10 +205,10 @@ export function dataURLToBlob (dataURL) {
|
|||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to a data URL string
|
* Convert a <code>Blob</code> to a data URL string
|
||||||
* (e.g. <code>'...'</code>).
|
* (e.g. <code>'...'</code>).
|
||||||
* @param {Blob} blob
|
* @param blob
|
||||||
* @returns {Promise} Promise that resolves with the data URL string
|
* @returns Promise that resolves with the data URL string
|
||||||
*/
|
*/
|
||||||
export function blobToDataURL (blob) {
|
export function blobToDataURL (blob: Blob): Promise<string> {
|
||||||
return blobToBase64String(blob).then(function (base64String) {
|
return blobToBase64String(blob).then(function (base64String) {
|
||||||
return 'data:' + blob.type + ';base64,' + base64String
|
return 'data:' + blob.type + ';base64,' + base64String
|
||||||
})
|
})
|
||||||
@ -217,15 +221,15 @@ export function blobToDataURL (blob) {
|
|||||||
* <p/>Note: this will coerce the image to the desired content type, and it
|
* <p/>Note: this will coerce the image to the desired content type, and it
|
||||||
* will only paint the first frame of an animated GIF.
|
* will only paint the first frame of an animated GIF.
|
||||||
*
|
*
|
||||||
* @param {string} src
|
* @param src - image src
|
||||||
* @param {string|undefined} type - the content type (optional, defaults to 'image/png')
|
* @param type - the content type (optional, defaults to 'image/png')
|
||||||
* @param {string|undefined} crossOrigin - for CORS-enabled images, set this to
|
* @param crossOrigin - for CORS-enabled images, set this to
|
||||||
* 'Anonymous' to avoid "tainted canvas" errors
|
* 'Anonymous' to avoid "tainted canvas" errors
|
||||||
* @param {number|undefined} quality - a number between 0 and 1 indicating image quality
|
* @param quality - a number between 0 and 1 indicating image quality
|
||||||
* if the requested type is 'image/jpeg' or 'image/webp'
|
* if the requested type is 'image/jpeg' or 'image/webp'
|
||||||
* @returns {Promise} Promise that resolves with the data URL string
|
* @returns Promise that resolves with the data URL string
|
||||||
*/
|
*/
|
||||||
export function imgSrcToDataURL (src, type, crossOrigin, quality) {
|
export function imgSrcToDataURL (src: string, type?: string, crossOrigin?: string, quality?: number): Promise<string> {
|
||||||
type = type || 'image/png'
|
type = type || 'image/png'
|
||||||
|
|
||||||
return loadImage(src, crossOrigin).then(imgToCanvas).then(function (canvas) {
|
return loadImage(src, crossOrigin).then(imgToCanvas).then(function (canvas) {
|
||||||
@ -235,13 +239,13 @@ export function imgSrcToDataURL (src, type, crossOrigin, quality) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>canvas</code> to a <code>Blob</code>.
|
* Convert a <code>canvas</code> to a <code>Blob</code>.
|
||||||
* @param {string} canvas
|
* @param canvas
|
||||||
* @param {string|undefined} type - the content type (optional, defaults to 'image/png')
|
* @param type - the content type (optional, defaults to 'image/png')
|
||||||
* @param {number|undefined} quality - a number between 0 and 1 indicating image quality
|
* @param quality - a number between 0 and 1 indicating image quality
|
||||||
* if the requested type is 'image/jpeg' or 'image/webp'
|
* if the requested type is 'image/jpeg' or 'image/webp'
|
||||||
* @returns {Promise} Promise that resolves with the <code>Blob</code>
|
* @returns Promise that resolves with the <code>Blob</code>
|
||||||
*/
|
*/
|
||||||
export function canvasToBlob (canvas, type, quality) {
|
export function canvasToBlob (canvas: HTMLCanvasElement, type?: string, quality?: number): Promise<Blob> {
|
||||||
if (typeof canvas.toBlob === 'function') {
|
if (typeof canvas.toBlob === 'function') {
|
||||||
return new Promise(function (resolve) {
|
return new Promise(function (resolve) {
|
||||||
canvas.toBlob(resolve, type, quality)
|
canvas.toBlob(resolve, type, quality)
|
||||||
@ -257,15 +261,15 @@ export function canvasToBlob (canvas, type, quality) {
|
|||||||
* <p/>Note: this will coerce the image to the desired content type, and it
|
* <p/>Note: this will coerce the image to the desired content type, and it
|
||||||
* will only paint the first frame of an animated GIF.
|
* will only paint the first frame of an animated GIF.
|
||||||
*
|
*
|
||||||
* @param {string} src
|
* @param src - image src
|
||||||
* @param {string|undefined} type - the content type (optional, defaults to 'image/png')
|
* @param type - the content type (optional, defaults to 'image/png')
|
||||||
* @param {string|undefined} crossOrigin - for CORS-enabled images, set this to
|
* @param crossOrigin - for CORS-enabled images, set this to
|
||||||
* 'Anonymous' to avoid "tainted canvas" errors
|
* 'Anonymous' to avoid "tainted canvas" errors
|
||||||
* @param {number|undefined} quality - a number between 0 and 1 indicating image quality
|
* @param quality - a number between 0 and 1 indicating image quality
|
||||||
* if the requested type is 'image/jpeg' or 'image/webp'
|
* if the requested type is 'image/jpeg' or 'image/webp'
|
||||||
* @returns {Promise} Promise that resolves with the <code>Blob</code>
|
* @returns Promise that resolves with the <code>Blob</code>
|
||||||
*/
|
*/
|
||||||
export function imgSrcToBlob (src, type, crossOrigin, quality) {
|
export function imgSrcToBlob (src: string, type?: string, crossOrigin?: string, quality?: number): Promise<Blob> {
|
||||||
type = type || 'image/png'
|
type = type || 'image/png'
|
||||||
|
|
||||||
return loadImage(src, crossOrigin).then(imgToCanvas).then(function (canvas) {
|
return loadImage(src, crossOrigin).then(imgToCanvas).then(function (canvas) {
|
||||||
@ -276,20 +280,20 @@ export function imgSrcToBlob (src, type, crossOrigin, quality) {
|
|||||||
/**
|
/**
|
||||||
* Convert an <code>ArrayBuffer</code> to a <code>Blob</code>.
|
* Convert an <code>ArrayBuffer</code> to a <code>Blob</code>.
|
||||||
*
|
*
|
||||||
* @param {ArrayBuffer} buffer
|
* @param buffer
|
||||||
* @param {string|undefined} type - the content type (optional)
|
* @param type - the content type (optional)
|
||||||
* @returns {Blob}
|
* @returns Blob
|
||||||
*/
|
*/
|
||||||
export function arrayBufferToBlob (buffer, type) {
|
export function arrayBufferToBlob (buffer: ArrayBuffer, type?: string): Blob {
|
||||||
return createBlob([buffer], type)
|
return createBlob([buffer], type)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to an <code>ArrayBuffer</code>.
|
* Convert a <code>Blob</code> to an <code>ArrayBuffer</code>.
|
||||||
* @param {Blob} blob
|
* @param blob
|
||||||
* @returns {Promise} Promise that resolves with the <code>ArrayBuffer</code>
|
* @returns Promise that resolves with the <code>ArrayBuffer</code>
|
||||||
*/
|
*/
|
||||||
export function blobToArrayBuffer (blob) {
|
export function blobToArrayBuffer (blob: Blob): Promise<ArrayBuffer> {
|
||||||
return new Promise(function (resolve, reject) {
|
return new Promise(function (resolve, reject) {
|
||||||
var reader = new FileReader()
|
var reader = new FileReader()
|
||||||
reader.onloadend = function (e) {
|
reader.onloadend = function (e) {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user