Added some functionality leveraging downshift but nothing visually set it yet
This commit is contained in:
@ -1,13 +1,38 @@
|
||||
import { HStack, SpanBox, VStack } from './../../elements/LayoutPrimitives'
|
||||
import { useState } from 'react'
|
||||
import { Sliders, X } from 'phosphor-react'
|
||||
import Downshift from 'downshift'
|
||||
|
||||
import { HStack, VStack } from './../../elements/LayoutPrimitives'
|
||||
import { FormInput } from '../../elements/FormElements'
|
||||
import { Button } from '../../elements/Button'
|
||||
import { Sliders, SlidersHorizontal, X } from 'phosphor-react'
|
||||
import { theme } from '../../tokens/stitches.config'
|
||||
import { styled, theme } from '../../tokens/stitches.config'
|
||||
import { SearchCoordinator } from './LibraryContainer'
|
||||
|
||||
// Styles
|
||||
|
||||
const List = styled('ul', {
|
||||
width: '65%',
|
||||
alignSelf: 'center',
|
||||
color: '#0A0806CC',
|
||||
fontSize: 24,
|
||||
fontWeight: '700',
|
||||
'@smDown': {
|
||||
fontSize: 16,
|
||||
},
|
||||
})
|
||||
|
||||
const Item = styled('li', {
|
||||
listStyleType: 'none',
|
||||
})
|
||||
|
||||
export type LibrarySearchBarProps = {
|
||||
coordinator: SearchCoordinator
|
||||
options?: OptionType[]
|
||||
onChange?: (selectedItem: string) => void // this is for later
|
||||
}
|
||||
|
||||
type OptionType = {
|
||||
value?: string
|
||||
}
|
||||
|
||||
// export type searchHistoryProps = {
|
||||
@ -15,98 +40,154 @@ export type LibrarySearchBarProps = {
|
||||
// index: number
|
||||
// }
|
||||
|
||||
|
||||
export function LibrarySearchBar(props: LibrarySearchBarProps): JSX.Element {
|
||||
const [searchTerm, setSearchTerm] = useState('')
|
||||
//const [recentSearches, setRecentSearches] = useState(Array<searchHistoryProps>())
|
||||
const [searchTerm, setSearchTerm] = useState('')
|
||||
const [recentSearches, setRecentSearches] = useState(['apple', 'pear', 'orange', 'grape', 'banana'])
|
||||
|
||||
return (
|
||||
<>
|
||||
<VStack alignment="start" distribution="start" css={{ pl: '32px', width: '100%', height: '100%' }}>
|
||||
<HStack alignment="start" distribution="start" css={{ width: '100%', borderBottom: 'solid 1px $grayBorder' }}>
|
||||
<form
|
||||
style={{ width: '100%' }}
|
||||
onSubmit={(event) => {
|
||||
event.preventDefault()
|
||||
// props.applySearchQuery(searchTerm || '')
|
||||
// inputRef.current?.blur()
|
||||
}}
|
||||
>
|
||||
<FormInput
|
||||
css={{
|
||||
width: '100%',
|
||||
height: '80px',
|
||||
fontSize: '24px',
|
||||
fontFamily: 'Inter',
|
||||
}}
|
||||
type="text"
|
||||
tabIndex={0}
|
||||
value={searchTerm}
|
||||
placeholder="Search"
|
||||
onChange={(event) => {
|
||||
setSearchTerm(event.target.value)
|
||||
}}
|
||||
/>
|
||||
</form>
|
||||
{!searchTerm && (
|
||||
<Button
|
||||
style="plainIcon"
|
||||
onClick={(event) => {
|
||||
// Display the advanced search sheet
|
||||
}}
|
||||
css={{
|
||||
display: 'flex',
|
||||
flexDirection: 'row',
|
||||
height: '100%',
|
||||
alignItems: 'center',
|
||||
}}
|
||||
>
|
||||
<Sliders size={24} color={theme.colors.utilityTextDefault.toString()} />
|
||||
</Button>
|
||||
)}
|
||||
{searchTerm && (
|
||||
<HStack alignment="center" distribution="start" css={{ height: '100%' }}>
|
||||
<VStack
|
||||
alignment="start"
|
||||
distribution="start"
|
||||
css={{ pl: '32px', width: '100%', height: '100%' }}
|
||||
>
|
||||
<HStack
|
||||
alignment="start"
|
||||
distribution="start"
|
||||
css={{ width: '100%', borderBottom: 'solid 1px $grayBorder' }}
|
||||
>
|
||||
<Downshift>
|
||||
{({
|
||||
getInputProps,
|
||||
getRootProps,
|
||||
getMenuProps,
|
||||
getItemProps,
|
||||
getToggleButtonProps,
|
||||
isOpen,
|
||||
highlightedIndex,
|
||||
}) => (
|
||||
<div
|
||||
{...getRootProps({ refKey: 'ref' }, { suppressRefError: true })}
|
||||
>
|
||||
<form
|
||||
style={{ width: '100%' }}
|
||||
onSubmit={(event) => {
|
||||
event.preventDefault()
|
||||
// props.applySearchQuery(searchTerm || '')
|
||||
// inputRef.current?.blur()
|
||||
}}
|
||||
{...getRootProps()}
|
||||
>
|
||||
<FormInput
|
||||
css={{
|
||||
width: '100%',
|
||||
height: '80px',
|
||||
fontSize: '24px',
|
||||
fontFamily: 'Inter',
|
||||
}}
|
||||
type="text"
|
||||
tabIndex={0}
|
||||
value={searchTerm}
|
||||
placeholder="Search"
|
||||
onChange={(event) => {
|
||||
setSearchTerm(event.target.value)
|
||||
}}
|
||||
{...getInputProps()}
|
||||
/>
|
||||
<Button {...getToggleButtonProps()}>
|
||||
{isOpen ? '-' : '+'} .
|
||||
</Button>
|
||||
<List {...getMenuProps()}>
|
||||
{isOpen &&
|
||||
props.options?.map((item, index) => (
|
||||
<Item
|
||||
key={item.value}
|
||||
{...getItemProps({
|
||||
item,
|
||||
index,
|
||||
style: {
|
||||
backgroundColor:
|
||||
index === highlightedIndex
|
||||
? 'lightgray'
|
||||
: undefined,
|
||||
},
|
||||
})}
|
||||
>
|
||||
{item.value}
|
||||
</Item>
|
||||
))}
|
||||
</List>
|
||||
</form>
|
||||
</div>
|
||||
)}
|
||||
</Downshift>
|
||||
|
||||
{!searchTerm && (
|
||||
<Button
|
||||
style="plainIcon"
|
||||
onClick={(event) => {
|
||||
event.preventDefault()
|
||||
setSearchTerm('')
|
||||
//props.applySearchQuery('')
|
||||
// inputRef.current?.blur()
|
||||
// Display the advanced search sheet
|
||||
}}
|
||||
css={{
|
||||
display: 'flex',
|
||||
flexDirection: 'row',
|
||||
mr: '16px',
|
||||
height: '100%',
|
||||
alignItems: 'center',
|
||||
}}
|
||||
>
|
||||
<X
|
||||
width={24}
|
||||
height={24}
|
||||
color={theme.colors.grayTextContrast.toString()}
|
||||
<Sliders
|
||||
size={24}
|
||||
color={theme.colors.utilityTextDefault.toString()}
|
||||
/>
|
||||
</Button>
|
||||
|
||||
<Button
|
||||
style="ctaDarkYellow"
|
||||
onClick={(event) => {
|
||||
event.preventDefault()
|
||||
//recentSearches.push({searchQuery: searchTerm, index: recentSearches.length })
|
||||
localStorage.setItem(searchTerm,searchTerm)
|
||||
//setRecentSearches(recentSearches)
|
||||
|
||||
// props.applySearchQuery('')
|
||||
// inputRef.current?.blur()
|
||||
}}
|
||||
)}
|
||||
{searchTerm && (
|
||||
<HStack
|
||||
alignment="center"
|
||||
distribution="start"
|
||||
css={{ height: '100%' }}
|
||||
>
|
||||
Search
|
||||
</Button>
|
||||
</HStack>
|
||||
)}
|
||||
</HStack>
|
||||
<Button
|
||||
style="plainIcon"
|
||||
onClick={(event) => {
|
||||
event.preventDefault()
|
||||
setSearchTerm('')
|
||||
//props.applySearchQuery('')
|
||||
// inputRef.current?.blur()
|
||||
}}
|
||||
css={{
|
||||
display: 'flex',
|
||||
flexDirection: 'row',
|
||||
mr: '16px',
|
||||
height: '100%',
|
||||
alignItems: 'center',
|
||||
}}
|
||||
>
|
||||
<X
|
||||
width={24}
|
||||
height={24}
|
||||
color={theme.colors.grayTextContrast.toString()}
|
||||
/>
|
||||
</Button>
|
||||
|
||||
<Button
|
||||
style="ctaDarkYellow"
|
||||
onClick={(event) => {
|
||||
event.preventDefault()
|
||||
//recentSearches.push({searchQuery: searchTerm, index: recentSearches.length })
|
||||
localStorage.setItem(searchTerm, searchTerm)
|
||||
//setRecentSearches(recentSearches)
|
||||
|
||||
// props.applySearchQuery('')
|
||||
// inputRef.current?.blur()
|
||||
}}
|
||||
>
|
||||
Search
|
||||
</Button>
|
||||
</HStack>
|
||||
)}
|
||||
</HStack>
|
||||
</VStack>
|
||||
</>
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user