aboutsummaryrefslogtreecommitdiffstats
path: root/spec
diff options
context:
space:
mode:
Diffstat (limited to 'spec')
-rw-r--r--spec/spec/elements/G.js142
1 files changed, 126 insertions, 16 deletions
diff --git a/spec/spec/elements/G.js b/spec/spec/elements/G.js
index 2c2efc8..385419e 100644
--- a/spec/spec/elements/G.js
+++ b/spec/spec/elements/G.js
@@ -1,4 +1,4 @@
-import { G, Rect, makeInstance } from '../../../src/main';
+import { Box, G, Rect, makeInstance } from '../../../src/main.js';
const { any, createSpy, objectContaining } = jasmine
@@ -15,6 +15,68 @@ describe('G.js', () => {
})
})
+ describe('Container', () => {
+ describe('group()', () => {
+ it('creates a group in the container', () => {
+ const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+ expect(g).toEqual(any(G))
+ expect(g.parent()).toBe(canvas)
+ })
+ })
+ })
+
+ describe('dmove()', () => {
+ it('moves the bbox of the group by a certain amount (1)', () => {
+ const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+
+ g.add(new Rect({width:100, height:120, x:10, y:20}))
+ g.add(new Rect({width:70, height:100, x:50, y:60}))
+
+ g.dmove(10, 10)
+
+ const box = g.bbox()
+ expect(box).toEqual(objectContaining({
+ x: 20, y: 30, width: box.width, height: box.height
+ }))
+ })
+
+ it('moves the bbox of the group by a certain amount (2)', () => {
+ const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+
+ g.rect(400, 200).move(123, 312).rotate(34).skew(12)
+ g.rect(100, 50).move(11, 43).translate(123, 32).skew(-12)
+ g.rect(400, 200).rotate(90)
+ g.group().rotate(23).group().skew(32).rect(100, 40).skew(11).rotate(12)
+
+ const oldBox = g.bbox()
+
+ g.dmove(10, 10)
+
+ const newBox = g.bbox()
+
+ expect(newBox.x).toBeCloseTo(oldBox.x + 10, 4)
+ expect(newBox.y).toBeCloseTo(oldBox.y + 10, 4)
+ expect(newBox.w).toBeCloseTo(oldBox.w, 4)
+ expect(newBox.h).toBeCloseTo(oldBox.h, 4)
+ })
+ })
+
+ describe('move()', () => {
+ it('calls dmove() with the correct difference', () => {
+ const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+ g.rect(100, 200).move(111, 223)
+
+ spyOn(g, 'dmove')
+
+ g.move(100, 150)
+ expect(g.dmove).toHaveBeenCalledWith(-11, -73)
+ })
+ })
+
describe('x()', () => {
it('gets the x value of the bbox', () => {
const canvas = makeInstance().addTo('#canvas')
@@ -28,19 +90,15 @@ describe('G.js', () => {
expect(g.x()).toBe(g.bbox().x)
expect(g.x()).toBe(10)
})
- it('sets the x value of the bbox by moving all children', () => {
+ it('calls move with the paramater as x', () => {
const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+ g.rect(100, 200).move(111, 223)
- const g = new G()
- g.add(new Rect({width:100, height:120, x:10, y:20}))
- g.add(new Rect({width:70, height:100, x:50, y:60}))
-
- g.addTo(canvas)
+ spyOn(g, 'move')
- expect(g.x(0)).toBe(g)
- expect(g.bbox().x).toBe(0)
- expect(g.children()[0].x()).toBe(0)
- expect(g.children()[1].x()).toBe(40)
+ g.x(100)
+ expect(g.move).toHaveBeenCalledWith(100, g.bbox().y, any(Box))
})
})
@@ -57,7 +115,20 @@ describe('G.js', () => {
expect(g.y()).toBe(g.bbox().y)
expect(g.y()).toBe(20)
})
- it('sets the y value of the bbox by moving all children', () => {
+ it('calls move with the paramater as y', () => {
+ const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+ g.rect(100, 200).move(111, 223)
+
+ spyOn(g, 'move')
+
+ g.y(100)
+ expect(g.move).toHaveBeenCalledWith(g.bbox().x, 100, any(Box))
+ })
+ })
+
+ describe('size()', () => {
+ it('changes the dimensions of the bbox (1)', () => {
const canvas = makeInstance().addTo('#canvas')
const g = new G()
@@ -66,11 +137,50 @@ describe('G.js', () => {
g.addTo(canvas)
- expect(g.y(0)).toBe(g)
- expect(g.bbox().y).toBe(0)
- expect(g.children()[0].y()).toBe(0)
- expect(g.children()[1].y()).toBe(40)
+ const oldBox = g.bbox()
+
+ expect(g.size(100, 100)).toBe(g)
+
+ const newBox = g.bbox()
+
+ expect(newBox.x).toBeCloseTo(oldBox.x, 4)
+ expect(newBox.y).toBeCloseTo(oldBox.y, 4)
+ expect(newBox.w).toBeCloseTo(100, 4)
+ expect(newBox.h).toBeCloseTo(100, 4)
+
+ expect(g.children()[0].width()).toBeCloseTo(90.909, 3)
+ expect(g.children()[1].width()).toBeCloseTo(63.636, 3)
+
+ expect(g.children()[0].x()).toBeCloseTo(10, 3)
+ expect(g.children()[1].x()).toBeCloseTo(46.364, 3)
+ expect(g.children()[0].height()).toBeCloseTo(85.714, 3)
+ expect(g.children()[1].height()).toBeCloseTo(71.429, 3)
+ expect(g.children()[0].y()).toBeCloseTo(20, 3)
+ expect(g.children()[1].y()).toBeCloseTo(48.571, 3)
+ })
+
+ it('changes the dimensions of the bbox (2)', () => {
+ const canvas = makeInstance().addTo('#canvas')
+ const g = canvas.group()
+
+ g.rect(400, 200).move(123, 312).rotate(34).skew(12)
+ g.rect(100, 50).move(11, 43).translate(123, 32).skew(-12)
+ g.rect(400, 200).rotate(90)
+ g.group().rotate(23).group().skew(32).rect(100, 40).skew(11).rotate(12)
+
+ const oldBox = g.bbox()
+
+ g.size(100, 100)
+
+ const newBox = g.bbox()
+
+ expect(newBox.x).toBeCloseTo(oldBox.x, 4)
+ expect(newBox.y).toBeCloseTo(oldBox.y, 4)
+ expect(newBox.w).toBeCloseTo(100, 4)
+ expect(newBox.h).toBeCloseTo(100, 4)
})
+
+
})
describe('width()', () => {