diff --git a/package.json b/package.json index 5908446b..24bab760 100644 --- a/package.json +++ b/package.json @@ -12,6 +12,7 @@ "@types/color": "^3.0.3", "@types/crypto-js": "^4.1.1", "@types/keymaster": "^1.6.30", + "@types/lodash": "^4.14.184", "animate.css": "^4.1.1", "axios": "^0.27.2", "color": "^4.2.3", 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/packages/public/publicConfig.ts b/src/packages/public/publicConfig.ts index a285cf13..ddccc09d 100644 --- a/src/packages/public/publicConfig.ts +++ b/src/packages/public/publicConfig.ts @@ -104,5 +104,5 @@ export class PublicGroupConfigClass extends publicConfig implements CreateCompon // 标识 public id = getUUID() // 基本信息 - public attr = { w: 0, h: 0, x: 0, y: 0, zIndex: -1 } + public attr = { w: 0, h: 0, x: 0, y: 0, offsetX: 0, offsetY: 0, zIndex: -1 } } diff --git a/src/settings/designSetting.ts b/src/settings/designSetting.ts index 56e2d6ad..b919db14 100644 --- a/src/settings/designSetting.ts +++ b/src/settings/designSetting.ts @@ -25,7 +25,10 @@ export const chartInitConfig = { x: 50, y: 50, w: 500, - h: 300 + h: 300, + // 不建议动 offset + offsetX: 0, + offsetY: 0, } // dialog 图标的大小 diff --git a/src/store/modules/chartEditStore/chartEditStore.ts b/src/store/modules/chartEditStore/chartEditStore.ts index e8ebcaa3..68c77dec 100644 --- a/src/store/modules/chartEditStore/chartEditStore.ts +++ b/src/store/modules/chartEditStore/chartEditStore.ts @@ -337,6 +337,28 @@ export const useChartEditStore = defineStore({ loadingError() } }, + // * 重置组件位置 + resetComponentPosition(item: CreateComponentType | CreateComponentGroupType, isForward: boolean): void { + const index = this.fetchTargetIndex(item.id) + if (index > -1) { + const componentInstance = this.getComponentList[index] + 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 + }) + } + } + }, + // * 移动组件 + moveComponentList(item: Array) { + chartHistoryStore.createMoveHistory(item) + }, // * 更新组件列表某一项的值 updateComponentList(index: number, newData: CreateComponentType | CreateComponentGroupType) { if (index < 1 && index > this.getComponentList.length) return @@ -554,6 +576,15 @@ export const useChartEditStore = defineStore({ return } + // 处理移动 + const isMove = HistoryItem.actionType === HistoryActionTypeEnum.MOVE + if (isMove) { + historyData.forEach(item => { + this.resetComponentPosition(item, isForward) + }) + return + } + // 处理层级 const isTop = HistoryItem.actionType === HistoryActionTypeEnum.TOP const isBottom = HistoryItem.actionType === HistoryActionTypeEnum.BOTTOM @@ -586,12 +617,12 @@ export const useChartEditStore = defineStore({ if (isGroup || isUnGroup) { if ((isGroup && isForward) || (isUnGroup && !isForward)) { const ids: string[] = [] - if(historyData.length > 1) { + if (historyData.length > 1) { historyData.forEach(item => { ids.push(item.id) }) } else { - (historyData[0] as CreateComponentGroupType).groupList.forEach(item => { + ;(historyData[0] as CreateComponentGroupType).groupList.forEach(item => { ids.push(item.id) }) } @@ -599,7 +630,7 @@ export const useChartEditStore = defineStore({ return } // 都需使用子组件的id去解组 - if(historyData.length > 1) { + if (historyData.length > 1) { this.setUnGroup([(historyData[0] as CreateComponentType).id], undefined, false) } else { this.setUnGroup([(historyData[0] as CreateComponentGroupType).groupList[0].id], undefined, false) diff --git a/src/views/chart/ContentEdit/components/EditAlignLine/index.vue b/src/views/chart/ContentEdit/components/EditAlignLine/index.vue index 21cd161f..e65f5c6d 100644 --- a/src/views/chart/ContentEdit/components/EditAlignLine/index.vue +++ b/src/views/chart/ContentEdit/components/EditAlignLine/index.vue @@ -85,6 +85,8 @@ const canvasPositionList = computed(() => { h: cloneDeep(chartEditStore.getEditCanvasConfig.height), x: 0, y: 0, + offsetX: 0, + offsetY: 0, zIndex: 0 } } diff --git a/src/views/chart/ContentEdit/components/EditSelect/index.vue b/src/views/chart/ContentEdit/components/EditSelect/index.vue index e307e118..1a8df6c7 100644 --- a/src/views/chart/ContentEdit/components/EditSelect/index.vue +++ b/src/views/chart/ContentEdit/components/EditSelect/index.vue @@ -41,7 +41,10 @@ watch( // 宽 w: 0, // 高 - h: 0 + h: 0, + // 偏移 + offsetX: 0, + offsetY: 0 } // 处理位置 diff --git a/src/views/chart/ContentEdit/hooks/useDrag.hook.ts b/src/views/chart/ContentEdit/hooks/useDrag.hook.ts index ed15914f..2e2218b6 100644 --- a/src/views/chart/ContentEdit/hooks/useDrag.hook.ts +++ b/src/views/chart/ContentEdit/hooks/useDrag.hook.ts @@ -7,7 +7,7 @@ import { useContextMenu } from '@/views/chart/hooks/useContextMenu.hook' import { useChartEditStore } from '@/store/modules/chartEditStore/chartEditStore' import { EditCanvasTypeEnum } from '@/store/modules/chartEditStore/chartEditStore.d' import { loadingStart, loadingFinish, loadingError } from '@/utils' -import throttle from 'lodash/throttle' +import { throttle, cloneDeep } from 'lodash' const chartEditStore = useChartEditStore() const { onClickOutSide } = useContextMenu() @@ -111,7 +111,7 @@ export const mousedownBoxSelect = (e: MouseEvent, item?: CreateComponentType | C selectAttr.x1 = Math.round(startOffsetX - (startScreenX - moveEvent.screenX) / scale) selectAttr.y1 = startOffsetY selectAttr.x2 = startOffsetX - selectAttr.y2 = Math.round(startOffsetY + (moveEvent.screenY - startScreenY ) / scale) + selectAttr.y2 = Math.round(startOffsetY + (moveEvent.screenY - startScreenY) / scale) // 左下方向 } else { // 左上方向 @@ -222,6 +222,16 @@ export const useMouseHandle = () => { const startX = e.screenX const startY = e.screenY + // 记录历史位置 + let prevComponentInstance: Array = [] + chartEditStore.getTargetChart.selectId.forEach(id => { + if (!targetMap.has(id)) return + + const index = chartEditStore.fetchTargetIndex(id) + // 拿到初始位置数据 + prevComponentInstance.push(cloneDeep(chartEditStore.getComponentList[index])) + }) + // 记录初始位置 chartEditStore.setMousePosition(undefined, undefined, startX, startY) @@ -267,6 +277,24 @@ export const useMouseHandle = () => { const mouseup = () => { chartEditStore.setMousePosition(0, 0, 0, 0) chartEditStore.setEditCanvas(EditCanvasTypeEnum.IS_DRAG, false) + // 加入历史栈 + if (prevComponentInstance.length) { + chartEditStore.getTargetChart.selectId.forEach(id => { + if (!targetMap.has(id)) return + const index = chartEditStore.fetchTargetIndex(id) + const curComponentInstance = chartEditStore.getComponentList[index] + // 找到记录的所选组件 + prevComponentInstance.forEach(preItem => { + if (preItem.id === id) { + preItem.attr = Object.assign(preItem.attr, { + offsetX: curComponentInstance.attr.x - preItem.attr.x, + offsetY: curComponentInstance.attr.y - preItem.attr.y + }) + } + }) + }) + chartEditStore.moveComponentList(prevComponentInstance) + } document.removeEventListener('mousemove', mousemove) document.removeEventListener('mouseup', mouseup) }