fix: address CTO review feedback on quick-find search (GH #97, GRO-134)

- Remove unused makeSelectChain function from search.test.ts (lint blocker)
- Fix handleClientClick/handlePetClick to navigate to /admin/clients?highlight={id}
  so the target client is identified in the URL rather than silently ignored
- Add console.warn for fetch errors in GlobalSearch instead of swallowing silently

Auth middleware verified: searchRouter is registered on the api Hono instance
which applies authMiddleware + resolveStaffMiddleware globally — no coverage gap.

Co-Authored-By: Paperclip <noreply@paperclip.ing>
This commit is contained in:
Scrubs McBarkley
2026-03-22 04:10:54 +00:00
parent c826f65bd6
commit 0c182da366
2 changed files with 4 additions and 14 deletions
-10
View File
@@ -34,16 +34,6 @@ vi.mock("@groombook/db", () => {
const clients = tableProxy("clients");
const pets = tableProxy("pets");
function makeSelectChain(results: unknown[]): unknown {
const chain: Record<string, unknown> = {};
const terminal = () => Promise.resolve(results);
chain.from = () => chain;
chain.innerJoin = () => chain;
chain.where = () => chain;
chain.limit = terminal;
return chain;
}
return {
getDb: () => ({
select: (_fields?: unknown) => {
+4 -4
View File
@@ -52,8 +52,8 @@ export function GlobalSearch() {
setResults(data);
setOpen(true);
}
} catch {
// ignore fetch errors
} catch (err) {
console.warn("GlobalSearch: fetch error", err);
} finally {
setLoading(false);
}
@@ -83,13 +83,13 @@ export function GlobalSearch() {
function handleClientClick(client: ClientResult) {
setOpen(false);
setQuery("");
navigate("/admin/clients");
navigate(`/admin/clients?highlight=${client.id}`);
}
function handlePetClick(pet: PetResult) {
setOpen(false);
setQuery("");
navigate("/admin/clients");
navigate(`/admin/clients?highlight=${pet.clientId}`);
}
const hasResults = results && (results.clients.length > 0 || results.pets.length > 0);