Browse Source

Merge branch 'develop' of https://github.com/almende/vis into develop

revert-3409-performance
Yotam Berkowitz 8 years ago
parent
commit
fae21a0e31
14 changed files with 134 additions and 41 deletions
  1. +22
    -2
      .eslintrc
  2. +1
    -0
      .travis.yml
  3. +1
    -1
      docs/network/edges.html
  4. +4
    -6
      lib/graph3d/Graph3d.js
  5. +0
    -1
      lib/network/modules/LayoutEngine.js
  6. +0
    -1
      lib/timeline/DateUtil.js
  7. +2
    -2
      lib/timeline/component/ItemSet.js
  8. +5
    -0
      lib/timeline/component/css/item.css
  9. +2
    -2
      lib/timeline/component/item/Item.js
  10. +1
    -1
      misc/how_to_help.md
  11. +3
    -0
      package.json
  12. +65
    -0
      test/PointItem.test.js
  13. +22
    -0
      test/TestSupport.js
  14. +6
    -25
      test/TimelineRange.test.js

+ 22
- 2
.eslintrc View File

@ -1,6 +1,26 @@
{
"env": {
"browser": true,
"es6": true,
"node": true,
"mocha": true
},
"parser": "babel-eslint",
"extends": "eslint:recommended",
"rules": {
"complexity": [2, 50],
"max-statements": [2, 100]
"complexity": [2, 55],
"max-statements": [2, 115],
"no-console": 0,
"no-empty": 0,
"no-extra-semi": 0,
"no-fallthrough": 0,
"no-inner-declarations": 0,
"no-mixed-spaces-and-tabs": 0,
"no-redeclare": 0,
"no-unreachable": 1,
"no-unused-vars": 0,
}
}

+ 1
- 0
.travis.yml View File

@ -1,6 +1,7 @@
language: node_js
node_js: "6"
before_script:
- npm run lint
- npm install -g gulp
script:
- gulp

+ 1
- 1
docs/network/edges.html View File

