Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

delete.test.ts 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. import state from 'state'
  2. import inputs from 'state/inputs'
  3. import { ShapeType } from 'types'
  4. import { getShape } from 'utils'
  5. import {
  6. idsAreSelected,
  7. point,
  8. rectangleId,
  9. arrowId,
  10. getOnlySelectedShape,
  11. assertShapeProps,
  12. } from './test-utils'
  13. import * as json from './__mocks__/document.json'
  14. describe('deleting single shapes', () => {
  15. state.reset()
  16. state.send('MOUNTED').send('LOADED_FROM_FILE', { json: JSON.stringify(json) })
  17. it('deletes a shape and undoes the delete', () => {
  18. state
  19. .send('CANCELED')
  20. .send('POINTED_SHAPE', inputs.pointerDown(point(), rectangleId))
  21. .send('STOPPED_POINTING', inputs.pointerUp(point(), rectangleId))
  22. expect(idsAreSelected(state.data, [rectangleId])).toBe(true)
  23. state.send('DELETED')
  24. expect(idsAreSelected(state.data, [])).toBe(true)
  25. expect(getShape(state.data, rectangleId)).toBe(undefined)
  26. state.send('UNDO')
  27. expect(getShape(state.data, rectangleId)).toBeTruthy()
  28. expect(idsAreSelected(state.data, [rectangleId])).toBe(true)
  29. state.send('REDO')
  30. expect(getShape(state.data, rectangleId)).toBe(undefined)
  31. state.send('UNDO')
  32. })
  33. })
  34. describe('deletes and restores grouped shapes', () => {
  35. state.reset()
  36. state.send('MOUNTED').send('LOADED_FROM_FILE', { json: JSON.stringify(json) })
  37. it('creates a group', () => {
  38. expect(state.data.document).toMatchSnapshot('data after mount from file')
  39. state
  40. .send('CANCELED')
  41. .send('POINTED_SHAPE', inputs.pointerDown(point(), rectangleId))
  42. .send('STOPPED_POINTING', inputs.pointerUp(point(), rectangleId))
  43. .send(
  44. 'POINTED_SHAPE',
  45. inputs.pointerDown(point({ shiftKey: true }), arrowId)
  46. )
  47. .send(
  48. 'STOPPED_POINTING',
  49. inputs.pointerUp(point({ shiftKey: true }), arrowId)
  50. )
  51. expect(idsAreSelected(state.data, [rectangleId, arrowId])).toBe(true)
  52. state.send('GROUPED')
  53. const group = getOnlySelectedShape(state.data)
  54. // Should select the group
  55. expect(assertShapeProps(group, { type: ShapeType.Group }))
  56. const arrow = getShape(state.data, arrowId)
  57. // The arrow should be have the group as its parent
  58. expect(assertShapeProps(arrow, { parentId: group.id }))
  59. })
  60. // it('selects the new group', () => {
  61. // expect(idsAreSelected(state.data, [groupId])).toBe(true)
  62. // })
  63. // it('assigns a new parent', () => {
  64. // expect(groupId === state.data.currentPageId).toBe(false)
  65. // })
  66. // // Rectangle has the same new parent?
  67. // it('assigns new parent to all selected shapes', () => {
  68. // expect(hasParent(state.data, arrowId, groupId)).toBe(true)
  69. // })
  70. // // New parent is selected?
  71. // it('selects the new parent', () => {
  72. // expect(idsAreSelected(state.data, [groupId])).toBe(true)
  73. // })
  74. })
  75. // // it('selects the group when pointing a shape', () => {
  76. // // state
  77. // // .send('CANCELED')
  78. // // .send('POINTED_SHAPE', inputs.pointerDown(point(), rectangleId))
  79. // // .send('STOPPED_POINTING', inputs.pointerUp(point(), rectangleId))
  80. // // expect(idsAreSelected(state.data, [groupId])).toBe(true)
  81. // // })
  82. // // it('keeps selection when pointing bounds', () => {
  83. // // state
  84. // // .send('CANCELED')
  85. // // .send('POINTED_BOUNDS', inputs.pointerDown(point(), 'bounds'))
  86. // // .send('STOPPED_POINTING', inputs.pointerUp(point(), 'bounds'))
  87. // // expect(idsAreSelected(state.data, [groupId])).toBe(true)
  88. // // })
  89. // // it('selects a grouped shape by double-pointing', () => {
  90. // // state
  91. // // .send('CANCELED')
  92. // // .send('DOUBLE_POINTED_SHAPE', inputs.pointerDown(point(), rectangleId))
  93. // // .send('STOPPED_POINTING', inputs.pointerUp(point(), rectangleId))
  94. // // expect(idsAreSelected(state.data, [rectangleId])).toBe(true)
  95. // // })
  96. // // it('selects a sibling on point when selecting a grouped shape', () => {
  97. // // state
  98. // // .send('POINTED_SHAPE', inputs.pointerDown(point(), arrowId))
  99. // // .send('STOPPED_POINTING', inputs.pointerUp(point(), arrowId))
  100. // // expect(idsAreSelected(state.data, [arrowId])).toBe(true)
  101. // // })
  102. // // it('rises up a selection level when escape is pressed', () => {
  103. // // state
  104. // // .send('CANCELED')
  105. // // .send('POINTED_SHAPE', inputs.pointerDown(point(), rectangleId))
  106. // // .send('STOPPED_POINTING', inputs.pointerUp(point(), rectangleId))
  107. // // expect(idsAreSelected(state.data, [groupId])).toBe(true)
  108. // // })
  109. // // it('deletes and restores one shape', () => {
  110. // // // Delete the rectangle first
  111. // // state.send('UNDO')
  112. // // expect(getShape(state.data, rectangleId)).toBeTruthy()
  113. // // expect(idsAreSelected(state.data, [rectangleId])).toBe(true)
  114. // // state.send('REDO')
  115. // // expect(getShape(state.data, rectangleId)).toBe(undefined)
  116. // // state.send('UNDO')
  117. // // expect(getShape(state.data, rectangleId)).toBeTruthy()
  118. // // expect(idsAreSelected(state.data, [rectangleId])).toBe(true)
  119. // // })
  120. // })