You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

delete-page.ts 1.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. import Command from './command'
  2. import history from '../history'
  3. import { Data } from 'types'
  4. import { current } from 'immer'
  5. import storage from 'state/storage'
  6. export default function deletePage(data: Data, pageId: string): void {
  7. const snapshot = getSnapshot(data, pageId)
  8. history.execute(
  9. data,
  10. new Command({
  11. name: 'delete_page',
  12. category: 'canvas',
  13. do(data) {
  14. data.currentPageId = snapshot.nextPageId
  15. delete data.document.pages[pageId]
  16. delete data.pageStates[pageId]
  17. storage.loadPage(data, snapshot.nextPageId)
  18. },
  19. undo(data) {
  20. data.currentPageId = snapshot.currentPageId
  21. data.document.pages[pageId] = snapshot.page
  22. data.pageStates[pageId] = snapshot.pageState
  23. storage.loadPage(data, snapshot.currentPageId)
  24. },
  25. })
  26. )
  27. }
  28. function getSnapshot(data: Data, pageId: string) {
  29. const cData = current(data)
  30. const { currentPageId, document } = cData
  31. const page = document.pages[pageId]
  32. const pageState = cData.pageStates[pageId]
  33. const isCurrent = currentPageId === pageId
  34. // const nextIndex = isCurrent
  35. // ? page.childIndex === 0
  36. // ? 1
  37. // : page.childIndex - 1
  38. // : document.pages[currentPageId].childIndex
  39. const nextPageId = isCurrent
  40. ? Object.values(document.pages).filter((page) => page.id !== pageId)[0]?.id // TODO: should be at nextIndex
  41. : cData.currentPageId
  42. return {
  43. nextPageId,
  44. isCurrent,
  45. currentPageId,
  46. page,
  47. pageState,
  48. }
  49. }