SearchModal.tsx 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import React, {
  2. useState, useCallback, useEffect,
  3. } from 'react';
  4. import Downshift from 'downshift';
  5. import { useRouter } from 'next/router';
  6. import { Modal, ModalBody } from 'reactstrap';
  7. import type { DownshiftItem } from '../interfaces/downshift';
  8. import { useSearchModal } from '../stores/search';
  9. import { SearchForm } from './SearchForm';
  10. import { SearchHelp } from './SearchHelp';
  11. import { SearchMethodMenuItem } from './SearchMethodMenuItem';
  12. import { SearchResultMenuItem } from './SearchResultMenuItem';
  13. const SearchModal = (): JSX.Element => {
  14. const [searchKeyword, setSearchKeyword] = useState('');
  15. const { data: searchModalData, close: closeSearchModal } = useSearchModal();
  16. const router = useRouter();
  17. const changeSearchTextHandler = useCallback((searchText: string) => {
  18. setSearchKeyword(searchText);
  19. }, []);
  20. const clickClearButtonHandler = useCallback(() => {
  21. setSearchKeyword('');
  22. }, []);
  23. const selectSearchMenuItemHandler = useCallback((url: string) => {
  24. closeSearchModal();
  25. router.push(url);
  26. }, [closeSearchModal, router]);
  27. useEffect(() => {
  28. if (!searchModalData?.isOpened) {
  29. setSearchKeyword('');
  30. }
  31. }, [searchModalData?.isOpened]);
  32. return (
  33. <Modal size="lg" isOpen={searchModalData?.isOpened ?? false} toggle={closeSearchModal}>
  34. <ModalBody>
  35. <Downshift onChange={(selectedItem: DownshiftItem) => { selectSearchMenuItemHandler(selectedItem.url) }}>
  36. {({
  37. getInputProps,
  38. getItemProps,
  39. getMenuProps,
  40. highlightedIndex,
  41. }) => (
  42. <div>
  43. <SearchForm
  44. searchKeyword={searchKeyword}
  45. onChangeSearchText={changeSearchTextHandler}
  46. onClickClearButton={clickClearButtonHandler}
  47. getInputProps={getInputProps}
  48. />
  49. <ul {...getMenuProps()} className="list-unstyled">
  50. <div className="border-top mt-3 mb-3" />
  51. <SearchMethodMenuItem searchKeyword={searchKeyword} getItemProps={getItemProps} highlightedIndex={highlightedIndex} />
  52. <div className="border-top mt-3 mb-3" />
  53. <SearchResultMenuItem searchKeyword={searchKeyword} getItemProps={getItemProps} highlightedIndex={highlightedIndex} />
  54. </ul>
  55. </div>
  56. )}
  57. </Downshift>
  58. <SearchHelp />
  59. </ModalBody>
  60. </Modal>
  61. );
  62. };
  63. export default SearchModal;