vis.js is a dynamic, browser-based visualization library

198 lines
5.2 KiB

11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
  1. /**
  2. * Jake build script
  3. */
  4. var jake = require('jake'),
  5. browserify = require('browserify'),
  6. wrench = require('wrench'),
  7. CleanCSS = require('clean-css'),
  8. fs = require('fs');
  9. require('jake-utils');
  10. // constants
  11. var DIST = './dist';
  12. var VIS = DIST + '/vis.js';
  13. var VIS_CSS = DIST + '/vis.css';
  14. var VIS_TMP = DIST + '/vis.js.tmp';
  15. var VIS_MIN = DIST + '/vis.min.js';
  16. var VIS_MIN_CSS = DIST + '/vis.min.css';
  17. /**
  18. * default task
  19. */
  20. desc('Default task: build all libraries');
  21. task('default', ['build', 'minify'], function () {
  22. console.log('done');
  23. });
  24. /**
  25. * build the visualization library vis.js
  26. */
  27. desc('Build the visualization library vis.js');
  28. task('build', {async: true}, function () {
  29. jake.mkdirP(DIST);
  30. jake.mkdirP(DIST + '/img');
  31. // concatenate and stringify the css files
  32. concat({
  33. src: [
  34. './src/timeline/component/css/timeline.css',
  35. './src/timeline/component/css/panel.css',
  36. './src/timeline/component/css/groupset.css',
  37. './src/timeline/component/css/itemset.css',
  38. './src/timeline/component/css/item.css',
  39. './src/timeline/component/css/timeaxis.css',
  40. './src/timeline/component/css/currenttime.css',
  41. './src/timeline/component/css/customtime.css',
  42. './src/graph/css/graph-manipulation.css',
  43. './src/graph/css/graph-navigation.css'
  44. ],
  45. dest: VIS_CSS,
  46. separator: '\n'
  47. });
  48. console.log('created ' + VIS_CSS);
  49. // concatenate the script files
  50. concat({
  51. dest: VIS_TMP,
  52. src: [
  53. './src/module/imports.js',
  54. './src/shim.js',
  55. './src/util.js',
  56. './src/DataSet.js',
  57. './src/DataView.js',
  58. './src/timeline/TimeStep.js',
  59. './src/timeline/Stack.js',
  60. './src/timeline/Range.js',
  61. './src/timeline/Controller.js',
  62. './src/timeline/component/Component.js',
  63. './src/timeline/component/Panel.js',
  64. './src/timeline/component/RootPanel.js',
  65. './src/timeline/component/TimeAxis.js',
  66. './src/timeline/component/CurrentTime.js',
  67. './src/timeline/component/CustomTime.js',
  68. './src/timeline/component/ItemSet.js',
  69. './src/timeline/component/item/*.js',
  70. './src/timeline/component/Group.js',
  71. './src/timeline/component/GroupSet.js',
  72. './src/timeline/Timeline.js',
  73. './src/graph/dotparser.js',
  74. './src/graph/shapes.js',
  75. './src/graph/Node.js',
  76. './src/graph/Edge.js',
  77. './src/graph/Popup.js',
  78. './src/graph/Groups.js',
  79. './src/graph/Images.js',
  80. './src/graph/graphMixins/physics/PhysicsMixin.js',
  81. './src/graph/graphMixins/physics/HierarchialRepulsion.js',
  82. './src/graph/graphMixins/physics/BarnesHut.js',
  83. './src/graph/graphMixins/physics/Repulsion.js',
  84. './src/graph/graphMixins/HierarchicalLayoutMixin.js',
  85. './src/graph/graphMixins/ManipulationMixin.js',
  86. './src/graph/graphMixins/SectorsMixin.js',
  87. './src/graph/graphMixins/ClusterMixin.js',
  88. './src/graph/graphMixins/SelectionMixin.js',
  89. './src/graph/graphMixins/NavigationMixin.js',
  90. './src/graph/graphMixins/MixinLoader.js',
  91. './src/graph/Graph.js',
  92. './src/module/exports.js'
  93. ],
  94. separator: '\n'
  95. });
  96. // copy images
  97. wrench.copyDirSyncRecursive('./src/graph/img', DIST + '/img/graph', {
  98. forceDelete: true
  99. });
  100. wrench.copyDirSyncRecursive('./src/timeline/img', DIST + '/img/timeline', {
  101. forceDelete: true
  102. });
  103. var timeStart = Date.now();
  104. // bundle the concatenated script and dependencies into one file
  105. var b = browserify();
  106. b.add(VIS_TMP);
  107. b.bundle({
  108. standalone: 'vis'
  109. }, function (err, code) {
  110. if(err) {
  111. throw err;
  112. }
  113. console.log("browserify",Date.now() - timeStart); timeStart = Date.now();
  114. // add header and footer
  115. var lib = read('./src/module/header.js') + code;
  116. // write bundled file
  117. write(VIS, lib);
  118. console.log('created js' + VIS);
  119. // remove temporary file
  120. fs.unlinkSync(VIS_TMP);
  121. // update version number and stuff in the javascript files
  122. replacePlaceholders(VIS);
  123. complete();
  124. });
  125. });
  126. /**
  127. * minify the visualization library vis.js
  128. */
  129. desc('Minify the visualization library vis.js');
  130. task('minify', {async: true}, function () {
  131. // minify javascript
  132. minify({
  133. src: VIS,
  134. dest: VIS_MIN,
  135. header: read('./src/module/header.js')
  136. });
  137. // update version number and stuff in the javascript files
  138. replacePlaceholders(VIS_MIN);
  139. console.log('created minified ' + VIS_MIN);
  140. var minified = new CleanCSS().minify(read(VIS_CSS));
  141. write(VIS_MIN_CSS, minified);
  142. console.log('created minified ' + VIS_MIN_CSS);
  143. });
  144. /**
  145. * test task
  146. */
  147. desc('Test the library');
  148. task('test', function () {
  149. // TODO: use a testing suite for testing: nodeunit, mocha, tap, ...
  150. var filelist = new jake.FileList();
  151. filelist.include([
  152. './test/**/*.js'
  153. ]);
  154. var files = filelist.toArray();
  155. files.forEach(function (file) {
  156. require('./' + file);
  157. });
  158. console.log('Executed ' + files.length + ' test files successfully');
  159. });
  160. /**
  161. * replace version, date, and name placeholders in the provided file
  162. * @param {String} filename
  163. */
  164. var replacePlaceholders = function (filename) {
  165. replace({
  166. replacements: [
  167. {pattern: '@@date', replacement: today()},
  168. {pattern: '@@version', replacement: version()}
  169. ],
  170. src: filename
  171. });
  172. };