Commit 10d44ce7 authored by Anshul Riyal's avatar Anshul Riyal

Refactored statistics chart responsiveness

See merge request https://gitlab.com/gitlab-org/gitlab/-/merge_requests/81457
parent 6172b14a
<script> <script>
import { GlResizeObserverDirective } from '@gitlab/ui';
import { GlAreaChart } from '@gitlab/ui/dist/charts'; import { GlAreaChart } from '@gitlab/ui/dist/charts';
import dateFormat from 'dateformat'; import dateFormat from 'dateformat';
import { isFunction } from 'lodash';
import { COLORS, DATE_FORMATS, TIME } from './constants'; import { COLORS, DATE_FORMATS, TIME } from './constants';
...@@ -11,9 +9,6 @@ export default { ...@@ -11,9 +9,6 @@ export default {
components: { components: {
GlAreaChart, GlAreaChart,
}, },
directives: {
GlResizeObserverDirective,
},
props: { props: {
data: { data: {
type: Object, type: Object,
...@@ -87,18 +82,13 @@ export default { ...@@ -87,18 +82,13 @@ export default {
onChartCreated(chartInstance) { onChartCreated(chartInstance) {
this.chartInstance = chartInstance; this.chartInstance = chartInstance;
}, },
onResize() {
if (isFunction(this.chartInstance?.resize)) {
this.chartInstance.resize();
}
},
}, },
}; };
</script> </script>
<template> <template>
<gl-area-chart <gl-area-chart
v-gl-resize-observer-directive="onResize" :responsive="true"
:data="chartData" :data="chartData"
:option="chartOptions" :option="chartOptions"
:include-legend-avg-max="false" :include-legend-avg-max="false"
......
...@@ -4,6 +4,7 @@ exports[`StatisticsHistory component chart tooltip renders the title and series ...@@ -4,6 +4,7 @@ exports[`StatisticsHistory component chart tooltip renders the title and series
<div <div
data="[object Object],[object Object]" data="[object Object],[object Object]"
option="[object Object]" option="[object Object]"
responsive="true"
> >
<div> <div>
Dec 4, 2019 12:00am (Time) Dec 4, 2019 12:00am (Time)
......
import { GlAreaChart } from '@gitlab/ui/dist/charts'; import { GlAreaChart } from '@gitlab/ui/dist/charts';
import { shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vue, { nextTick } from 'vue'; import { nextTick } from 'vue';
import { TOTAL_REQUESTS, ANOMALOUS_REQUESTS } from 'ee/threat_monitoring/components/constants'; import { TOTAL_REQUESTS, ANOMALOUS_REQUESTS } from 'ee/threat_monitoring/components/constants';
import StatisticsHistory from 'ee/threat_monitoring/components/statistics_history.vue'; import StatisticsHistory from 'ee/threat_monitoring/components/statistics_history.vue';
import { mockNominalHistory, mockAnomalousHistory } from '../mocks/mock_data'; import { mockNominalHistory, mockAnomalousHistory } from '../mocks/mock_data';
let resizeCallback = null;
const MockResizeObserverDirective = {
bind(el, { value }) {
resizeCallback = value;
},
simulateResize() {
// Let tests fail if callback throws or isn't callable
resizeCallback();
},
unbind() {
resizeCallback = null;
},
};
Vue.directive('gl-resize-observer-directive', MockResizeObserverDirective);
describe('StatisticsHistory component', () => { describe('StatisticsHistory component', () => {
let wrapper; let wrapper;
...@@ -75,38 +57,6 @@ describe('StatisticsHistory component', () => { ...@@ -75,38 +57,6 @@ describe('StatisticsHistory component', () => {
}); });
}); });
describe('given the component needs to resize', () => {
let mockChartInstance;
beforeEach(() => {
factory();
mockChartInstance = {
resize: jest.fn(),
};
});
describe('given the chart has not emitted the created event', () => {
beforeEach(() => {
MockResizeObserverDirective.simulateResize();
});
it('there is no attempt to resize the chart instance', () => {
expect(mockChartInstance.resize).not.toHaveBeenCalled();
});
});
describe('given the chart has emitted the created event', () => {
beforeEach(() => {
findChart().vm.$emit('created', mockChartInstance);
MockResizeObserverDirective.simulateResize();
});
it('the chart instance is resized', () => {
expect(mockChartInstance.resize).toHaveBeenCalledTimes(1);
});
});
});
describe('chart tooltip', () => { describe('chart tooltip', () => {
beforeEach(async () => { beforeEach(async () => {
const mockParams = { const mockParams = {
......
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