From ba5ca6c3d007d46601c26e511786717c91fe7084 Mon Sep 17 00:00:00 2001 From: QuantCode Agent Date: Mon, 15 Jun 2026 03:32:04 +0000 Subject: [PATCH] fix: repair cross-package bugs so tests and typecheck pass - utils: re-export useDebounce as useSearchDebounce to match consumer + tests - web: import useSearchDebounce from @e2e/utils (was stale useThrottle) - ui: forward aria-label on icon-only Button for accessible name - utils: fix formatDate to en-AU non-zero-padded day/month order - tsconfig: register already-installed bun-types to resolve bun:test types --- apps/web/src/lib/api.ts | 11 ++--------- packages/ui/src/components/Button/Button.tsx | 6 ++++-- packages/utils/src/format/date.ts | 10 ++++------ packages/utils/src/index.ts | 1 + tsconfig.json | 19 +++++++++++++++---- 5 files changed, 26 insertions(+), 21 deletions(-) diff --git a/apps/web/src/lib/api.ts b/apps/web/src/lib/api.ts index 2d4731b..bd15146 100644 --- a/apps/web/src/lib/api.ts +++ b/apps/web/src/lib/api.ts @@ -1,14 +1,8 @@ /** * API client utilities for the web app. - * - * BUG: imports `useThrottle` from @e2e/utils, but that hook was renamed to - * `useDebounce`. This causes a TypeScript error and a runtime crash. - * - * Fix: change the import to `useDebounce`. */ -// BUG: useThrottle no longer exists — was renamed to useDebounce -import { useThrottle } from "@e2e/utils" +import { useSearchDebounce } from "@e2e/utils" import { formatDate, formatAUD } from "@e2e/utils" export const BASE_URL = process.env.API_URL ?? "http://localhost:3000" @@ -28,5 +22,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 { useSearchDebounce } diff --git a/packages/ui/src/components/Button/Button.tsx b/packages/ui/src/components/Button/Button.tsx index af65c97..036cfe2 100644 --- a/packages/ui/src/components/Button/Button.tsx +++ b/packages/ui/src/components/Button/Button.tsx @@ -34,13 +34,15 @@ export function Button({ onClick, "aria-label": ariaLabel, }: Props) { + if (iconOnly && !ariaLabel) { + console.warn("Button: iconOnly is true but no aria-label was provided. This button will have no accessible name.") + } return (