mutations.ts 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. import { MutationTree } from 'vuex'
  2. import { MutationTypes } from './constants'
  3. import { State } from './index'
  4. import { Slide, PPTElement } from '@/types/slides'
  5. import { FONT_NAMES } from '@/configs/fontName'
  6. import { isSupportFontFamily } from '@/utils/fontFamily'
  7. interface UpdateElementData {
  8. id: string | string[];
  9. props: Partial<PPTElement>;
  10. }
  11. export const mutations: MutationTree<State> = {
  12. // editor
  13. [MutationTypes.SET_ACTIVE_ELEMENT_ID_LIST](state, activeElementIdList: string[]) {
  14. if(activeElementIdList.length === 1) state.handleElementId = activeElementIdList[0]
  15. else state.handleElementId = ''
  16. state.activeElementIdList = activeElementIdList
  17. },
  18. [MutationTypes.SET_HANDLE_ELEMENT_ID](state, handleElementId: string) {
  19. state.handleElementId = handleElementId
  20. },
  21. [MutationTypes.SET_CANVAS_PERCENTAGE](state, percentage: number) {
  22. state.canvasPercentage = percentage
  23. },
  24. [MutationTypes.SET_CANVAS_SCALE](state, scale: number) {
  25. state.canvasScale = scale
  26. },
  27. [MutationTypes.SET_THUMBNAILS_FOCUS](state, isFocus: boolean) {
  28. state.thumbnailsFocus = isFocus
  29. },
  30. [MutationTypes.SET_EDITORAREA_FOCUS](state, isFocus: boolean) {
  31. state.editorAreaFocus = isFocus
  32. },
  33. [MutationTypes.SET_DISABLE_HOTKEYS_STATE](state, disable: boolean) {
  34. state.disableHotkeys = disable
  35. },
  36. [MutationTypes.SET_GRID_LINES_STATE](state, show: boolean) {
  37. state.showGridLines = show
  38. },
  39. [MutationTypes.SET_AVAILABLE_FONTS](state) {
  40. state.availableFonts = FONT_NAMES.filter(font => isSupportFontFamily(font.en))
  41. },
  42. // slides
  43. [MutationTypes.SET_SLIDES](state, slides: Slide[]) {
  44. state.slides = slides
  45. },
  46. [MutationTypes.ADD_SLIDE](state, slide: Slide) {
  47. const addIndex = state.slideIndex + 1
  48. state.slides.splice(addIndex, 0, slide)
  49. state.slideIndex = addIndex
  50. },
  51. [MutationTypes.UPDATE_SLIDE](state, props: Partial<Slide>) {
  52. const slideIndex = state.slideIndex
  53. state.slides[slideIndex] = { ...state.slides[slideIndex], ...props }
  54. },
  55. [MutationTypes.DELETE_SLIDE](state, slideId: string) {
  56. const deleteIndex = state.slides.findIndex(item => item.id === slideId)
  57. if(deleteIndex === state.slides.length - 1) {
  58. state.slideIndex = deleteIndex - 1
  59. }
  60. state.slides.splice(deleteIndex, 1)
  61. },
  62. [MutationTypes.UPDATE_SLIDE_INDEX](state, index: number) {
  63. state.slideIndex = index
  64. },
  65. [MutationTypes.ADD_ELEMENT](state, element: PPTElement | PPTElement[]) {
  66. const elements = Array.isArray(element) ? element : [element]
  67. const currentSlideEls = state.slides[state.slideIndex].elements
  68. const newEls = [...currentSlideEls, ...elements]
  69. state.slides[state.slideIndex].elements = newEls
  70. },
  71. [MutationTypes.UPDATE_ELEMENT](state, data: UpdateElementData) {
  72. const { id, props } = data
  73. const elIdList = typeof id === 'string' ? [id] : id
  74. const slideIndex = state.slideIndex
  75. const slide = state.slides[slideIndex]
  76. const elements = slide.elements.map(el => {
  77. return elIdList.includes(el.id) ? { ...el, ...props } : el
  78. })
  79. state.slides[slideIndex].elements = (elements as PPTElement[])
  80. },
  81. // snapshot
  82. [MutationTypes.SET_SNAPSHOT_CURSOR](state, cursor: number) {
  83. state.snapshotCursor = cursor
  84. },
  85. [MutationTypes.SET_SNAPSHOT_LENGTH](state, length: number) {
  86. state.snapshotLength = length
  87. },
  88. // keyboard
  89. [MutationTypes.SET_CTRL_KEY_STATE](state, isActive: boolean) {
  90. state.ctrlKeyState = isActive
  91. },
  92. [MutationTypes.SET_SHIFT_KEY_STATE](state, isActive: boolean) {
  93. state.shiftKeyState = isActive
  94. },
  95. // screen
  96. [MutationTypes.SET_SCREENING](state, screening) {
  97. state.screening = screening
  98. },
  99. }