Change design of audio player in web UI (#34520)
This commit is contained in:
		
					parent
					
						
							
								24c25ec4f5
							
						
					
				
			
			
				commit
				
					
						b4394ec129
					
				
			
		
					 26 changed files with 1476 additions and 1088 deletions
				
			
		|  | @ -1,37 +0,0 @@ | |||
| import PropTypes from 'prop-types'; | ||||
| import { PureComponent } from 'react'; | ||||
| 
 | ||||
| import { FormattedMessage } from 'react-intl'; | ||||
| 
 | ||||
| import { connect } from 'react-redux'; | ||||
| 
 | ||||
| import CancelPresentationIcon from '@/material-icons/400-24px/cancel_presentation.svg?react'; | ||||
| import { removePictureInPicture } from 'mastodon/actions/picture_in_picture'; | ||||
| import { Icon }  from 'mastodon/components/icon'; | ||||
| 
 | ||||
| class PictureInPicturePlaceholder extends PureComponent { | ||||
| 
 | ||||
|   static propTypes = { | ||||
|     dispatch: PropTypes.func.isRequired, | ||||
|     aspectRatio: PropTypes.string, | ||||
|   }; | ||||
| 
 | ||||
|   handleClick = () => { | ||||
|     const { dispatch } = this.props; | ||||
|     dispatch(removePictureInPicture()); | ||||
|   }; | ||||
| 
 | ||||
|   render () { | ||||
|     const { aspectRatio } = this.props; | ||||
| 
 | ||||
|     return ( | ||||
|       <div className='picture-in-picture-placeholder' style={{ aspectRatio }} role='button' tabIndex={0} onClick={this.handleClick}> | ||||
|         <Icon id='window-restore' icon={CancelPresentationIcon} /> | ||||
|         <FormattedMessage id='picture_in_picture.restore' defaultMessage='Put it back' /> | ||||
|       </div> | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| export default connect()(PictureInPicturePlaceholder); | ||||
|  | @ -0,0 +1,46 @@ | |||
| import { useCallback } from 'react'; | ||||
| 
 | ||||
| import { FormattedMessage } from 'react-intl'; | ||||
| 
 | ||||
| import PipExitIcon from '@/material-icons/400-24px/pip_exit.svg?react'; | ||||
| import { removePictureInPicture } from 'mastodon/actions/picture_in_picture'; | ||||
| import { Icon } from 'mastodon/components/icon'; | ||||
| import { useAppDispatch } from 'mastodon/store'; | ||||
| 
 | ||||
| export const PictureInPicturePlaceholder: React.FC<{ aspectRatio: string }> = ({ | ||||
|   aspectRatio, | ||||
| }) => { | ||||
|   const dispatch = useAppDispatch(); | ||||
| 
 | ||||
|   const handleClick = useCallback(() => { | ||||
|     dispatch(removePictureInPicture()); | ||||
|   }, [dispatch]); | ||||
| 
 | ||||
|   const handleKeyDown = useCallback( | ||||
|     (e: React.KeyboardEvent) => { | ||||
|       if (e.key === 'Enter' || e.key === ' ') { | ||||
|         e.preventDefault(); | ||||
|         e.stopPropagation(); | ||||
|         handleClick(); | ||||
|       } | ||||
|     }, | ||||
|     [handleClick], | ||||
|   ); | ||||
| 
 | ||||
|   return ( | ||||
|     <div /* eslint-disable-line jsx-a11y/click-events-have-key-events */ | ||||
|       className='picture-in-picture-placeholder' | ||||
|       style={{ aspectRatio }} | ||||
|       role='button' | ||||
|       tabIndex={0} | ||||
|       onClick={handleClick} | ||||
|       onKeyDownCapture={handleKeyDown} | ||||
|     > | ||||
|       <Icon id='' icon={PipExitIcon} /> | ||||
|       <FormattedMessage | ||||
|         id='picture_in_picture.restore' | ||||
|         defaultMessage='Put it back' | ||||
|       /> | ||||
|     </div> | ||||
|   ); | ||||
| }; | ||||
|  | @ -17,7 +17,7 @@ import RepeatIcon from '@/material-icons/400-24px/repeat.svg?react'; | |||
| import { ContentWarning } from 'mastodon/components/content_warning'; | ||||
| import { FilterWarning } from 'mastodon/components/filter_warning'; | ||||
| import { Icon }  from 'mastodon/components/icon'; | ||||
| import PictureInPicturePlaceholder from 'mastodon/components/picture_in_picture_placeholder'; | ||||
| import { PictureInPicturePlaceholder } from 'mastodon/components/picture_in_picture_placeholder'; | ||||
| import { withOptionalRouter, WithOptionalRouterPropTypes } from 'mastodon/utils/react_router'; | ||||
| 
 | ||||
| import Card from '../features/status/components/card'; | ||||
|  | @ -484,9 +484,6 @@ class Status extends ImmutablePureComponent { | |||
|                 foregroundColor={attachment.getIn(['meta', 'colors', 'foreground'])} | ||||
|                 accentColor={attachment.getIn(['meta', 'colors', 'accent'])} | ||||
|                 duration={attachment.getIn(['meta', 'original', 'duration'], 0)} | ||||
|                 width={this.props.cachedMediaWidth} | ||||
|                 height={110} | ||||
|                 cacheWidth={this.props.cacheMediaWidth} | ||||
|                 deployPictureInPicture={pictureInPicture.get('available') ? this.handleDeployPictureInPicture : undefined} | ||||
|                 sensitive={status.get('sensitive')} | ||||
|                 blurhash={attachment.get('blurhash')} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue