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

react-file-uploader

Package Overview
Dependencies
Maintainers
1
Versions
15
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-file-uploader

A set of file-upload-components with React.js.

  • 0.2.2
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

react-file-uploader

react-file-uploader is a set of components written in React.js which helps you to upload file easily. You can check out the LIVE DEMO here.

Installation

To install:

npm install --save react-file-uploader

Documentation

this module currently contains 4 major entities, which are

  1. Receiver
  2. UploadManager
  3. UploadHandler
  4. File Status

Receiver

Receiver helps you to manage file upload triggered by Drag and Drop. Once you mounted the Receiver component, the Drag and Drop function will be enabled.

import { Receiver } from 'react-file-uploader';

<Receiver
	customClass={CLASS_STRING_OR_ARRAY}
	style={STYLE_OBJECT}
	isOpen={BOOLEAN}
	onDragEnter={FUNCTION}
	onDragOver={FUNCTION}
	onDragLeave={FUNCTION}
	onFileDrop={FUNCTION} >
	<div>
		visual layer of the receiver (drag & drop panel)
	</div>
</Receiver>
Props
  • customClass - string | array: the class name(s) for the div wrapper
  • style - object: the style for the div wrapper
  • isOpen - boolean required: it enables you to control in the parent component whether the Receiver is opened.
  • onDragEnter - function required: this will be fired with the window event of onDragEnter once only when isOpen is false.
// @param e Object DragEnter Event
function onDragEnter(e) {
	// your codes here
}
  • onDragOver - function: this will be fired with the window event of onDragOver.
// @param e Object DragOver Event
function onDragOver(e) {
	// your codes here
}
  • onDragLeave - function required: this will be fired with the window event of onDragLeave once only when the drag event entirely left the client (i.e. dragLevel == 0).
// @param e Object DragLeave Event
function onDragLeave(e) {
	// your codes here
}
  • onFileDrop - function required: this will be fired with the window event of drop. You may execute any validation / checking process here i.e. size, file type, etc.
// @param target Object the target node of the drop event
// @param files Array the files dropped on the target node
function onFileDrop(target, files) {
	// your codes here
}

UploadManager

Upload Manager serves as a high order component which helps you to manage the upload related parameters and functions. It prepares the upload logic with superagent for the UploadHandler as its children, and helps you to update the lifecycle status of the uploading files.

**IMPORTANT: this high order component serves only for ** UploadHandler

import { UploadManager } from 'react-file-uploader';

<UploadManager
	customClass={CLASS_STRING_OR_ARRAY}
	style={STYLE_OBJECT}
	files={FILES_OJBECT_ARRAY}
	uploadUrl={UPLOAD_API_END_POINT_STRING}
	onUpload={FUNCTION}
	onUploadProgress={FUNCTION}
	onUploadEnd={FUNCTION} >
	
	// UploadHandler as children
	<UploadHandle file={FILE_OBJECT} autoStart={BOOLEAN} />
	
</UploadManager>
Props
  • customClass - string | array: the class name(s) for the div wrapper
  • style - object: the style for the div wrapper
  • files - array: the array of files object that are uploaded / going to be uploaded to be shown in the file list.
  • uploadUrl - string required: the url of the upload end point from your server.
  • onUploadStart - function: this will be fired when the POST request is just sent.
// @param file Object the file object returned with UPLOADING status and 0% progress.
function onUploadStart(file) {
	// your codes here
}
  • onUploadProgress - function: this will be fired when the POST request returns progress.
// @param file Object the file object returned with UPLOADING status and n% progress.
function onUploadProgress(file) {
	// your codes here
}
  • onUploadEnd - function required: this will be fired upon the end of POST request.
// @param file Object the file object returned with either UPLOADED status and 100% progress
// or FAILED status, 0% progress and error reason.
function onUploadEnd(file) {
	// your codes here
}

UploadHandler

Upload Handler helps you to execute the upload lifecycle, which is start, progress and end. It also acts as the presentation layer of a file, showing users the info of the uploading / uploaded file.

import { UploadHandler } from 'react-file-uploader';

<UploadHandler
	customClass={CLASS_STRING_OR_ARRAY}
	style={STYLE_OBJECT}
	file={FILE_OBJECT}
	autoStart={BOOLEAN}
	upload={UPLOAD_FUNCTION} />
Props
  • customClass - string | array: the class name(s) for the div wrapper

  • style - object: the style for the div wrapper

  • file - object required: the file object that is uploaded / going to be uploaded.

  • autoStart - boolean: when autoStart is set to true, upon the UploadHandler component did mount, it will detect if the file i.e. as props is with the PENDING status and initialise a POST request which is sent to the uploadUrl you passed to the UploadManager.

  • upload - function: the function that contains the upload logic, you may pass it directly when you are using UploadHandler alone, or it could be prepared by UploadManager.

// @param url String API upload end point
// @param file Object File Object
function upload(url, file) {
	// your codes here
}

File Status

react-file-uploader defines a set of status constants to represent the file status. The corresponding status will be assign to a file object throughout the uploading life cycle.

FAILED = -1
PEDNING = 0
UPLOADING = 1
UPLOADED = 2

TODOs

  • add test cases
  • add example
  • support optional data, i.e. custom image name and destination

License

MIT

Keywords

FAQs

Package last updated on 22 Nov 2015

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