* fix emoji picker scroll on firefox and chrome * click outside emoji picker to dismiss * dynamically position emoji picker * dynamically placing picker
This commit is contained in:
		
							parent
							
								
									04992f14f1
								
							
						
					
					
						commit
						4bec7c1d85
					
				
					 1 changed files with 36 additions and 16 deletions
				
			
		|  | @ -1,10 +1,11 @@ | ||||||
| import React from 'react' | import React from 'react' | ||||||
| import Picker from '@emoji-mart/react' | import Picker from '@emoji-mart/react' | ||||||
| import {StyleSheet, View} from 'react-native' | import {StyleSheet, TouchableWithoutFeedback, View} from 'react-native' | ||||||
| import * as DropdownMenu from '@radix-ui/react-dropdown-menu' | import * as DropdownMenu from '@radix-ui/react-dropdown-menu' | ||||||
| import {textInputWebEmitter} from '../TextInput.web' | import {textInputWebEmitter} from '../TextInput.web' | ||||||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||||
| import {usePalette} from 'lib/hooks/usePalette' | import {usePalette} from 'lib/hooks/usePalette' | ||||||
|  | import {useMediaQuery} from 'react-responsive' | ||||||
| 
 | 
 | ||||||
| export type Emoji = { | export type Emoji = { | ||||||
|   aliases?: string[] |   aliases?: string[] | ||||||
|  | @ -23,6 +24,9 @@ export function EmojiPickerButton() { | ||||||
|   const onOpenChange = (o: boolean) => { |   const onOpenChange = (o: boolean) => { | ||||||
|     setOpen(o) |     setOpen(o) | ||||||
|   } |   } | ||||||
|  |   const close = () => { | ||||||
|  |     setOpen(false) | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <DropdownMenu.Root open={open} onOpenChange={onOpenChange}> |     <DropdownMenu.Root open={open} onOpenChange={onOpenChange}> | ||||||
|  | @ -35,13 +39,7 @@ export function EmojiPickerButton() { | ||||||
|       </DropdownMenu.Trigger> |       </DropdownMenu.Trigger> | ||||||
| 
 | 
 | ||||||
|       <DropdownMenu.Portal> |       <DropdownMenu.Portal> | ||||||
|         <DropdownMenu.Content> |         <EmojiPicker close={close} /> | ||||||
|           <EmojiPicker |  | ||||||
|             close={() => { |  | ||||||
|               setOpen(false) |  | ||||||
|             }} |  | ||||||
|           /> |  | ||||||
|         </DropdownMenu.Content> |  | ||||||
|       </DropdownMenu.Portal> |       </DropdownMenu.Portal> | ||||||
|     </DropdownMenu.Root> |     </DropdownMenu.Root> | ||||||
|   ) |   ) | ||||||
|  | @ -52,15 +50,31 @@ export function EmojiPicker({close}: {close: () => void}) { | ||||||
|     textInputWebEmitter.emit('emoji-inserted', emoji) |     textInputWebEmitter.emit('emoji-inserted', emoji) | ||||||
|     close() |     close() | ||||||
|   } |   } | ||||||
|  |   const reducedPadding = useMediaQuery({query: '(max-height: 750px)'}) | ||||||
|  |   const noPadding = useMediaQuery({query: '(max-height: 550px)'}) | ||||||
|  |   const noPicker = useMediaQuery({query: '(max-height: 350px)'}) | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <View style={styles.mask}> |     // eslint-disable-next-line react-native-a11y/has-valid-accessibility-descriptors
 | ||||||
|       <Picker |     <TouchableWithoutFeedback onPress={close} accessibilityViewIsModal> | ||||||
|         // @ts-ignore we set emojiMartData in `emoji-mart-data.js` file
 |       <View style={styles.mask}> | ||||||
|         data={window.emojiMartData} |         <View | ||||||
|         onEmojiSelect={onInsert} |           style={[ | ||||||
|         autoFocus={false} |             styles.picker, | ||||||
|       /> |             { | ||||||
|     </View> |               paddingTop: noPadding ? 0 : reducedPadding ? 150 : 325, | ||||||
|  |               display: noPicker ? 'none' : 'flex', | ||||||
|  |             }, | ||||||
|  |           ]}> | ||||||
|  |           <Picker | ||||||
|  |             // @ts-ignore we set emojiMartData in `emoji-mart-data.js` file
 | ||||||
|  |             data={window.emojiMartData} | ||||||
|  |             onEmojiSelect={onInsert} | ||||||
|  |             autoFocus={false} | ||||||
|  |           /> | ||||||
|  |         </View> | ||||||
|  |       </View> | ||||||
|  |     </TouchableWithoutFeedback> | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -70,6 +84,8 @@ const styles = StyleSheet.create({ | ||||||
|     top: 0, |     top: 0, | ||||||
|     left: 0, |     left: 0, | ||||||
|     right: 0, |     right: 0, | ||||||
|  |     width: '100%', | ||||||
|  |     height: '100%', | ||||||
|   }, |   }, | ||||||
|   trigger: { |   trigger: { | ||||||
|     backgroundColor: 'transparent', |     backgroundColor: 'transparent', | ||||||
|  | @ -78,4 +94,8 @@ const styles = StyleSheet.create({ | ||||||
|     paddingHorizontal: 10, |     paddingHorizontal: 10, | ||||||
|     cursor: 'pointer', |     cursor: 'pointer', | ||||||
|   }, |   }, | ||||||
|  |   picker: { | ||||||
|  |     marginHorizontal: 'auto', | ||||||
|  |     paddingRight: 50, | ||||||
|  |   }, | ||||||
| }) | }) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue