vis.js is a dynamic, browser-based visualization library
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

77 lines
1.7 KiB

  1. <html>
  2. <head>
  3. <title>Timeline | Horizontal Scroll Option</title>
  4. <script src="../../../dist/vis.js"></script>
  5. <link href="../../../dist/vis.css" rel="stylesheet" type="text/css" />
  6. </head>
  7. <body>
  8. <h1>Timeline horizontal scroll option</h1>
  9. <div id="mytimeline"></div>
  10. <script>
  11. // create groups
  12. var numberOfGroups = 25;
  13. var groups = new vis.DataSet()
  14. for (var i = 0; i < numberOfGroups; i++) {
  15. groups.add({
  16. id: i,
  17. content: 'Truck&nbsp;' + i
  18. })
  19. }
  20. // create items
  21. var numberOfItems = 1000;
  22. var items = new vis.DataSet();
  23. var itemsPerGroup = Math.round(numberOfItems/numberOfGroups);
  24. for (var truck = 0; truck < numberOfGroups; truck++) {
  25. var date = new Date();
  26. for (var order = 0; order < itemsPerGroup; order++) {
  27. date.setHours(date.getHours() + 4 * (Math.random() < 0.2));
  28. var start = new Date(date);
  29. date.setHours(date.getHours() + 2 + Math.floor(Math.random()*4));
  30. var end = new Date(date);
  31. items.add({
  32. id: order + itemsPerGroup * truck,
  33. group: truck,
  34. start: start,
  35. end: end,
  36. content: 'Order ' + order
  37. });
  38. }
  39. }
  40. // specify options
  41. var options = {
  42. stack: true,
  43. horizontalScroll: true,
  44. zoomKey: 'ctrlKey',
  45. maxHeight: 400,
  46. start: new Date(),
  47. end: new Date(1000*60*60*24 + (new Date()).valueOf()),
  48. editable: true,
  49. margin: {
  50. item: 10, // minimal margin between items
  51. axis: 5 // minimal margin between items and the axis
  52. },
  53. orientation: 'top'
  54. };
  55. // create a Timeline
  56. var container = document.getElementById('mytimeline');
  57. timeline = new vis.Timeline(container, items, groups, options);
  58. </script>
  59. </body>
  60. </html>