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.

create-page.ts 1.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import Command from './command'
  2. import history from '../history'
  3. import { Data, Page, PageState } from 'types'
  4. import { uniqueId } from 'utils/utils'
  5. import storage from 'state/storage'
  6. export default function createPage(data: Data, goToPage = true): void {
  7. const snapshot = getSnapshot(data)
  8. history.execute(
  9. data,
  10. new Command({
  11. name: 'create_page',
  12. category: 'canvas',
  13. do(data) {
  14. const { page, pageState, currentPageId } = snapshot
  15. data.document.pages[page.id] = page
  16. data.pageStates[page.id] = pageState
  17. data.currentPageId = page.id
  18. storage.savePage(data, data.document.id, page.id)
  19. storage.saveDocumentToLocalStorage(data)
  20. if (goToPage) {
  21. data.currentPageId = page.id
  22. } else {
  23. data.currentPageId = currentPageId
  24. }
  25. },
  26. undo(data) {
  27. const { page, currentPageId } = snapshot
  28. delete data.document.pages[page.id]
  29. delete data.pageStates[page.id]
  30. data.currentPageId = currentPageId
  31. storage.saveDocumentToLocalStorage(data)
  32. },
  33. })
  34. )
  35. }
  36. function getSnapshot(data: Data) {
  37. const { currentPageId } = data
  38. const pages = Object.values(data.document.pages)
  39. const unchanged = pages.filter((page) => page.name.startsWith('Page '))
  40. const id = uniqueId()
  41. const page: Page = {
  42. type: 'page',
  43. id,
  44. name: `Page ${unchanged.length + 1}`,
  45. childIndex: pages.length,
  46. shapes: {},
  47. }
  48. const pageState: PageState = {
  49. id,
  50. selectedIds: new Set([]),
  51. camera: {
  52. point: [0, 0],
  53. zoom: 1,
  54. },
  55. }
  56. return {
  57. currentPageId,
  58. page,
  59. pageState,
  60. }
  61. }