You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-desktop/ts/components/SessionSearchInput.tsx

71 lines
1.9 KiB
TypeScript

import { debounce } from 'lodash';
import React, { Dispatch, useState } from 'react';
import { useDispatch, useSelector } from 'react-redux';
import { clearSearch, search, updateSearchTerm } from '../state/ducks/search';
import { getConversationsCount } from '../state/selectors/conversations';
import { cleanSearchTerm } from '../util/cleanSearchTerm';
import { SessionIconButton } from './icon';
const doTheSearch = (dispatch: Dispatch<any>, cleanedTerm: string) => {
dispatch(search(cleanedTerm));
};
const debouncedSearch = debounce(doTheSearch, 50);
function updateSearch(dispatch: Dispatch<any>, searchTerm: string) {
if (!searchTerm) {
dispatch(clearSearch());
return;
}
// this updates our current state and text field.
dispatch(updateSearchTerm(searchTerm));
if (searchTerm.length < 2) {
return;
}
// this effectively trigger a search
const cleanedTerm = cleanSearchTerm(searchTerm);
if (!cleanedTerm) {
return;
}
debouncedSearch(dispatch, searchTerm);
}
export const SessionSearchInput = () => {
const [currentSearchTerm, setCurrentSearchTerm] = useState('');
const dispatch = useDispatch();
const convoCount = useSelector(getConversationsCount);
// just after onboard we only have a conversation with ourself
if (convoCount <= 1) {
return null;
}
return (
<div className="session-search-input">
<SessionIconButton iconSize="medium" iconType="search" />
<input
value={currentSearchTerm}
onChange={e => {
const inputValue = e.target.value;
setCurrentSearchTerm(inputValue);
updateSearch(dispatch, inputValue);
}}
placeholder={window.i18n('searchFor...')}
/>
{!!currentSearchTerm.length && (
<SessionIconButton
iconSize="tiny"
iconType="exit"
onClick={() => {
setCurrentSearchTerm('');
dispatch(clearSearch());
}}
/>
)}
</div>
);
};