UNPKG

filestack-js

Version:

Official JavaScript library for Filestack

150 lines (148 loc) 42.4 kB
/* * Copyright (c) 2018 by Filestack * Some rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { __awaiter, __generator } from "tslib"; import { loadModule, FILESTACK_MODULES } from '@filestack/loader'; import { FilestackError, FilestackErrorType } from './../filestack_error'; import { getValidator, PickerParamsSchema } from './../schema'; export var RotateDirection; (function (RotateDirection) { RotateDirection["cw"] = "CW"; RotateDirection["ccw"] = "CCW"; })(RotateDirection || (RotateDirection = {})); export var PickerDisplayMode; (function (PickerDisplayMode) { PickerDisplayMode["inline"] = "inline"; PickerDisplayMode["overlay"] = "overlay"; PickerDisplayMode["dropPane"] = "dropPane"; })(PickerDisplayMode || (PickerDisplayMode = {})); /** * @private * A synchronous-looking wrapper for loading the picker and calling its methods. * This is currently needed because the picker module is loaded asynchronously. * Eventually we should offer a bundle with the picker module included. */ var PickerLoader = /** @class */ (function () { function PickerLoader(client, options) { var validateRes = getValidator(PickerParamsSchema)(options); if (validateRes.errors.length) { validateRes.errors.forEach(function (error) { if (error.path.includes('fromSources')) { console.warn("Warning: Invalid source \"".concat(error.instance, "\" found and removed!")); options.fromSources = options.fromSources.filter(function (source) { return source !== error.instance; }); } else { throw new FilestackError("Invalid picker params", validateRes.errors, FilestackErrorType.VALIDATION); } }); if (!options.fromSources.length) { delete options.fromSources; } } this._initialized = this.loadModule(client, options); } PickerLoader.prototype.open = function () { return __awaiter(this, void 0, void 0, function () { var picker; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._initialized]; case 1: picker = _a.sent(); return [4 /*yield*/, picker.open()]; case 2: _a.sent(); return [2 /*return*/]; } }); }); }; PickerLoader.prototype.crop = function (files) { return __awaiter(this, void 0, void 0, function () { var picker; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._initialized]; case 1: picker = _a.sent(); return [4 /*yield*/, picker.crop(files)]; case 2: _a.sent(); return [2 /*return*/]; } }); }); }; PickerLoader.prototype.close = function () { return __awaiter(this, void 0, void 0, function () { var picker; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._initialized]; case 1: picker = _a.sent(); return [4 /*yield*/, picker.close()]; case 2: _a.sent(); return [2 /*return*/]; } }); }); }; PickerLoader.prototype.cancel = function () { return __awaiter(this, void 0, void 0, function () { var picker; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._initialized]; case 1: picker = _a.sent(); return [4 /*yield*/, picker.cancel()]; case 2: _a.sent(); return [2 /*return*/]; } }); }); }; PickerLoader.prototype.loadModule = function (client, options) { return __awaiter(this, void 0, void 0, function () { var url, Picker; return __generator(this, function (_a) { switch (_a.label) { case 0: url = client.session.urls.pickerUrl; return [4 /*yield*/, loadModule(FILESTACK_MODULES.PICKER, url)]; case 1: Picker = _a.sent(); return [2 /*return*/, new Picker(client, options)]; } }); }); }; return PickerLoader; }()); /** * Loads and creates picker instance * * @private * @param client * @param options */ export var picker = function (client, options) { return new PickerLoader(client, options); }; //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/picker.ts"],"names":[],"mappings":"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","file":"lib/picker.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { loadModule, FILESTACK_MODULES } from '@filestack/loader';\nimport { FilestackError, FilestackErrorType } from './../filestack_error';\nimport { Client } from './client';\nimport { FSProgressEvent, UploadOptions, WorkflowConfig } from './api/upload/types';\nimport { getValidator, PickerParamsSchema } from './../schema';\n\nexport interface PickerInstance {\n  /**\n   * Close picker. This operation is idempotent.\n   */\n  close: () => Promise<void>;\n\n  /**\n   * Cancel picker uploads. This operation is idempotent.\n   */\n  cancel: () => Promise<void>;\n\n  /**\n   * Open picker. This operation is idempotent.\n   */\n  open: () => Promise<void>;\n\n  /**\n   * Specify a list of files to open in the picker for cropping\n   *\n   * ### Example\n   *\n   * ```js\n   * // <input id=\"fileSelect\" type=\"file\">\n   *\n   * const inputEl = document.getElementById('fileSelect');\n   * const picker = client.picker({\n   *   onUploadDone: res => console.log(res),\n   * });\n   *\n   * inputEl.addEventListener('change', (e) => {\n   *   picker.crop(e.target.files);\n   * });\n   *\n   * // Or pass an array of URL strings\n   * const urls = [\n   *   'https://d1wtqaffaaj63z.cloudfront.net/images/fox_in_forest1.jpg',\n   *   'https://d1wtqaffaaj63z.cloudfront.net/images/sail.jpg',\n   * ];\n   * picker.crop(urls);\n   * ```\n   */\n  crop: (files: any[]) => Promise<void>;\n}\n\nexport interface PickerCroppedData {\n  cropArea: {\n    /**\n     * [x, y]\n     */\n    position: [number, number];\n    /**\n     * [width, height]\n     */\n    size: [number, number];\n  };\n    /**\n     * [width, height]\n     */\n  originalImageSize: [number, number];\n}\n\nexport enum RotateDirection {\n  cw = 'CW',\n  ccw= 'CCW',\n}\n\nexport interface PickerRotatedData {\n  /**\n   * Amount rotated in degrees.\n   */\n  value: number;\n  /**\n   * Can be CW or CCW (clockwise / counter-clockwise)\n   */\n  direction: RotateDirection;\n}\n\nexport interface PickerFileMetadata {\n  /**\n   * The cloud container for the uploaded file.\n   */\n  container?: string;\n  /**\n   * Position and size information for cropped images.\n   */\n  cropped?: PickerCroppedData;\n  /**\n   * Name of the file.\n   */\n  filename: string;\n  /**\n   * Filestack handle for the uploaded file.\n   */\n  handle: string;\n  /**\n   * The hash-prefixed cloud storage path.\n   */\n  key?: string;\n  /**\n   * The MIME type of the file.\n   */\n  mimetype: string;\n  /**\n   * Properties of the local binary file. Also see the pick option `exposeOriginalFile` if you want the underlying `File` object.\n   */\n  originalFile?: object | File;\n  /**\n   * The origin of the file, e.g. /Folder/file.jpg.\n   */\n  originalPath: string;\n  /**\n   * Direction and value information for rotated images.\n   */\n  rotated?: PickerRotatedData;\n  /**\n   * Size in bytes of the uploaded file.\n   */\n  size: number;\n  /**\n   * The source from where the file was picked.\n   */\n  source: string;\n  /**\n   * Indicates Filestack transit status.\n   */\n  status?: string;\n  /**\n   * A uuid for tracking this file in callbacks.\n   */\n  uploadId: string;\n  /**\n   * The Filestack CDN URL for the uploaded file.\n   */\n  url: string;\n  /**\n   * Alt text for images\n   */\n  alt: string;\n}\n\nexport interface CustomAuthTextOptions {\n  [key: string]: {\n    top?: string[],\n    bottom?: string[]\n  };\n}\n\nexport interface PickerResponse {\n  filesUploaded: PickerFileMetadata[];\n  filesFailed: PickerFileMetadata[];\n}\n\nexport interface PickerFileCallback {\n  (file: PickerFileMetadata): void | Promise<any>;\n}\nexport interface PickerFileWithTokenCallback {\n  (file: PickerFileMetadata, token?: {pause?: () => void, resume?: () => void, cancel?: () => void}): void | Promise<any>;\n}\n\nexport interface PickerFileCancelCallback {\n  (file: PickerFileMetadata): void;\n}\n\nexport interface PickerFileErrorCallback {\n  (file: PickerFileMetadata, error: Error): void;\n}\n\nexport interface PickerFileProgressCallback {\n  (file: PickerFileMetadata, event: FSProgressEvent): void;\n}\n\nexport interface PickerUploadStartedCallback {\n  (files: PickerFileMetadata[]): void;\n}\n\nexport interface PickerUploadDoneCallback {\n  (files: PickerResponse): void;\n}\n\nexport enum PickerDisplayMode {\n  inline = 'inline',\n  overlay = 'overlay',\n  dropPane = 'dropPane',\n}\n\nexport interface PickerDropPaneOptions {\n  /**\n   * Toggle the crop UI for dropped files.\n   */\n  cropFiles?: boolean;\n  /**\n   * Customize the text content in the drop pane.\n   */\n  customText?: string;\n  /**\n   * Disable the file input on click. This does not disable the `onClick` callback.\n   */\n  disableClick?: boolean;\n  /**\n   * Toggle the full-page drop zone overlay.\n   */\n  overlay?: boolean;\n  onDragEnter?: (evt: DragEvent) => void;\n  onDragLeave?: () => void;\n  onDragOver?: (evt: DragEvent) => void;\n  onDrop?: (evt: DragEvent) => void;\n  /**\n   * `onSuccess` must be used instead of `onUploadDone`. The drop pane uses its own callbacks for compatibility purposes. This might eventually change.\n   */\n  onSuccess?: (files: PickerFileMetadata[]) => void;\n  onError?: (files: PickerFileMetadata[]) => void;\n  onProgress?: (percent: number) => void;\n  onClick?: (evt: any) => void;\n  /**\n   * Toggle icon element in drop pane.\n   */\n  showIcon?: boolean;\n  /**\n   * Toggle upload progress display.\n   */\n  showProgress?: boolean;\n}\n\nexport interface PickerStoreOptions {\n  /**\n   * Location for stored file. One of 's3', 'gcs', 'azure', 'rackspace', or 'dropbox'.\n   */\n  location?: string;\n  /**\n   * Specify storage container.\n   */\n  container?: string;\n  /**\n   * Set container path. Indicate a folder by adding a trailing slash. Without a trailing slash all files will be stored to the same object.\n   */\n  path?: string;\n  /**\n   * Specify S3 region.\n   */\n  region?: string;\n  /**\n   * S3 container access. 'public' or 'private'.\n   */\n  access?: string;\n\n  /**\n   * Workflows ids to run after upload\n   */\n  workflows?: string[] | WorkflowConfig[];\n}\n\nexport interface PickerCustomText {\n  // Actions\n  Upload?: string;\n  'Upload more'?: string;\n  'Deselect All'?: string;\n  'View/Edit Selected'?: string;\n  'Sign Out'?: string;\n\n  // Source Labels\n  'My Device'?: string;\n  'Web Search'?: string;\n  'Take Photo'?: string;\n  'Link (URL)'?: string;\n  'Record Video'?: string;\n  'Record Audio'?: string;\n\n  // Custom Source\n  'Custom Source'?: string;\n\n  // Footer Text\n  Add?: string;\n  'more file'?: string;\n  'more files'?: string;\n\n  // Cloud\n  'Connect {providerName}'?: string;\n  'Select Files from {providerName}'?: string;\n  'You need to authenticate with {providerName}.'?: string;\n  'A new page will open to connect your account.'?: string;\n  'We only extract images and never modify or delete them.'?: string;\n  'To disconnect from {providerName} click \"Sign out\" button in the menu.'?: string;\n  'Sign in with Google'?: string;\n  'Go back'?: string;\n  'This folder is empty.'?: string;\n\n  // Summary\n  Files?: string;\n  Images?: string;\n  Uploaded?: string;\n  Uploading?: string;\n  Completed?: string;\n  Filter?: string;\n  'Cropped Images'?: string;\n  'Edited Images'?: string;\n  'Selected Files'?: string;\n  'Crop is required on images'?: string;\n\n  // Transform\n  Crop?: string;\n  Circle?: string;\n  Rotate?: string;\n  Mask?: string;\n  Revert?: string;\n  Edit?: string;\n  Reset?: string;\n  Done?: string;\n  Save?: string;\n  Next?: string;\n  'Edit Image'?: string;\n  'This image cannot be edited'?: string;\n\n  // Retry messaging\n  'Connection Lost'?: string;\n  'Failed While Uploading'?: string;\n  'Retrying in'?: string;\n  'Try again'?: string;\n  'Try now'?: string;\n\n  // Local File Source\n  'Drag and Drop, Copy and Paste Files'?: string;\n  'or Drag and Drop, Copy and Paste Files'?: string;\n  'Select Files to Upload'?: string;\n  'Select From'?: string;\n  'Drop your files anywhere'?: string;\n\n  // Input placeholders\n  'Enter a URL'?: string;\n  'Search images'?: string;\n\n  // Webcam Source\n  'Webcam Disabled'?: string;\n  'Webcam Not Supported'?: string;\n  'Please enable your webcam to take a photo.'?: string;\n  'Your current browser does not support webcam functionality.'?: string;\n  'We suggest using Chrome or Firefox.'?: string;\n\n  // Error Notifications\n  'File {displayName} is not an accepted file type. The accepted file types are {types}'?: string;\n  'File {displayName} is too big. The accepted file size is less than {roundFileSize}'?: string;\n  'Our file upload limit is {maxFiles} {filesText}'?: string;\n  'No search results found for \"{search}\"'?: string;\n  'An error occurred. Please try again.'?: string;\n}\n\nexport interface PickerOptions {\n  /**\n   * Restrict file types that are allowed to be picked. Formats accepted:\n   *  - .pdf <- any file extension\n   *  - image/jpeg <- any mime type commonly known by browsers\n   *  - image/* <- accept all types of images\n   *  - video/* <- accept all types of video files\n   *  - audio/* <- accept all types of audio files\n   *  - application/* <- accept all types of application files\n   *  - text/* <- accept all types of text files\n   */\n  accept?: string | string[];\n  /**\n   * Custom accept check function\n   * ```javascript\n   * acceptFn: (file, options) => {\n   *  return options.mimeFromMagicBytes(file.originalFile).then((res) => { // we can check mimetype from magic bytes\n   *    //console.log(options.mimeFromExtension(file.originalFile.name)); // or check extension from filestack extensions database\n   *    // throw new Error('Cannot accept that file') // we can throw exception to block file upload\n   *    // return Promise.reject('Cannot accept that file'') // or reject a promise\n   *    return Promise.resolve();\n   *  });\n   * }\n   * ```\n   */\n  acceptFn?: (PickerFileMetadata, PickerAcceptFnOptions) => Promise<string>;\n  /**\n   * Prevent modal close on upload failure and allow users to retry.\n   */\n  allowManualRetry?: boolean;\n  /**\n   *  Valid sources are:\n   *  - local_file_system - Default\n   *  - url - Default\n   *  - imagesearch - Default\n   *  - facebook - Default\n   *  - instagram - Default\n   *  - googledrive - Default\n   *  - dropbox - Default\n   *  - webcam - Uses device menu on mobile. Not currently supported in Safari and IE.\n   *  - video - Uses device menu on mobile. Not currently supported in Safari and IE.\n   *  - audio - Uses device menu on mobile. Not currently supported in Safari and IE.\n   *  - box\n   *  - github\n   *  - gmail\n   *  - googlephotos\n   *  - onedrive\n   *  - onedriveforbusiness\n   *  - customsource - Configure this in your Filestack Dev Portal.\n   *  - unsplash\n   */\n  fromSources?: string[];\n  /**\n   * Provide default text value for Image Search\n   * ```javascript\n   * websearch: {\n   *  predefinedText: 'Sample text'\n   * }\n   * ```\n   */\n  websearch?: object;\n  /**\n   * Container where picker should be appended. Only relevant for `inline` and `dropPane` display modes.\n   */\n  container?: string | Node;\n\n  /**\n   * Turn on cleaning JPEG image exif. Method can keep image orientation or color profiles\n   * ```javascript\n   * cleanupImageExif: {\n   *   keepOrientation: true\n   *   keepICCandAPP: true\n   * }\n   * ```\n   */\n  cleanupImageExif?: boolean | {\n    keepOrientation?: boolean,\n    keepICCandAPP?: boolean\n  };\n  /**\n   * Customize the text on the cloud authentication screen in Picker.\n   * Use a cloud source name (see {@link PickerOptions.fromSources})\n   * or a 'default' as a key, then put your custom notice or consent\n   * to the 'top' or the 'bottom' key to show it respectivly above or under 'Connect button'.\n   *\n   * ```javascript\n   * customAuthText: {\n   *   // use it for every cloud authentication screen\n   *   default: {\n   *     top: [\n   *       'default top first line',\n   *       'default top second line'\n   *     ],\n   *     bottom: [\n   *       'default bottom first line',\n   *       'default bottom second line'\n   *     ]\n   *   },\n   *   // override a default bottom text for only gmail\n   *   gmail: {\n   *     bottom: [\n   *       'We need your permission to access your data and',\n   *       'process it with our machine learning system.'\n   *     ]\n   *   }\n   * }\n   * ```\n   */\n  customAuthText?: CustomAuthTextOptions;\n  /**\n   * Picker display mode, one of `'inline'`, `'overlay'`, `'dropPane'` - default is `'overlay'`.\n   */\n  displayMode?: PickerDisplayMode;\n  /**\n   * Max number of files to upload concurrently. Default is 4.\n   */\n  concurrency?: number;\n  /**\n   * Set the default container for your custom source.\n   */\n  customSourceContainer?: string;\n  /**\n   * Set the default path for your custom source container.\n   */\n  customSourcePath?: string;\n  /**\n   * Set the display name for the custom source.\n   */\n  customSourceName?: string;\n  /**\n   * Provide an object for mapping picker strings to your own strings.\n   * Strings surrounded by brackets, `{ foobar }`, are interpolated with runtime values.\n   * Source labels are also available to override, e.g. Facebook, Instagram, Dropbox, etc.\n   */\n  customText?: PickerCustomText;\n  /**\n   * set support email to display in case of error\n   */\n  supportEmail?: string;\n  /**\n   * When true removes the hash prefix on stored files.\n   */\n  disableStorageKey?: boolean;\n  /**\n   * When true removes ability to edit images.\n   */\n  disableTransformer?: boolean;\n  /**\n   * Disables alt text view/edit in the summary screen.\n   */\n  disableAltText?: boolean;\n  /**\n   * Disables local image thumbnail previews in the summary screen.\n   */\n  disableThumbnails?: boolean;\n  /**\n   * Configure the drop pane behavior, i.e. when `displayMode` is `dropPane`.\n   */\n  dropPane?: PickerDropPaneOptions;\n  /**\n   * When true the `originalFile` metadata will be the actual `File` object instead of a POJO\n   */\n  exposeOriginalFile?: boolean;\n  /**\n   * Toggle the drop zone to be active on all views. Default is active only on local file source.\n   */\n  globalDropZone?: boolean;\n  /**\n   * Hide the picker modal UI once uploading begins. Defaults to `false`.\n   */\n  hideModalWhenUploading?: boolean;\n\n  /**\n   * Specify image dimensions. e.g. [800, 600]. Only for JPEG, PNG, and BMP files.\n   * Local and cropped images will be resized (upscaled or downscaled) to the specified dimensions before uploading.\n   * The original height to width ratio is maintained. To resize all images based on the width, set [width, null], e.g. [800, null].\n   * For the height set [null, height], e.g. [null, 600].\n   */\n  imageDim?: [number, number];\n  /**\n   * Specify maximum image dimensions. e.g. [800, 600]. Only for JPEG, PNG, and BMP files.\n   * Images bigger than the specified dimensions will be resized to the maximum size while maintaining the original aspect ratio.\n   * The output will not be exactly 800x600 unless the imageMax matches the aspect ratio of the original image.\n   */\n  imageMax?: [number, number];\n  /**\n   * Specify minimum image dimensions. e.g. [800, 600]. Only for JPEG, PNG, and BMP files.\n   * Images smaller than the specified dimensions will be upscaled to the minimum size while maintaining the original aspect ratio.\n   * The output will not be exactly 800x600 unless the imageMin matches the aspect ratio of the original image.\n   */\n  imageMin?: [number, number];\n  /**\n   * Sets locale. Accepts: ca, da, de, en, es, fr, he, it, ja, ko, nl, no, pl, pt, sv, ru, vi, zh, tr\n   */\n  lang?: string;\n  /**\n   * Minimum number of files required to start uploading. Defaults to 1.\n   */\n  minFiles?: number;\n  /**\n   * Maximum number of files allowed to upload. Defaults to 1.\n   */\n  maxFiles?: number;\n  /**\n   * Restrict selected files to a maximum number of bytes. (e.g. 10 \\* 1024 \\* 1024 for 10MB limit).\n   */\n  maxSize?: number;\n\n  /**\n   * Default view type option for file browser\n   */\n  viewType?: 'grid' | 'list';\n\n  /**\n   * Timeout for error messages\n   */\n  errorsTimeout?: number;\n  /**\n   * Specify [width, height] in pixels of the desktop modal.\n   */\n  modalSize?: [number, number];\n  /**\n   * Called when all uploads in a pick are cancelled.\n   */\n  onCancel?: PickerUploadDoneCallback;\n  /**\n   * Called when the UI is exited.\n   */\n  onClose?: () => void;\n  /**\n   * Called when the UI is mounted.\n   * @param PickerInstance application handle\n   */\n  onOpen?: (handle: PickerInstance) => void;\n  /**\n   * Called whenever user selects a file.\n   * ### Example\n   *\n   * ```js\n   * // Using to veto file selection\n   * // If you throw any error in this function it will reject the file selection.\n   * // The error message will be displayed to the user as an alert.\n   * onFileSelected(file) {\n   *   if (file.size > 1000 * 1000) {\n   *     throw new Error('File too big, select something smaller than 1MB');\n   *   }\n   * }\n   *\n   * // Using to change selected file name\n   * // NOTE: This currently only works for local uploads\n   * onFileSelected(file) {\n   *   // It's important to return a new file by the end of this function.\n   *   return { ...file, name: 'foo' };\n   * }\n   * ```\n   *\n   * The callback function can also return a Promise to allow asynchronous validation logic.\n   * You can pass a file object to `resolve` for changing the file name, it will behave the same as when\n   * the file is returned from the non-async callback.\n   *\n   * ```js\n   * onFileSelected(file) {\n   *   return new Promise((resolve, reject) => {\n   *     // Do something async\n   *     resolve();\n   *     // Or reject the selection with reject()\n   *   });\n   * }\n   * ```\n   */\n  onFileSelected?: PickerFileCallback;\n  /**\n   * Called when a file upload has been canceled.\n   */\n  onFileUploadCancel?: PickerFileCancelCallback;\n  /**\n   * Called when a file begins uploading.\n   */\n  onFileUploadStarted?: PickerFileWithTokenCallback;\n  /**\n   * Called when a file is done uploading.\n   */\n  onFileUploadFinished?: PickerFileCallback;\n  /**\n   * Called when uploading a file fails.\n   */\n  onFileUploadFailed?: PickerFileErrorCallback;\n  /**\n   * Called during multi-part upload progress events. Local files only.\n   */\n  onFileUploadProgress?: PickerFileProgressCallback;\n  /**\n   * Called when file is cropped in picker\n   */\n  onFileCropped?: PickerFileCallback;\n  /**\n   * Called when uploading starts (user initiates uploading).\n   */\n  onUploadStarted?: PickerUploadStartedCallback;\n  /**\n   * Called when all files have been uploaded.\n   */\n  onUploadDone?: PickerUploadDoneCallback;\n\n  /**\n   * Define a unique id for the application mount point.\n   * May be useful for more advanced use cases.\n   * For example, if you wish to have more than one picker instance open at once,\n   * then each will need their own unique rootId.\n   *\n   * **Note:** This option is ignored when `displayMode` is `dropPane`.\n   */\n  rootId?: string;\n  /**\n   * Whether to start uploading automatically when maxFiles is hit. Defaults to `false`.\n   */\n  startUploadingWhenMaxFilesReached?: boolean;\n  /**\n   * Options for file storage.\n   */\n  storeTo?: PickerStoreOptions;\n  /**\n   * Specify options for images passed to the crop UI.\n   */\n  transformations?: PickerTransformationOptions;\n  /**\n   * Whether to use the new transformations UI. Defaults to `false`.\n   */\n  transformationsUI?: boolean;\n  /**\n   * Options for local file uploads.\n   */\n  uploadConfig?: UploadOptions;\n  /**\n   * Start uploading immediately on file selection. Defaults to `true`.\n   * @important The feature is can be enabled only if crop is disabled - disableTransformer: true\n   */\n  uploadInBackground?: boolean;\n  /**\n   * Sets the resolution of recorded video. One of \"320x240\", \"640x480\" or \"1280x720\". Default is `\"640x480\"`.\n   */\n  videoResolution?: string;\n  /**\n   * Use Sentry Breadcrumbs mechanism to log information about occured errors.\n   * It can override global objects like console, error etc. Defaults to `true`.\n   */\n  useSentryBreadcrumbs?: boolean;\n  /**\n   * Specify which Picker instance should respond to paste event.\n   * By default only hovered instance responds to event.\n   * @param {boolean = false} pasteToFirstInViewPort If none instance is hovered take first picker instance fully visible in viewport\n   * @param {boolean = false} pasteToFirstInstance If none instance is hovered take first picker instance that is initialized\n   * @pasteToFirstInViewPort is checked first\n   */\n  pasteMode?: {\n    pasteToFirstInViewPort?: boolean,\n    pasteToFirstInstance?: boolean\n  };\n  /**\n   * Disable/Enable possibility to upload directories.\n   */\n  disableDirectoryUpload?: boolean;\n  /**\n   * Enable/Disable Mini Uploader\n   */\n  miniUploader?: boolean;\n  /**\n   * Enable/Disable possibility to multiple file upload\n   */\n  multipleFileUpload?: boolean;\n}\n\nexport interface PickerCropOptions {\n  /**\n   * Maintain aspect ratio for crop selection. (e.g. 16/9, 800/600).\n   */\n  aspectRatio?: number;\n  /**\n   * Force all images to be cropped before uploading.\n   */\n  force?: boolean;\n}\n\nexport interface PickerTransformationOptions {\n  /**\n   * Enable crop. Defaults to `true`.\n   */\n  crop?: boolean | PickerCropOptions;\n  /**\n   * Enable circle crop. Disabled if crop.aspectRatio is defined and not 1. Converts to PNG. Defaults to `true`.\n   */\n  circle?: boolean;\n  /**\n   * Enable image rotation. Defaults to `true`.\n   */\n  rotate?: boolean;\n\n  /**\n   * Global force crop option. Can be use ie with circle\n   */\n  force?: boolean;\n}\n\nexport interface PickerAcceptFnOptions {\n  /**\n   * Provided accept string\n   */\n  accept: string[];\n  /**\n   * Accept string converted to mimetype\n   */\n  acceptMime: string[];\n  /**\n   * Mimetype based magic bytes\n   * {@link https://filestack.github.io/filestack-js/globals.html#getmimetype}\n   */\n  mimeFromMagicBytes: Promise<string>;\n  /**\n   * Mimetype based on file extension\n   * {@link https://filestack.github.io/filestack-js/globals.html#extensiontomime}\n   */\n  mimeFromExtension: string;\n}\n\n/**\n * @private\n * A synchronous-looking wrapper for loading the picker and calling its methods.\n * This is currently needed because the picker module is loaded asynchronously.\n * Eventually we should offer a bundle with the picker module included.\n */\nclass PickerLoader {\n\n  private _initialized: Promise<PickerInstance>;\n  constructor(client: Client, options?: PickerOptions) {\n    const validateRes = getValidator(PickerParamsSchema)(options);\n\n    if (validateRes.errors.length) {\n      validateRes.errors.forEach(error => {\n        if (error.path.includes('fromSources')) {\n          console.warn(`Warning: Invalid source \\\"${error.instance}\\\" found and removed!`);\n          options.fromSources = options.fromSources.filter(source => source !== error.instance);\n        } else {\n          throw new FilestackError(`Invalid picker params`, validateRes.errors, FilestackErrorType.VALIDATION);\n        }\n      });\n      if (!options.fromSources.length) {\n        delete options.fromSources;\n      }\n    }\n\n    this._initialized = this.loadModule(client, options);\n  }\n\n  async open(): Promise<void> {\n    const picker = await this._initialized;\n    await picker.open();\n  }\n\n  async crop(files: any[]): Promise<void> {\n    const picker = await this._initialized;\n    await picker.crop(files);\n  }\n\n  async close(): Promise<void> {\n    const picker = await this._initialized;\n    await picker.close();\n  }\n\n  async cancel(): Promise<void> {\n    const picker = await this._initialized;\n    await picker.cancel();\n  }\n\n  private async loadModule(client: Client, options?: PickerOptions): Promise<PickerInstance> {\n    const { session: { urls: { pickerUrl: url } } } = client;\n    const Picker = await loadModule(FILESTACK_MODULES.PICKER, url);\n    return new Picker(client, options);\n  }\n}\n\n/**\n * Loads and creates picker instance\n *\n * @private\n * @param client\n * @param options\n */\nexport const picker = (client: Client, options?: PickerOptions): PickerInstance => {\n  return new PickerLoader(client, options);\n};\n"]}