Commit cbb49c97 authored by Miguel Rincon's avatar Miguel Rincon

Merge branch '235734-mlunoe-address-size-of-chart-skeleton-loader' into 'master'

Fix(chart skeleton loader): adjust size

Closes #235734

See merge request gitlab-org/gitlab!41904
parents 8b3efc47 d844bca2
export const DEFAULT_RX = 0.4; export const DEFAULT_RX = 0.4;
export const DEFAULT_BAR_WIDTH = 6; export const DEFAULT_BAR_WIDTH = 4;
export const DEFAULT_LABEL_WIDTH = 4; export const DEFAULT_LABEL_WIDTH = 3;
export const DEFAULT_LABEL_HEIGHT = 5; export const DEFAULT_LABEL_HEIGHT = 3;
export const BAR_HEIGHTS = [5, 7, 9, 14, 21, 35, 50, 80]; export const BAR_HEIGHTS = [5, 7, 9, 14, 21, 35, 50, 80];
export const GRID_YS = [30, 60, 90]; export const GRID_YS = [30, 60, 90];
...@@ -61,35 +61,37 @@ export default { ...@@ -61,35 +61,37 @@ export default {
}; };
</script> </script>
<template> <template>
<gl-skeleton-loader :unique-key="uniqueKey"> <div class="gl-px-8">
<rect <gl-skeleton-loader :unique-key="uniqueKey" class="gl-p-8">
v-for="(y, index) in $options.GRID_YS" <rect
:key="`grid-${index}`" v-for="(y, index) in $options.GRID_YS"
data-testid="skeleton-chart-grid" :key="`grid-${index}`"
x="0" data-testid="skeleton-chart-grid"
:y="`${y}%`" x="0"
width="100%" :y="`${y}%`"
height="1px" width="100%"
/> height="1px"
<rect />
v-for="(height, index) in $options.BAR_HEIGHTS" <rect
:key="`bar-${index}`" v-for="(height, index) in $options.BAR_HEIGHTS"
data-testid="skeleton-chart-bar" :key="`bar-${index}`"
:x="`${getBarXPosition(index)}%`" data-testid="skeleton-chart-bar"
:y="`${90 - height}%`" :x="`${getBarXPosition(index)}%`"
:width="`${barWidth}%`" :y="`${90 - height}%`"
:height="`${height}%`" :width="`${barWidth}%`"
:rx="`${rx}%`" :height="`${height}%`"
/> :rx="`${rx}%`"
<rect />
v-for="(height, index) in $options.BAR_HEIGHTS" <rect
:key="`label-${index}`" v-for="(height, index) in $options.BAR_HEIGHTS"
data-testid="skeleton-chart-label" :key="`label-${index}`"
:x="`${labelCentering + getBarXPosition(index)}%`" data-testid="skeleton-chart-label"
:y="`${100 - labelHeight}%`" :x="`${labelCentering + getBarXPosition(index)}%`"
:width="`${labelWidth}%`" :y="`${100 - labelHeight}%`"
:height="`${labelHeight}%`" :width="`${labelWidth}%`"
:rx="`${rx}%`" :height="`${labelHeight}%`"
/> :rx="`${rx}%`"
</gl-skeleton-loader> />
</gl-skeleton-loader>
</div>
</template> </template>
...@@ -127,11 +127,11 @@ export default { ...@@ -127,11 +127,11 @@ export default {
:error="error" :error="error"
/> />
</div> </div>
<resizable-chart-container v-else-if="loaded" class="insights-chart"> <resizable-chart-container v-else class="insights-chart">
<h5 class="text-center">{{ title }}</h5> <h5 class="text-center">{{ title }}</h5>
<p v-if="description" class="text-center">{{ description }}</p> <p v-if="description" class="text-center">{{ description }}</p>
<gl-column-chart <gl-column-chart
v-if="isColumnChart" v-if="loaded && isColumnChart"
v-bind="$attrs" v-bind="$attrs"
:height="$options.height" :height="$options.height"
:data="data.datasets" :data="data.datasets"
...@@ -142,7 +142,7 @@ export default { ...@@ -142,7 +142,7 @@ export default {
@created="onChartCreated" @created="onChartCreated"
/> />
<gl-stacked-column-chart <gl-stacked-column-chart
v-else-if="isStackedColumnChart" v-else-if="loaded && isStackedColumnChart"
v-bind="$attrs" v-bind="$attrs"
:height="$options.height" :height="$options.height"
:data="data.datasets" :data="data.datasets"
...@@ -155,13 +155,13 @@ export default { ...@@ -155,13 +155,13 @@ export default {
@created="onChartCreated" @created="onChartCreated"
/> />
<gl-line-chart <gl-line-chart
v-else-if="isLineChart" v-else-if="loaded && isLineChart"
v-bind="$attrs" v-bind="$attrs"
:height="$options.height" :height="$options.height"
:data="data.datasets" :data="data.datasets"
:option="chartOptions" :option="chartOptions"
@created="onChartCreated" @created="onChartCreated"
/> />
<chart-skeleton-loader v-else />
</resizable-chart-container> </resizable-chart-container>
<chart-skeleton-loader v-else />
</template> </template>
---
title: Fix the size of chart placeholder on Analytics pages for Merge Requests, Insights and Value stream, so it matches the actual charts.
the size of the real chart shown afterwards
merge_request: 41904
author:
type: fixed
...@@ -10,8 +10,17 @@ import { ...@@ -10,8 +10,17 @@ import {
import InsightsChart from 'ee/insights/components/insights_chart.vue'; import InsightsChart from 'ee/insights/components/insights_chart.vue';
import InsightsChartError from 'ee/insights/components/insights_chart_error.vue'; import InsightsChartError from 'ee/insights/components/insights_chart_error.vue';
import { CHART_TYPES } from 'ee/insights/constants'; import { CHART_TYPES } from 'ee/insights/constants';
import ResizableChartContainer from '~/vue_shared/components/resizable_chart/resizable_chart_container.vue';
import ChartSkeletonLoader from '~/vue_shared/components/resizable_chart/skeleton_loader.vue'; import ChartSkeletonLoader from '~/vue_shared/components/resizable_chart/skeleton_loader.vue';
const DEFAULT_PROPS = {
loaded: false,
type: chartInfo.type,
title: chartInfo.title,
data: null,
error: '',
};
describe('Insights chart component', () => { describe('Insights chart component', () => {
let wrapper; let wrapper;
...@@ -26,66 +35,32 @@ describe('Insights chart component', () => { ...@@ -26,66 +35,32 @@ describe('Insights chart component', () => {
}); });
describe('when chart is loading', () => { describe('when chart is loading', () => {
it('displays the chart loader', () => { it('displays the chart loader in the container', () => {
wrapper = factory({ wrapper = factory(DEFAULT_PROPS);
loaded: false,
type: CHART_TYPES.BAR,
title: chartInfo.title,
data: null,
error: '',
});
expect(wrapper.find(ChartSkeletonLoader).exists()).toBe(true); expect(wrapper.find(ChartSkeletonLoader).exists()).toBe(true);
expect(wrapper.find(ResizableChartContainer).exists()).toBe(true);
}); });
}); });
describe('when chart is loaded', () => { describe.each`
it('displays a bar chart', () => { type | component | name | data
wrapper = factory({ ${CHART_TYPES.BAR} | ${GlColumnChart} | ${'GlColumnChart'} | ${barChartData}
loaded: true, ${CHART_TYPES.LINE} | ${GlLineChart} | ${'GlLineChart'} | ${lineChartData}
type: CHART_TYPES.BAR, ${CHART_TYPES.STACKED_BAR} | ${GlStackedColumnChart} | ${'GlStackedColumnChart'} | ${stackedBarChartData}
title: chartInfo.title, ${CHART_TYPES.PIE} | ${GlColumnChart} | ${'GlColumnChart'} | ${barChartData}
data: barChartData, `('when chart is loaded', ({ type, component, name, data }) => {
error: '', it(`when ${type} is passed: displays the a ${name}-chart in container and not the loader`, () => {
});
expect(wrapper.find(GlColumnChart).exists()).toBe(true);
});
it('displays a line chart', () => {
wrapper = factory({
loaded: true,
type: CHART_TYPES.LINE,
title: chartInfo.title,
data: lineChartData,
error: '',
});
expect(wrapper.find(GlLineChart).exists()).toBe(true);
});
it('displays a stacked bar chart', () => {
wrapper = factory({
loaded: true,
type: CHART_TYPES.STACKED_BAR,
title: chartInfo.title,
data: stackedBarChartData,
error: '',
});
expect(wrapper.find(GlStackedColumnChart).exists()).toBe(true);
});
it('displays a bar chart when a pie chart is requested', () => {
wrapper = factory({ wrapper = factory({
...DEFAULT_PROPS,
loaded: true, loaded: true,
type: CHART_TYPES.PIE, type,
title: chartInfo.title, data,
data: barChartData,
error: '',
}); });
expect(wrapper.find(GlColumnChart).exists()).toBe(true); expect(wrapper.find(ChartSkeletonLoader).exists()).toBe(false);
expect(wrapper.find(ResizableChartContainer).exists()).toBe(true);
expect(wrapper.find(component).exists()).toBe(true);
}); });
}); });
...@@ -94,15 +69,15 @@ describe('Insights chart component', () => { ...@@ -94,15 +69,15 @@ describe('Insights chart component', () => {
beforeEach(() => { beforeEach(() => {
wrapper = factory({ wrapper = factory({
loaded: false, ...DEFAULT_PROPS,
type: chartInfo.type,
title: chartInfo.title,
data: {}, data: {},
error, error,
}); });
}); });
it('displays info about the error', () => { it('displays info about the error', () => {
expect(wrapper.find(ChartSkeletonLoader).exists()).toBe(false);
expect(wrapper.find(ResizableChartContainer).exists()).toBe(false);
expect(wrapper.find(InsightsChartError).exists()).toBe(true); expect(wrapper.find(InsightsChartError).exists()).toBe(true);
}); });
}); });
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment