104 lines
2.1 KiB
TypeScript
104 lines
2.1 KiB
TypeScript
import { ShapeType } from 'types'
|
|
import TestState from '../test-utils'
|
|
|
|
describe('rectangle shape', () => {
|
|
const tt = new TestState()
|
|
tt.resetDocumentState().save()
|
|
|
|
describe('creating rectangles', () => {
|
|
it('creates shape', () => {
|
|
tt.reset().restore().send('SELECTED_RECTANGLE_TOOL')
|
|
|
|
expect(tt.state.isIn('rectangle.creating')).toBe(true)
|
|
|
|
tt.startClick('canvas').movePointerBy([100, 100]).stopClick('canvas')
|
|
|
|
const id = tt.getSortedPageShapeIds()[0]
|
|
|
|
tt.assertShapeType(id, ShapeType.Rectangle)
|
|
})
|
|
|
|
it('creates shapes when pointing a shape', () => {
|
|
tt.reset()
|
|
.restore()
|
|
.send('SELECTED_RECTANGLE_TOOL')
|
|
.send('TOGGLED_TOOL_LOCK')
|
|
|
|
tt.startClick('canvas').movePointerBy([100, 100]).stopClick('canvas')
|
|
tt.startClick('canvas').movePointerBy([-200, 100]).stopClick('canvas')
|
|
|
|
expect(tt.getSortedPageShapeIds()).toHaveLength(2)
|
|
})
|
|
|
|
it('creates shapes when shape locked', () => {
|
|
tt.reset()
|
|
.restore()
|
|
.createShape(
|
|
{
|
|
type: ShapeType.Rectangle,
|
|
point: [0, 0],
|
|
size: [100, 100],
|
|
childIndex: 1,
|
|
},
|
|
'rect1'
|
|
)
|
|
.send('SELECTED_RECTANGLE_TOOL')
|
|
|
|
tt.startClick('rect1').movePointerBy([100, 100]).stopClick('canvas')
|
|
|
|
expect(tt.getSortedPageShapeIds()).toHaveLength(2)
|
|
})
|
|
|
|
it('cancels shape while creating', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
})
|
|
|
|
it('moves shape', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('rotates shape', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('rotates shape in a group', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('measures shape bounds', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('measures shape rotated bounds', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('transforms single shape', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('transforms in a group', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
/* -------------------- Specific -------------------- */
|
|
|
|
it('creates aspect-ratio-locked shape with shift key', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
|
|
it('resizes aspect-ratio-locked shape with shift key', () => {
|
|
// TODO
|
|
null
|
|
})
|
|
})
|