The Kendo UI for jQuery DropTarget widget wrapped as a React component.
npm i kendo-ui-react-jquery-droptarget
import React from 'react';
import ReactDOM from 'react-dom';
import KendoDropTarget from 'kendo-ui-react-jquery-droptarget';
//Don't forget CSS, webpack used to include CSS
import 'kendo-ui-core/css/web/kendo.common.core.min.css';
import 'kendo-ui-core/css/web/kendo.default.min.css';
var App = React.createClass({
render: function() {
return (
<KendoDropTarget options={{
drop: function(){alert('dropped')}
}} >
<div style={{width:200,height:200,backgroundColor:'#919922'}}>drop</div>
</KendoDropTarget>
<KendoDraggable options={{
hint: function(element) {return element.clone()}
}}>
<div style={{width:50,height:50,backgroundColor:'#569988'}}>drag me</div>
</KendoDraggable>
);
}
});
ReactDOM.render(<App />, document.getElementById('app'));
Every KUI React Wrapper can make use of the following React props:
options
methods
events
unbindEvents
triggerEvents
Each is demonstrated below using a <KendoDropDownList>
KUI React wrapper.
<KendoDropDownList
//only updates upon state change from above if widget supports setOptions()
//don't define events here, do it in events prop
options={{ //nothing new here, object of KUI configuration values
dataSource:[{
text: "Item1",
value: "1"
}, {
text: "Item2",
value: "2"
}, {
text: "Item3",
value: "3"
}],
dataTextField: "text",
dataValueField: "value"
}}
//updates if object is different from initial mount
methods={{ //name of method and array of arguments to pass to method
open:[], //send empty array if no arguments
value:['2']
}}
//Right now, always updates
events={{ //name of event, and callback
close:function(){console.log('dropdown closed')},
select:function(){console.log('item selected')},
open:function(){console.log('dropdown opened')}
}}
//updates if array is different from initial mount
unbindEvents={[ //name of event to unbind, string
"select"
]}
//updates if array is different from initial mount
triggerEvents={[ //name of event to trigger, string
"open",
]}>
<input className="kendoDropDownList" />
</KendoDropDownList>
- DropTarget demos: http://demos.telerik.com/kendo-ui/dragdrop/index
- DropTarget docs: http://docs.telerik.com/kendo-ui/controls/interactivity/draganddrop/overview#droptarget
- DropTarget API: http://docs.telerik.com/kendo-ui/api/javascript/ui/droptarget