Change navigation layout on small screens in web UI (#34910)
This commit is contained in:
		
					parent
					
						
							
								8cf246e4d3
							
						
					
				
			
			
				commit
				
					
						a13b33d851
					
				
			
		
					 34 changed files with 1390 additions and 682 deletions
				
			
		|  | @ -2,34 +2,47 @@ import { useCallback } from 'react'; | |||
| 
 | ||||
| import { useIntl, defineMessages } from 'react-intl'; | ||||
| 
 | ||||
| import { useSelector, useDispatch } from 'react-redux'; | ||||
| 
 | ||||
| import CloseIcon from '@/material-icons/400-24px/close.svg?react'; | ||||
| import { cancelReplyCompose } from 'mastodon/actions/compose'; | ||||
| import { Account } from 'mastodon/components/account'; | ||||
| import { IconButton } from 'mastodon/components/icon_button'; | ||||
| import { me } from 'mastodon/initial_state'; | ||||
| import { useAppDispatch, useAppSelector } from 'mastodon/store'; | ||||
| 
 | ||||
| import { ActionBar } from './action_bar'; | ||||
| 
 | ||||
| 
 | ||||
| const messages = defineMessages({ | ||||
|   cancel: { id: 'reply_indicator.cancel', defaultMessage: 'Cancel' }, | ||||
| }); | ||||
| 
 | ||||
| export const NavigationBar = () => { | ||||
|   const dispatch = useDispatch(); | ||||
| export const NavigationBar: React.FC = () => { | ||||
|   const dispatch = useAppDispatch(); | ||||
|   const intl = useIntl(); | ||||
|   const isReplying = useSelector(state => !!state.getIn(['compose', 'in_reply_to'])); | ||||
|   const isReplying = useAppSelector( | ||||
|     (state) => !!state.compose.get('in_reply_to'), | ||||
|   ); | ||||
| 
 | ||||
|   const handleCancelClick = useCallback(() => { | ||||
|     dispatch(cancelReplyCompose()); | ||||
|   }, [dispatch]); | ||||
| 
 | ||||
|   if (!me) { | ||||
|     return null; | ||||
|   } | ||||
| 
 | ||||
|   return ( | ||||
|     <div className='navigation-bar'> | ||||
|       <Account id={me} minimal /> | ||||
|       {isReplying ? <IconButton title={intl.formatMessage(messages.cancel)} iconComponent={CloseIcon} onClick={handleCancelClick} /> : <ActionBar />} | ||||
|       {isReplying ? ( | ||||
|         <IconButton | ||||
|           title={intl.formatMessage(messages.cancel)} | ||||
|           icon='' | ||||
|           iconComponent={CloseIcon} | ||||
|           onClick={handleCancelClick} | ||||
|         /> | ||||
|       ) : ( | ||||
|         <ActionBar /> | ||||
|       )} | ||||
|     </div> | ||||
|   ); | ||||
| }; | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue