Choose mention candidates from follows
This commit is contained in:
		
							parent
							
								
									0296e8411e
								
							
						
					
					
						commit
						9f4b5fba4f
					
				
					 1 changed files with 19 additions and 4 deletions
				
			
		|  | @ -16,14 +16,25 @@ const WARNING_TEXT_LENGTH = 200 | ||||||
| const DANGER_TEXT_LENGTH = 255 | const DANGER_TEXT_LENGTH = 255 | ||||||
| export const snapPoints = ['100%'] | export const snapPoints = ['100%'] | ||||||
| 
 | 
 | ||||||
| const DEBUG_USERNAMES = ['alice.test', 'bob.test', 'carol.test'] |  | ||||||
| 
 |  | ||||||
| export function Component({replyTo}: {replyTo?: string}) { | export function Component({replyTo}: {replyTo?: string}) { | ||||||
|   const store = useStores() |   const store = useStores() | ||||||
|   const [error, setError] = useState('') |   const [error, setError] = useState('') | ||||||
|   const [text, setText] = useState('') |   const [text, setText] = useState('') | ||||||
|  |   const [followedUsers, setFollowedUsers] = useState< | ||||||
|  |     undefined | GetUserFollows.OutputSchema['follows'] | ||||||
|  |   >(undefined) | ||||||
|   const [autocompleteOptions, setAutocompleteOptions] = useState<string[]>([]) |   const [autocompleteOptions, setAutocompleteOptions] = useState<string[]>([]) | ||||||
| 
 | 
 | ||||||
|  |   useEffect(() => { | ||||||
|  |     store.api.todo.social | ||||||
|  |       .getUserFollows({ | ||||||
|  |         user: store.me.did || '', | ||||||
|  |       }) | ||||||
|  |       .then(res => { | ||||||
|  |         setFollowedUsers(res.data.follows) | ||||||
|  |       }) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|   const onChangeText = (newText: string) => { |   const onChangeText = (newText: string) => { | ||||||
|     if (newText.length > MAX_TEXT_LENGTH) { |     if (newText.length > MAX_TEXT_LENGTH) { | ||||||
|       newText = newText.slice(0, MAX_TEXT_LENGTH) |       newText = newText.slice(0, MAX_TEXT_LENGTH) | ||||||
|  | @ -31,9 +42,13 @@ export function Component({replyTo}: {replyTo?: string}) { | ||||||
|     setText(newText) |     setText(newText) | ||||||
| 
 | 
 | ||||||
|     const prefix = extractTextAutocompletePrefix(newText) |     const prefix = extractTextAutocompletePrefix(newText) | ||||||
|     if (typeof prefix === 'string') { |     if (typeof prefix === 'string' && followedUsers) { | ||||||
|       setAutocompleteOptions( |       setAutocompleteOptions( | ||||||
|         DEBUG_USERNAMES.filter(name => name.includes(prefix)), |         [prefix].concat( | ||||||
|  |           followedUsers | ||||||
|  |             .filter(user => user.name.startsWith(prefix)) | ||||||
|  |             .map(user => user.name), | ||||||
|  |         ), | ||||||
|       ) |       ) | ||||||
|     } else if (autocompleteOptions) { |     } else if (autocompleteOptions) { | ||||||
|       setAutocompleteOptions([]) |       setAutocompleteOptions([]) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue