Skip to content

Commit

Permalink
Update #687 - Native File Example (#696)
Browse files Browse the repository at this point in the history
* add native file DnD example

* add native file DnD example

* fix lint errors

* revert repo url

* Update the native file example by adding an 'other' category
  • Loading branch information
darthtrevino authored Mar 14, 2017
1 parent 39576c8 commit 9e062eb
Show file tree
Hide file tree
Showing 7 changed files with 287 additions and 151 deletions.
37 changes: 37 additions & 0 deletions examples/06 Other/Native Files/Container.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import React, { Component } from 'react';
import { DragDropContext, DragDropContextProvider } from 'react-dnd';
import HTML5Backend, { NativeTypes } from 'react-dnd-html5-backend';
import TargetBox from './TargetBox';
import FileList from './FileList';

@DragDropContext(HTML5Backend)
export default class Container extends Component {
constructor(props) {
super(props);

this.handleFileDrop = this.handleFileDrop.bind(this);

this.state = { droppedFiles: [] };
}

handleFileDrop(item, monitor) {
if (monitor) {
const droppedFiles = monitor.getItem().files;
this.setState({ droppedFiles });
}
}

render() {
const { FILE } = NativeTypes;
const { droppedFiles } = this.state;

return (
<DragDropContextProvider backend={HTML5Backend}>
<div>
<TargetBox accepts={[FILE]} onDrop={this.handleFileDrop} />
<FileList files={droppedFiles} />
</div>
</DragDropContextProvider>
);
}
}
23 changes: 23 additions & 0 deletions examples/06 Other/Native Files/FileList.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import React, { PropTypes, Component } from 'react';

export default class FileList extends Component {
static propTypes = {
files: PropTypes.arrayOf(PropTypes.object),
};

list(files) {
return files.map(file => <li key={file.name}>{`'${file.name}'' of size '${file.size}' and type '${file.type}'`}</li>);
}

render() {
const { files } = this.props;

if (files.length === 0) {
return <div>Nothing to display</div>;
}

return (
<div>{ this.list(files) }</div>
);
}
}
48 changes: 48 additions & 0 deletions examples/06 Other/Native Files/TargetBox.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
import React, { PropTypes, Component } from 'react';
import { DropTarget } from 'react-dnd';

const style = {
border: '1px solid gray',
height: '15rem',
width: '15rem',
padding: '2rem',
textAlign: 'center',
};

const boxTarget = {
drop(props, monitor) {
if (props.onDrop) {
props.onDrop(props, monitor);
}
},
};

@DropTarget(props => props.accepts, boxTarget, (connect, monitor) => ({
connectDropTarget: connect.dropTarget(),
isOver: monitor.isOver(),
canDrop: monitor.canDrop(),
}))

export default class TargetBox extends Component {
static propTypes = {
connectDropTarget: PropTypes.func.isRequired,
isOver: PropTypes.bool.isRequired,
canDrop: PropTypes.bool.isRequired,
accepts: PropTypes.arrayOf(PropTypes.string).isRequired,
onDrop: PropTypes.func,
};

render() {
const { canDrop, isOver, connectDropTarget } = this.props;
const isActive = canDrop && isOver;

return connectDropTarget(
<div style={style}>
{isActive ?
'Release to drop' :
'Drag file here'
}
</div>,
);
}
}
18 changes: 18 additions & 0 deletions examples/06 Other/Native Files/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import React, { Component } from 'react';
import Container from './Container';

export default class NativeFiles extends Component {
render() {
return (
<div>
<p>
<b><a href="https://github.com/react-dnd/react-dnd/tree/master/examples/05%20Customize/Native%20Files">Browse the Source</a></b>
</p>
<p>
Example demonstrating drag and drop of native files.
</p>
<Container />
</div>
);
}
}
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,8 @@
"author": "Dan Abramov <[email protected]> (http://github.com/gaearon)",
"contributors": [
"Chris Trevino <[email protected]> (http://github.com/darthtrevino)",
"Jordan Gensler (http://github.com/kesne)"
"Jordan Gensler (http://github.com/kesne)",
"Gagan (https://github.com/thetechie)"
],
"license": "MIT",
"bugs": {
Expand Down
Loading

0 comments on commit 9e062eb

Please sign in to comment.