Skip to content

Latest commit

 

History

History
96 lines (73 loc) · 2.28 KB

README.md

File metadata and controls

96 lines (73 loc) · 2.28 KB

Example demo

React File Drag-Drop

Preview of file drag drop react component

This is frontend file dropper include axios under the hood for sending file and receiving its token. Token is used as temporary user and file identifier and is generated by backend app. For frontend component ussage is not necessary, it is just ilustrating the full concept of uploading files for app.

About full process

  • This repo contains only Frontend component (is a component trim of personal UI lib)

Example demo

Custom project file upload process

Description

The image describe simplified version of file upload handling for custom system...

This componnent helps to push file over API to backend to get tmp file token which is used to commit file using form...

Concepts
  • Just poit it to API and get result
  • Self managed component
  • Ability to cancle request in flight
  • Process indicator
  • Validate file types on drop based on "accept" input string
Other
  • Using Tailwind you can style it in your way
  • Using PurgeCss by default
  • Using functional components and hooks

Installation

  1. Clone the repo
    git clone https://github.com/damikun/React-File-DragDrop.git
  2. CD to project dir
    cd .\File-DragDropper\
  3. Restore packages
    yarn install
    
  4. Build and run demo
    yarn run start
    

Configuration API

 <FileDragDrop
   className="text-gray-600"
   accept="image/png"
   multiple={false}
   api_url="https://localhost:5001/api/Data/UploadFile"

   onSuccess={(token, response) => {
     setstate(token);
   }}

   onError={(type, message, object) => {
     window.alert(`Type: ${type}, Messagbe: ${type}, Object: ${object}`)   
     if (type === "Exception") console.log(object);
     setstate("");
   }}
 />