Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

filestack-js

filestack264.2kMIT3.37.5TypeScript support: included

Official JavaScript library for Filestack

filestack, filepicker, upload, files, multipart, S3, transform, cropper, document viewer, images, image processing, file management, universal, isomorphic

readme

Javascript SDK for the Filestack API and content management system.



Table of Contents

What's in the box?

  • A multi-part uploader powered on the backend by the Filestack CIN.
  • An interface to the Filestack Processing Engine for transforming assets via URLs.
  • The Filestack Picker - an upload widget for the web that integrates over a dozen cloud providers and provides pre-upload image editing.

Installation

npm install filestack-js

To get your free API key, sign up for a Filestack account here: https://dev.filestack.com/signup/free.

API Documentation

https://filestack.github.io/filestack-js/

Usage

Browsers

ES module

import * as filestack from 'filestack-js';
const client = filestack.init('apikey');

UMD module

<script src="//static.filestackapi.com/filestack-js/{MAJOR_VERSION}.x.x/filestack.min.js" crossorigin="anonymous"></script>
<script>
  const client = filestack.init('apikey');
</script>

where {MAJOR_VERSION} is one of the MAJOR versions of the filestack-js ie:

<script src="//static.filestackapi.com/filestack-js/3.x.x/filestack.min.js" crossorigin="anonymous"></script>
<script>
  const client = filestack.init('apikey');
</script>

SRI

Subresource Integrity (SRI) is a security feature that enables browsers to verify that files they fetch (for example, from a CDN) are delivered without unexpected manipulation. It works by allowing you to provide a cryptographic hash that a fetched file must match

To obtain sri hashes for filestack-js library check manifest.json file on CDN:

https://static.filestackapi.com/filestack-js/{LIBRARY_VERSION}/manifest.json
<script src="//static.filestackapi.com/filestack-js/{LIBRARY_VERSION}/filestack.min.js.gz" integrity="{FILE_HASH}" crossorigin="anonymous"></script>

Where {LIBRARY_VERSION} is currently used library version and {FILE_HASH} is one of the hashes from integrity field in manifest.json file

Node

CommonJS module

const client = require('filestack-js').init('apikey');

Module Overview

The package.json specifies two separate modules:

  • main for the CommonJS module (intended for Node runtimes)
  • browser for the pre-bundled ES module (intended for browser runtimes)

Node projects which depend on filestack-js will follow the main field in package.json. When building for the browser, newer tools (like Webpack, Rollup, and Parcel) follow the browser field, which will resolve to the pre-bundled ES module. Both modules follow the same API, but some methods behave differently based on their runtime. For example, client.upload treats the file argument as a file path in Node but in browsers it assumes a Blob object.

The pre-bundled browser module is also available in UMD format. This is useful if you are using script tags on a web page instead of bundling your application. It can be retrieved from both the Filestack CDN and the unpkg CDN:

Releases Info

Major releases will bo listed (with detailed examples) in releases folder starting from version 3.0.0

Live examples (JSFiddle)

Upload image
Multiupload
Open picker
Open picker in inline mode
Crop images
Multiple drop panes
Preview
Import using RequireJS
Retrieve image data
Transform image
Custom Picker CSS
Assign file to user

Examples can be run locally with:

npm run examples

Picker Quick Start

If you are here to use the picker widget, it can be initialized from the Filestack client by calling client.picker(options). Options for the picker are documented here.

The picker instance returned from client.picker can be controlled with a few methods:

  • open - Create the application and mount it into the DOM based on the displayMode.
  • close - Close the application and remove its resources from the DOM.
  • crop(files) - Create the application, mount it, and pre-select the passed files for cropping.
  • cancel - Cancel all uploads controlled by this instance.

Please see our examples above to learn more about customizing the picker for your use case.

Polyfills

If you target IE11 or iOS before 8.0 you will need to add additional polyfills to your page or application. (We are no longer support IE11 and older browser, so it can stop working on this browser)

Polyfills we recommend:**

Module (for bundling):

Development

Most tests in this library are expected to interface with actual backend services. Because we like to run tests during development, these services are mocked during unit testing.

All tests are using Jest.

To run units:

npm test

Debugging

Filestack-js uses debug, so just run with environmental variable DEBUG set to fs.*.

Node

DEBUG=fs.* node example_upload.js

Browser

Debug's enable state is persisted by localStorage

localStorage.debug = 'fs:*'

And then refresh the page.

Error event

The upload.error event was added to sdk. To obtain every upload request error just add callback to it. Error contains details field with responseBody, responseHeaders, code (only when error type is FilestackErrorType.REQUEST)

<script>
  const client = filestack.init('apikey');
  client.on('upload.error', (filestackError) => {
    console.log(filestackError);
  });
</script>

Upload abort throws an FilestackError with type FilestackErrorType.ABORTED

Sentry Integration

If you're using Sentry to monitor your application, Filestack will automatically report upload errors to Sentry, and tag them with helpful diagnostic information via @sentry/minimal.

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

Contributing

We follow the conventional commits specification to ensure consistent commit messages and changelog formatting.

changelog

