Skip to content

Commit

Permalink
Merge pull request #2387 from Ekep-Obasi/feat/search-input-url-state
Browse files Browse the repository at this point in the history
feat: display search query in the input field when present
  • Loading branch information
Rassl authored Oct 27, 2024
2 parents 558e462 + fa25e78 commit a11ed37
Show file tree
Hide file tree
Showing 3 changed files with 83 additions and 4 deletions.
77 changes: 77 additions & 0 deletions src/components/App/SideBar/RegularView/__tests__/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
import { ThemeProvider } from '@mui/material'
import { render, renderHook, RenderResult } from '@testing-library/react'
import React, { ReactElement } from 'react'
import { FormProvider, useForm, useFormContext } from 'react-hook-form'
import { MemoryRouter } from 'react-router-dom'
import { ThemeProvider as StyleThemeProvider } from 'styled-components'
import { RegularView } from '..'
import { appTheme } from '../../../Providers'

const QUERY_SEARCH = 'satoshi'

jest.mock('react-hook-form', () => ({
...jest.requireActual('react-hook-form'),
useFormContext: jest.fn(),
}))

jest.mock('react-router-dom', () => ({
...jest.requireActual('react-router-dom'),
useSearchParams: () => [new URLSearchParams({ q: QUERY_SEARCH })],
}))

Object.defineProperty(window, 'matchMedia', {
writable: true,
value: jest.fn().mockImplementation(() => ({
matches: false,
addListener: jest.fn(),
removeListener: jest.fn(),
})),
})

const renderWithProviders = (ui: ReactElement): RenderResult => {
const { result } = renderHook(() =>
useForm<{ search: string }>({
defaultValues: {
search: QUERY_SEARCH,
},
}),
)

return render(
<MemoryRouter>
<ThemeProvider theme={appTheme}>
<StyleThemeProvider theme={appTheme}>
<FormProvider {...result.current}>{ui}</FormProvider>
</StyleThemeProvider>
</ThemeProvider>
</MemoryRouter>,
)
}

describe('RegularView Component', () => {
let setValueMock: jest.Mock

beforeEach(() => {
setValueMock = jest.fn()

const useFormContextMock = useFormContext as jest.Mock

useFormContextMock.mockReturnValue({
setValue: setValueMock,
register: jest.fn(() => ({ name: 'search', value: QUERY_SEARCH })),
watch: jest.fn((field: string) => (field === 'search' ? QUERY_SEARCH : undefined)),
})
})

it('should call setValue with "search" and the correct query value on mount', () => {
renderWithProviders(<RegularView />)
expect(setValueMock).toHaveBeenCalledWith('search', QUERY_SEARCH)
})

it('should display the correct search query in the input field', () => {
const { queryByTestId } = renderWithProviders(<RegularView />)
const searchInput = queryByTestId('search_input') as HTMLInputElement

expect(searchInput.value).toBe(QUERY_SEARCH)
})
})
9 changes: 5 additions & 4 deletions src/components/App/SideBar/RegularView/index.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import clsx from 'clsx'
import React, { useEffect, useRef, useState } from 'react'
import { useFormContext } from 'react-hook-form'
import { useNavigate } from 'react-router-dom'
import { useNavigate, useSearchParams } from 'react-router-dom'
import { ClipLoader } from 'react-spinners'
import styled from 'styled-components'
import { SelectWithPopover } from '~/components/App/SideBar/Dropdown'
Expand All @@ -25,7 +25,6 @@ import { Trending } from '../Trending'

export const MENU_WIDTH = 390

// eslint-disable-next-line react/display-name
export const RegularView = () => {
const { isFetching: isLoading, setSidebarFilter } = useDataStore((s) => s)

Expand All @@ -42,10 +41,12 @@ export const RegularView = () => {
const [isScrolled, setIsScrolled] = useState(false)
const [isFilterOpen, setIsFilterOpen] = useState(false)
const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null)
const [searchParams] = useSearchParams()
const query = searchParams.get('q') ?? ''

useEffect(() => {
setValue('search', searchFormValue)
}, [setValue, searchFormValue])
setValue('search', query || searchFormValue)
}, [setValue, searchFormValue, query])

useEffect(() => {
const component = componentRef.current
Expand Down
1 change: 1 addition & 0 deletions src/components/SearchBar/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ export const SearchBar = ({ loading, placeholder = 'Search', onSubmit }: Props)
return (
<Input
{...register('search')}
data-testid="search_input"
disabled={loading}
id="main-search"
onKeyPress={(event) => {
Expand Down

0 comments on commit a11ed37

Please sign in to comment.