From 1c95da8f23f409b467c41db5a6365889b0a4bb42 Mon Sep 17 00:00:00 2001 From: ilgizar Date: Tue, 30 Jan 2018 09:52:30 +0500 Subject: [PATCH] Fix horizontal panel repeat. Fix #10672. --- .../app/features/dashboard/dashboard_model.ts | 19 ++-- .../features/dashboard/specs/repeat.jest.ts | 92 +++++++++++++++++++ 2 files changed, 104 insertions(+), 7 deletions(-) diff --git a/public/app/features/dashboard/dashboard_model.ts b/public/app/features/dashboard/dashboard_model.ts index 6c291c3b69a..eba4cfa398f 100644 --- a/public/app/features/dashboard/dashboard_model.ts +++ b/public/app/features/dashboard/dashboard_model.ts @@ -342,6 +342,7 @@ export class DashboardModel { let minWidth = panel.minSpan || 6; let xPos = 0; let yPos = panel.gridPos.y; + let yOffset = 0; for (let index = 0; index < selectedOptions.length; index++) { let option = selectedOptions[index]; @@ -354,13 +355,8 @@ export class DashboardModel { if (panel.repeatDirection === REPEAT_DIR_VERTICAL) { copy.gridPos.y = yPos; yPos += copy.gridPos.h; - - // Update gridPos for panels below - let panelBelowIndex = panelIndex + index + 1; - for (let i = panelBelowIndex; i < this.panels.length; i++) { - if (this.panels[i].gridPos.y < yPos) { - this.panels[i].gridPos.y += copy.gridPos.h; - } + if (index > 0) { + yOffset += copy.gridPos.h; } } else { // set width based on how many are selected @@ -375,9 +371,18 @@ export class DashboardModel { if (xPos + copy.gridPos.w > GRID_COLUMN_COUNT) { xPos = 0; yPos += copy.gridPos.h; + yOffset += copy.gridPos.h; } } } + + // Update gridPos for panels below + if (yOffset > 0) { + let panelBelowIndex = panelIndex + selectedOptions.length; + for (let i = panelBelowIndex; i < this.panels.length; i++) { + this.panels[i].gridPos.y += yOffset; + } + } } repeatRow(panel: PanelModel, panelIndex: number, variable) { diff --git a/public/app/features/dashboard/specs/repeat.jest.ts b/public/app/features/dashboard/specs/repeat.jest.ts index e05162dc69f..ec3a1fbb7af 100644 --- a/public/app/features/dashboard/specs/repeat.jest.ts +++ b/public/app/features/dashboard/specs/repeat.jest.ts @@ -178,6 +178,98 @@ describe('given dashboard with panel repeat in vertical direction', function() { }); }); +describe('given dashboard with row repeat and panel repeat in horizontal direction', () => { + let dashboard, dashboardJSON; + + beforeEach(() => { + dashboardJSON = { + panels: [ + { + id: 1, + type: 'row', + repeat: 'region', + gridPos: { x: 0, y: 0, h: 1, w: 24 }, + }, + { + id: 2, + type: 'graph', + repeat: 'app', + gridPos: { x: 0, y: 1, h: 2, w: 6 }, + }, + ], + templating: { + list: [ + { + name: 'region', + current: { + text: 'reg1, reg2', + value: ['reg1', 'reg2'], + }, + options: [{ text: 'reg1', value: 'reg1', selected: true }, { text: 'reg2', value: 'reg2', selected: true }], + }, + { + name: 'app', + current: { + text: 'se1, se2, se3, se4, se5, se6', + value: ['se1', 'se2', 'se3', 'se4', 'se5', 'se6'], + }, + options: [ + { text: 'se1', value: 'se1', selected: true }, + { text: 'se2', value: 'se2', selected: true }, + { text: 'se3', value: 'se3', selected: true }, + { text: 'se4', value: 'se4', selected: true }, + { text: 'se5', value: 'se5', selected: true }, + { text: 'se6', value: 'se6', selected: true }, + ], + }, + ], + }, + }; + dashboard = new DashboardModel(dashboardJSON); + dashboard.processRepeats(false); + }); + + it('should panels in self row', () => { + const panel_types = _.map(dashboard.panels, 'type'); + expect(panel_types).toEqual([ + 'row', + 'graph', + 'graph', + 'graph', + 'graph', + 'graph', + 'graph', + 'row', + 'graph', + 'graph', + 'graph', + 'graph', + 'graph', + 'graph', + ]); + }); + + it('should be placed in their places', function() { + expect(dashboard.panels[0].gridPos).toMatchObject({ x: 0, y: 0, h: 1, w: 24 }); + + expect(dashboard.panels[1].gridPos).toMatchObject({ x: 0, y: 1, h: 2, w: 6 }); + expect(dashboard.panels[2].gridPos).toMatchObject({ x: 6, y: 1, h: 2, w: 6 }); + expect(dashboard.panels[3].gridPos).toMatchObject({ x: 12, y: 1, h: 2, w: 6 }); + expect(dashboard.panels[4].gridPos).toMatchObject({ x: 18, y: 1, h: 2, w: 6 }); + expect(dashboard.panels[5].gridPos).toMatchObject({ x: 0, y: 3, h: 2, w: 6 }); + expect(dashboard.panels[6].gridPos).toMatchObject({ x: 6, y: 3, h: 2, w: 6 }); + + expect(dashboard.panels[7].gridPos).toMatchObject({ x: 0, y: 5, h: 1, w: 24 }); + + expect(dashboard.panels[8].gridPos).toMatchObject({ x: 0, y: 6, h: 2, w: 6 }); + expect(dashboard.panels[9].gridPos).toMatchObject({ x: 6, y: 6, h: 2, w: 6 }); + expect(dashboard.panels[10].gridPos).toMatchObject({ x: 12, y: 6, h: 2, w: 6 }); + expect(dashboard.panels[11].gridPos).toMatchObject({ x: 18, y: 6, h: 2, w: 6 }); + expect(dashboard.panels[12].gridPos).toMatchObject({ x: 0, y: 8, h: 2, w: 6 }); + expect(dashboard.panels[13].gridPos).toMatchObject({ x: 6, y: 8, h: 2, w: 6 }); + }); +}); + describe('given dashboard with row repeat', function() { let dashboard, dashboardJSON;