import React, { memo, useState, useEffect, useCallback, useRef } from 'react'; import get from 'lodash/get'; import { FiUsers, FiX } from 'react-icons/fi'; import withModal from 'components/modals/withModal'; import Button from 'components/ui/Button'; import { join } from 'state/channels'; import { select } from 'state/tab'; import { searchChannels } from 'state/channelSearch'; import { linkify } from 'utils'; const Channel = memo(({ server, name, topic, userCount, joined, ...props }) => { const handleJoinClick = useCallback(() => props.join([name], server), []); return (

{name}

{userCount} {joined ? ( Joined ) : ( )}

{linkify(topic)}

); }); const AddChannel = ({ search, payload: { server }, onClose, ...props }) => { const [q, setQ] = useState(''); const inputEl = useRef(); const resultsEl = useRef(); const prevSearch = useRef(''); useEffect(() => { inputEl.current.focus(); props.searchChannels(server, ''); }, []); const handleSearch = useCallback( e => { let nextQ = e.target.value.trim().toLowerCase(); setQ(nextQ); if (nextQ !== q) { resultsEl.current.scrollTop = 0; while (nextQ.charAt(0) === '#') { nextQ = nextQ.slice(1); } if (nextQ !== prevSearch.current) { prevSearch.current = nextQ; props.searchChannels(server, nextQ); } } }, [q] ); const handleKey = useCallback(e => { if (e.key === 'Enter') { let channel = e.target.value.trim(); if (channel !== '') { onClose(false); if (channel.charAt(0) !== '#') { channel = `#${channel}`; } props.join([channel], server); props.select(server, channel); } } }, []); const handleLoadMore = useCallback( () => props.searchChannels(server, q, search.results.length), [q, search.results.length] ); let hasMore = !search.end; if (hasMore) { if (search.results.length < 10) { hasMore = false; } else if ( search.results.length > 10 && (search.results.length - 10) % 50 !== 0 ) { hasMore = false; } } return ( <>
{search.results.map(channel => ( ))} {hasMore && ( )}
); }; export default withModal({ name: 'channel', state: { channels: state => state.channels, search: state => state.channelSearch }, actions: { searchChannels, join, select } })(AddChannel);