aboutsummaryrefslogtreecommitdiffstats
path: root/apps/web/components/dashboard/search/SearchInput.tsx
blob: 1ca6a0ae1b0b04d2d0f98bd9b318a6df573e3676 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
"use client";

import React from "react";
import { Input } from "@/components/ui/input";
import { useDoBookmarkSearch } from "@/lib/hooks/bookmark-search";
import { cn } from "@/lib/utils";

const SearchInput = React.forwardRef<
  HTMLInputElement,
  React.HTMLAttributes<HTMLInputElement> & { loading?: boolean }
>(({ className, loading = false, ...props }, ref) => {
  const { debounceSearch, searchQuery } = useDoBookmarkSearch();

  return (
    <Input
      ref={ref}
      placeholder="Search"
      defaultValue={searchQuery}
      onChange={(e) => debounceSearch(e.target.value)}
      className={cn(loading ? "animate-pulse-border" : undefined, className)}
      {...props}
    />
  );
});
SearchInput.displayName = "SearchInput";

export { SearchInput };