diff options
| author | Armand Philippot <git@armandphilippot.com> | 2023-11-15 16:37:16 +0100 |
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2023-11-15 17:26:17 +0100 |
| commit | c826ad66df066b90b09009f2f4b83b56d018436e (patch) | |
| tree | 6320b85c7a4fdedf8e4384eaca290c02ea2a71e2 /src/utils/hooks/use-scroll-position/use-scroll-position.test.ts | |
| parent | 0f38aee374029213a47ef7c29bd164093fe63c85 (diff) | |
refactor(hooks): rewrite useScrollPosition hook
* return the scroll position (both X and Y)
* no longer accepts arguments
* add tests
Diffstat (limited to 'src/utils/hooks/use-scroll-position/use-scroll-position.test.ts')
| -rw-r--r-- | src/utils/hooks/use-scroll-position/use-scroll-position.test.ts | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/src/utils/hooks/use-scroll-position/use-scroll-position.test.ts b/src/utils/hooks/use-scroll-position/use-scroll-position.test.ts new file mode 100644 index 0000000..49370ae --- /dev/null +++ b/src/utils/hooks/use-scroll-position/use-scroll-position.test.ts @@ -0,0 +1,25 @@ +import { describe, expect, it } from '@jest/globals'; +import { fireEvent, renderHook } from '@testing-library/react'; +import { type ScrollPosition, useScrollPosition } from './use-scroll-position'; + +describe('useScrollPosition', () => { + it('returns the scroll position based on window', () => { + const { result } = renderHook(() => useScrollPosition()); + + expect(result.current.x).toBe(0); + expect(result.current.y).toBe(0); + + const newPos: ScrollPosition = { + x: 50, + y: 100, + }; + + fireEvent.scroll(window, { target: { scrollX: newPos.x } }); + + expect(result.current.x).toBe(newPos.x); + + fireEvent.scroll(window, { target: { scrollY: newPos.y } }); + + expect(result.current.y).toBe(newPos.y); + }); +}); |
