diff --git a/components/button/src/dropdown-button/__tests__/dropdown-button.test.js b/components/button/src/dropdown-button/__tests__/dropdown-button.test.js index c926ef5aaa..a38e8e167a 100644 --- a/components/button/src/dropdown-button/__tests__/dropdown-button.test.js +++ b/components/button/src/dropdown-button/__tests__/dropdown-button.test.js @@ -1,8 +1,10 @@ import { Layer } from '@dhis2-ui/layer' import { Popper } from '@dhis2-ui/popper' +import { render, fireEvent, waitFor } from '@testing-library/react' import { mount } from 'enzyme' import React from 'react' import { act } from 'react-dom/test-utils' +import { Modal } from '../../../../modal/src/modal/modal.js' import { Button } from '../../index.js' import { DropdownButton } from '../dropdown-button.js' @@ -43,7 +45,64 @@ describe('', () => { }) ) }) + it('closes dropdown when escape key is pressed', async () => { + const componentText = 'Dropdown Content' + + const { getByTestId, queryByText } = render( + + ) + + const toggleButton = getByTestId( + 'dhis2-uicore-dropdownbutton-toggle' + ) + fireEvent.click(toggleButton) + + await waitFor(() => { + expect(queryByText(componentText)).toBeInTheDocument() + }) + + fireEvent.keyDown(document, { key: 'Escape' }) + + await waitFor(() => { + expect(queryByText(componentText)).not.toBeInTheDocument() + }) + }) + test('modal remains open when dropdown button is closed on escape click', async () => { + const dropdownButtonText = 'Dropdown Content' + const headingText = 'Heading Text' + const modalContent = ( +
+

{headingText}

+ +
+ ) + + const { getByTestId, queryByText } = render( + {}}> + {modalContent} + + ) + + const toggleButton = getByTestId( + 'dhis2-uicore-dropdownbutton-toggle' + ) + fireEvent.click(toggleButton) + + await waitFor(() => { + expect(queryByText(dropdownButtonText)).toBeInTheDocument() + }) + + fireEvent.keyDown(document, { key: 'Escape' }) + + await waitFor(() => { + expect( + queryByText(dropdownButtonText) + ).not.toBeInTheDocument() + expect(queryByText(headingText)).toBeInTheDocument() + }) + }) }) + describe('closed state', () => { const onClick = jest.fn() const wrapper = mount( diff --git a/components/button/src/dropdown-button/dropdown-button.js b/components/button/src/dropdown-button/dropdown-button.js index f225206c9d..ec0cc2b337 100644 --- a/components/button/src/dropdown-button/dropdown-button.js +++ b/components/button/src/dropdown-button/dropdown-button.js @@ -69,6 +69,31 @@ class DropdownButton extends Component { anchorRef = React.createRef() + componentDidMount() { + document.addEventListener('keydown', this.handleKeyDown) + } + + componentWillUnmount() { + document.removeEventListener('keydown', this.handleKeyDown) + } + + // handleKeyDown = (event) => { + // event.preventDefault() + // if (event.key === 'Escape' && this.state.open) { + // event.stopPropagation() + // this.setState({ open: false }) + // } + // } + + handleKeyDown = (event) => { + if (event.key === 'Escape') { + if (this.state.open) { + event.stopPropagation() + this.setState({ open: false }) + } + } + } + onClickHandler = ({ name, value }, event) => { const handleClick = (open) => { if (this.props.onClick) { @@ -133,6 +158,7 @@ class DropdownButton extends Component { tabIndex={tabIndex} type={type} initialFocus={initialFocus} + data-test="dhis2-uicore-dropdownbutton-toggle" > {children}