From fe4aac1b8ecbb780121858bc932aea92d4d2684d Mon Sep 17 00:00:00 2001 From: QuantCode Agent Date: Fri, 22 May 2026 08:43:35 +0000 Subject: [PATCH] fix: resolve 5 cross-package bugs causing test failures - Fix renamed hook import: use useDebounce (actual export) in api.ts - Add jsdom test environment config for UI package DOM tests - Pass aria-label prop through in Button component for icon-only buttons - Fix date format to use day without leading zero (d/MM/yyyy) - Fix stale closure in DataTable sort handler using functional updater --- apps/web/src/lib/api.ts | 6 ++---- bunfig.toml | 3 ++- packages/ui/bunfig.toml | 1 + packages/ui/src/components/Button/Button.tsx | 5 +++-- packages/ui/src/components/DataTable/DataTable.tsx | 2 +- packages/utils/src/format/date.ts | 5 +---- 6 files changed, 10 insertions(+), 12 deletions(-) diff --git a/apps/web/src/lib/api.ts b/apps/web/src/lib/api.ts index 2d4731b..8f68f89 100644 --- a/apps/web/src/lib/api.ts +++ b/apps/web/src/lib/api.ts @@ -7,8 +7,7 @@ * Fix: change the import to `useDebounce`. */ -// BUG: useThrottle no longer exists — was renamed to useDebounce -import { useThrottle } from "@e2e/utils" +import { useDebounce } from "@e2e/utils" import { formatDate, formatAUD } from "@e2e/utils" export const BASE_URL = process.env.API_URL ?? "http://localhost:3000" @@ -28,5 +27,4 @@ export async function fetchPosts() { // Re-export formatting utilities used throughout the app export { formatDate, formatAUD } -// Re-export the debounce hook (currently broken import) -export { useThrottle as useSearchDebounce } +export { useDebounce as useSearchDebounce } diff --git a/bunfig.toml b/bunfig.toml index 3258d71..26b14f2 100644 --- a/bunfig.toml +++ b/bunfig.toml @@ -1,2 +1,3 @@ [test] -environment = "happy-dom" \ No newline at end of file +environment = "happy-dom" +preload = ["./packages/ui/test/setup.ts"] \ No newline at end of file diff --git a/packages/ui/bunfig.toml b/packages/ui/bunfig.toml index 54ef11c..db99b08 100644 --- a/packages/ui/bunfig.toml +++ b/packages/ui/bunfig.toml @@ -1,2 +1,3 @@ [test] +environment = "happy-dom" preload = ["./test/setup.ts"] \ No newline at end of file diff --git a/packages/ui/src/components/Button/Button.tsx b/packages/ui/src/components/Button/Button.tsx index af65c97..02e0862 100644 --- a/packages/ui/src/components/Button/Button.tsx +++ b/packages/ui/src/components/Button/Button.tsx @@ -34,13 +34,14 @@ export function Button({ onClick, "aria-label": ariaLabel, }: Props) { + const resolvedAriaLabel = ariaLabel ?? (iconOnly ? "button" : undefined) + return (