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

file-dropzone

Package Overview
Dependencies
Maintainers
1
Versions
9
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

file-dropzone

Drop files anywhere on your web page. Based on jQuery.

  • 1.0.9
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
37
increased by105.56%
Maintainers
1
Weekly downloads
 
Created
Source

file-dropzone

A simple lightweight file dropzone component based on jQuery. You can easily make any existing element become a dropzone that holds files.

var myDropzone = new FileDropzone({
  target: '#box',
  fileHoverClass: 'entered',
  clickable: true,
  multiple: true,
  forceReplace: false,
  paramName: 'my-file',
  accept: '',
  onChange: function () {
    var files = this.getFiles()
    var elem = this.element
    elem.empty()
    files.forEach(function (item) {
      elem.append('<div class="file-name">' + item.name + '</div>')
    })
  },
  onEnter: function () {
    console.log('enter')
  },
  onLeave: function () {
    console.log('leave')
  },
  onHover: function () {
    console.log('hover')
  },
  onDrop: function () {
    console.log('drop')
  },
  onInvalid: function (files) {
    console.log('file invalid')
    console.log(files)
  },
  beforeAdd: function () {
    return true
  }
})

Construtor

// method 1
var options = {}
new FileDropzone($('#container'), options)

// method 2
var options = { target: '#container' }
new FileDropzone(options)

Options

optiontypeexplaindefault
targetstringcss selector string. specifies which element you want to be a dropzone
fileHoverClassstringclass name that will be added to target element when file dragged over it'dropzone--file-hover'
clickablebooleanwhether the file choosing window will pop up when target element is clickedtrue
multiplebooleanwhether the dropzone can hold multiple filestrue
noFolderbooleanwhether to filter out folders when droppingtrue
uniquebooleanwhether to ignore duplicate files when addingfalse
forceReplacebooleanwhether to replace the existing file list when adding. If set to false, new files will append to the listfalse
acceptstringmimetype or file extensions separated by comma to specify a certain types of files the dropzone accepts
capturebooleansame as input[type=file] element's capture attributetrue
paramNamestringsame as input[type=file] element's name attribute'file'
onChangefunctioncalled when file list length changed
onEnterfunctioncalled when file dragged enters the target element. accepts 1 argument which is native dragenter event object.
onLeavefunctioncalled when file dragged leaves the target element. accepts 1 argument which is native dragleave event object.
onHoverfunctioncalled when file dragged moves on the target element. accepts 1 argument which is native dragover event object.
onDropfunctioncalled when file dropped into to target element. accepts 1 argument which is native drop event object.
onFolderFoundfunctioncalled when on or more folders found among the files user chooses. accepts 1 argument which is an array of the folders (they are also File objects).
onInvalidfunctioncalled when invalid type files found among the files user chooses. accepts 1 argument which is an array of the spotted invalid files.
beforeAddfunctioncalled right before adding new files to the list. accepts 1 argument which is an array of the valid files that are about to be added to the list. If the function return false, the adding action will be stopped.

Methods

getFiles()
  • Returns an array of files (File object) which are currently in the dropzone.
removeFile(foo)
  • args:
    • foo: (File object or Number) if foo is a file which is already in the file list, it will be removed from the list. If foo is a number, the number indicates the index of file that will be removed.
  • Returns the removed file if it is removed successfully, otherwise returns null.
pop()
  • This method tries to remove the last file from the current file list.
  • Returns the removed file or null if the list is empty.
shift()
  • This method tries to remove the first file from the current file list.
  • Returns the removed file or null if the list is empty.
clearAll()
  • This method tries to clear the current file list ,making it an empty array.
openFileChooser()
  • This method programmatically opens the file choosing window of os for user to add files.
disable()
  • This method disables click and drag&drop to prevent file adding, which is enabled by default.
enable()
  • This method does the opposite to disable().
disableClick()
  • This method prevent file choosing window of os to pop up on click, which is enabled by default.
enableClick()
  • This method does the opposite to disableClick().
static getFileSize(file, unit)
  • args:
    • file: (File object) the file whose size you want to get.
    • unit: specifies the unit. It should be one of these: b, kb, mb, gb, tb.
  • Returns file size (Number) in the unit specified.
  • This is a static method. You should call it on the FileDropzone constructor.
var file = myDropzone.getFiles()[0]
var size = FileDropzone.getFileSize(file, 'mb')

Keywords

FAQs

Package last updated on 05 Jul 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

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