chore: update page search input (#4805)

This commit is contained in:
Aaryan Khandelwal 2024-06-13 16:56:48 +05:30 committed by GitHub
parent d75e33ccf0
commit 645764e53d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 17 additions and 13 deletions

View File

@ -52,7 +52,10 @@ export const PagesListHeaderRoot: React.FC<Props> = observer((props) => {
<div className="flex-shrink-0 h-[50px] w-full border-b border-custom-border-200 px-6 relative flex items-center gap-4 justify-between">
<PageTabNavigation workspaceSlug={workspaceSlug} projectId={projectId} pageType={pageType} />
<div className="h-full flex items-center gap-2 self-end">
<PageSearchInput />
<PageSearchInput
searchQuery={filters.searchQuery}
updateSearchQuery={(val) => updateFilters("searchQuery", val)}
/>
<PageOrderByDropdown
sortBy={filters.sortBy}
sortKey={filters.sortKey}

View File

@ -1,16 +1,17 @@
import { FC, useState, useRef } from "react";
import { observer } from "mobx-react-lite";
import { Search, X } from "lucide-react";
// helpers
import { cn } from "@/helpers/common.helper";
import { useProjectPages } from "@/hooks/store";
// hooks
import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
export const PageSearchInput: FC = observer(() => {
// hooks
const {
filters: { searchQuery },
updateFilters,
} = useProjectPages();
type Props = {
searchQuery: string;
updateSearchQuery: (val: string) => void;
};
export const PageSearchInput: FC<Props> = (props) => {
const { searchQuery, updateSearchQuery } = props;
// states
const [isSearchOpen, setIsSearchOpen] = useState(false);
// refs
@ -22,7 +23,7 @@ export const PageSearchInput: FC = observer(() => {
const handleInputKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {
if (e.key === "Escape") {
if (searchQuery && searchQuery.trim() !== "") updateFilters("searchQuery", "");
if (searchQuery && searchQuery.trim() !== "") updateSearchQuery("");
else {
setIsSearchOpen(false);
inputRef.current?.blur();
@ -59,7 +60,7 @@ export const PageSearchInput: FC = observer(() => {
className="w-full max-w-[234px] border-none bg-transparent text-sm text-custom-text-100 placeholder:text-custom-text-400 focus:outline-none"
placeholder="Search pages"
value={searchQuery}
onChange={(e) => updateFilters("searchQuery", e.target.value)}
onChange={(e) => updateSearchQuery(e.target.value)}
onKeyDown={handleInputKeyDown}
/>
{isSearchOpen && (
@ -67,7 +68,7 @@ export const PageSearchInput: FC = observer(() => {
type="button"
className="grid place-items-center"
onClick={() => {
updateFilters("searchQuery", "");
updateSearchQuery("");
setIsSearchOpen(false);
}}
>
@ -77,4 +78,4 @@ export const PageSearchInput: FC = observer(() => {
</div>
</>
);
});
};