diff --git a/src/store/modules/chartEditStore/chartEditStore.ts b/src/store/modules/chartEditStore/chartEditStore.ts index 36ad45d7..61ccd070 100644 --- a/src/store/modules/chartEditStore/chartEditStore.ts +++ b/src/store/modules/chartEditStore/chartEditStore.ts @@ -10,16 +10,13 @@ import { requestInterval, previewScaleType, requestIntervalUnit } from '@/settin import { useChartHistoryStore } from '@/store/modules/chartHistoryStore/chartHistoryStore' // 全局设置 import { useSettingStore } from '@/store/modules/settingStore/settingStore' -import { HistoryActionTypeEnum, HistoryItemType, HistoryTargetTypeEnum } from '@/store/modules/chartHistoryStore/chartHistoryStore.d' +import { + HistoryActionTypeEnum, + HistoryItemType, + HistoryTargetTypeEnum +} from '@/store/modules/chartHistoryStore/chartHistoryStore.d' import { MenuEnum } from '@/enums/editPageEnum' -import { - getUUID, - loadingStart, - loadingFinish, - loadingError, - isString, - isArray -} from '@/utils' +import { getUUID, loadingStart, loadingFinish, loadingError, isString, isArray } from '@/utils' import { ChartEditStoreEnum, ChartEditStorage, @@ -115,8 +112,8 @@ export const useChartEditStore = defineStore({ requestIntervalUnit: requestIntervalUnit, requestParams: { Body: { - "form-data": {}, - "x-www-form-urlencoded": {}, + 'form-data': {}, + 'x-www-form-urlencoded': {}, json: '', xml: '' }, @@ -163,11 +160,11 @@ export const useChartEditStore = defineStore({ }, actions: { // * 设置 editCanvas 数据项 - setEditCanvas(key: T, value: K) { + setEditCanvas(key: T, value: K) { this.editCanvas[key] = value }, // * 设置 editCanvasConfig(需保存后端) 数据项 - setEditCanvasConfig(key: T, value: K) { + setEditCanvasConfig(key: T, value: K) { this.editCanvasConfig[key] = value }, // * 设置右键菜单 @@ -175,7 +172,7 @@ export const useChartEditStore = defineStore({ this.rightMenuShow = value }, // * 设置目标数据 hover - setTargetHoverChart(hoverId?:TargetChartType["hoverId"]) { + setTargetHoverChart(hoverId?: TargetChartType['hoverId']) { this.targetChart.hoverId = hoverId }, // * 设置目标数据 select @@ -226,7 +223,7 @@ export const useChartEditStore = defineStore({ }, // * 找到目标 id 数据的下标位置,id可为父级或子集数组(无则返回-1) fetchTargetIndex(id?: string): number { - const targetId = id || this.getTargetChart.selectId.length && this.getTargetChart.selectId[0] || undefined + const targetId = id || (this.getTargetChart.selectId.length && this.getTargetChart.selectId[0]) || undefined if (!targetId) { loadingFinish() return -1 @@ -238,9 +235,9 @@ export const useChartEditStore = defineStore({ return targetIndex } else { const length = this.getComponentList.length - for(let i = 0; i < length; i++) { + for (let i = 0; i < length; i++) { if (this.getComponentList[i].isGroup) { - for(const cItem of (this.getComponentList[i] as CreateComponentGroupType).groupList) { + for (const cItem of (this.getComponentList[i] as CreateComponentGroupType).groupList) { if (cItem.id === targetId) { return i } @@ -256,7 +253,7 @@ export const useChartEditStore = defineStore({ if (!id) { idArr.push(...this.getTargetChart.selectId) return idArr - } + } if (isString(id)) idArr.push(id) if (isArray(id)) idArr.push(...id) return idArr @@ -268,16 +265,15 @@ export const useChartEditStore = defineStore({ * @param isHistory 是否进行记录 * @returns */ - addComponentList( + addComponentList( componentInstance: | CreateComponentType | CreateComponentGroupType - | CreateComponentType[] - | CreateComponentGroupType[], + | Array, isHead = false, isHistory = false ): void { - if(componentInstance instanceof Array) { + if (componentInstance instanceof Array) { componentInstance.forEach(item => { this.addComponentList(item, isHead, isHistory) }) @@ -293,16 +289,16 @@ export const useChartEditStore = defineStore({ this.componentList.push(componentInstance) }, // * 删除组件 - removeComponentList(id?:string | string[], isHistory = true): void { + removeComponentList(id?: string | string[], isHistory = true): void { try { const idArr = this.idPreFormat(id) const history: Array = [] // 遍历所有对象 if (!idArr.length) return - + loadingStart() idArr.forEach(ids => { - const index = this.fetchTargetIndex(ids) + const index = this.fetchTargetIndex(ids) if (index !== -1) { history.push(this.getComponentList[index]) this.componentList.splice(index, 1) @@ -311,7 +307,7 @@ export const useChartEditStore = defineStore({ isHistory && chartHistoryStore.createDeleteHistory(history) loadingFinish() return - } catch(value) { + } catch (value) { loadingError() } }, @@ -321,10 +317,7 @@ export const useChartEditStore = defineStore({ this.componentList[index] = newData }, // * 设置页面样式属性 - setPageStyle( - key: T, - value: any - ): void { + setPageStyle(key: T, value: any): void { const dom = this.getEditCanvas.editContentDom if (dom) { dom.style[key] = value @@ -343,17 +336,17 @@ export const useChartEditStore = defineStore({ return } - const index = this.fetchTargetIndex() + const index = this.fetchTargetIndex() const targetData = this.getComponentList[index] if (index !== -1) { // 置底排除最底层, 置顶排除最顶层 - if ((isEnd && index === 0) || (!isEnd && index === length - 1 )) { + if ((isEnd && index === 0) || (!isEnd && index === length - 1)) { loadingFinish() return } // 记录原有位置 - const setIndex = (componentInstance:CreateComponentType | CreateComponentGroupType, i:number) => { + const setIndex = (componentInstance: CreateComponentType | CreateComponentGroupType, i: number) => { const temp = cloneDeep(componentInstance) temp.attr.zIndex = i return temp @@ -369,11 +362,11 @@ export const useChartEditStore = defineStore({ // 插入两端 this.addComponentList(targetData, isEnd) - this.getComponentList.splice(isEnd ? index + 1: index, 1) + this.getComponentList.splice(isEnd ? index + 1 : index, 1) loadingFinish() return } - } catch(value) { + } catch (value) { loadingError() } }, @@ -398,7 +391,7 @@ export const useChartEditStore = defineStore({ return } - const index:number = this.fetchTargetIndex() + const index: number = this.fetchTargetIndex() if (index !== -1) { // 下移排除最底层, 上移排除最顶层 if ((isDown && index === 0) || (!isDown && index === length - 1)) { @@ -422,7 +415,7 @@ export const useChartEditStore = defineStore({ loadingFinish() return } - } catch(value) { + } catch (value) { loadingError() } }, @@ -441,17 +434,17 @@ export const useChartEditStore = defineStore({ if (this.getTargetChart.selectId.length > 1) return loadingStart() - const index:number = this.fetchTargetIndex() + const index: number = this.fetchTargetIndex() if (index !== -1) { - const copyData:RecordChartType = { - charts :this.getComponentList[index], - type: isCut ? HistoryActionTypeEnum.CUT : HistoryActionTypeEnum.COPY + const copyData: RecordChartType = { + charts: this.getComponentList[index], + type: isCut ? HistoryActionTypeEnum.CUT : HistoryActionTypeEnum.COPY } this.setRecordChart(copyData) window['$message'].success(isCut ? '剪切图表成功' : '复制图表成功!') loadingFinish() } - } catch(value) { + } catch (value) { loadingError() } }, @@ -499,7 +492,7 @@ export const useChartEditStore = defineStore({ this.setRecordChart(undefined) } loadingFinish() - } catch(value) { + } catch (value) { loadingError() } }, @@ -512,7 +505,7 @@ export const useChartEditStore = defineStore({ } let historyData = HistoryItem.historyData as Array - if(isArray(historyData)) { + if (isArray(historyData)) { // 选中目标元素,支持多个 historyData.forEach((item: CreateComponentType | CreateComponentGroupType) => { this.setTargetSelectChart(item.id, true) @@ -566,10 +559,25 @@ export const useChartEditStore = defineStore({ const isUnGroup = HistoryItem.actionType === HistoryActionTypeEnum.UN_GROUP if (isGroup || isUnGroup) { if ((isGroup && isForward) || (isUnGroup && !isForward)) { - this.setGroup(false) + const ids: string[] = [] + if(historyData.length > 1) { + historyData.forEach(item => { + ids.push(item.id) + }) + } else { + (historyData[0] as CreateComponentGroupType).groupList.forEach(item => { + ids.push(item.id) + }) + } + this.setGroup(ids, false) return } - this.setUnGroup([historyData[0].id], undefined, false) + // 都需使用子组件的id去解组 + 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) + } return } }, @@ -584,8 +592,7 @@ export const useChartEditStore = defineStore({ } this.setBackAndSetForwardHandle(targetData) loadingFinish() - - } catch(value) { + } catch (value) { loadingError() } }, @@ -600,37 +607,36 @@ export const useChartEditStore = defineStore({ } this.setBackAndSetForwardHandle(targetData, true) loadingFinish() - - } catch(value) { + } catch (value) { loadingError() } }, // * 移动位置 setMove(keyboardValue: MenuEnum) { - const index = this.fetchTargetIndex() + const index = this.fetchTargetIndex() if (index === -1) return const attr = this.getComponentList[index].attr const distance = settingStore.getChartMoveDistance switch (keyboardValue) { case MenuEnum.ARROW_UP: attr.y -= distance - break; + break case MenuEnum.ARROW_RIGHT: attr.x += distance - break; + break case MenuEnum.ARROW_DOWN: attr.y += distance - break; + break case MenuEnum.ARROW_LEFT: attr.x -= distance - break; + break } }, // * 创建分组 - setGroup(isHistory = true) { + setGroup(id?: string | string[], isHistory = true) { try { - const selectIds = this.getTargetChart.selectId - if (selectIds.length < 2) return + const selectIds = this.idPreFormat(id) || this.getTargetChart.selectId + if (selectIds.length < 2) return loadingStart() const groupClass = new PublicGroupConfigClass() @@ -649,12 +655,16 @@ export const useChartEditStore = defineStore({ selectIds.forEach((id: string) => { const targetIndex = this.fetchTargetIndex(id) if (targetIndex !== -1 && this.getComponentList[targetIndex].isGroup) { - this.setUnGroup([id], (e: CreateComponentType[]) => { - e.forEach(e => { - this.addComponentList(e) - newSelectIds.push(e.id) - }) - }, false) + this.setUnGroup( + [id], + (e: CreateComponentType[]) => { + e.forEach(e => { + this.addComponentList(e) + newSelectIds.push(e.id) + }) + }, + false + ) } else if (targetIndex !== -1) { newSelectIds.push(id) } @@ -671,15 +681,14 @@ export const useChartEditStore = defineStore({ // 宽 groupAttr.r = r < x + w ? x + w : r // 高 - groupAttr.b = b < y + h ? y + h : b + groupAttr.b = b < y + h ? y + h : b targetList.push(item) historyList.push(toRaw(item)) }) // 修改原数据之前,先记录 - console.log(historyList) - if(isHistory) chartHistoryStore.createGroupHistory(historyList) + if (isHistory) chartHistoryStore.createGroupHistory(historyList) // 设置子组件的位置 targetList.forEach((item: CreateComponentType) => { @@ -705,7 +714,7 @@ export const useChartEditStore = defineStore({ } }, // * 解除分组 - setUnGroup(ids?:string[] , callBack?:(e: CreateComponentType[]) => void, isHistory = true) { + setUnGroup(ids?: string[], callBack?: (e: CreateComponentType[]) => void, isHistory = true) { try { const selectGroupIdArr = ids || this.getTargetChart.selectId if (selectGroupIdArr.length !== 1) return @@ -717,8 +726,8 @@ export const useChartEditStore = defineStore({ if (!targetGroup.isGroup) return // 记录数据 - if(isHistory) chartHistoryStore.createUnGroupHistory([targetGroup]) - + if (isHistory) chartHistoryStore.createUnGroupHistory(cloneDeep([targetGroup])) + // 分离组件并还原位置属性 targetGroup.groupList.forEach(item => { item.attr.x = item.attr.x + targetGroup.attr.x @@ -732,7 +741,7 @@ export const useChartEditStore = defineStore({ this.removeComponentList(targetGroup.id, false) if (callBack) { - callBack(targetGroup.groupList) + callBack(targetGroup.groupList) } } @@ -759,32 +768,24 @@ export const useChartEditStore = defineStore({ computedScale() { if (this.getEditCanvas.editLayoutDom) { // 现有展示区域 - const width = - this.getEditCanvas.editLayoutDom.clientWidth - this.getEditCanvas.offset * 2 - 5 - const height = - this.getEditCanvas.editLayoutDom.clientHeight - this.getEditCanvas.offset * 4 + const width = this.getEditCanvas.editLayoutDom.clientWidth - this.getEditCanvas.offset * 2 - 5 + const height = this.getEditCanvas.editLayoutDom.clientHeight - this.getEditCanvas.offset * 4 // 用户设定大小 const editCanvasWidth = this.editCanvasConfig.width const editCanvasHeight = this.editCanvasConfig.height // 需保持的比例 - const baseProportion = parseFloat( - (editCanvasWidth / editCanvasHeight).toFixed(5) - ) + const baseProportion = parseFloat((editCanvasWidth / editCanvasHeight).toFixed(5)) const currentRate = parseFloat((width / height).toFixed(5)) if (currentRate > baseProportion) { // 表示更宽 - const scaleWidth = parseFloat( - ((height * baseProportion) / editCanvasWidth).toFixed(5) - ) - this.setScale( scaleWidth > 1 ? 1 : scaleWidth) + const scaleWidth = parseFloat(((height * baseProportion) / editCanvasWidth).toFixed(5)) + this.setScale(scaleWidth > 1 ? 1 : scaleWidth) } else { // 表示更高 - const scaleHeight = parseFloat( - (width / baseProportion / editCanvasHeight).toFixed(5) - ) + const scaleHeight = parseFloat((width / baseProportion / editCanvasHeight).toFixed(5)) this.setScale(scaleHeight > 1 ? 1 : scaleHeight) } } else { @@ -817,4 +818,4 @@ export const useChartEditStore = defineStore({ } } } -}) \ No newline at end of file +}) diff --git a/src/store/modules/chartHistoryStore/chartHistoryStore.ts b/src/store/modules/chartHistoryStore/chartHistoryStore.ts index 31847f03..b8627ca6 100644 --- a/src/store/modules/chartHistoryStore/chartHistoryStore.ts +++ b/src/store/modules/chartHistoryStore/chartHistoryStore.ts @@ -166,7 +166,7 @@ export const useChartHistoryStore = defineStore({ }, // * 解除分组 createUnGroupHistory(item: Array) { - this.createStackItem(item, HistoryActionTypeEnum.GROUP, HistoryTargetTypeEnum.CHART) + this.createStackItem(item, HistoryActionTypeEnum.UN_GROUP, HistoryTargetTypeEnum.CHART) } } }) diff --git a/src/views/chart/ContentEdit/components/EditHistory/index.vue b/src/views/chart/ContentEdit/components/EditHistory/index.vue index de4cf48c..4346905b 100644 --- a/src/views/chart/ContentEdit/components/EditHistory/index.vue +++ b/src/views/chart/ContentEdit/components/EditHistory/index.vue @@ -93,7 +93,7 @@ const labelHandle = (e: HistoryItemType) => { // 画布编辑 if (e.targetType === HistoryTargetTypeEnum.CANVAS) { return historyActionTypeName[HistoryTargetTypeEnum.CANVAS] - } else if (e.actionType === HistoryActionTypeEnum.GROUP) { + } else if (e.actionType === HistoryActionTypeEnum.GROUP || e.actionType === HistoryActionTypeEnum.UN_GROUP) { return `${historyActionTypeName[e.actionType]}` } else if (e.historyData.length) { return `${historyActionTypeName[e.actionType]} - ${(e.historyData[0] as CreateComponentType).chartConfig.title}`