Skip to content

Commit

Permalink
Add reset to initial state button/logic
Browse files Browse the repository at this point in the history
  • Loading branch information
cee-chen committed Dec 1, 2021
1 parent f2e108a commit 37f3640
Show file tree
Hide file tree
Showing 4 changed files with 107 additions and 15 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
- Updated `EuiDataGrid`'s full screen mode to use the `fullScreenExit` icon ([#5415](https://github.com/elastic/eui/pull/5415))
- Added `left.append` and `left.prepend` to `EuiDataGrid`'s `toolbarVisibility.additionalControls` prop [#5394](https://github.com/elastic/eui/pull/5394))
- Added a row height control to `EuiDataGrid`'s toolbar ([#5372](https://github.com/elastic/eui/pull/5372))
- Added a reset button to `EuiDataGrid`'s display controls ([#5428](https://github.com/elastic/eui/pull/5428))

**Bug fixes**

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`useDataGridDisplaySelector displaySelector renders a toolbar button/popover allowing users to customize display settings 1`] = `
exports[`useDataGridDisplaySelector displaySelector renders a toolbar button/popover allowing users to customize & reset display settings 1`] = `
<Fragment>
<EuiPopover
anchorPosition="downRight"
Expand Down Expand Up @@ -73,6 +73,15 @@ exports[`useDataGridDisplaySelector displaySelector renders a toolbar button/pop
>
<Component />
</EuiI18n>
<EuiPopoverFooter>
<EuiButtonEmpty
data-test-subj="resetDisplaySelector"
onClick={[Function]}
size="xs"
>
Reset to default
</EuiButtonEmpty>
</EuiPopoverFooter>
</EuiPopover>
</Fragment>
`;
52 changes: 51 additions & 1 deletion src/components/datagrid/controls/display_selector.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ describe('useDataGridDisplaySelector', () => {
});
};

it('renders a toolbar button/popover allowing users to customize display settings', () => {
it('renders a toolbar button/popover allowing users to customize & reset display settings', () => {
const component = shallow(<MockComponent />);
expect(component).toMatchSnapshot();
});
Expand Down Expand Up @@ -136,6 +136,22 @@ describe('useDataGridDisplaySelector', () => {
expect(getSelection(component)).toEqual('');
});
});

it('correctly resets density to initial developer-passed state', () => {
const component = mount(
<MockComponent gridStyles={{ fontSize: 'l', cellPadding: 'l' }} />
);
openPopover(component);
expect(getSelection(component)).toEqual('expanded');

component.find('[data-test-subj="compact"]').simulate('change');
expect(getSelection(component)).toEqual('compact');

component
.find('button[data-test-subj="resetDisplaySelector"]')
.simulate('click');
expect(getSelection(component)).toEqual('expanded');
});
});

describe('row height', () => {
Expand Down Expand Up @@ -208,6 +224,22 @@ describe('useDataGridDisplaySelector', () => {
});
});

it('correctly resets row height to initial developer-passed state', () => {
const component = mount(
<MockComponent rowHeightsOptions={{ defaultHeight: undefined }} />
);
openPopover(component);
expect(getSelection(component)).toEqual('undefined');

component.find('[data-test-subj="auto"]').simulate('change');
expect(getSelection(component)).toEqual('auto');

component
.find('button[data-test-subj="resetDisplaySelector"]')
.simulate('click');
expect(getSelection(component)).toEqual('undefined');
});

describe('lineCount', () => {
const getLineCountNumber = (component: ReactWrapper) =>
component
Expand Down Expand Up @@ -278,6 +310,24 @@ describe('useDataGridDisplaySelector', () => {
setLineCountNumber(component, -50);
expect(getLineCountNumber(component)).toEqual(2);
});

it('correctly resets lineCount to initial developer-passed state', () => {
const component = mount(
<MockComponent
rowHeightsOptions={{ defaultHeight: { lineCount: 3 } }}
/>
);
openPopover(component);
expect(getLineCountNumber(component)).toEqual(3);

setLineCountNumber(component, 5);
expect(getLineCountNumber(component)).toEqual(5);

component
.find('button[data-test-subj="resetDisplaySelector"]')
.simulate('click');
expect(getLineCountNumber(component)).toEqual(3);
});
});
});
});
Expand Down
58 changes: 45 additions & 13 deletions src/components/datagrid/controls/display_selector.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@
import React, { ReactNode, useState, useMemo, useCallback } from 'react';