@ -935,7 +935,7 @@ var options: {
<td>String</td>
<td><code>'dynamic'</code></td>
<td>Possible options: <code>'dynamic', 'continuous', 'discrete', 'diagonalCross', 'straightCross', 'horizontal',
'vertical', 'curvedCW', 'curvedCCW', 'cubicBezier'</code>. Take a look at our example 26 to see what these look like
'vertical', 'curvedCW', 'curvedCCW', 'cubicBezier'</code>. Take a look at <a href="http://visjs.org/examples/network/edgeStyles/smooth.html">this example</a> to see what these look like
and pick the one that you like best!
<br><br>
When using dynamic, the edges will have an invisible support node guiding the shape. This node is part of the

+ 4
- 6
lib/graph3d/Graph3d.js View File

@ -12,13 +12,13 @@ var Settings = require('./Settings');
/// enumerate the available styles
Graph3d.STYLE = Settings.STYLE;
Graph3d.STYLE = Settings.STYLE;
/**
* Following label is used in the settings to describe values which should be
* determined by the code while running, from the current data and graph style.
*
*
* Using 'undefined' directly achieves the same thing, but this is more
* descriptive by describing the intent.
*/
@ -524,7 +524,7 @@ Graph3d.prototype._dataInitialize = function (rawData, style) {
}
}
// set the scale dependent on the ranges.
this._setScale();
};
@ -699,7 +699,6 @@ Graph3d.prototype.create = function () {
var onclick = function(event) {me._onClick(event);};
// TODO: these events are never cleaned up... can give a 'memory leakage'
util.addEventListener(this.frame.canvas, 'keydown', onkeydown);
util.addEventListener(this.frame.canvas, 'mousedown', onmousedown);
util.addEventListener(this.frame.canvas, 'touchstart', ontouchstart);
util.addEventListener(this.frame.canvas, 'mousewheel', onmousewheel);
@ -902,7 +901,6 @@ Graph3d.prototype.setPointDrawingMethod = function() {
default:
throw new Error('Can not determine point drawing method '
+ 'for graph style \'' + this.style + '\'');
break;
}
this._pointDrawingMethod = method;
@ -1338,7 +1336,7 @@ Graph3d.prototype._redrawAxis = function() {
if (this.showYAxis) {
xText = (armVector.y > 0) ? xRange.min : xRange.max;
point3d = new Point3d(xText, y, zRange.min);
var msg = ' ' + this.yValueLabel(y) + ' ';
var msg = ' ' + this.yValueLabel(y) + ' ';
this.drawAxisLabelY(ctx, point3d, msg, armAngle, textMargin);
}

+ 0
- 1
lib/network/modules/LayoutEngine.js View File

@ -327,7 +327,6 @@ class LayoutEngine {
// if the user defined some levels but not all, alert and run without hierarchical layout
if (undefinedLevel === true && definedLevel === true) {
throw new Error('To use the hierarchical layout, nodes require either no predefined levels or levels have to be defined for all nodes.');
return;
}
else {
// define levels if undefined by the users. Based on hubsize.

+ 0
- 1
lib/timeline/DateUtil.js View File

@ -500,7 +500,6 @@ exports.isHidden = function(time, hiddenDates) {
if (time >= startDate && time < endDate) { // if the start is entering a hidden zone
return {hidden: true, startDate: startDate, endDate: endDate};
break;
}
}
return {hidden: false, startDate: startDate, endDate: endDate};

+ 2
- 2
lib/timeline/component/ItemSet.js View File

@ -1828,8 +1828,8 @@ ItemSet.prototype._onGroupDragEnd = function (event) {
var switchGroup = dataset.get(newOrder[curPos]);
var shouldBeGroup = dataset.get(origOrder[curPos]);
me.options.groupOrderSwap(switchGroup, shouldBeGroup, dataset);
groupsData.update(switchGroup);
groupsData.update(shouldBeGroup);
dataset.update(switchGroup);
dataset.update(shouldBeGroup);
var switchGroupId = newOrder[curPos];
newOrder[curPos] = origOrder[curPos];

+ 5
- 0
lib/timeline/component/css/item.css View File

@ -6,6 +6,7 @@
border-width: 1px;
background-color: #D5DDF6;
display: inline-block;
z-index: 1;
/*overflow: hidden;*/
}
@ -103,6 +104,10 @@
white-space: nowrap;
padding: 5px;
border-radius: 1px;
transition: 0.4s;
-o-transition: 0.4s;
-moz-transition: 0.4s;
-webkit-transition: 0.4s;
}
.vis-item .vis-delete, .vis-item .vis-delete-rtl {

+ 2
- 2
lib/timeline/component/item/Item.js View File

@ -18,7 +18,7 @@ function Item (data, conversion, options) {
this.data = data;
this.dom = null;
this.conversion = conversion || {};
this.options = options || {};
this.options = options || {};
this.selected = false;
this.displayed = false;
this.groupShowing = true;
@ -85,7 +85,7 @@ Item.prototype.setData = function(data) {
remove: this.data.editable
}
}
else if(typeof options.editable === 'object') {
else if(typeof this.options.editable === 'object') {
this.editable = {};
util.selectiveExtend(['updateTime', 'updateGroup', 'remove'], this.editable, data.editable);
}

+ 1
- 1
misc/how_to_help.md View File

@ -12,7 +12,7 @@ A better way to ask questions on how to use vis.js is [stackoverflow](https://st
### Closing old issues
A new issue is often opened fast and then forgotten. Please help go trough [the old issues](//github.com/almende/vis/issues?q=is%3Aissue+is%3Aopen+sort%3Acreated-asc) (especially the [questions](//github.com/almende/vis/issues?q=is%3Aissue+is%3Aopen+sort%3Acreated-asc+label%3AQuestion)) and ask the creator of the issues if the problem still exists before closing the issue. The support team uses the **issue inactive** label to mark these issues.
A new issue is often opened fast and then forgotten. Please help go through [the old issues](//github.com/almende/vis/issues?q=is%3Aissue+is%3Aopen+sort%3Acreated-asc) (especially the [questions](//github.com/almende/vis/issues?q=is%3Aissue+is%3Aopen+sort%3Acreated-asc+label%3AQuestion)) and ask the creator of the issues if the problem still exists before closing the issue. The support team uses the **issue inactive** label to mark these issues.
### Improve the webpage

+ 3
- 0
package.json View File

@ -25,6 +25,7 @@
"scripts": {
"test": "mocha",
"build": "gulp",
"lint": "eslint lib",
"watch": "gulp watch",
"watch-dev": "gulp watch --bundle"
},
@ -45,8 +46,10 @@
},
"devDependencies": {
"async": "^2.1.4",
"babel-eslint": "^7.1.1",
"babelify": "^7.3.0",
"clean-css": "^4.0.2",
"eslint": "^3.15.0",
"gulp": "^3.9.1",
"gulp-clean-css": "^2.3.2",
"gulp-concat": "^2.6.1",

+ 65
- 0
test/PointItem.test.js View File

@ -0,0 +1,65 @@
var assert = require('assert');
var vis = require('../dist/vis');
var jsdom = require('mocha-jsdom');
var moment = vis.moment;
var timeline = vis.timeline;
var PointItem = require("../lib/timeline/component/item/PointItem");
var Range = timeline.Range;
var TestSupport = require('./TestSupport');
describe('Timeline PointItem', function () {
jsdom();
it('should initialize with minimal data', function() {
var now = moment().toDate();
var pointItem = new PointItem({start: now}, null, null);
assert.equal(pointItem.props.content.height, 0);
assert.equal(pointItem.data.start, now);
});
it('should have a default width of 0', function() {
var now = moment().toDate();
var pointItem = new PointItem({start: now}, null, null);
assert.equal(pointItem.getWidthRight(), 0);
assert.equal(pointItem.getWidthLeft(), 0);
});
it('should error if there is missing data', function () {
assert.throws(function () { new PointItem({}, null, null)}, Error);
});
it('should be visible if the range is during', function() {
var now = moment();
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
range.start = now.clone().add(-1, 'second');
range.end = range.start.clone().add(1, 'hour');
var pointItem = new PointItem({start: now.toDate()}, null, null);
assert(pointItem.isVisible(range));
});
it('should not be visible if the range is after', function() {
var now = moment();
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
range.start = now.clone().add(1, 'second');
range.end = range.start.clone().add(1, 'hour');
var pointItem = new PointItem({start: now.toDate()}, null, null);
assert(!pointItem.isVisible(range));
});
it('should not be visible if the range is before', function() {
var now = moment();
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
range.end = now.clone().add(-1, 'second');
range.start = range.end.clone().add(-1, 'hour');
var pointItem = new PointItem({start: now.toDate()}, null, null);
assert(!pointItem.isVisible(range));
});
it('should be visible for a "now" point with a default range', function() {
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
var now = moment().toDate();
var pointItem = new PointItem({start: now}, null, null);
assert(pointItem.isVisible(range));
});
});

+ 22
- 0
test/TestSupport.js View File

@ -0,0 +1,22 @@
module.exports = {
buildSimpleTimelineRangeBody: function () {
var body = {
dom: {
center: {
clientWidth: 1000
}
},
domProps: this.props,
emitter: {
on: function () {},
off: function () {},
emit: function () {}
},
hiddenDates: [],
util: {}
}
body.dom.rollingModeBtn = document.createElement('div')
return body
}
}

+ 6
- 25
test/TimelineRange.test.js View File

@ -4,26 +4,7 @@ var jsdom = require('mocha-jsdom')
var moment = vis.moment;
var timeline = vis.timeline;
var Range = timeline.Range;
function buildSimpleBody() {
var body = {
dom: {
center: {
clientWidth: 1000
}
},
domProps: this.props,
emitter: {
on: function() {},
off: function() {},
emit: function() {}
},
hiddenDates: [],
util: {}
};
body.dom.rollingModeBtn = document.createElement('div');
return body;
}
var TestSupport = require('./TestSupport');
describe('Timeline Range', function () {
@ -31,30 +12,30 @@ describe('Timeline Range', function () {
it('should have start default before now', function () {
var now = moment().hours(0).minutes(0).seconds(0).milliseconds(0).valueOf();
var range = new Range(buildSimpleBody());
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
assert(range.start < now, "Default start is before now");
});
it('should have end default after now', function () {
var now = moment().hours(0).minutes(0).seconds(0).milliseconds(0).valueOf();
var range = new Range(buildSimpleBody());
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
assert(range.end > now, "Default end is after now");
});
it('should support custom start and end dates', function () {
var range = new Range(buildSimpleBody());
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
range.setRange(new Date(2017, 0, 26, 13, 26, 3, 320), new Date(2017, 3, 11, 0, 23, 35, 0), false, false, null);
assert.equal(range.start, new Date(2017, 0, 26, 13, 26, 3, 320).valueOf(), "start is as expected");
assert.equal(range.end, new Date(2017, 3, 11, 0, 23, 35, 0).valueOf(), "end is as expected");
});
it('should calculate milliseconds per pixel', function () {
var range = new Range(buildSimpleBody());
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
assert(range.getMillisecondsPerPixel() > 0, "positive value for milliseconds per pixel");
});
it('should calculate 1 millisecond per pixel for simple range', function () {
var range = new Range(buildSimpleBody());
var range = new Range(TestSupport.buildSimpleTimelineRangeBody());
range.setRange(new Date(2017, 0, 26, 13, 26, 3, 320), new Date(2017, 0, 26, 13, 26, 4, 320), false, false, null);
assert.equal(range.getMillisecondsPerPixel(), 1, "one second over 1000 pixels");
});

Loading…
Cancel
Save