diff options
| author | Ivan Chen <ivan@tagg.id> | 2021-04-09 16:28:26 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-09 16:28:26 -0400 | 
| commit | 3ec56863bfdd47b2ee8d0f0fe5a45be779508660 (patch) | |
| tree | 9c247b84bf6ffee90de6ebf5bac6075640b16263 /src/screens/chat/NewChatModal.tsx | |
| parent | fb5cca5bd8aff7232c2ab5e01df0e79dddbef504 (diff) | |
| parent | db51757cb968564dbc1554e0f10880eb009db7bc (diff) | |
Merge pull request #357 from ankit-thanekar007/tma-771-new-chat-modal
[TMA-771] : Modal for Suggested People
Diffstat (limited to 'src/screens/chat/NewChatModal.tsx')
| -rw-r--r-- | src/screens/chat/NewChatModal.tsx | 161 | 
1 files changed, 161 insertions, 0 deletions
| diff --git a/src/screens/chat/NewChatModal.tsx b/src/screens/chat/NewChatModal.tsx new file mode 100644 index 00000000..95e46ecd --- /dev/null +++ b/src/screens/chat/NewChatModal.tsx @@ -0,0 +1,161 @@ +import React, {useEffect, useState} from 'react'; +import { +  Keyboard, +  SectionListData, +  StatusBar, +  StyleSheet, +  Text, +  View, +} from 'react-native'; +import {useSharedValue} from 'react-native-reanimated'; +import {BottomDrawer} from '../../components'; +import { +  SEARCH_ENDPOINT_MESSAGES, +  SEARCH_ENDPOINT_SUGGESTED, +} from '../../constants'; +import {loadSearchResults} from '../../services'; +import {ScreenType} from '../../types'; +import {normalize} from '../../utils'; +import {ChatResultsList, ChatSearchBar} from './index'; +interface NewChatModalProps { +  modalVisible: boolean; +  setChatModalVisible: (open: boolean) => void; +} + +const NewChatModal: React.FC<NewChatModalProps> = ({ +  modalVisible, +  setChatModalVisible, +}) => { +  const [searching, setSearching] = useState(false); +  /* +   * Animated value +   */ +  const animationProgress = useSharedValue<number>(0); +  const [results, setResults] = useState<SectionListData<any>[]>([]); +  const [query, setQuery] = useState<string>(''); +  const handleFocus = () => { +    setSearching(true); +  }; +  const handleBlur = () => { +    Keyboard.dismiss(); +  }; +  const handleCancel = () => { +    setSearching(false); +  }; + +  const getDefaultSuggested = async () => { +    const searchResults = await loadSearchResults( +      `${SEARCH_ENDPOINT_SUGGESTED}`, +    ); +    console.log(searchResults); +    const sanitizedResult = [ +      { +        title: 'users', +        data: searchResults?.users, +      }, +    ]; +    console.log(searchResults, sanitizedResult); +    setResults(sanitizedResult); +  }; + +  const getQuerySuggested = async () => { +    const searchResults = await loadSearchResults( +      `${SEARCH_ENDPOINT_MESSAGES}?query=${query}`, +    ); +    if (query.length > 2) { +      const sanitizedResult = [ +        { +          title: 'users', +          data: searchResults?.users, +        }, +      ]; +      setResults(sanitizedResult); +    } else { +      setResults([]); +    } +  }; + +  useEffect(() => { +    if (query.length === 0) { +      getDefaultSuggested(); +    } + +    if (!searching) { +      return; +    } + +    if (query.length < 3) { +      return; +    } +    getQuerySuggested(); +  }, [query]); + +  const _modalContent = () => { +    return ( +      <View style={styles.modalShadowContainer}> +        <View style={styles.titleContainerStyles}> +          <Text style={styles.titleTextStyles}>New Message</Text> +        </View> +        <ChatSearchBar +          onCancel={handleCancel} +          onChangeText={setQuery} +          onBlur={handleBlur} +          onFocus={handleFocus} +          value={query} +          {...{animationProgress, searching}} +          placeholder={''} +        /> +        {results.length > 0 && ( +          <View style={styles.headerContainerStyles}> +            <Text style={styles.headerTextStyles}>Suggested</Text> +          </View> +        )} +        <ChatResultsList +          {...{results, setChatModalVisible}} +          previewType={'Search'} +          screenType={ScreenType.Search} +        /> +      </View> +    ); +  }; + +  return ( +    <View> +      <StatusBar barStyle="dark-content" /> +      <BottomDrawer +        initialSnapPosition={'90%'} +        isOpen={modalVisible} +        setIsOpen={setChatModalVisible} +        showHeader={false}> +        {_modalContent()} +      </BottomDrawer> +    </View> +  ); +}; + +const styles = StyleSheet.create({ +  modalShadowContainer: { +    height: '100%', +    borderRadius: 9, +    backgroundColor: 'white', +  }, +  titleContainerStyles: {marginVertical: 24}, +  titleTextStyles: { +    fontWeight: 'bold', +    fontSize: normalize(18), +    lineHeight: normalize(21), +    textAlign: 'center', +  }, +  headerContainerStyles: { +    marginTop: 26, +    marginBottom: 10, +    marginHorizontal: 28, +  }, +  headerTextStyles: { +    fontWeight: 'bold', +    fontSize: normalize(17), +    lineHeight: normalize(20), +  }, +}); + +export default NewChatModal; | 
