diff --git a/packages/core/upload/admin/src/components/FolderCard/tests/FolderCard.test.js b/packages/core/upload/admin/src/components/FolderCard/tests/FolderCard.test.js index e91e4408d5..a46955a338 100644 --- a/packages/core/upload/admin/src/components/FolderCard/tests/FolderCard.test.js +++ b/packages/core/upload/admin/src/components/FolderCard/tests/FolderCard.test.js @@ -3,7 +3,7 @@ import { BaseLink } from '@strapi/design-system/BaseLink'; import { Flex } from '@strapi/design-system/Flex'; import { ThemeProvider, lightTheme } from '@strapi/design-system'; import { Typography } from '@strapi/design-system/Typography'; -import { render, fireEvent } from '@testing-library/react'; +import { render, fireEvent, act } from '@testing-library/react'; import { FolderCard } from '../FolderCard'; import { FolderCardBody } from '../FolderCardBody'; @@ -12,7 +12,7 @@ import { FolderCardCheckbox } from '../FolderCardCheckbox'; const ID_FIXTURE = 'folder-1'; // eslint-disable-next-line react/prop-types -const ComponentFixture = ({ children, ...props }) => { +const ComponentFixture = props => { return ( { onDoubleClick={() => {}} {...props} > - {children || ''} - - - ); -}; - -describe('FolderCard', () => { - it('renders and matches the snapshot', () => { - const { container } = render(); - expect(container).toMatchSnapshot(); - }); - - it('properly calls the onDoubleClick callback', () => { - const callback = jest.fn(); - const { container } = render(); - - fireEvent(container.querySelector('a'), new MouseEvent('dblclick', { bubbles: true })); - - expect(callback).toHaveBeenCalledTimes(1); - }); - - it('has all required ids set when rendering a start action', () => { - const { container } = render( - }> @@ -56,10 +32,39 @@ describe('FolderCard', () => { - - ); + + + ); +}; - expect(container.querySelector(`[id="${ID_FIXTURE}-title"]`)).toBeInTheDocument(); - expect(container.querySelector(`[aria-labelledby="${ID_FIXTURE}-title"]`)).toBeInTheDocument(); +const setup = props => render(); + +describe('FolderCard', () => { + test('renders and matches the snapshot', () => { + const { container } = setup(); + expect(container).toMatchSnapshot(); + }); + + test('properly calls the onDoubleClick callback', () => { + const callback = jest.fn(); + const { container } = setup({ onDoubleClick: callback }); + + act(() => { + fireEvent(container.querySelector('button'), new MouseEvent('dblclick', { bubbles: true })); + }); + + expect(callback).toHaveBeenCalledTimes(1); + }); + + test('has all required ids set when rendering a start action', () => { + const { container } = setup({ + startAction: , + }); + + expect(container).toMatchSnapshot(); + expect(container.querySelector(`[id="${ID_FIXTURE}-3-title"]`)).toBeInTheDocument(); + expect( + container.querySelector(`[aria-labelledby="${ID_FIXTURE}-3-title"]`) + ).toBeInTheDocument(); }); }); diff --git a/packages/core/upload/admin/src/components/FolderCard/tests/__snapshots__/FolderCard.test.js.snap b/packages/core/upload/admin/src/components/FolderCard/tests/__snapshots__/FolderCard.test.js.snap index 2851e7ab2a..33208d3da0 100644 --- a/packages/core/upload/admin/src/components/FolderCard/tests/__snapshots__/FolderCard.test.js.snap +++ b/packages/core/upload/admin/src/components/FolderCard/tests/__snapshots__/FolderCard.test.js.snap @@ -1,11 +1,30 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`FolderCard renders and matches the snapshot 1`] = ` -.c1 { +exports[`FolderCard has all required ids set when rendering a start action 1`] = ` +.c12 { cursor: pointer; } -.c8 { +.c9 { + position: relative; + z-index: 3; +} + +.c10 { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-align-items: flex-start; + -webkit-box-align: flex-start; + -ms-flex-align: flex-start; + align-items: flex-start; +} + +.c14 { border: 0; -webkit-clip: rect(0 0 0 0); clip: rect(0 0 0 0); @@ -17,11 +36,91 @@ exports[`FolderCard renders and matches the snapshot 1`] = ` width: 1px; } +.c13 { + font-weight: 500; + color: #32324d; + font-size: 0.875rem; + line-height: 1.43; +} + +.c6 { + margin: 0; + height: 18px; + min-width: 18px; + border-radius: 4px; + border: 1px solid #c0c0cf; + -webkit-appearance: none; + background-color: #ffffff; + cursor: pointer; +} + +.c6:checked { + background-color: #4945ff; + border: 1px solid #4945ff; +} + +.c6:checked:after { + content: ''; + display: block; + position: relative; + background: url() no-repeat no-repeat center center; + width: 10px; + height: 10px; + left: 50%; + top: 50%; + -webkit-transform: translateX(-50%) translateY(-50%); + -ms-transform: translateX(-50%) translateY(-50%); + transform: translateX(-50%) translateY(-50%); +} + +.c6:checked:disabled:after { + background: url() no-repeat no-repeat center center; +} + +.c6:disabled { + background-color: #dcdce4; + border: 1px solid #c0c0cf; +} + +.c6:indeterminate { + background-color: #4945ff; + border: 1px solid #4945ff; +} + +.c6:indeterminate:after { + content: ''; + display: block; + position: relative; + color: white; + height: 2px; + width: 10px; + background-color: #ffffff; + left: 50%; + top: 50%; + -webkit-transform: translateX(-50%) translateY(-50%); + -ms-transform: translateX(-50%) translateY(-50%); + transform: translateX(-50%) translateY(-50%); +} + +.c6:indeterminate:disabled { + background-color: #dcdce4; + border: 1px solid #c0c0cf; +} + +.c6:indeterminate:disabled:after { + background-color: #8e8ea9; +} + .c0 { position: relative; } -.c6 { +.c5 { + position: relative; + z-index: 2; +} + +.c7 { background: #eaf5ff; color: #66b7f1; padding-top: 8px; @@ -31,7 +130,7 @@ exports[`FolderCard renders and matches the snapshot 1`] = ` border-radius: 4px; } -.c3 { +.c2 { background: #ffffff; padding-top: 12px; padding-right: 16px; @@ -43,7 +142,7 @@ exports[`FolderCard renders and matches the snapshot 1`] = ` cursor: pointer; } -.c4 { +.c3 { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; @@ -57,16 +156,16 @@ exports[`FolderCard renders and matches the snapshot 1`] = ` align-items: center; } -.c5 > * { +.c4 > * { margin-left: 0; margin-right: 0; } -.c5 > * + * { +.c4 > * + * { margin-left: 12px; } -.c2 { +.c1 { height: 100%; left: 0; position: absolute; @@ -75,43 +174,58 @@ exports[`FolderCard renders and matches the snapshot 1`] = ` width: 100%; } -.c2:hover, -.c2:focus { +.c1:hover, +.c1:focus { -webkit-text-decoration: none; text-decoration: none; } -.c7 path { +.c8 path { fill: currentColor; } +.c11 { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +
+

