Skip to content

Commit

Permalink
[Lens] fix chart switching when on VisualizationDimensionEditor (#70689)
Browse files Browse the repository at this point in the history
  • Loading branch information
mbondyra authored Aug 5, 2020
1 parent e23c5ea commit cf6413a
Show file tree
Hide file tree
Showing 2 changed files with 82 additions and 30 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ jest.mock('../../../id_generator');

describe('LayerPanel', () => {
let mockVisualization: jest.Mocked<Visualization>;
let mockVisualization2: jest.Mocked<Visualization>;
let mockDatasource: DatasourceMock;

function getDefaultProps() {
Expand All @@ -36,6 +37,7 @@ describe('LayerPanel', () => {
activeVisualizationId: 'vis1',
visualizationMap: {
vis1: mockVisualization,
vis2: mockVisualization2,
},
activeDatasourceId: 'ds1',
datasourceMap: {
Expand Down Expand Up @@ -72,6 +74,18 @@ describe('LayerPanel', () => {
],
};

mockVisualization2 = {
...createMockVisualization(),
id: 'testVis2',
visualizationTypes: [
{
icon: 'empty',
id: 'testVis2',
label: 'TEST2',
},
],
};

mockVisualization.getLayerIds.mockReturnValue(['first']);
mockDatasource = createMockDatasource('ds1');
});
Expand Down Expand Up @@ -209,16 +223,6 @@ describe('LayerPanel', () => {
const panel = mount(group.prop('panel'));

expect(panel.find('EuiTabbedContent').prop('tabs')).toHaveLength(2);
act(() => {
panel.find('EuiTab#visualization').simulate('click');
});
expect(mockVisualization.renderDimensionEditor).toHaveBeenCalledWith(
expect.any(Element),
expect.objectContaining({
groupId: 'a',
accessor: 'newid',
})
);
});

it('should keep the popover open when configuring a new dimension', () => {
Expand Down Expand Up @@ -267,5 +271,56 @@ describe('LayerPanel', () => {

expect(component.find(EuiPopover).prop('isOpen')).toBe(true);
});
it('should close the popover when the active visualization changes', () => {
/**
* The ID generation system for new dimensions has been messy before, so
* this tests that the ID used in the first render is used to keep the popover
* open in future renders
*/

(generateId as jest.Mock).mockReturnValueOnce(`newid`);
(generateId as jest.Mock).mockReturnValueOnce(`bad`);
mockVisualization.getConfiguration.mockReturnValueOnce({
groups: [
{
groupLabel: 'A',
groupId: 'a',
accessors: [],
filterOperations: () => true,
supportsMoreColumns: true,
dataTestSubj: 'lnsGroup',
},
],
});
// Normally the configuration would change in response to a state update,
// but this test is updating it directly
mockVisualization.getConfiguration.mockReturnValueOnce({
groups: [
{
groupLabel: 'A',
groupId: 'a',
accessors: ['newid'],
filterOperations: () => true,
supportsMoreColumns: false,
dataTestSubj: 'lnsGroup',
},
],
});

const component = mountWithIntl(<LayerPanel {...getDefaultProps()} />);

const group = component.find('DimensionPopover');
const triggerButton = mountWithIntl(group.prop('trigger'));
act(() => {
triggerButton.find('[data-test-subj="lns-empty-dimension"]').first().simulate('click');
});
component.update();
expect(component.find(EuiPopover).prop('isOpen')).toBe(true);
act(() => {
component.setProps({ activeVisualizationId: 'vis2' });
});
component.update();
expect(component.find(EuiPopover).prop('isOpen')).toBe(false);
});
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
* you may not use this file except in compliance with the Elastic License.
*/

import React, { useContext, useState } from 'react';
import React, { useContext, useState, useEffect } from 'react';
import {
EuiPanel,
EuiSpacer,
Expand All @@ -26,6 +26,13 @@ import { generateId } from '../../../id_generator';
import { ConfigPanelWrapperProps, DimensionPopoverState } from './types';
import { DimensionPopover } from './dimension_popover';

const initialPopoverState = {
isOpen: false,
openId: null,
addingToGroupId: null,
tabId: null,
};

export function LayerPanel(
props: Exclude<ConfigPanelWrapperProps, 'state' | 'setState'> & {
layerId: string;
Expand All @@ -41,15 +48,15 @@ export function LayerPanel(
}
) {
const dragDropContext = useContext(DragContext);
const [popoverState, setPopoverState] = useState<DimensionPopoverState>({
isOpen: false,
openId: null,
addingToGroupId: null,
tabId: null,
});
const [popoverState, setPopoverState] = useState<DimensionPopoverState>(initialPopoverState);

const { framePublicAPI, layerId, isOnlyLayer, onRemoveLayer } = props;
const datasourcePublicAPI = framePublicAPI.datasourceLayers[layerId];

useEffect(() => {
setPopoverState(initialPopoverState);
}, [props.activeVisualizationId]);

if (
!datasourcePublicAPI ||
!props.activeVisualizationId ||
Expand Down Expand Up @@ -243,12 +250,7 @@ export function LayerPanel(
suggestedPriority: group.suggestedPriority,
togglePopover: () => {
if (popoverState.isOpen) {
setPopoverState({
isOpen: false,
openId: null,
addingToGroupId: null,
tabId: null,
});
setPopoverState(initialPopoverState);
} else {
setPopoverState({
isOpen: true,
Expand All @@ -264,7 +266,7 @@ export function LayerPanel(
panel={
<EuiTabbedContent
tabs={tabs}
initialSelectedTab={tabs.find((t) => t.id === popoverState.tabId)}
selectedTab={tabs.find((t) => t.id === popoverState.tabId) || tabs[0]}
size="s"
onTabClick={(tab) => {
setPopoverState({
Expand Down Expand Up @@ -358,12 +360,7 @@ export function LayerPanel(
})}
onClick={() => {
if (popoverState.isOpen) {
setPopoverState({
isOpen: false,
openId: null,
addingToGroupId: null,
tabId: null,
});
setPopoverState(initialPopoverState);
} else {
setPopoverState({
isOpen: true,
Expand Down

0 comments on commit cf6413a

Please sign in to comment.