Coder Social home page Coder Social logo

ludea / mui2-file-dropzone Goto Github PK

View Code? Open in Web Editor NEW

This project forked from deckstar/mui-file-dropzone

1.0 0.0 1.0 8.06 MB

A Material-UI file-upload dropzone. Written in TypeScript.

License: MIT License

JavaScript 3.74% TypeScript 96.26%

mui2-file-dropzone's Introduction

material-ui-dropzone

Material-UI-dropzone is a React component using Material-UI and is based on the excellent react-dropzone library.

License All Contributors

Rebuild Dist Workflow Status Update Docs Workflow Status

npm package npm downloads

This components provide either a file-upload dropzone or a file-upload dropzone inside of a dialog.

The file-upload dropzone features some snazzy "File Allowed/Not Allowed" effects, previews and alerts.

Installation

npm install --save mui-file-dropzone

or

yarn add mui-file-dropzone

Support

mui-file-dropzone complies to the following support matrix.

version React Material-UI
4.x 17.0+ 5.x
3.x 16.8+ 4.x
2.x 15.x or 16.x 3.x or 4.x

Screenshots

This is the Dialog component:

Dialog Dialog with Previews

When you drag a file onto the dropzone, you get a neat effect:

Drag Overlay

And if you drag in a wrong type of file, you'll get yelled at:

Drag Error Overlay

N.B. This has some limitations (see here for more details).

Documentation and Examples

See https://yuvaleros.github.io/material-ui-dropzone for Documentation and Examples.

Components

DropzoneArea

This components creates the dropzone, previews and snackbar notifications without a dialog

import React, { Component } from "react";
import { DropzoneArea } from "mui-file-dropzone";

class DropzoneAreaExample extends Component {
  constructor(props) {
    super(props);
    this.state = {
      files: [],
    };
  }
  handleChange(files) {
    this.setState({
      files: files,
    });
  }
  render() {
    return <DropzoneArea onChange={this.handleChange.bind(this)} />;
  }
}

export default DropzoneAreaExample;

DropzoneDialog

This component provides the DropzoneArea inside of a MaterialUI Dialog.

import React, { Component } from "react";
import { DropzoneDialog } from "mui-file-dropzone";
import Button from "@mui/material/Button";

export default class DropzoneDialogExample extends Component {
  constructor(props) {
    super(props);
    this.state = {
      open: false,
      files: [],
    };
  }

  handleClose() {
    this.setState({
      open: false,
    });
  }

  handleSave(files) {
    //Saving files to state for further use and closing Modal.
    this.setState({
      files: files,
      open: false,
    });
  }

  handleOpen() {
    this.setState({
      open: true,
    });
  }

  render() {
    return (
      <div>
        <Button onClick={this.handleOpen.bind(this)}>Add Image</Button>
        <DropzoneDialog
          open={this.state.open}
          onSave={this.handleSave.bind(this)}
          acceptedFiles={["image/jpeg", "image/png", "image/bmp"]}
          showPreviews={true}
          maxFileSize={5000000}
          onClose={this.handleClose.bind(this)}
        />
      </div>
    );
  }
}

License

MIT

Contributors

Thanks goes to these wonderful people (emoji key):


Yuvaleros

๐Ÿค” ๐Ÿ’ป ๐ŸŽจ ๐Ÿ“– ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿšง

Mattia Panzeri

๐Ÿค” ๐Ÿ’ป ๐ŸŽจ ๐Ÿ“– ๐Ÿ’ก ๐Ÿš‡ ๐Ÿ› ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿšง

Max Carroll

๐Ÿค” ๐Ÿ’ป ๐ŸŽจ ๐Ÿ’ก ๐Ÿ‘€

Matthew Corner

๐Ÿ› ๐Ÿค” ๐Ÿ’ป

Barry Loong

๐Ÿค” ๐Ÿ’ป

JF Blouin

๐Ÿค” ๐Ÿ’ป

Anthony Raymond

๐Ÿ’ป ๐Ÿ’ก

isaacbuckman

๐Ÿ› ๐Ÿ’ป ๐Ÿ’ก

MatthijsMud

๐Ÿ› ๐Ÿ’ป

This project follows the all-contributors specification. Contributions of any kind welcome!

mui2-file-dropzone's People

Contributors

yuvaleros avatar ludea avatar dependabot[bot] avatar panz3r avatar deckstar avatar yuvfolinks avatar loongyh avatar aheissenberger avatar arunkumarpalaniappan avatar jporsay avatar erichunzeker avatar aflatoonsingh avatar isaacbuckman avatar chattling avatar mattcorner avatar dimitriadamou avatar max-carroll avatar piccirello avatar jluboff avatar anthonyraymond avatar peterchq avatar is343 avatar igornfaustino avatar lukafurlan123 avatar sah avatar diaver avatar haysclark avatar voros1 avatar keropodium avatar georgiydubrov avatar

Stargazers

ไฝ™่…พ้– avatar

Forkers

tjx666

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.