Show parent post in composer when replying (close #3)
This commit is contained in:
		
							parent
							
								
									0840c3f8f7
								
							
						
					
					
						commit
						fbcf0d79d1
					
				
					 5 changed files with 66 additions and 5 deletions
				
			
		|  | @ -16,6 +16,7 @@ import {UserAutocompleteViewModel} from '../../../state/models/user-autocomplete | |||
| import {Autocomplete} from './Autocomplete' | ||||
| import Toast from '../util/Toast' | ||||
| import ProgressCircle from '../util/ProgressCircle' | ||||
| import {TextLink} from '../util/Link' | ||||
| import {useStores} from '../../../state' | ||||
| import * as apilib from '../../../state/lib/api' | ||||
| import {ComposerOpts} from '../../../state/models/shell-ui' | ||||
|  | @ -163,6 +164,21 @@ export const ComposePost = observer(function ComposePost({ | |||
|             <Text style={s.red4}>{error}</Text> | ||||
|           </View> | ||||
|         )} | ||||
|         {replyTo ? ( | ||||
|           <View> | ||||
|             <Text style={s.gray4}> | ||||
|               Replying to{' '} | ||||
|               <TextLink | ||||
|                 href={`/profile/${replyTo.author.handle}`} | ||||
|                 text={'@' + replyTo.author.handle} | ||||
|                 style={[s.bold, s.gray5]} | ||||
|               /> | ||||
|             </Text> | ||||
|             <View style={styles.replyToPost}> | ||||
|               <Text style={s.gray5}>{replyTo.text}</Text> | ||||
|             </View> | ||||
|           </View> | ||||
|         ) : undefined} | ||||
|         <TextInput | ||||
|           multiline | ||||
|           scrollEnabled | ||||
|  | @ -250,4 +266,13 @@ const styles = StyleSheet.create({ | |||
|     padding: 5, | ||||
|     fontSize: 21, | ||||
|   }, | ||||
|   replyToPost: { | ||||
|     paddingHorizontal: 8, | ||||
|     paddingVertical: 6, | ||||
|     borderWidth: 1, | ||||
|     borderColor: colors.gray2, | ||||
|     borderRadius: 6, | ||||
|     marginTop: 5, | ||||
|     marginBottom: 10, | ||||
|   }, | ||||
| }) | ||||
|  |  | |||
|  | @ -50,7 +50,15 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
| 
 | ||||
|   const onPressReply = () => { | ||||
|     store.shell.openComposer({ | ||||
|       replyTo: {uri: item.uri, cid: item.cid}, | ||||
|       replyTo: { | ||||
|         uri: item.uri, | ||||
|         cid: item.cid, | ||||
|         text: item.record.text as string, | ||||
|         author: { | ||||
|           handle: item.author.handle, | ||||
|           displayName: item.author.displayName, | ||||
|         }, | ||||
|       }, | ||||
|       onPost: onPostReply, | ||||
|     }) | ||||
|   } | ||||
|  |  | |||
|  | @ -73,7 +73,17 @@ export const Post = observer(function Post({uri}: {uri: string}) { | |||
|     replyHref = `/profile/${urip.hostname}/post/${urip.rkey}` | ||||
|   } | ||||
|   const onPressReply = () => { | ||||
|     store.shell.openComposer({replyTo: {uri: item.uri, cid: item.cid}}) | ||||
|     store.shell.openComposer({ | ||||
|       replyTo: { | ||||
|         uri: item.uri, | ||||
|         cid: item.cid, | ||||
|         text: item.record.text as string, | ||||
|         author: { | ||||
|           handle: item.author.handle, | ||||
|           displayName: item.author.displayName, | ||||
|         }, | ||||
|       }, | ||||
|     }) | ||||
|   } | ||||
|   const onPressToggleRepost = () => { | ||||
|     item | ||||
|  |  | |||
|  | @ -43,7 +43,17 @@ export const FeedItem = observer(function FeedItem({ | |||
|   }, [record.reply]) | ||||
| 
 | ||||
|   const onPressReply = () => { | ||||
|     store.shell.openComposer({replyTo: {uri: item.uri, cid: item.cid}}) | ||||
|     store.shell.openComposer({ | ||||
|       replyTo: { | ||||
|         uri: item.uri, | ||||
|         cid: item.cid, | ||||
|         text: item.record.text as string, | ||||
|         author: { | ||||
|           handle: item.author.handle, | ||||
|           displayName: item.author.displayName, | ||||
|         }, | ||||
|       }, | ||||
|     }) | ||||
|   } | ||||
|   const onPressToggleRepost = () => { | ||||
|     item | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue