Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

blob-util

Package Overview
Dependencies
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

blob-util - npm Package Compare versions

Comparing version 1.3.0 to 2.0.0

CHANGELOG.md

50

package.json
{
"name": "blob-util",
"version": "1.3.0",
"version": "2.0.0",
"description": "Utilities for working with Blob objects in the browser",
"main": "lib/index.js",
"main": "dist/blob-util.cjs.js",
"module": "dist/blob-util.es.js",
"types": "dist/blob-util.d.ts",
"repository": {

@@ -23,29 +25,38 @@ "type": "git",

"scripts": {
"jshint": "jshint -c .jshintrc lib/*.js test/test.js",
"test": "npm run jshint && zuul ./test/test.js",
"test-local": "zuul ./test/test.js --local 9000",
"build": "mkdirp dist && npm run browserify && npm run min",
"browserify": "browserify . -p bundle-collapser/plugin -s blobUtil | ./bin/es3ify.js | derequire > dist/blob-util.js",
"lint": "standard test/*js bin/*js && tslint src/*ts",
"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",
"clean": "rimraf dist lib && mkdirp dist lib",
"build": "run-s clean build-ts build-js min",
"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 && rimraf lib",
"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-umd": "rollup -i lib/blob-util.js -f umd -n blobUtil -o dist/blob-util.js",
"min": "uglifyjs dist/blob-util.js -mc > dist/blob-util.min.js",
"jsdoc2md": "jsdoc2md --heading-depth 3 ./lib/index.js > README.md",
"jsdoc": "jsdoc -d docs ./lib/index.js && mv -f docs/global.html docs/index.html"
"doc": "run-s cleanup-doc gen-doc gen-readme cleanup-doc",
"gen-doc": "typedoc --out docs-tmp --target ES6 --theme markdown --mdHideSources --excludePrivate --exclude private.ts src",
"gen-readme": "node bin/write-docs-to-readme.js",
"cleanup-doc": "rimraf docs-tmp"
},
"dependencies": {
"blob": "0.0.4",
"native-or-lie": "1.0.2"
},
"devDependencies": {
"browserify": "^9.0.3",
"bundle-collapser": "^1.1.4",
"chai": "~1.8.1",
"chai-as-promised": "~4.1.0",
"derequire": "^2.0.0",
"es3ify": "^0.1.3",
"cpy-cli": "^1.0.1",
"istanbul": "^0.2.7",
"jsdoc": "^3.3.0-alpha10",
"jsdoc-to-markdown": "^0.5.9",
"jshint": "~2.3.0",
"mkdirp": "^0.5.0",
"mocha": "~1.18",
"native-or-lie": "1.0.2",
"npm-run-all": "^4.1.3",
"pify": "^3.0.0",
"request": "^2.36.0",
"rimraf": "^2.6.2",
"rollup": "^0.59.1",
"standard": "^11.0.1",
"tslint": "^5.10.0",
"tslint-config-standard": "^7.0.0",
"typedoc": "^0.11.1",
"typedoc-plugin-markdown": "^1.1.11",
"typescript": "^2.8.3",
"uglify-js": "^2.4.13",

@@ -56,5 +67,4 @@ "zuul": "^3.10.1",

"files": [
"lib",
"dist"
]
}

561

README.md

@@ -1,2 +0,2 @@

blob-util [![Build Status](https://travis-ci.org/nolanlawson/blob-util.svg)](https://travis-ci.org/nolanlawson/blob-util)
blob-util [![Build Status](https://travis-ci.org/nolanlawson/blob-util.svg)](https://travis-ci.org/nolanlawson/blob-util) [![TypeScript](https://img.shields.io/badge/%3C%2F%3E-typescript-blue.svg)](http://www.typescriptlang.org/)
=====

@@ -30,27 +30,36 @@

Download it from the `dist/` folder above, or use NPM:
Via npm:
```bash
$ npm install blob-util
npm install blob-util
```
or Bower:
ES modules are supported:
```bash
$ bower install blob-util
```js
import { canvasToBlob } from 'blob-util'
canvasToBlob(canvas, 'image/png').then(/* ... */)
```
Then stick it in your HTML:
Or as a script tag:
```html
<script src="blob-util.js"></script>
<script src="https://unpkg.com/blob-util/dist/blob-util.min.js"></script>
```
Now you have a `window.blobUtil` object. Or if you don't like globals, you can use Browserify.
Then it's available as a global `blobUtil` object:
```js
blobUtil.canvasToBlob(canvas, 'image/png').then(/* ... */)
```
Browser support
-----
As of v2.0.0, a built-in `Promise` polyfill is no longer provided. Assuming you provide a `Promise`
polyfill, the supported browsers are:
* Firefox
* Chrome
* Edge
* IE 10+

@@ -110,133 +119,162 @@ * Safari 6+

Warning: this API uses [Promises](https://promisesaplus.com/), because it's not 2009 anymore.
<!-- begin insert API -->
### Overview
## Index
* [createBlob(parts, options)](#createBlob)
* [createObjectURL(blob)](#createObjectURL)
* [revokeObjectURL(url)](#revokeObjectURL)
* [blobToBinaryString(blob)](#blobToBinaryString)
* [base64StringToBlob(base64, type)](#base64StringToBlob)
* [binaryStringToBlob(binary, type)](#binaryStringToBlob)
* [blobToBase64String(blob)](#blobToBase64String)
* [dataURLToBlob(dataURL)](#dataURLToBlob)
* [blobToDataURL(blob)](#blobToDataURL)
* [imgSrcToDataURL(src, type, crossOrigin, quality)](#imgSrcToDataURL)
* [canvasToBlob(canvas, type, quality)](#canvasToBlob)
* [imgSrcToBlob(src, type, crossOrigin, quality)](#imgSrcToBlob)
* [arrayBufferToBlob(buffer, type)](#arrayBufferToBlob)
* [blobToArrayBuffer(blob)](#blobToArrayBuffer)
<a name="createBlob"></a>
### createBlob(parts, options)
Shim for
[new Blob()](https://developer.mozilla.org/en-US/docs/Web/API/Blob.Blob)
to support
[older browsers that use the deprecated <code>BlobBuilder</code> API](http://caniuse.com/blob).
### Functions
**Params**
* [arrayBufferToBinaryString](#arraybuffertobinarystring)
* [arrayBufferToBlob](#arraybuffertoblob)
* [base64StringToBlob](#base64stringtoblob)
* [binaryStringToArrayBuffer](#binarystringtoarraybuffer)
* [binaryStringToBlob](#binarystringtoblob)
* [blobToArrayBuffer](#blobtoarraybuffer)
* [blobToBase64String](#blobtobase64string)
* [blobToBinaryString](#blobtobinarystring)
* [blobToDataURL](#blobtodataurl)
* [canvasToBlob](#canvastoblob)
* [createBlob](#createblob)
* [createObjectURL](#createobjecturl)
* [dataURLToBlob](#dataurltoblob)
* [imgSrcToBlob](#imgsrctoblob)
* [imgSrcToDataURL](#imgsrctodataurl)
* [revokeObjectURL](#revokeobjecturl)
- parts `Array` - content of the <code>Blob</code>
- options `Object` - usually just <code>{type: myContentType}</code>
---
**Returns**: `Blob`
## Functions
**Example**:
<a id="arraybuffertobinarystring"></a>
### arrayBufferToBinaryString
▸ **arrayBufferToBinaryString**(buffer: *`ArrayBuffer`*): `string`
Convert an `ArrayBuffer` to a binary string.
Example:
```js
var myBlob = blobUtil.createBlob(['hello world'], {type: 'text/plain'});
var myString = blobUtil.arrayBufferToBinaryString(arrayBuff)
```
<a name="createObjectURL"></a>
### createObjectURL(blob)
Shim for
[URL.createObjectURL()](https://developer.mozilla.org/en-US/docs/Web/API/URL.createObjectURL)
to support browsers that only have the prefixed
<code>webkitURL</code> (e.g. Android <4.4).
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| buffer | `ArrayBuffer` | array buffer |
- blob `Blob`
**Returns:** `string`
binary string
**Returns**: `string` - url
___
<a id="arraybuffertoblob"></a>
**Example**:
### arrayBufferToBlob
▸ **arrayBufferToBlob**(buffer: *`ArrayBuffer`*, type?: *`string`*): `Blob`
Convert an `ArrayBuffer` to a `Blob`.
Example:
```js
var myUrl = blobUtil.createObjectURL(blob);
var blob = blobUtil.arrayBufferToBlob(arrayBuff, 'audio/mpeg');
```
<a name="revokeObjectURL"></a>
### revokeObjectURL(url)
Shim for
[URL.revokeObjectURL()](https://developer.mozilla.org/en-US/docs/Web/API/URL.revokeObjectURL)
to support browsers that only have the prefixed
<code>webkitURL</code> (e.g. Android <4.4).
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| buffer | `ArrayBuffer` | - |
| `Optional` type | `string` | the content type (optional) |
- url `string`
**Returns:** `Blob`
Blob
**Example**:
___
<a id="base64stringtoblob"></a>
### base64StringToBlob
▸ **base64StringToBlob**(base64: *`string`*, type?: *`string`*): `Blob`
Convert a base64-encoded string to a `Blob`.
Example:
```js
blobUtil.revokeObjectURL(myUrl);
var blob = blobUtil.base64StringToBlob(base64String);
```
<a name="blobToBinaryString"></a>
### blobToBinaryString(blob)
Convert a <code>Blob</code> to a binary string. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| base64 | `string` | base64-encoded string |
| `Optional` type | `string` | the content type (optional) |
- blob `Blob`
**Returns:** `Blob`
Blob
**Returns**: `Promise` - Promise that resolves with the binary string
___
<a id="binarystringtoarraybuffer"></a>
**Example**:
### binaryStringToArrayBuffer
▸ **binaryStringToArrayBuffer**(binary: *`string`*): `ArrayBuffer`
Convert a binary string to an `ArrayBuffer`.
```js
blobUtil.blobToBinaryString(blob).then(function (binaryString) {
// success
}).catch(function (err) {
// error
});
var myBuffer = blobUtil.binaryStringToArrayBuffer(binaryString)
```
<a name="base64StringToBlob"></a>
### base64StringToBlob(base64, type)
Convert a base64-encoded string to a <code>Blob</code>. Returns a Promise.
**Params**
**Parameters:**
- base64 `string`
- type `string` | `undefined` - the content type (optional)
| Param | Type | Description |
| ------ | ------ | ------ |
| binary | `string` | binary string |
**Returns**: `Promise` - Promise that resolves with the <code>Blob</code>
**Returns:** `ArrayBuffer`
array buffer
**Example**:
___
<a id="binarystringtoblob"></a>
### binaryStringToBlob
▸ **binaryStringToBlob**(binary: *`string`*, type?: *`string`*): `Blob`
Convert a binary string to a `Blob`.
Example:
```js
blobUtil.base64StringToBlob(base64String).then(function (blob) {
// success
}).catch(function (err) {
// error
});
var blob = blobUtil.binaryStringToBlob(binaryString);
```
<a name="binaryStringToBlob"></a>
### binaryStringToBlob(binary, type)
Convert a binary string to a <code>Blob</code>. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| binary | `string` | binary string |
| `Optional` type | `string` | the content type (optional) |
- binary `string`
- type `string` | `undefined` - the content type (optional)
**Returns:** `Blob`
Blob
**Returns**: `Promise` - Promise that resolves with the <code>Blob</code>
___
<a id="blobtoarraybuffer"></a>
**Example**:
### blobToArrayBuffer
▸ **blobToArrayBuffer**(blob: *`Blob`*): `Promise`<`ArrayBuffer`>
Convert a `Blob` to an `ArrayBuffer`.
Example:
```js
blobUtil.binaryStringToBlob(binaryString).then(function (blob) {
blobUtil.blobToArrayBuffer(blob).then(function (arrayBuff) {
// success

@@ -248,15 +286,22 @@ }).catch(function (err) {

<a name="blobToBase64String"></a>
### blobToBase64String(blob)
Convert a <code>Blob</code> to a binary string. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| blob | `Blob` | - |
- blob `Blob`
**Returns:** `Promise`<`ArrayBuffer`>
Promise that resolves with the <code>ArrayBuffer</code>
**Returns**: `Promise` - Promise that resolves with the binary string
___
<a id="blobtobase64string"></a>
### blobToBase64String
**Example**:
▸ **blobToBase64String**(blob: *`Blob`*): `Promise`<`string`>
Convert a `Blob` to a binary string.
Example:
```js

@@ -270,18 +315,24 @@ blobUtil.blobToBase64String(blob).then(function (base64String) {

<a name="dataURLToBlob"></a>
### dataURLToBlob(dataURL)
Convert a data URL string
(e.g. <code>'data:image/png;base64,iVBORw0KG...'</code>)
to a <code>Blob</code>. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| blob | `Blob` | - |
- dataURL `string`
**Returns:** `Promise`<`string`>
Promise that resolves with the binary string
**Returns**: `Promise` - Promise that resolves with the <code>Blob</code>
___
<a id="blobtobinarystring"></a>
**Example**:
### blobToBinaryString
▸ **blobToBinaryString**(blob: *`Blob`*): `Promise`<`string`>
Convert a `Blob` to a binary string.
Example:
```js
blobUtil.dataURLToBlob(dataURL).then(function (blob) {
blobUtil.blobToBinaryString(blob).then(function (binaryString) {
// success

@@ -292,46 +343,49 @@ }).catch(function (err) {

```
<a name="blobToDataURL"></a>
###blobToDataURL(blob)
Convert a <code>Blob</code> to a data URL string
(e.g. <code>'data:image/png;base64,iVBORw0KG...'</code>).
Returns a Promise.
**Params**
**Parameters:**
- blob `Blob`
| Param | Type | Description |
| ------ | ------ | ------ |
| blob | `Blob` | - |
**Returns**: `Promise` - Promise that resolves with the data URL string
**Returns:** `Promise`<`string`>
Promise that resolves with the binary string
**Example**:
___
<a id="blobtodataurl"></a>
### blobToDataURL
▸ **blobToDataURL**(blob: *`Blob`*): `Promise`<`string`>
Convert a `Blob` to a data URL string (e.g. `'data:image/png;base64,iVBORw0KG...'`).
Example:
```js
blobUtil.blobToDataURL(blob).then(function (dataURL) {
// success
}).catch(function (err) {
// error
});
var dataURL = blobUtil.blobToDataURL(blob);
```
<a name="imgSrcToDataURL"></a>
### imgSrcToDataURL(src, type, crossOrigin, quality)
Convert an image's <code>src</code> URL to a data URL by loading the image and painting
it to a <code>canvas</code>. Returns a Promise.
<p/>Note: this will coerce the image to the desired content type, and it
will only paint the first frame of an animated GIF.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| blob | `Blob` | - |
- src `string`
- type `string` | `undefined` - the content type (optional, defaults to 'image/png')
- crossOrigin `string` | `undefined` - for CORS-enabled images, set this to
'Anonymous' to avoid "tainted canvas" errors
- quality `number` | `undefined` - a number between 0 and 1 indicating image quality
if the requested type is 'image/jpeg' or 'image/webp'
**Returns:** `Promise`<`string`>
Promise that resolves with the data URL string
**Returns**: `Promise` - Promise that resolves with the data URL string
___
<a id="canvastoblob"></a>
**Examples**:
### canvasToBlob
▸ **canvasToBlob**(canvas: *`HTMLCanvasElement`*, type?: *`string`*, quality?: *`number`*): `Promise`<`Blob`>
Convert a `canvas` to a `Blob`.
Examples:
```js
blobUtil.imgSrcToDataURL('http://mysite.com/img.png').then(function (dataURL) {
blobUtil.canvasToBlob(canvas).then(function (blob) {
// success

@@ -343,5 +397,6 @@ }).catch(function (err) {

Most browsers support converting a canvas to both `'image/png'` and `'image/jpeg'`. You may also want to try `'image/webp'`, which will work in some browsers like Chrome (and in other browsers, will just fall back to `'image/png'`):
```js
blobUtil.imgSrcToDataURL('http://some-other-site.com/img.jpg', 'image/jpeg',
'Anonymous', 1.0).then(function (dataURL) {
blobUtil.canvasToBlob(canvas, 'image/webp').then(function (blob) {
// success

@@ -353,59 +408,100 @@ }).catch(function (err) {

<a name="canvasToBlob"></a>
### canvasToBlob(canvas, type, quality)
Convert a <code>canvas</code> to a <code>Blob</code>. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| canvas | `HTMLCanvasElement` | HTMLCanvasElement |
| `Optional` type | `string` | the content type (optional, defaults to 'image/png') |
| `Optional` quality | `number` | a number between 0 and 1 indicating image quality if the requested type is 'image/jpeg' or 'image/webp' |
- canvas `string`
- type `string` | `undefined` - the content type (optional, defaults to 'image/png')
- quality `number` | `undefined` - a number between 0 and 1 indicating image quality
if the requested type is 'image/jpeg' or 'image/webp'
**Returns:** `Promise`<`Blob`>
Promise that resolves with the <code>Blob</code>
**Returns**: `Promise` - Promise that resolves with the <code>Blob</code>
___
<a id="createblob"></a>
### createBlob
**Examples**:
▸ **createBlob**(parts: *`Array`<`any`>*, properties?: * `BlobPropertyBag` &#124; `string`*): `Blob`
Shim for [`new Blob()`](https://developer.mozilla.org/en-US/docs/Web/API/Blob.Blob ) to support [older browsers that use the deprecated `BlobBuilder` API](http://caniuse.com/blob ).
Example:
```js
blobUtil.canvasToBlob(canvas).then(function (blob) {
// success
}).catch(function (err) {
// error
});
var myBlob = blobUtil.createBlob(['hello world'], {type: 'text/plain'});
```
Most browsers support converting a canvas to both `'image/png'` and `'image/jpeg'`. You may
also want to try `'image/webp'`, which will work in some browsers like Chrome (and in other browsers, will just fall back to `'image/png'`):
**Parameters:**
| Param | Type | Description |
| ------ | ------ | ------ |
| parts | `Array`<`any`> | content of the <code>Blob</code> |
| `Optional` properties | `BlobPropertyBag` &#124; `string`| usually <code>{type: myContentType}</code>, you can also pass a string for the content type |
**Returns:** `Blob`
Blob
___
<a id="createobjecturl"></a>
### createObjectURL
▸ **createObjectURL**(blob: *`Blob`*): `string`
Shim for [`URL.createObjectURL()`](https://developer.mozilla.org/en-US/docs/Web/API/URL.createObjectURL ) to support browsers that only have the prefixed `webkitURL` (e.g. Android <4.4).
Example:
```js
blobUtil.canvasToBlob(canvas, 'image/webp').then(function (blob) {
// success
}).catch(function (err) {
// error
});
var myUrl = blobUtil.createObjectURL(blob);
```
<a name="imgSrcToBlob"></a>
### imgSrcToBlob(src, type, crossOrigin, quality)
Convert an image's <code>src</code> URL to a <code>Blob</code> by loading the image and painting
it to a <code>canvas</code>. Returns a Promise.
**Parameters:**
<p/>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 | Description |
| ------ | ------ | ------ |
| blob | `Blob` | - |
**Params**
**Returns:** `string`
url
- src `string`
- type `string` | `undefined` - the content type (optional, defaults to 'image/png')
- crossOrigin `string` | `undefined` - for CORS-enabled images, set this to
'Anonymous' to avoid "tainted canvas" errors
- quality `number` | `undefined` - a number between 0 and 1 indicating image quality
if the requested type is 'image/jpeg' or 'image/webp'
___
<a id="dataurltoblob"></a>
**Returns**: `Promise` - Promise that resolves with the <code>Blob</code>
### dataURLToBlob
**Examples**:
▸ **dataURLToBlob**(dataURL: *`string`*): `Blob`
Convert a data URL string (e.g. `'data:image/png;base64,iVBORw0KG...'`) to a `Blob`.
Example:
```js
var blob = blobUtil.dataURLToBlob(dataURL);
```
**Parameters:**
| Param | Type | Description |
| ------ | ------ | ------ |
| dataURL | `string` | dataURL-encoded string |
**Returns:** `Blob`
Blob
___
<a id="imgsrctoblob"></a>
### imgSrcToBlob
▸ **imgSrcToBlob**(src: *`string`*, type?: *`string`*, crossOrigin?: *`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.
Examples:
```js
blobUtil.imgSrcToBlob('http://mysite.com/img.png').then(function (blob) {

@@ -417,5 +513,4 @@ // success

```
```js
blobUtil.imgSrcToBlob('http://some-other-site.com/img.jpg', 'image/jpeg',
blobUtil.imgSrcToBlob('http://some-other-site.com/img.jpg', 'image/jpeg',
'Anonymous', 1.0).then(function (blob) {

@@ -428,17 +523,29 @@ // success

<a name="arrayBufferToBlob"></a>
### arrayBufferToBlob(buffer, type)
Convert an <code>ArrayBuffer</code> to a <code>Blob</code>. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| src | `string` | image src |
| `Optional` type | `string` | the content type (optional, defaults to 'image/png') |
| `Optional` crossOrigin | `string` | for CORS-enabled images, set this to 'Anonymous' to avoid "tainted canvas" errors |
| `Optional` quality | `number` | a number between 0 and 1 indicating image quality if the requested type is 'image/jpeg' or 'image/webp' |
- buffer `ArrayBuffer`
- type `string` | `undefined` - the content type (optional)
**Returns:** `Promise`<`Blob`>
Promise that resolves with the <code>Blob</code>
**Returns**: `Promise` - Promise that resolves with the <code>Blob</code>
___
<a id="imgsrctodataurl"></a>
**Example**:
### imgSrcToDataURL
▸ **imgSrcToDataURL**(src: *`string`*, type?: *`string`*, crossOrigin?: *`string`*, quality?: *`number`*): `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.
Examples:
```js
blobUtil.arrayBufferToBlob(arrayBuff, 'audio/mpeg').then(function (blob) {
blobUtil.imgSrcToDataURL('http://mysite.com/img.png').then(function (dataURL) {
// success

@@ -449,48 +556,62 @@ }).catch(function (err) {

```
```js
blobUtil.imgSrcToDataURL('http://some-other-site.com/img.jpg', 'image/jpeg',
'Anonymous', 1.0).then(function (dataURL) {
// success
}).catch(function (err) {
// error
});
```
<a name="blobToArrayBuffer"></a>
### blobToArrayBuffer(blob)
Convert a <code>Blob</code> to an <code>ArrayBuffer</code>. Returns a Promise.
**Parameters:**
**Params**
| Param | Type | Description |
| ------ | ------ | ------ |
| src | `string` | image src |
| `Optional` type | `string` | the content type (optional, defaults to 'image/png') |
| `Optional` crossOrigin | `string` | for CORS-enabled images, set this to 'Anonymous' to avoid "tainted canvas" errors |
| `Optional` quality | `number` | a number between 0 and 1 indicating image quality if the requested type is 'image/jpeg' or 'image/webp' |
- blob `Blob`
**Returns:** `Promise`<`string`>
Promise that resolves with the data URL string
**Returns**: `Promise` - Promise that resolves with the <code>ArrayBuffer</code>
___
<a id="revokeobjecturl"></a>
**Example**:
### revokeObjectURL
▸ **revokeObjectURL**(url: *`string`*): `void`
Shim for [`URL.revokeObjectURL()`](https://developer.mozilla.org/en-US/docs/Web/API/URL.revokeObjectURL ) to support browsers that only have the prefixed `webkitURL` (e.g. Android <4.4).
Example:
```js
blobUtil.blobToArrayBuffer(blob).then(function (arrayBuff) {
// success
}).catch(function (err) {
// error
});
blobUtil.revokeObjectURL(myUrl);
```
Credits
----
**Parameters:**
Thanks to [webmodules/blob](https://github.com/webmodules/blob) for the Blob constructor shim, and to the rest of [the PouchDB team](https://github.com/pouchdb/pouchdb/graphs/contributors) for figuring most of this crazy stuff out.
| Param | Type | Description |
| ------ | ------ | ------ |
| url | `string` | |
Building the library
----
**Returns:** `void`
npm install
npm run build
___
To generate documentation in `doc/`:
npm run jsdoc
or in markdown format as `api.md`
<!-- end insert API -->
npm run jsdoc2md
Credits
----
The playground is just `jsdoc` with some extra text containing Kirby and the code samples and such.
Thanks to the rest of [the PouchDB team](https://github.com/pouchdb/pouchdb/graphs/contributors) for figuring most of this crazy stuff out.
So unfortunately you will need to do a manual diff to get the docs up to date. You'll need to diff:
Building the library
----
* `README.md` to its previous version (make sure to keep the code samples, which were manually added)
* `docs` to its previous version
npm install
npm run build

@@ -509,1 +630,5 @@ Testing the library

npm run test-local
To build the API docs and insert them in the README:
npm run doc
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc