UserSearch.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. import React, { useState, useEffect, useRef } from "react";
  2. import { actionFindUsers } from '../actions'
  3. import {store} from '../reducers'
  4. import { connect } from "react-redux";
  5. const UserSearch = ({
  6. findedUsers,
  7. onSearch,
  8. alreadySearched = [],
  9. onAdd,
  10. open,
  11. }) => {
  12. const [finded, setFinded] = useState([])
  13. const [input, setInput] = useState(null)
  14. useEffect(() => {
  15. let timeout
  16. if (input !== null) {
  17. timeout = setTimeout(() => {
  18. onSearch(input)
  19. }, 500)
  20. }
  21. return () => {
  22. clearTimeout(timeout)
  23. }
  24. }, [input])
  25. useEffect(() => {
  26. setFinded(findedUsers)
  27. }, [findedUsers])
  28. useEffect(() => {
  29. setInput(null)
  30. setFinded([])
  31. }, [open])
  32. return (
  33. <div className="userSearchBox">
  34. <div className="searchField">
  35. <input setInput={setInput} text={'Найти пользователя'} />
  36. </div>
  37. <div className="usersBox">
  38. <div className="usersList">
  39. {finded.map((user) => (
  40. <input
  41. key={user._id}
  42. user={user}
  43. onAction={() => onAdd(user)}
  44. disabled={
  45. !!alreadySearched.find(
  46. (searchedUser) =>
  47. searchedUser._id === user._id
  48. )
  49. }
  50. />
  51. ))}
  52. </div>
  53. </div>
  54. </div>
  55. )
  56. }
  57. const useLocalStoredState = (defaultState, localStorageKey) => {
  58. const json = localStorage[localStorageKey];
  59. try {
  60. defaultState = JSON.parse(json);
  61. } catch (e) {}
  62. const [state, setState] = useState(defaultState);
  63. localStorage.setItem(localStorageKey, JSON.stringify(state));
  64. return [state, setState];
  65. };
  66. export const Input = () => {
  67. const [text, setText] = useLocalStoredState(" ", "inputText");
  68. return <input value={text} onChange={(e) => setText(e.target.value)} />;
  69. };
  70. const ThemeContext = React.createContext();
  71. export const InputDebounce = ({}) => {
  72. const [text, setText] = useState("");
  73. const timeoutRef = useRef();
  74. useEffect(() => {
  75. clearInterval(timeoutRef.current);
  76. if (text)
  77. timeoutRef.current = setTimeout(
  78. () => console.log(store.dispatch(actionFindUsers())),
  79. 2000
  80. );
  81. }, [text]);
  82. return <input value={text} onChange={(e) => setText(e.target.value)} />;
  83. };
  84. export const CUserSearch = connect(
  85. (state) => ({ findedUsers: state.promise.findUsers?.payload || [] }),
  86. { onSearch: actionFindUsers }
  87. )(InputDebounce)