mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
2326195324
* Add DS Popover component * Update to Popover story * make role a prop with PopoverRole enum * update to Hiro design changes * fix snapshot * Update ui/components/component-library/popover/README.mdx Co-authored-by: George Marshall <george.marshall@consensys.net> * Update ui/components/component-library/popover/README.mdx Co-authored-by: George Marshall <george.marshall@consensys.net> * small story changes and removal of unused forwardRef * add more test coverage * add more story demos * add more popover demos * if escKeyClose is passed then it will add event listener * isPortal story * add if statement * replace Text with Box for now * add esc test coverage * add README docs * fix readme and onEscKeyClose * onEscKeyClose to onPressEscKey * Update ui/components/component-library/popover/README.mdx Co-authored-by: George Marshall <george.marshall@consensys.net> * change conditional on useEffect --------- Co-authored-by: legobeat <109787230+legobeat@users.noreply.github.com> Co-authored-by: George Marshall <george.marshall@consensys.net>
254 lines
7.0 KiB
TypeScript
254 lines
7.0 KiB
TypeScript
/* eslint-disable jest/require-top-level-describe */
|
|
import { render, fireEvent } from '@testing-library/react';
|
|
import React, { useState } from 'react';
|
|
import { Popover } from './popover';
|
|
import { PopoverPosition } from './popover.types';
|
|
|
|
describe('Popover', () => {
|
|
it('should render popover element correctly', () => {
|
|
const { getByTestId, getByText, container } = render(
|
|
<Popover data-testid="popover" isOpen={true} isPortal={false}>
|
|
Popover
|
|
</Popover>,
|
|
);
|
|
expect(getByText('Popover')).toBeDefined();
|
|
expect(container.querySelector('popover')).toBeDefined();
|
|
expect(getByTestId('popover')).toHaveClass('mm-popover');
|
|
expect(container).toMatchSnapshot();
|
|
});
|
|
|
|
it('should NOT render popover', () => {
|
|
const { queryByTestId } = render(
|
|
<>
|
|
<Popover isOpen={false}>Popover not open</Popover>
|
|
</>,
|
|
);
|
|
expect(queryByTestId('popover')).not.toBeInTheDocument();
|
|
});
|
|
|
|
it('should render popover children', () => {
|
|
const { getByText } = render(
|
|
<Popover isOpen={true}>Popover content goes here</Popover>,
|
|
);
|
|
expect(getByText('Popover content goes here')).toBeDefined();
|
|
});
|
|
|
|
it('should render popover position', () => {
|
|
const { getByTestId } = render(
|
|
<>
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.Auto}
|
|
position={PopoverPosition.Auto}
|
|
>
|
|
{PopoverPosition.Auto}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid="top"
|
|
position={PopoverPosition.Top}
|
|
>
|
|
{PopoverPosition.Top}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.TopStart}
|
|
position={PopoverPosition.TopStart}
|
|
>
|
|
{PopoverPosition.TopStart}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.TopEnd}
|
|
position={PopoverPosition.TopEnd}
|
|
>
|
|
{PopoverPosition.TopEnd}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.Right}
|
|
position={PopoverPosition.Right}
|
|
>
|
|
{PopoverPosition.Right}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.RightStart}
|
|
position={PopoverPosition.RightStart}
|
|
>
|
|
{PopoverPosition.RightStart}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.RightEnd}
|
|
position={PopoverPosition.RightEnd}
|
|
>
|
|
{PopoverPosition.RightEnd}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.Bottom}
|
|
position={PopoverPosition.Bottom}
|
|
>
|
|
{PopoverPosition.Bottom}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.BottomStart}
|
|
position={PopoverPosition.BottomStart}
|
|
>
|
|
{PopoverPosition.BottomStart}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.BottomEnd}
|
|
position={PopoverPosition.BottomEnd}
|
|
>
|
|
{PopoverPosition.BottomEnd}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.Left}
|
|
position={PopoverPosition.Left}
|
|
>
|
|
{PopoverPosition.Left}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.LeftStart}
|
|
position={PopoverPosition.LeftStart}
|
|
>
|
|
{PopoverPosition.LeftStart}
|
|
</Popover>
|
|
|
|
<Popover
|
|
isOpen={true}
|
|
isPortal={false}
|
|
data-testid={PopoverPosition.LeftEnd}
|
|
position={PopoverPosition.LeftEnd}
|
|
>
|
|
{PopoverPosition.LeftEnd}
|
|
</Popover>
|
|
</>,
|
|
);
|
|
|
|
expect(getByTestId(PopoverPosition.Auto)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.Top)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.TopStart)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.TopEnd)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.Right)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.RightStart)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.RightEnd)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.Bottom)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.BottomStart)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.BottomEnd)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.Left)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.LeftStart)).toBeDefined();
|
|
expect(getByTestId(PopoverPosition.LeftEnd)).toBeDefined();
|
|
});
|
|
|
|
it('should render an arrow on popover', () => {
|
|
const { getByTestId } = render(
|
|
<Popover data-testid="popover" isOpen={true} hasArrow>
|
|
Popover
|
|
</Popover>,
|
|
);
|
|
|
|
const arrowElement =
|
|
getByTestId('popover').querySelector('.mm-popover__arrow');
|
|
expect(arrowElement).toHaveClass('mm-popover__arrow');
|
|
});
|
|
});
|
|
|
|
test('should render Popover with isPortal set to false', () => {
|
|
const { getByTestId } = render(
|
|
<div>
|
|
<Popover
|
|
data-testid="popover"
|
|
isOpen={true}
|
|
position={PopoverPosition.Bottom}
|
|
isPortal={false}
|
|
>
|
|
<p>Popover content</p>
|
|
</Popover>
|
|
</div>,
|
|
);
|
|
// Check that the Popover is rendered inside the body DOM
|
|
expect(getByTestId('popover')).toBeInTheDocument();
|
|
});
|
|
|
|
test('should render Popover with isPortal set to true', () => {
|
|
const { getByTestId } = render(
|
|
<div>
|
|
<Popover data-testid="popover" isOpen={true} isPortal={true}>
|
|
<p>Popover content</p>
|
|
</Popover>
|
|
</div>,
|
|
);
|
|
|
|
expect(getByTestId('popover')).toBeTruthy();
|
|
});
|
|
|
|
test('should add reference-hidden classname when referenceHidden prop is true', () => {
|
|
const { getByTestId } = render(
|
|
<div>
|
|
<Popover data-testid="popover" isOpen={true} referenceHidden={true}>
|
|
<p>Popover content</p>
|
|
</Popover>
|
|
</div>,
|
|
);
|
|
|
|
expect(getByTestId('popover')).toHaveClass('mm-popover--reference-hidden');
|
|
});
|
|
|
|
const EscKeyTestComponent = () => {
|
|
const [isOpen, setIsOpen] = useState(true);
|
|
|
|
return (
|
|
<Popover
|
|
isOpen={isOpen}
|
|
referenceHidden={false}
|
|
onPressEscKey={() => setIsOpen(false)}
|
|
>
|
|
Press esc key to close
|
|
</Popover>
|
|
);
|
|
};
|
|
|
|
test('Press esc key to close fires', () => {
|
|
// Render the component
|
|
const { getByText, queryByText } = render(<EscKeyTestComponent />);
|
|
|
|
// Assert that the popover is initially visible
|
|
expect(getByText('Press esc key to close')).toBeVisible();
|
|
|
|
// Trigger the "Escape" key press event
|
|
fireEvent.keyDown(document, { key: 'Escape' });
|
|
|
|
// Assert that the popover closes
|
|
expect(queryByText('Press esc key to close')).not.toBeInTheDocument();
|
|
});
|