Changelog

All notable changes to this project will be documented in this file. See standard-version for commit guidelines.

3.37.5 (2025-01-23)

  • revert: getMimeType changes reverted

3.36.4 (2024-12-11)

  • picker: Updated picker v1.31.4

3.35.4 (2024-10-14)

  • picker: Updated picker v1.30.4
  • picker: Added disableAltText option (3164a1)

3.34.4 (2024-10-18)

  • picker: Updated picker v1.29.4
  • client.upload: Added check for altText check (df5a23)

3.34.3 (2024-10-01)

  • picker: Updated picker v1.29.3 disabled transformations ui as default editor (0ff66c85177)

3.33.3 (2024-09-30)

  • picker: Updated picker v1.28.3 with transformations-ui as default editor
  • fromSources: Added back picasa as a potential source (#567
  • fix(dependency): Updated fast-xml-parser (#7b862752f6

3.32.3 (2024-06-18)

  • fromSources: revert version (b2767e5)

3.32.2 (2024-06-14)

  • picker: Upgraded picker to v1.27.3.
  • fromSources: Fixed declaring the custom source at first place in fromSources array

3.32.1 (2024-05-30)

  • miemtypes: Fixed support for vsdx file using through accept params

3.32.0 (2024-04-03)

Updgrade

  • picker: Upgraded picker to v1.27.1.
  • picker: Fixed support for hpt file type (558)

3.30.2 (2024-03-10)

Updgrade

  • picker: Upgraded picker to v1.27.0.

3.30.2 (2024-03-04)

Updgrade

  • picker: Upgraded picker to v1.26.2.

3.30.1 (2024-02-07)

Updgrade

  • picker: Upgraded picker to v1.26.1.

3.30.0 (2024-01-18)

Updgrade

  • picker: Upgraded picker to v1.26.0.

3.29.0 (2024-01-05)

Updgrade

  • file-type: Upgraded file-type to v16.5.4.

3.28.0 (2023-12-12)

Updgrade

  • Dependency-upgrade: Upgraded packages to the latest possible version while maintaining backward compatibility.

3.27.0 (2023-08-07)

Fix

  • fast-xml-parser: It's a security upgrade based on (#518) . Dependabot did the version bump and then fixed the tests(#521).

3.26.1 (2023-04-06)

Fix

  • picker: Fixed console error during file select and upload

3.26.0 (2023-03-30)

Feature

  • picker: Added possibility to predefine the results for the imagesearch in Picker
  • picker: Picker - Display Unsplash Search and Good Old Image Search as two tabs of one "source"

3.25.0 (2021-10-05)

Features

  • picker: bump version (f047a4e)
  • picker: Picker paste event add configuration options (#454) (a5a249b)
  • picker: support callback for tags (#461) (cf89ee0)
  • upload: emit event on file upload start (#462) (c676b48)

3.24.1 (2021-07-28)

Bug Fixes

  • picker: bump picker version for multiple fixes (3e364e9)
  • request: Large file upload memory leak (#453) (8f7f7a8)
  • schema-validation: disable bucker region validation (#448) (70b7e38)

3.24.0 (2021-06-28)

Features

  • picker: add onFileUploadCancel callback (c1e5bab)

3.23.2 (2021-06-14)

Bug Fixes

  • examples: fix uplad example (160a1bd)
  • picker: fix problems with exif cleanup (27774da)
  • upload/onprogress: add if statement for progress callback (#435) (2c61d53)

3.23.1 (2021-03-31)

Bug Fixes

  • getfile: fix get file for b64 encoded string (dbc65b7)

3.23.0 (2021-03-31)

Features

  • acceptfn: add acceptFn to picker schema (f349094)
  • github: add issue template (b45ae45)
  • picker: bump picker to v.1.21.1 (00677a6)

Bug Fixes

  • nodejs/base64: fix base64 upload (815fbed)

3.22.1 (2021-03-08)

Bug Fixes

3.22.0 (2021-03-08)

Features

  • download: Add download file method (#415) (5ed6afd)
  • picker: bump picker version to 1.21.0 (162673f)

Bug Fixes

  • pickerschema: update missing picker options (5ab80b5)
  • publish: fix error in publis script (#410) (3170f29)
  • sentry: remove discouraged configureScope (#417) (e20cc10)
  • storeurl: support for workflows to storeURL (#406) (2e8ba7c)

3.21.1 (2021-01-25)

Bug Fixes

  • picker: fix accept option in picker, bump version to 1.20.1 (7e48a30)

3.21.0 (2021-01-13)

Features

  • picker: bump picker to 1.20.0 (7b0d9ed)

3.20.0 (2020-11-18)

Features

  • picker: bump picker version (4b155b3)
  • utils: add converting extension to mimetype (#400) (669e178)

Bug Fixes

  • sentry: update sentry errors (5a53ddd)

3.19.0 (2020-11-03)

Features

  • picker: add custom source to picker - v 1.19.0 (9038607)

3.18.0 (2020-10-01)

Features

  • miemtypes: add key extension to list (a12b477)
  • mimetypes: check apple mimetypes based on extensions (#386) (08f1154)
  • picker: bump picker version to 18 (multiple bugfixes) (a304076)
  • utils: Replace 'getVersion' function's return statement to use static constant instead of dynamic require. (77fa52d)

Bug Fixes

  • cancelToken: move cancel token to event emmiter (#384) (b1cada8)
  • mimetypes: if we have mimetype and we cant find excluded type by extension fallback to magic by (20cfa49)
  • prefetch: clone deep config before send to avoid referances (#388) (7f3c153)

3.17.0 (2020-08-24)

Features

  • clouds: add mimetype filtering in clouds (#375) (5acd6b4)
  • clouds: add store adapter for better localstore/sessionstore support (#376) (ecb922e)
  • picker: bump picker version to 1.17.0 (6078164)

Bug Fixes

  • s3/complete: fix target for complete request (#371) (9536c27)

3.16.0 (2020-07-09)

Features

  • picker: bump picker version to 1.16.0 (f595695)

3.15.0 (2020-05-14)

Features

  • picker: Fix picker problems with cropFiles, erorrHandlers, add better mime detection (9dbe806)
  • pickerOptions: add support email to picker options (09d40b0)

Bug Fixes

  • mimetype: Update mimetype detection function (#356) (bf4146d)

3.14.0 (2020-04-21)

3.13.2 (2020-04-07)

Bug Fixes

  • build: Fix build webpack scripts (37b2617)

3.13.1 (2020-04-07)

Bug Fixes

  • prefetch: always ask for inapp_browser setting (61764f7)

3.13.0 (2020-04-01)

Features

  • picker: bump picker version with new prefetch request (77bc025)
  • prefetch: Separate and update new prefetch request (7132ab1)
  • request/http: add progress monitor to node http library (96ead9b)

3.12.4 (2020-02-17)

Bug Fixes

  • picker: fix problems with picker minimalization (d23b79e)

3.12.3 (2020-02-12)

3.12.2 (2020-02-12)

Bug Fixes

  • api/file: remove new debug headers from old api requests (a9a03fb)

3.12.1 (2020-02-12)

Bug Fixes

  • request: add missing filestack debug headers in request library (0356cd1)

3.12.0 (2020-02-12)

Features

  • request: Change axios library to filestack one (52a605a)

3.11.2 (2020-01-24)

Bug Fixes

  • polymorphic: Split libs into node and browser env, update webpack config (82689c2)

3.11.1 (2020-01-22)

Bug Fixes

  • require: fix problem during builds libs for browser - missing fs lib (f77e4d1), closes #319

3.11.0 (2020-01-15)

Features

  • picker: bump picker version to 1.11.1 (#318) (e1bdb2c)

3.10.1 (2019-11-14)

Features

  • clouds: Fix problems in in-app browsers like facebook, instagram, twitter (0cf0df1)

3.10.0 (2019-11-12)

Features

  • picker: remove clouddrive from sources - now this one is deprecated (#305) (cd47a38)

3.9.0 (2019-10-29)

Features

  • upload: add posibility to disable s3 integrity check (md5 gener… (#299) (207e4c7)

3.8.0 (2019-10-07)

Bug Fixes

  • getMimetype: Check x-msi by an extension (#280) (3e4c35b)
  • picker: Fix Spanish translation (a9fa2f7)
  • 🐛 Update old sdk references (#281) (494d774)

Build System

  • gzip: Remove gzip script, use cdn in-fly gzip feature (#282) (35cca80)

Features

  • s3: add disablele storage key to uplaoder (#291) (2cf27fd)

3.7.0 (2019-08-23)

Bug Fixes

  • picker: fix onFileSelected problem (#278) (22454fd)
  • README: Add String.prototype.includes to polyfill (#277) (460d585)

Features

  • transforms: Add animate transformation (#274) (3a82f02)
  • transforms: Add autoImage transformation (#276) (d371552)
  • transforms: Update enhance preset definition (#275) (32afd54)
  • uploader/s3: Regular upload - display error when there is missing etag field in s3 response (#267) (747e3b1)

3.6.0 (2019-08-07)

Features

3.5.0 (2019-07-25)

Features

  • picker: Add onFileCropped callback (#264) (a598ea6)
  • sdk: Export additional interface (#262)

3.4.2 (2019-07-15)

Bug Fixes

  • file_tools: Fix problems with uploading large files (f2c1ab9)

3.4.1 (2019-07-11)

Bug Fixes

  • p-queue: revert version (737baff)

Build System

  • aws-sdk: revert aws-sdk in dev-deps (c020a0a)

3.4.0 (2019-07-11)

Features

  • errors: Update error event, update libs (#254) (983084c)

3.3.5 (2019-07-03)

Bug Fixes

  • base64: Fix b64 url safe creation in filelink (#253) (80fa3a7)

3.3.4 (2019-06-25)

Bug Fixes

3.3.3 (2019-06-11)

3.3.2 (2019-06-07)

Bug Fixes

  • cloud/store: bring back "/" at the end of url (14ba091)
  • README: fix typo (ec33eb5)

3.3.1 (2019-06-07)

Bug Fixes

  • promises: Remove finally from promises, there was some problems with polyfils (2fab112)

3.3.0 (2019-06-07)

Bug Fixes

Features

  • picker: Bump picker version (fbd35ba)
  • webhookValidator: Add wh signature validator (a4975aa)

3.2.0 (2019-06-03)

Bug Fixes

  • types: Fix path in types file (793b8f1)

Features

  • picker: update picker version (037bbed)
  • picker: Update pickerOptions interface (#236) (2d6b533)

3.1.1 (2019-05-31)

3.1.0 (2019-05-31)

Features

  • validation: add all supported regions to validation (#233) (4cf82e7)

3.0.0 (2019-05-30)

2.1.0 (2019-05-06)

Features

2.0.7 (2019-04-18)

  • picker Update version of picker (1.4.7)

2.0.6 (2019-04-15)

  • filelink: Add zip, minifyCss and minifyJs tasks
  • picker Update version of picker (1.4.6)

2.0.5 (2019-04-08)

Bug Fixes

  • transforms: Fix typo in schema (d6cf4b0)

2.0.4 (2019-04-08)

  • filelink: Add possibility to disable validation on tasks params (2d3eb7f)

2.0.3 (2019-03-28)

Features

  • filelink: Add support for fallback task (dbb0b4b)

2.0.2 (2019-03-19)

Bug Fixes

  • urllib: Add url dep to build (6c17c47)

2.0.1 (2019-03-15)

2.0.0 (2019-03-15)

Bug Fixes

  • es5: replace ajv with jsonschema in transform validator (e59a5ba)

BREAKING CHANGES

  • es5: Validation errors from transform are updated to ValidationError from jsonschema

  • feat(Gzip): Add info about gzip support in README

  • ci(publish script): Udpate publish script for supporting gzip ContentEncoding

1.14.6 (2019-03-01)

Bug Fixes

  • trasnformSchema: Fix regexp for video convert task clip params (e572698)

1.14.5 (2019-02-27)

1.14.2 (2019-02-15)

Bug Fixes

  • filelink: Fix regexp for safari browser (11c46db)

1.14.1 (2019-02-12)

Bug Fixes

  • filelink: Add check hasOwnProperty to loop (c3e930f)

1.14.0 (2019-02-11)

Features

  • picker: Add tr language pack to picker (#202) (4448986)

1.13.4 (2019-02-07)

Bug Fixes

  • storeUrl: Add missing security (a6b0404), closes #198

1.13.3 (2019-02-07)

1.13.2 (2019-02-06)

1.13.1 (2019-02-04)

Bug Fixes

  • transformations: Fix videoconvert params (978d763)

1.13.0 (2019-01-31)

Features

  • Filelink: Add Filelink class to replace client.transform (#195) (5738b37)

BREAKING CHANGES

  • Filelink: Add new Filelink class for better transforms support

  • docs(Filelink): Add documentation to filelink

1.12.1 (2019-01-29)

Bug Fixes

  • transformations: Fix pdfconvert schema oneOf -> anyOf (c95bab2)

1.12.0 (2019-01-29)

Features

  • transforms: add pdfinfo and pdfconvert to transforms (#192) (da62507)

1.11.0 (2019-01-23)

Features

  • transforms: add base64 support to transforms (83f07e2)

1.10.0 (2019-01-15)

Bug Fixes

Features

1.9.0 (2018-12-18)

Features

  • picker: Add exif removal option to picker (9ca93b4)

1.8.3 (2018-12-11)

Bug Fixes

  • transforms: allow uppercased values in transform (#179) (9b7c3ba)

1.8.2 (2018-12-10)

1.8.1 (2018-11-22)

Bug Fixes

  • tslib: move tslib to deps (121d233)

1.8.0 (2018-11-21)

Bug Fixes

  • har-validator: fix har-validator in package json (d4475a0)
  • har-validator: fix version for har-validator (1a5d343)
  • har-validator: fix version in package-json lock (#172) (5f585a6)
  • storeURL: fix if statement for replacing special chars in store url (41188ec)

1.7.7 (2018-10-29)

Bug Fixes

  • browser_utils: fix slice file in browser utils (#166) (9210eb7)

1.7.6 (2018-10-25)

Bug Fixes

  • workflows: fix condition in workflows (03738ba)

1.7.5 (2018-10-25)

Bug Fixes

  • workflows: fix workflows in uploads (95d90e1)

1.7.4 (2018-10-25)

1.7.3 (2018-10-23)

Bug Fixes

  • upload: add signature and policy to complete upload event (#164) (7d98a27)

1.7.2 (2018-10-11)

1.7.1 (2018-10-10)

Bug Fixes

  • pickerOptions/workflows: Fix workflowIds name in options (#160) (b53af12)

1.7.0 (2018-10-10)

Features

  • workflows: Add workflows ids to store options (#159) (4ca1b34)

1.6.1 (2018-10-05)

Bug Fixes

  • picker/cname: Load assets from given cname instead of fielstackapi domain - picker v1.2.2 (#156) (e3ea711)

1.6.0 (2018-09-24)

Features

  • workflows: Add support for workflows (#150) (ddeb93a)

1.5.1 (2018-08-13)

Bug Fixes

1.5.0 (2018-08-08)

Features

1.4.1 (2018-07-25)

Picker Updates

  • fix issue with storeTo not being respected in dropPane mode with cropFiles: true

1.4.0 (2018-07-19)

Bug Fixes

  • downgrade rollup to fix ES module bundling (6c05b40)
  • respect empty values for transform tasks without props (4b4f9a6)

Features

  • add removeMetadata method to allow file delete calls with skip_storage param (#125) (45e628a)

1.3.2 (2018-07-17)

1.3.1 (2018-07-17)

Bug Fixes

  • transform: Transform cache option can be boolean (#127) (b4e15d4)

1.3.0 (2018-07-17)

Features

1.2.1 (2018-07-05)

Bug Fixes

  • resolve some issues with types (1455632)

1.2.0 (2018-07-02)

Picker Updates

  • add new option customText for replacing strings in the picker UI Read more
  • add new cropped and rotated fields to the returned picker metadata Read more
  • fix issue related to minified CSS namespace collision in animations
  • update Danish and Korean translations

1.1.0 (2018-06-13)

Features

  • transforms: Add safe for work and tags transform (#121) (ed0f4c6)

1.0.2 (2018-06-11)

Bug Fixes

  • transform: correct typo in video locations enum (6fcf41b)
  • picker: fix bug where onUploadDone was called twice if allowManualRetry was true
  • picker: fix issue where event listeners were being unnecessarily removed

1.0.1 (2018-05-31)

Bug Fixes

  • picker: fix syntax error in IE11 related to untransformed module import (51e4873)

1.0.0 (2018-05-31)

The source code for this repository has been made available under the Apache 2.0 license. Contributions are more than welcome, and we will be working to improve the contribution experience over time. It should be noted that the source code for the picker UI is not yet licensed for sharing.

Module Updates

  • Browser and Node runtimes are now both supported. This is accomplished using the appropriate module fields in package.json. Read more.
  • All modules have been rewritten in TypeScript. Generated docs are now derived from the interfaces used within the source code. API Docs

Breaking Changes

  • filestack.init now takes 2 arguments, apikey and options. Read more.
  • No more default export. The ES module must be imported using qualified imports, such as import * as filestack from 'filestack-js'.
  • Custom source in the picker must now use customSourceName to configure the name of the source in the UI. This is no longer pulled from the Filestack application.
  • rejectOnCancel has been removed from the picker options.
  • hideWhenUploading has been renamed to hideModalWhenUploading, since it applies only when displayMode is 'overlay'
  • pick, makeDropPane, and cropFiles have been replaced by a unifying picker instance that exposes methods for controlling the picker lifecycle. Supporting this change are two new picker options, displayMode and container, which allow users to configure how their pickers are integrated into the document.

Migration path for filestack.init:

const security = {
  policy: '12345',
  signature: 'abcdef'
};

const cname = 'fs.mydomain.com';

// pre 1.0

filestack.init(apikey, security, cname);

// ---> 1.0

const options = {
  security,
  cname,
};

filestack.init(apikey, options);

Picker Changes

We have changed the interface for using the picker. This was necessitated by new features and motivated by developer feedback. Because the picker now supports being embedded in addition to being a one-time modal, the Promise interface has been removed. This means client.pick is replaced by client.picker, which returns a Picker instance that exposes methods open, close, cancel, and crop. The picker instance can be configured to open in overlay, inline, or dropPane modes.

The recommended way moving forward is to replace your usage of client.pick with picker.open and set up any callbacks you need as options when instantiating the picker.

For example:


// pre-1.0

const client = filestack.init('apikey');

const pickOptions = {
  accept: ['image/jpeg', '.jpg', '.jpeg'],
  maxFiles: 4,
  imageMax: [1280, 720]
  // etc.
};

client.pick(pickOptions).then(callback);


// ---> 1.0

const client = filestack.init('apikey');

const pickOptions = {
  accept: ['image/jpeg', '.jpg', '.jpeg'],
  maxFiles: 4,
  imageMax: [1280, 720],
  onUploadDone: callback, 
};

client.picker(pickOptions).open();

In line with this change, we have removed the helper methods cropFiles and makeDropPane, but the same functionality can still be retained.

The old makeDropPane method can be achieved with this adapter:

const makeDropPane = (dropPaneOptions, pickerOptions) => {
  const options = {
    ...pickerOptions,
    displayMode: 'dropPane',
    container: dropPaneOptions.id, // container can be a CSS selector or DOM node
    dropPane: dropPaneOptions,
  };

  const picker = client.picker(options);
  picker.open();
  // close drop pane with picker.close()
};

cropFiles is replaced by the crop method on the picker instance. This can only be used when displayMode is overlay (default) or inline. The crop method will take the input files and apply the force crop mode automatically for those files.

const pickerOptions = {
  onUploadDone: res => console.log(res),
};

const picker = client.picker(pickerOptions);
picker.crop('http://link-to-an-image'); // can pass an array of Blobs or URLs

OAuth Changes

The OAuth flow for our cloud service has been updated to remove the need for cross-origin cookies. Unfortunately this is only possible by leveraging a feature of the OAuth 2 specification, which some cloud sources do not yet support. Because of this the following cloud sources are currently unsupported in the new picker:

  • Flickr
  • Evernote

Due to how these services implement OAuth we cannot reliably track end-user sessions in our system. These providers will still operate in previous versions, and we will continue to search for a solution moving forward.

Picker Changes Summary

  • New options displayMode and container to enable better DOM integration
  • MutationObserver is now used to clean up picker resources when its root node is destroyed in the DOM
  • onOpen now passes the picker instance and adds the app property to it which is a reference to the Vue instance
  • Non-local source views can now be toggled between list and grid
  • Shift-click for range selection is now supported in cloud source views
  • Fix issue related to folder limit in drag events
  • Fix issue where infinite scroll for some cloud sources made duplicate requests
  • Fix issue where accept parameter was not passed to mobile local file selection
  • Change accept to reject files without extensions if extension types are whitelisted
  • The modal sidebar will now auto-hide if only one source exists in fromSources
  • First-time render speed has been improved due to removing a blocking network request
  • Cross-origin cookies have been removed in favor of localStorage. This should resolve issues in Safari 11 and removes the need for the OAuth relay hosted by Filestack. This also means that Filestack cloud sessions will not persist across separate domains.
  • New option customSourceName for specifying the name of the custom source. This needs to be used if you were defining your custom source name in the dev portal.
  • webcam, audio and video sources on mobile are no longer hidden. Their behavior will be to open the device menu instead of using the desktop functionality.
  • Update Dutch translations
  • Add Catalan translations

API Client Updates

  • transform has been rewritten and now supports all image tasks from the Filestack catalog. Read more.
  • preview will now respect the CNAME option passed to the client when constructing URLs.
  • New option sessionCache to enable/disable storing the Filestack Cloud API token in the browser. Defaults to false. When true then users will not need to re-authorize their cloud sources if their session has not expired yet on the backend.

0.11.2 (2018-01-24)

Picker changes

  • Prevent ICC profile from being stripped on transformed images
  • Update Norwegian translations

0.11.1 (2018-01-18)

Picker changes

  • Fix a regression introduced in 0.10 where deselection of files prevented further uploads

0.11.0 (2018-01-12)

Picker changes

  • Remove global event handlers from drop pane components on destroy

Client changes

  • Update preview to use the new file viewer service (/preview instead of /api/preview)
  • Update preview to support storage aliases (e.g. src://my-alias/my-file)
  • Add preview option v1 for users who wish to continue using the deprecated file viewer

Note The new file viewer has been redesigned so custom CSS may no longer work as intended. Users can continue using the old viewer by passing { v1: true } in the client.preview options.

0.10.1 (2017-12-14)

Picker changes

  • Fix regression with uploadConfig.timeout not being respected

0.10.0 (2017-12-07)

Picker changes

  • Add new option concurrency to control maximum amount of running uploads
  • Fix a memory issue related to image resize and upload concurrency
  • Fix issue where 'fallback' for intelligent uploads was not respected
  • Fix issue where editing cloud images stripped EXIF metadata
  • Fix disableThumbnails option to respect edited cloud images
  • Refactor resize logic to provide better UX -- image resize operations no longer block user actions (like upload and edit)
  • Update Polish and Mandarin translations
  • Add Korean (ko), Norwegian (no), Swedish (sv), and Vietnamese (vi) translations

0.9.12 (2017-11-08)

Client changes

  • Introduce 'fallback' mode for intelligent uploads. When intelligent: 'fallback' is specified parts will only go through the intelligent ingestion flow when network conditions are degraded. The default behavior of intelligent: true remains unchanged -- when true all parts go through the intelligent flow regardless of network state.

Note: This feature still requires intelligent ingestion to be enabled on your Filestack application.

0.9.11 (2017-11-01)

Client changes

  • Fix bug with form data being parsed incorrectly when storing URLs

0.9.10 (2017-11-01)

Picker changes

  • Fix browser crash in Chrome when bulk resizing images
  • Add some UX around currently resizing images in summary view (Upload button now says Resizing)

0.9.9 (2017-10-18)

Picker changes

  • Disable drag mode on crop interface (only 0.9.8 had this behavior)
  • Increase crop box drag anchor area to help mobile gestures

Client changes

  • Add new intelligentChunkSize option to override the initial FII chunk size
  • Increase default request timeout to 2 minutes

0.9.8 (2017-10-12)

Picker changes

  • Add modalSize option for setting width and height of desktop modal
  • Change image grid thumbnail styles to prevent stretching
  • Add support for CNAME for static picker files (thanks to @MichalPodeszwa)
  • Fix duplicated uploads bug when startUploadingWhenMaxFilesReached and uploadInBackground are true
  • Fix bug where infinite scroll would fetch files twice
  • Fix issue with exposeOriginalFile not being respected in all callbacks
  • Optimize all downloaded SVG assets for faster loading times

0.9.7 (2017-10-06)

Picker changes

  • Fire all file callbacks regardless of uploadInBackground value
  • Default global drop zone to false, add new option globalDropZone to enable it
  • Add exposeOriginalFile option to give access to underlying File instances
  • Fix bug with allowManualRetry and background uploads
  • Fix UI bug with selected cloud files when uploadInBackground is true

0.9.6 (2017-10-05)

Picker changes

  • Implement makeDropPane for mounting a drop zone into the DOM (see README for options)
  • Implement cropFiles for using the picker's crop UI on a specific list of files
  • Add new uploadId to file metadata for tracking the file in callbacks
  • Add new rootId to pick options for specifying an id for the root DOM node
  • Fix UX bug with background uploads and summary row styles

0.9.5 (2017-10-03)

  • Fixed a possible race condition in the module loader. See #57.

0.9.4 (2017-09-26)

Picker changes

  • Implement allowManualRetry option.

allowManualRetry will override the default picker behavior when failed uploads occur. The modal will remain open to let users retry failed files manually. Network interruptions are also detected when this option is true, and uploads that fail due to network disruption will be auto-retried until the network returns or until a user manually retries.

The UX for the summary screen has changed due to this feature, so users will now see completed, uploading, and failed files in separate sections. This change is visible to all users regardless of the option being enabled.

Manual retry for the single image flow will land in a later release. This option currently only applies to files viewed in the summary screen and not in the transformer.

Client changes

  • Increase upload request timeout default to 60s
  • Set an upper bound on exponential backoff interval
  • Expose logout method to clear cloud sessions

0.9.3 (2017-09-18)

Picker changes

  • Add onedriveforbusiness to sources
  • Fix issue related to raven-js global instrumenting

0.9.2 (2017-09-07)

Picker changes

  • Add new uploadConfig option to configure local file uploads
  • Fix UX related to failed uploads in the summary view
  • Update a few translations
  • Add a new error screen for invalid apikey

Client changes

  • Implement preview method to open document viewer for Filestack handles
  • Add timeout to upload method options

0.9.1 (2017-08-30)

Picker changes

  • Fix bug with customSourcePath on store and link calls
  • Implement disableStorageKey option to remove prefixes on stored files
  • Remove all argument mutation from the config parser

0.9.0 (2017-08-24)

Picker changes

  • Convert originalFile in metadata from File to object
  • Add onOpen and onUploadStarted callback options
  • Fix cloud folder fetching to ensure entire folder selection
  • Implement a fix for third-party cookie issues

0.8.5 (2017-08-21)

Picker changes

  • Put filename back into originalPath

0.8.4 (2017-08-18)

  • Add cname option to init wrapper

0.8.3 (2017-08-18)

Picker changes

  • Fix issue with originalPath for cloud folders not being human readable

Client changes

  • Implement cname option in filestack.init
  • Add option to enable/disable intelligent ingestion uploads
  • Fix issues with how upload progress is reported

0.8.2 (2017-08-14)

  • Force picker script URL to use HTTPS protocol

0.8.1 (2017-08-04)

Picker changes

  • Implement audio and video sources
  • Add videoResolution option for video source
  • Fix CSS bugs on iOS 8 Safari
  • Fix bug with cloud file selection/deselection

Client changes

  • Uploads will no longer retry on HTTP 4xx responses

0.8.0 (2017-07-26)

Picker changes

  • Fix typos in various languages including Italian and Danish
  • Add Hebrew language as he
  • Cancel uploads when the pick modal is closed (via close button or ESC key)
  • Convert all image transformations to run on the client
  • Implement force crop flow

New pick options

  • imageMax -- set maximum dimensions for client-side image resizing
  • imageMin -- set minimum dimensions for client-side image resizing
  • imageDim -- set dimensions for client-side image resizing
  • rejectOnCancel -- reject the Promise returned by pick on user cancel
  • transformations.crop.force -- force all images to be cropped before uploading
  • transformations.rotate -- enable/disable image rotation
  • transformations.circle -- enable/disable image circle crop

Deprecated pick options

As of 0.8.0 the following options are no longer supported:

  • transformations.maxDimensions -- Replaced by imageMax
  • transformations.minDimensions -- Replaced by imageMin
  • transformations.crop.circle -- Replaced by transformations.circle
  • transformations.filters -- These are now gone, for now

Client changes

  • upload will now accept a base64 encoded string which it will convert to a Blob.
  • Added new transform option output for file conversion URL generation

0.7.1 (2017-07-10)

Picker fixes

  • Fix bug with broken URL upload when security is enabled

0.7.0 (2017-07-03)

Picker changes

  • Cloud folder UX and interface have been overhauled
  • Implemented Filestack whitelabel account feature (disable brand footer)
  • Add new screen for blocked applications
  • Add new option disableThumbnails to remove local file thumbnails for performance increase
  • Add new sources url and customsource (plus customSourcePath and customSourceContainer options)
  • Various style updates
  • Bug fixes including removing a TypeError on extension checking

Client changes

  • Fix module loader breaking in Node environments
  • Fix memory leak in multi-part uploader
  • Abort multi-part uploads if ETag header does not exist on first chunk response

Breaking changes

  • Polyfills have been removed from the distributable. Please see the readme section Promises
  • fsp-button-auth is now fsp-button--auth

0.6.3 (2017-05-30)

Picker changes

  • Fix bug with file upload progress related to background uploads
  • Fix issue with crop overlay dimensions being set incorrectly

0.6.2 (2017-05-26)

Picker changes

  • Fix multiple file selection bug on mobile
  • Fix bug where uploadInBackground: false was not respecting storeTo options
  • Change crop selection area to behave more like a mask
  • Fix issue when picker is loaded alongside a global Vue/Vuex instance

0.6.1 (2017-05-22)

  • Add token parameter to upload method

0.6.0 (2017-05-10)

Picker changes

  • Implement webcam source for taking pictures
  • Remove sidebar pagination, implement sidebar scrolling
  • Fix performance issue in summary screen related to thumbnails
  • Implement onClose callback
  • Add new field originalPath to file data returned from pick

Breaking changes

  • The multi-part upload method was rewritten. Options to this method have slightly changed.
  • The signature of progress events has also changed, please see the readme.

0.5.2 (2017-04-20)

  • Fix one more transformations regression (sorry folks)

0.5.1 (2017-04-17)

  • Fix transformations regression with security enabled

0.5.0 (2017-04-17)

  • Implement single file/image flow in picker
  • Add translations for sidebar sources
  • Add Japanese locale
  • Add missing mimetypes to accept option
  • Fix grid style issue in Windows 10
  • General style changes, e.g. close button has been moved into the modal
  • Implemented several fixes for IE11
  • Breaking changes: pick option transformOptions changed to transformations. See README

0.4.2 (2017-03-25)

  • Fix regression with summary screen images
  • Add Danish language support

0.4.1 (2017-03-22)

  • Same as 0.4.0 - last release didn't include new bundle

0.4.0 (2017-03-22)

  • Fix folder dragging in Chrome and Firefox
  • Add ability to drag images from the web in Chrome and Firefox
  • Fix bug where cloud logout prevented subsequent logins
  • Add international language support
  • Add S3 key and container to returned file metadata
  • Breaking change: Rename name to filename in returned file metadata from pick

0.3.2 (2017-03-19)

  • Update transformer UI styles
  • Return unaltered source URL from transform when no options exist

0.3.1 (2017-03-15)

  • Add correct handle to storeURL response

0.3.0 (2017-03-14)

  • Add file size and upload progress in bytes to local files on summary screen
  • Fix issue where edited images have no transformations
  • Add behavior to show summary when maxFiles is reached
  • Remove autofocus from image-search input
  • Fix bug with security on process URLs
  • Add missing region parameter to storeURL
  • Throttle XHR events for performance gain
  • Reduce bundle size by about 100KB

0.2.1 (2017-03-08)

  • Expose getSecurity and setSecurity methods
  • Fix drag and drop bug due to variable screen size
  • Mobile style fixes
  • Fix renaming via onFileSelected for local files

0.2.0 (2017-03-06)

  • Change picker dependency to npm tarball

0.1.12 (2017-03-02)

  • Bump picker to 0.2.12

0.1.11 (2017-03-02)

  • Bump picker to 0.2.11, client to 0.2.1

0.1.10 (2017-03-01)

  • Bump picker to 0.2.10

0.1.9 (2017-03-01)

  • Bump client to 0.2.0

0.1.8 (2017-03-01)

  • Bump picker to 0.2.9
  • Add repository to package.json

0.1.7 (2017-03-01)

  • Bump picker to 0.2.8, client to 0.1.3

0.1.6 (2017-02-27)

  • Include new client in the bundle

0.1.5 (2017-02-27)

  • Bump picker to 0.2.7, client to 0.1.2
  • Fix typo in readme

0.1.4 (2017-02-26)

  • Bump picker to 0.2.6

0.1.3 (2017-02-26)

  • Update API methods
  • Bump picker to 0.2.5

0.1.2 (2017-02-25)

  • Bump picker to 0.2.4

0.1.1 (2017-02-25)

  • Bump to latest picker and client
  • Update to new security interface

0.1.0 (2017-02-24)

  • Bump picker to 0.2.1, api-client to 0.0.17
  • Add protocol agnostic picker URL

0.0.8 (2017-02-16)

  • Bump picker to 0.1.8, api-client to 0.0.16

0.0.7 (2017-02-13)

  • Return loader Promise instance from pick

0.0.6 (2017-02-12)

  • Pin picker version and bump to 0.1.7

0.0.5 (2017-02-12)

  • Bump api-client to 0.0.14

0.0.4 (2017-02-12)

  • Update readme
  • Bump api-client to 0.0.12

0.0.3 (2017-02-11)

  • Fix S3 bucket name

0.0.2 (2017-02-11)

  • Update api-client to 0.0.11
  • Update interfaces, build configs, envs, and readme

0.0.1 (2016-12-27)

  • Initial release