1
0
Fork 0
mirror of https://github.com/portainer/portainer.git synced 2025-07-20 22:09:41 +02:00

feat(ui): sort search bar icon [EE-3663] (#7205)

This commit is contained in:
Chaim Lev-Ari 2022-07-06 17:05:17 +03:00 committed by GitHub
parent 88c4a43a19
commit ce840997bf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
13 changed files with 73 additions and 54 deletions

View file

@ -1,6 +1,11 @@
import { useLocalStorage } from '@/portainer/hooks/useLocalStorage';
import { Search } from 'react-feather';
import { useEffect, useMemo, useState } from 'react';
import _ from 'lodash';
interface Props {
import { useLocalStorage } from '@/portainer/hooks/useLocalStorage';
import { AutomationTestingProps } from '@/types';
interface Props extends AutomationTestingProps {
value: string;
placeholder?: string;
onChange(value: string): void;
@ -10,21 +15,45 @@ export function SearchBar({
value,
placeholder = 'Search...',
onChange,
'data-cy': dataCy,
}: Props) {
const [searchValue, setSearchValue] = useDebounce(value, onChange);
return (
<div className="searchBar">
<i className="fa fa-search searchIcon" aria-hidden="true" />
<div className="searchBar items-center flex">
<Search className="searchIcon feather" />
<input
type="text"
className="searchInput"
value={value}
onChange={(e) => onChange(e.target.value)}
value={searchValue}
onChange={(e) => setSearchValue(e.target.value)}
placeholder={placeholder}
data-cy={dataCy}
/>
</div>
);
}
function useDebounce(defaultValue: string, onChange: (value: string) => void) {
const [searchValue, setSearchValue] = useState(defaultValue);
useEffect(() => {
setSearchValue(defaultValue);
}, [defaultValue]);
const onChangeDebounces = useMemo(
() => _.debounce(onChange, 300),
[onChange]
);
return [searchValue, handleChange] as const;
function handleChange(value: string) {
setSearchValue(value);
onChangeDebounces(value);
}
}
export function useSearchBarState(
key: string
): [string, (value: string) => void] {