|
@ -10,15 +10,16 @@ var TestSupport = require('./TestSupport'); |
|
|
describe('Timeline PointItem', function () { |
|
|
describe('Timeline PointItem', function () { |
|
|
|
|
|
|
|
|
jsdom(); |
|
|
jsdom(); |
|
|
var now = moment(); |
|
|
|
|
|
|
|
|
|
|
|
it('should initialize with minimal data', function() { |
|
|
it('should initialize with minimal data', function() { |
|
|
var pointItem = new PointItem({start: now.toDate()}, null, null); |
|
|
|
|
|
|
|
|
var now = moment().toDate(); |
|
|
|
|
|
var pointItem = new PointItem({start: now}, null, null); |
|
|
assert.equal(pointItem.props.content.height, 0); |
|
|
assert.equal(pointItem.props.content.height, 0); |
|
|
assert.deepEqual(pointItem.data.start, now.toDate()); |
|
|
|
|
|
|
|
|
assert.equal(pointItem.data.start, now); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
it('should have a default width of 0', function() { |
|
|
it('should have a default width of 0', function() { |
|
|
|
|
|
var now = moment().toDate(); |
|
|
var pointItem = new PointItem({start: now}, null, null); |
|
|
var pointItem = new PointItem({start: now}, null, null); |
|
|
assert.equal(pointItem.getWidthRight(), 0); |
|
|
assert.equal(pointItem.getWidthRight(), 0); |
|
|
assert.equal(pointItem.getWidthLeft(), 0); |
|
|
assert.equal(pointItem.getWidthLeft(), 0); |
|
@ -29,6 +30,7 @@ describe('Timeline PointItem', function () { |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
it('should be visible if the range is during', function() { |
|
|
it('should be visible if the range is during', function() { |
|
|
|
|
|
var now = moment(); |
|
|
var range = new Range(TestSupport.buildSimpleTimelineRangeBody()); |
|
|
var range = new Range(TestSupport.buildSimpleTimelineRangeBody()); |
|
|
range.start = now.clone().add(-1, 'second'); |
|
|
range.start = now.clone().add(-1, 'second'); |
|
|
range.end = range.start.clone().add(1, 'hour'); |
|
|
range.end = range.start.clone().add(1, 'hour'); |
|
@ -37,6 +39,7 @@ describe('Timeline PointItem', function () { |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
it('should not be visible if the range is after', function() { |
|
|
it('should not be visible if the range is after', function() { |
|
|
|
|
|
var now = moment(); |
|
|
var range = new Range(TestSupport.buildSimpleTimelineRangeBody()); |
|
|
var range = new Range(TestSupport.buildSimpleTimelineRangeBody()); |
|
|
range.start = now.clone().add(1, 'second'); |
|
|
range.start = now.clone().add(1, 'second'); |
|
|
range.end = range.start.clone().add(1, 'hour'); |
|
|
range.end = range.start.clone().add(1, 'hour'); |
|
@ -55,114 +58,8 @@ describe('Timeline PointItem', function () { |
|
|
|
|
|
|
|
|
it('should be visible for a "now" point with a default range', function() { |
|
|
it('should be visible for a "now" point with a default range', function() { |
|
|
var range = new Range(TestSupport.buildSimpleTimelineRangeBody()); |
|
|
var range = new Range(TestSupport.buildSimpleTimelineRangeBody()); |
|
|
var pointItem = new PointItem({start: now.toDate()}, null, null); |
|
|
|
|
|
|
|
|
var now = moment().toDate(); |
|
|
|
|
|
var pointItem = new PointItem({start: now}, null, null); |
|
|
assert(pointItem.isVisible(range)); |
|
|
assert(pointItem.isVisible(range)); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
it('should redraw() and then not be dirty', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate()}, null, {editable: false}); |
|
|
|
|
|
pointItem.setParent(TestSupport.buildMockItemSet()); |
|
|
|
|
|
assert(pointItem.dirty); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert(!pointItem.dirty); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have point attached to its parent', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate()}, null, {editable: false}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
assert(!parent.dom.foreground.hasChildNodes()); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert(parent.dom.foreground.hasChildNodes()); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for a non-editable item', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: false}, null, {editable: false}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-readonly"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-readonly"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable item (with object option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate()}, null, {editable: {updateTime: true, updateGroup: false}}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-editable"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-editable"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable item (with boolean option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate()}, null, {editable: true}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-editable"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-editable"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:false override item (with boolean option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: false}, null, {editable: true}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-readonly"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-readonly"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:true override item (with boolean option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: true}, null, {editable: false}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-editable"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-editable"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:false override item (with object option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: false}, null, {editable: {updateTime: true, updateGroup: false}}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-readonly"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-readonly"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:false override item (with object option for group change)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: false}, null, {editable: {updateTime: false, updateGroup: true}}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-readonly"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-readonly"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:true override item (with object option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: true}, null, {editable: {updateTime: false, updateGroup: false}}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-editable"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-editable"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:true non-override item (with object option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: true}, null, {editable: {updateTime: false, updateGroup: false, overrideItems: true}}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-readonly"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-readonly"); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should redraw() and then have the correct classname for an editable:false non-override item (with object option)', function() { |
|
|
|
|
|
var pointItem = new PointItem({start: now.toDate(), editable: false}, null, {editable: {updateTime: true, updateGroup: false, overrideItems: true}}); |
|
|
|
|
|
var parent = TestSupport.buildMockItemSet(); |
|
|
|
|
|
pointItem.setParent(parent); |
|
|
|
|
|
pointItem.redraw(); |
|
|
|
|
|
assert.equal(pointItem.dom.dot.className, "vis-item vis-dot vis-editable"); |
|
|
|
|
|
assert.equal(pointItem.dom.point.className, "vis-item vis-point vis-editable"); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
}); |