From f691bb8437258d0b0f5b1676a0dd9e97640c14a7 Mon Sep 17 00:00:00 2001 From: yangwq7 Date: Tue, 30 Aug 2022 14:14:56 +0800 Subject: [PATCH] =?UTF-8?q?perf:=20=E8=A7=A3=E8=80=A6=E7=A7=BB=E5=8A=A8?= =?UTF-8?q?=E7=9B=B8=E5=85=B3=E5=90=8E=E9=80=80=E3=80=81=E5=89=8D=E8=BF=9B?= =?UTF-8?q?=E9=80=BB=E8=BE=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/packages/index.d.ts | 2 +- .../modules/chartEditStore/chartEditStore.ts | 19 ++++-- .../chartHistoryStore/chartHistoryStore.ts | 65 +++---------------- .../chart/ContentEdit/hooks/useDrag.hook.ts | 9 +++ 4 files changed, 33 insertions(+), 62 deletions(-) diff --git a/src/packages/index.d.ts b/src/packages/index.d.ts index 153dc6af..8b80eced 100644 --- a/src/packages/index.d.ts +++ b/src/packages/index.d.ts @@ -63,7 +63,7 @@ export enum FilterEnum { export interface PublicConfigType { id: string isGroup: boolean - attr: { x: number; y: number; w: number; h: number; zIndex: number } + attr: { x: number; y: number; w: number; h: number; zIndex: number; offsetX: number; offsetY: number; } styles: { [FilterEnum.OPACITY]: number [FilterEnum.SATURATE]: number diff --git a/src/store/modules/chartEditStore/chartEditStore.ts b/src/store/modules/chartEditStore/chartEditStore.ts index c694436d..4a50a7eb 100644 --- a/src/store/modules/chartEditStore/chartEditStore.ts +++ b/src/store/modules/chartEditStore/chartEditStore.ts @@ -314,14 +314,21 @@ export const useChartEditStore = defineStore({ } }, // * 重置组件位置 - resetComponentPostion(item: CreateComponentType | CreateComponentGroupType):void{ + resetComponentPostion(item: CreateComponentType | CreateComponentGroupType, isForward: boolean):void{ const index = this.fetchTargetIndex(item.id) if(index > -1){ const componentInstance = this.getComponentList[index] - componentInstance.attr = Object.assign(componentInstance.attr, { - x: item.attr.x, - y: item.attr.y - }) + if(isForward){ + componentInstance.attr = Object.assign(componentInstance.attr, { + x: item.attr.x + item.attr.offsetX, + y: item.attr.y + item.attr.offsetY + }) + }else{ + componentInstance.attr = Object.assign(componentInstance.attr, { + x: item.attr.x, + y: item.attr.y + }) + } } }, // * 移动组件 @@ -549,7 +556,7 @@ export const useChartEditStore = defineStore({ const isMove = HistoryItem.actionType === HistoryActionTypeEnum.MOVE if(isMove){ historyData.forEach(item => { - this.resetComponentPostion(item) + this.resetComponentPostion(item, isForward) }) return } diff --git a/src/store/modules/chartHistoryStore/chartHistoryStore.ts b/src/store/modules/chartHistoryStore/chartHistoryStore.ts index 5f2f44df..b8627ca6 100644 --- a/src/store/modules/chartHistoryStore/chartHistoryStore.ts +++ b/src/store/modules/chartHistoryStore/chartHistoryStore.ts @@ -1,7 +1,6 @@ import { defineStore } from 'pinia' import { CreateComponentType, CreateComponentGroupType } from '@/packages/index.d' import { EditCanvasType } from '@/store/modules/chartEditStore/chartEditStore.d' -import { useChartEditStore } from '@/store/modules/chartEditStore/chartEditStore' import { loadingStart, loadingFinish, loadingError } from '@/utils' import { editHistoryMax } from '@/settings/designSetting' import { @@ -11,7 +10,6 @@ import { HistoryItemType, ChartHistoryStoreType } from './chartHistoryStore.d' -import { cloneDeep } from 'lodash' export const useChartHistoryStore = defineStore({ id: 'useChartHistoryStore', @@ -97,33 +95,12 @@ export const useChartHistoryStore = defineStore({ // 排除画布初始化 if (this.getBackStack.length > 1) { const targetData = this.popBackStackItem() - // 移动时逻辑单独处理 - const isMove = targetData?.actionType === HistoryActionTypeEnum.MOVE - if(isMove){ - const chartEditStore = useChartEditStore() - // 将当前状态存入前进栈 - const curTargetData:HistoryItemType = cloneDeep(targetData) - curTargetData.historyData.forEach(item => { - if(item.id){ - const index = chartEditStore.fetchTargetIndex(item.id) - if(index > -1){ - const componentInstance = chartEditStore.getComponentList[index] - item.attr = Object.assign(item.attr, { - x: componentInstance.attr.x, - y: componentInstance.attr.y - }) - } - } - }) - this.pushForwardStack(curTargetData) - }else{ - if (!targetData) { - loadingFinish() - return - } - // 移除记录到前进栈 - this.pushForwardStack(targetData) + if (!targetData) { + loadingFinish() + return } + // 移除记录到前进堆 + this.pushForwardStack(targetData) loadingFinish() return targetData } @@ -138,34 +115,12 @@ export const useChartHistoryStore = defineStore({ loadingStart() if (this.getForwardStack.length) { const targetData = this.popForwardStack() - // 移动时逻辑单独处理 - const isMove = targetData?.actionType === HistoryActionTypeEnum.MOVE - if(isMove){ - const chartEditStore = useChartEditStore() - // 将当前状态存入后退栈 - const curTargetData:HistoryItemType = cloneDeep(targetData) - curTargetData.historyData.forEach(item => { - if(item.id){ - const index = chartEditStore.fetchTargetIndex(item.id) - if(index > -1){ - const componentInstance = chartEditStore.getComponentList[index] - item.attr = Object.assign(item.attr, { - x: componentInstance.attr.x, - y: componentInstance.attr.y - }) - } - } - }) - this.pushBackStackItem(curTargetData, true) - }else{ - if (!targetData) { - loadingFinish() - return - } - // 放入后退栈 - this.pushBackStackItem(targetData, true) + if (!targetData) { + loadingFinish() + return } - + // 放入后退栈 + this.pushBackStackItem(targetData, true) loadingFinish() return targetData } diff --git a/src/views/chart/ContentEdit/hooks/useDrag.hook.ts b/src/views/chart/ContentEdit/hooks/useDrag.hook.ts index 1caac641..b6b1b61d 100644 --- a/src/views/chart/ContentEdit/hooks/useDrag.hook.ts +++ b/src/views/chart/ContentEdit/hooks/useDrag.hook.ts @@ -279,6 +279,15 @@ export const useMouseHandle = () => { chartEditStore.setEditCanvas(EditCanvasTypeEnum.IS_DRAG, false) // 加入历史栈 if(prevComponentInstance){ + chartEditStore.getTargetChart.selectId.forEach(id => { + if (!targetMap.has(id)) return + const index = chartEditStore.fetchTargetIndex(id) + const curComponentInstance = chartEditStore.getComponentList[index] + prevComponentInstance.attr = Object.assign(prevComponentInstance.attr, { + offsetX: curComponentInstance.attr.x - prevComponentInstance.attr.x, + offsetY: curComponentInstance.attr.y - prevComponentInstance.attr.y + }) + }) chartEditStore.moveComponentList(prevComponentInstance) } document.removeEventListener('mousemove', mousemove)