<!DOCTYPE HTML>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title>React Components in templates</title>
|
|
</head>
|
|
<body>
|
|
|
|
<div id='root'></div>
|
|
|
|
<!--
|
|
For ease of use, we are including the React, ReactDOM and Babel CDN
|
|
builds to make getting started as fast as possible.
|
|
|
|
In production, you'll want to instead look at using something
|
|
like Gulp, Grunt or WebPack (my personal recommendation)
|
|
to compile JSX into JavaScript. Also, check out:
|
|
http://facebook.github.io/react/docs/tooling-integration.html
|
|
-->
|
|
<script src="https://fb.me/react-15.0.1.js"></script>
|
|
<script src="https://fb.me/react-dom-15.0.1.js"></script>
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.23/browser.min.js"></script>
|
|
|
|
<script src="../../../dist/vis.js"></script>
|
|
<link href="../../../dist/vis.css" rel="stylesheet" type="text/css" />
|
|
|
|
<!--
|
|
This is where you link to your React code. Can be .js or .jsx
|
|
extension, doesn't really matter.
|
|
-->
|
|
<script type="text/babel">
|
|
var timeline;
|
|
|
|
// create groups
|
|
var numberOfGroups = 25;
|
|
var groups = new vis.DataSet()
|
|
for (var i = 0; i < numberOfGroups; i++) {
|
|
groups.add({
|
|
id: i,
|
|
content: 'Truck ' + i
|
|
})
|
|
}
|
|
|
|
// create items
|
|
var numberOfItems = 1000;
|
|
var items = new vis.DataSet();
|
|
var itemsPerGroup = Math.round(numberOfItems/numberOfGroups);
|
|
for (var truck = 0; truck < numberOfGroups; truck++) {
|
|
var date = new Date();
|
|
for (var order = 0; order < itemsPerGroup; order++) {
|
|
date.setHours(date.getHours() + 4 * (Math.random() < 0.2));
|
|
var start = new Date(date);
|
|
date.setHours(date.getHours() + 2 + Math.floor(Math.random()*4));
|
|
var end = new Date(date);
|
|
items.add({
|
|
id: order + itemsPerGroup * truck,
|
|
group: truck,
|
|
start: start,
|
|
end: end,
|
|
content: 'Order ' + order
|
|
});
|
|
}
|
|
}
|
|
|
|
var GroupTemplate = React.createClass({
|
|
render: function() {
|
|
var { group } = this.props;
|
|
return <div>
|
|
<label>{group.content}</label>
|
|
<button>do stuff</button>
|
|
</div>
|
|
}
|
|
})
|
|
|
|
var ItemTemplate = React.createClass({
|
|
render: function() {
|
|
var { item } = this.props;
|
|
return <div>
|
|
<label>{item.content}</label>
|
|
<button>do stuff</button>
|
|
</div>
|
|
}
|
|
})
|
|
|
|
// specify options
|
|
var options = {
|
|
rtl: true,
|
|
stack: true,
|
|
maxHeight: 400,
|
|
start: new Date(),
|
|
end: new Date(1000*60*60*24 + (new Date()).valueOf()),
|
|
editable: true,
|
|
margin: {
|
|
item: 10, // minimal margin between items
|
|
axis: 5 // minimal margin between items and the axis
|
|
},
|
|
template: function (item, element) {
|
|
ReactDOM.unmountComponentAtNode(element);
|
|
return ReactDOM.render(<ItemTemplate item={item} />, element);
|
|
},
|
|
groupTemplate: function (group, element) {
|
|
ReactDOM.unmountComponentAtNode(element);
|
|
return ReactDOM.render(<GroupTemplate group={group} />, element);
|
|
},
|
|
orientation: 'top'
|
|
}
|
|
|
|
|
|
var VisTimeline = React.createClass({
|
|
componentDidMount: function() {
|
|
initTimeline()
|
|
},
|
|
render: function() {
|
|
return <div>
|
|
<h1>Vis timline with React</h1>
|
|
<h2>Using react components for items and group templates</h2>
|
|
|
|
<div id="mytimeline"></div>
|
|
</div>
|
|
}
|
|
});
|
|
|
|
function initTimeline() {
|
|
var container = document.getElementById('mytimeline');
|
|
timeline = new vis.Timeline(container, items, groups, options);
|
|
}
|
|
|
|
ReactDOM.render(<VisTimeline />, document.getElementById('root'));
|
|
</script>
|
|
</body>
|
|
</html>
|