aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/atoms/overlay/overlay.test.tsx
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2023-10-31 17:41:43 +0100
committerArmand Philippot <git@armandphilippot.com>2023-11-11 18:15:27 +0100
commit2844a2bd71dcf1eb17a53992c10129b7496332e0 (patch)
tree6b59044ade226c7dad7d1e64c9586e8d6ff0374b /src/components/atoms/overlay/overlay.test.tsx
parent3ff4c37a7a2c40340c17f9e6c1754444bce0f839 (diff)
feat(components): add an Overlay component
* add useScrollbarWidth hook * add useScrollLock hook * add a new component to lock scroll with an overlay (it can be useful especially on small screens to prevent background contents to be scrolled)
Diffstat (limited to 'src/components/atoms/overlay/overlay.test.tsx')
-rw-r--r--src/components/atoms/overlay/overlay.test.tsx21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/components/atoms/overlay/overlay.test.tsx b/src/components/atoms/overlay/overlay.test.tsx
new file mode 100644
index 0000000..fcc694f
--- /dev/null
+++ b/src/components/atoms/overlay/overlay.test.tsx
@@ -0,0 +1,21 @@
+import { describe, expect, it } from '@jest/globals';
+import { render, screen as screenTL } from '@testing-library/react';
+import { Overlay } from './overlay';
+
+describe('overlay', () => {
+ it('renders its children in front of an overlay', () => {
+ const body = 'perferendis voluptatibus ut';
+
+ render(<Overlay>{body}</Overlay>);
+
+ expect(screenTL.getByText(body)).toHaveClass('overlay--visible');
+ });
+
+ it('can be hidden', () => {
+ const body = 'vel aspernatur mollitia';
+
+ render(<Overlay isVisible={false}>{body}</Overlay>);
+
+ expect(screenTL.getByText(body)).toHaveClass('overlay--hidden');
+ });
+});