+

+

+
+`; + +exports[`FolderCard renders and matches the snapshot 1`] = ` +.c10 { + cursor: pointer; +} + +.c7 { + position: relative; + z-index: 3; +} + +.c8 { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-align-items: flex-start; + -webkit-box-align: flex-start; + -ms-flex-align: flex-start; + align-items: flex-start; +} + +.c12 { + border: 0; + -webkit-clip: rect(0 0 0 0); + clip: rect(0 0 0 0); + height: 1px; + margin: -1px; + overflow: hidden; + padding: 0; + position: absolute; + width: 1px; +} + +.c11 { + font-weight: 500; + color: #32324d; + font-size: 0.875rem; + line-height: 1.43; +} + +.c0 { + position: relative; +} + +.c5 { + background: #eaf5ff; + color: #66b7f1; + padding-top: 8px; + padding-right: 12px; + padding-bottom: 8px; + padding-left: 12px; + border-radius: 4px; +} + +.c2 { + background: #ffffff; + padding-top: 12px; + padding-right: 16px; + padding-bottom: 12px; + padding-left: 16px; + border-radius: 4px; + box-shadow: 0px 1px 4px rgba(33,33,52,0.1); + cursor: pointer; + cursor: pointer; +} + +.c3 { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-align-items: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} + +.c4 > * { + margin-left: 0; + margin-right: 0; +} + +.c4 > * + * { + margin-left: 12px; +} + +.c1 { + height: 100%; + left: 0; + position: absolute; + opacity: 0; + top: 0; + width: 100%; +} + +.c1:hover, +.c1:focus { + -webkit-text-decoration: none; + text-decoration: none; +} + +.c6 path { + fill: currentColor; +} + +.c9 { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +
+
+
+