import { EuiI18n, useEuiI18n } from '../../i18n';
import { EuiPopover } from '../../popover';
import { EuiButtonIcon, EuiButtonGroup } from '../../button';
import { EuiPopover, EuiPopoverFooter } from '../../popover';
import { EuiButtonIcon, EuiButtonGroup, EuiButtonEmpty } from '../../button';
import { EuiFormRow, EuiRange } from '../../form';
import { EuiToolTip } from '../../tool_tip';

Expand Down Expand Up @@ -102,26 +102,36 @@ export const useDataGridDisplaySelector = (
'allowRowHeight'
);

// track styles specified by the user at run time
// Get initial state (also used when resetting)
const initialDensity = useMemo(
() => convertGridStylesToSelection(initialStyles),
[initialStyles]
);
const initialRowHeight = useMemo(
() => convertRowHeightsOptionsToSelection(initialRowHeightsOptions),
[initialRowHeightsOptions]
);
const initialLineCount = useMemo(
// @ts-ignore - optional chaining operator handles types & cases that aren't lineCount
() => initialRowHeightsOptions?.defaultHeight?.lineCount || 2,
[initialRowHeightsOptions?.defaultHeight]
);

// Track styles specified by the user at run time
const [userGridStyles, setUserGridStyles] = useState({});
const [userRowHeightsOptions, setUserRowHeightsOptions] = useState({});

// Normal is the default density
const [gridDensity, _setGridDensity] = useState(
convertGridStylesToSelection(initialStyles)
);
// Density state
const [gridDensity, _setGridDensity] = useState(initialDensity);
const setGridDensity = (density: string) => {
_setGridDensity(density);
setUserGridStyles(densityStyles[density]);
};

// Row height state
const [lineCount, setLineCount] = useState(
// @ts-ignore - optional chaining operator handles types & cases that aren't lineCount
initialRowHeightsOptions?.defaultHeight?.lineCount || 2
);
const [lineCount, setLineCount] = useState(initialLineCount);
const [rowHeightSelection, setRowHeightSelection] = useState(
convertRowHeightsOptionsToSelection(initialRowHeightsOptions)
initialRowHeight
);
const setRowHeight = useCallback(
(option: string) => {
Expand Down Expand Up @@ -153,7 +163,7 @@ export const useDataGridDisplaySelector = (
});
}, []);

// merge the developer-specified styles with any user overrides
// Merge the developer-specified configurations with user overrides
const gridStyles = useMemo(() => {
return {
...initialStyles,
Expand All @@ -168,10 +178,23 @@ export const useDataGridDisplaySelector = (
};
}, [initialRowHeightsOptions, userRowHeightsOptions]);

// Allow resetting to initial developer-specified configurations
const resetToInitialState = useCallback(() => {
setGridDensity(initialDensity);
setUserGridStyles({});
setRowHeightSelection(initialRowHeight);
setUserRowHeightsOptions({});
setLineCount(initialLineCount);
}, [initialDensity, initialRowHeight, initialLineCount]);

const buttonLabel = useEuiI18n(
'euiDisplaySelector.buttonText',
'Display options'
);
const resetButtonLabel = useEuiI18n(
'euiDisplaySelector.resetButtonText',
'Reset to default'
);

const displaySelector =
showDensityControls || showRowHeightControls ? (
Expand Down Expand Up @@ -311,6 +334,15 @@ export const useDataGridDisplaySelector = (
)}
</EuiI18n>
)}
<EuiPopoverFooter>
<EuiButtonEmpty
size="xs"
onClick={resetToInitialState}
data-test-subj="resetDisplaySelector"
>
{resetButtonLabel}
</EuiButtonEmpty>
</EuiPopoverFooter>
</EuiPopover>
) : null;

Expand Down

0 comments on commit 37f3640

Please sign in to comment.