Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Yuvaleros/material-ui-dropzone
A Material-UI file upload dropzone
https://github.com/Yuvaleros/material-ui-dropzone
dropzone file-upload material-ui modal react
Last synced: 4 months ago
JSON representation
A Material-UI file upload dropzone
- Host: GitHub
- URL: https://github.com/Yuvaleros/material-ui-dropzone
- Owner: Yuvaleros
- License: mit
- Created: 2017-10-16T11:50:16.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-03-13T13:14:33.000Z (11 months ago)
- Last Synced: 2024-05-22T08:44:04.138Z (9 months ago)
- Topics: dropzone, file-upload, material-ui, modal, react
- Language: JavaScript
- Homepage:
- Size: 5.97 MB
- Stars: 482
- Watchers: 7
- Forks: 249
- Open Issues: 109
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Support: docs/support.md
Awesome Lists containing this project
- awesome-material-ui - Material-UI Dropzone - Material-UI component built on top of react-dropzone. (Components)
README
# material-ui-dropzone
> Material-UI-dropzone is a [React](https://github.com/facebook/react) component using [Material-UI](https://github.com/mui-org/material-ui) and is based on the excellent [react-dropzone](https://github.com/react-dropzone/react-dropzone) library.
[data:image/s3,"s3://crabby-images/8b3ac/8b3ac8650198fe0e2f6eaa0f6c9d133f448e8da6" alt="License"](https://github.com/Yuvaleros/material-ui-dropzone/blob/master/LICENSE) [data:image/s3,"s3://crabby-images/97852/9785263819b4259a43fdc913f7767e7f2ccb8bb5" alt="All Contributors"](#contributors)
[data:image/s3,"s3://crabby-images/a5c60/a5c60b08a3da6381dea466d603ad5a28552e7616" alt="Rebuild Dist Workflow Status"](https://github.com/Yuvaleros/material-ui-dropzone/actions?query=workflow%3A%22Rebuild+Dist%22) [data:image/s3,"s3://crabby-images/22936/22936da73b76b4680544bc654cdfc7c879bfc3aa" alt="Update Docs Workflow Status"](https://github.com/Yuvaleros/material-ui-dropzone/actions?query=workflow%3A%22Update+Docs%22)
[data:image/s3,"s3://crabby-images/0e42e/0e42edd98024b1bef677b2dd9de32f8e4b902714" alt="npm package"](https://www.npmjs.com/package/material-ui-dropzone) [data:image/s3,"s3://crabby-images/817f2/817f2564bbab767c97f6482ddcd47df6a15ce862" alt="npm downloads"](https://www.npmjs.com/package/material-ui-dropzone)
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
```shell
npm install --save material-ui-dropzone
```or
```shell
yarn add material-ui-dropzone
```## Support
`material-ui-dropzone` complies to the following support matrix.
| version | React | Material-UI |
| ------- | ---------------- | -------------- |
| `3.x` | `16.8+` | `4.x` |
| `2.x` | `15.x` or `16.x` | `3.x` or `4.x` |## Screenshots
This is the Dialog component:
data:image/s3,"s3://crabby-images/514fa/514fa5d0a867cb82912beb988bdfa75919440fbb" alt="Dialog"
data:image/s3,"s3://crabby-images/15bf6/15bf6c433fe3a884bfebabf4771ed9154537fc2f" alt="Dialog with Previews"When you drag a file onto the dropzone, you get a neat effect:
data:image/s3,"s3://crabby-images/b0485/b0485fafb5e22d614614151b22026948785b4ddb" alt="Drag Overlay"
And if you drag in a wrong type of file, you'll get yelled at:
data:image/s3,"s3://crabby-images/bcfb5/bcfb59abfecffef643256cd4ae079eccbec4464e" alt="Drag Error Overlay"
**N.B. This has some limitations (see [here](https://github.com/react-dropzone/react-dropzone/tree/master/examples/accept#browser-limitations) for more details).**
## Documentation and Examples
See [https://yuvaleros.github.io/material-ui-dropzone](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
```jsx static
import React, {Component} from 'react'
import {DropzoneArea} from 'material-ui-dropzone'class DropzoneAreaExample extends Component{
constructor(props){
super(props);
this.state = {
files: []
};
}
handleChange(files){
this.setState({
files: files
});
}
render(){
return (
)
}
}export default DropzoneAreaExample;
```### DropzoneDialog
This component provides the DropzoneArea inside of a MaterialUI Dialog.
```jsx static
import React, { Component } from 'react'
import {DropzoneDialog} from 'material-ui-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 (
Add Image
);
}
}
```## License
MIT
## Contributors
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
Yuvaleros
🤔 💻 🎨 📖 💬 👀 🚧
Mattia Panzeri
🤔 💻 🎨 📖 💡 🚇 🐛 💬 👀 🚧
Max Carroll
🤔 💻 🎨 💡 👀
Matthew Corner
🐛 🤔 💻
Barry Loong
🤔 💻
JF Blouin
🤔 💻
Anthony Raymond
💻 💡
isaacbuckman
🐛 💻 💡
MatthijsMud
🐛 💻
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!