index.ts 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. import { EditorModule } from "..";
  2. import { DesignTemp } from "../../objects/DesignTemp";
  3. import { DesignComp } from "../../objects/DesignTemp/DesignComp";
  4. import { EditorMode, ICompKeys } from "../../typings";
  5. export const store = EditorModule.store({
  6. state: () => ({
  7. textEditingState: false,
  8. mode: "editPage" as EditorMode,
  9. currCompId: "root",
  10. designData: new DesignTemp(),
  11. }),
  12. getters: {
  13. isEditMode(): boolean {
  14. return !this.store.isPreview;
  15. },
  16. isEditPage(state) {
  17. return state.mode === "editPage";
  18. },
  19. isEditComp(state) {
  20. return state.mode === "editComp";
  21. },
  22. isPreview(state) {
  23. return state.mode === "preview";
  24. },
  25. currComp(state) {
  26. return state.designData.compMap[state.currCompId];
  27. },
  28. pageCompIds(state): string[] {
  29. return state.designData.compMap.root?.children.default || [];
  30. },
  31. },
  32. actions: {
  33. setCompData(id: string, data: any) {
  34. this.store.designData.compMap[id] = data;
  35. },
  36. setMode(v: EditorMode) {
  37. this.store.mode = v;
  38. },
  39. initDesignData(data: Partial<DesignTemp>) {
  40. this.store.designData = new DesignTemp(data);
  41. },
  42. async insertDesignContent(compKey: ICompKeys, index?: number) {
  43. const { pageCompIds } = this.store;
  44. index === undefined && (index = pageCompIds.length);
  45. const compId = await this.controls.compUICtrl.createCompId(
  46. compKey,
  47. "root"
  48. );
  49. pageCompIds.splice(index, 0, compId);
  50. return compId;
  51. },
  52. async insertCompContainer(compKey: ICompKeys, container: DesignComp) {
  53. const compId = await this.controls.compUICtrl.createCompId(
  54. compKey,
  55. container.id
  56. );
  57. container.children.default || (container.children.default = []);
  58. container.children.default.push(compId);
  59. return compId;
  60. },
  61. setCurrComp(compId: string) {
  62. this.store.currCompId = compId;
  63. },
  64. deleteComp(compId: string) {
  65. const { compMap } = this.store.designData;
  66. const parentComp = this.helper.findParentComp(compId);
  67. let deleteOK = false;
  68. if (parentComp) {
  69. const ids = parentComp.children.default;
  70. // 只能删除children.default中的组件
  71. if (ids?.includes(compId)) {
  72. const index = ids.findIndex((id) => id === compId);
  73. if (index >= 0) {
  74. ids.splice(index, 1);
  75. deleteOK = true;
  76. }
  77. }
  78. }
  79. if (deleteOK) {
  80. const comp = this.helper.findComp(compId) as DesignComp;
  81. const ids = comp.getChildIds();
  82. [compId, ...ids].forEach((id) => {
  83. delete compMap[id];
  84. });
  85. }
  86. },
  87. moveComp(selIndex: number, targetIndex: number) {
  88. const { pageCompIds } = this.store;
  89. const [selComp] = pageCompIds.splice(selIndex, 1);
  90. pageCompIds.splice(targetIndex, 0, selComp);
  91. },
  92. clearUnusedComps() {
  93. const used = new Set<string>();
  94. const getUsedIds = (ids: string[]) => {
  95. ids.forEach((id) => {
  96. const comp = this.helper.findComp(id);
  97. if (!comp) return;
  98. used.add(id);
  99. getUsedIds(comp.getChildIds());
  100. });
  101. return used;
  102. };
  103. const rootId = (this.helper.findRootComp() as DesignComp).id;
  104. getUsedIds([rootId]);
  105. Object.keys(this.store.designData.compMap).forEach((compId) => {
  106. if (!used.has(compId)) {
  107. delete this.store.designData.compMap[compId];
  108. }
  109. });
  110. },
  111. setTextEditingState(state: boolean) {
  112. this.store.textEditingState = state;
  113. },
  114. updateDesignThumbnail(url: string) {
  115. this.store.designData.thumbnail = url;
  116. },
  117. },
  118. });