2023-06-15 11:00:46 +00:00
|
|
|
import classNames from 'classnames'
|
2023-08-03 09:45:32 +00:00
|
|
|
import React, { ChangeEvent, LegacyRef } from 'react'
|
2023-06-15 11:00:46 +00:00
|
|
|
|
|
|
|
import { Search } from 'components/Icons'
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
value: string
|
|
|
|
placeholder: string
|
2023-08-03 09:45:32 +00:00
|
|
|
autoFocus?: boolean
|
2023-06-15 11:00:46 +00:00
|
|
|
onChange: (value: string) => void
|
|
|
|
}
|
|
|
|
|
2023-07-11 19:01:14 +00:00
|
|
|
const SearchBar = (props: Props, ref: LegacyRef<HTMLDivElement>) => {
|
2023-06-15 11:00:46 +00:00
|
|
|
function onChange(event: ChangeEvent<HTMLInputElement>) {
|
|
|
|
props.onChange(event.target.value)
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
className={classNames(
|
|
|
|
'flex w-full items-center justify-between rounded-sm bg-white/10 p-2.5',
|
2023-07-04 14:15:36 +00:00
|
|
|
'relative isolate max-w-full overflow-hidden rounded-sm',
|
|
|
|
'before:content-[" "] before:absolute before:inset-0 before:-z-1 before:rounded-sm before:p-[1px] before:border-glas',
|
2023-06-15 11:00:46 +00:00
|
|
|
)}
|
2023-07-11 19:01:14 +00:00
|
|
|
ref={ref}
|
2023-06-15 11:00:46 +00:00
|
|
|
>
|
|
|
|
<Search width={14} height={14} className='mr-2.5 text-white' />
|
|
|
|
<input
|
|
|
|
value={props.value}
|
2023-07-11 19:01:14 +00:00
|
|
|
className='h-full w-full bg-transparent text-xs placeholder-white/50 outline-none'
|
2023-06-15 11:00:46 +00:00
|
|
|
placeholder={props.placeholder}
|
|
|
|
onChange={(event) => onChange(event)}
|
2023-08-03 09:45:32 +00:00
|
|
|
autoFocus={props.autoFocus}
|
2023-06-15 11:00:46 +00:00
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
2023-07-03 07:39:34 +00:00
|
|
|
|
2023-07-11 19:01:14 +00:00
|
|
|
export default React.forwardRef(SearchBar)
|