116 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import React from 'react';
 | |
| import PropTypes from 'prop-types';
 | |
| import ImmutablePropTypes from 'react-immutable-proptypes';
 | |
| import ImmutablePureComponent from 'react-immutable-pure-component';
 | |
| import { MediaGallery, Video, Audio } from 'mastodon/features/ui/util/async-components';
 | |
| import Bundle from 'mastodon/features/ui/components/bundle';
 | |
| import noop from 'lodash/noop';
 | |
| 
 | |
| export default class MediaAttachments extends ImmutablePureComponent {
 | |
| 
 | |
|   static propTypes = {
 | |
|     status: ImmutablePropTypes.map.isRequired,
 | |
|     height: PropTypes.number,
 | |
|     width: PropTypes.number,
 | |
|   };
 | |
| 
 | |
|   static defaultProps = {
 | |
|     height: 110,
 | |
|     width: 239,
 | |
|   };
 | |
| 
 | |
|   updateOnProps = [
 | |
|     'status',
 | |
|   ];
 | |
| 
 | |
|   renderLoadingMediaGallery = () => {
 | |
|     const { height, width } = this.props;
 | |
| 
 | |
|     return (
 | |
|       <div className='media-gallery' style={{ height, width }} />
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   renderLoadingVideoPlayer = () => {
 | |
|     const { height, width } = this.props;
 | |
| 
 | |
|     return (
 | |
|       <div className='video-player' style={{ height, width }} />
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   renderLoadingAudioPlayer = () => {
 | |
|     const { height, width } = this.props;
 | |
| 
 | |
|     return (
 | |
|       <div className='audio-player' style={{ height, width }} />
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   render () {
 | |
|     const { status, width, height } = this.props;
 | |
|     const mediaAttachments = status.get('media_attachments');
 | |
| 
 | |
|     if (mediaAttachments.size === 0) {
 | |
|       return null;
 | |
|     }
 | |
| 
 | |
|     if (mediaAttachments.getIn([0, 'type']) === 'audio') {
 | |
|       const audio = mediaAttachments.get(0);
 | |
| 
 | |
|       return (
 | |
|         <Bundle fetchComponent={Audio} loading={this.renderLoadingAudioPlayer} >
 | |
|           {Component => (
 | |
|             <Component
 | |
|               src={audio.get('url')}
 | |
|               alt={audio.get('description')}
 | |
|               width={width}
 | |
|               height={height}
 | |
|               poster={audio.get('preview_url') || status.getIn(['account', 'avatar_static'])}
 | |
|               backgroundColor={audio.getIn(['meta', 'colors', 'background'])}
 | |
|               foregroundColor={audio.getIn(['meta', 'colors', 'foreground'])}
 | |
|               accentColor={audio.getIn(['meta', 'colors', 'accent'])}
 | |
|               duration={audio.getIn(['meta', 'original', 'duration'], 0)}
 | |
|             />
 | |
|           )}
 | |
|         </Bundle>
 | |
|       );
 | |
|     } else if (mediaAttachments.getIn([0, 'type']) === 'video') {
 | |
|       const video = mediaAttachments.get(0);
 | |
| 
 | |
|       return (
 | |
|         <Bundle fetchComponent={Video} loading={this.renderLoadingVideoPlayer} >
 | |
|           {Component => (
 | |
|             <Component
 | |
|               preview={video.get('preview_url')}
 | |
|               frameRate={video.getIn(['meta', 'original', 'frame_rate'])}
 | |
|               blurhash={video.get('blurhash')}
 | |
|               src={video.get('url')}
 | |
|               alt={video.get('description')}
 | |
|               width={width}
 | |
|               height={height}
 | |
|               inline
 | |
|               sensitive={status.get('sensitive')}
 | |
|               onOpenVideo={noop}
 | |
|             />
 | |
|           )}
 | |
|         </Bundle>
 | |
|       );
 | |
|     } else {
 | |
|       return (
 | |
|         <Bundle fetchComponent={MediaGallery} loading={this.renderLoadingMediaGallery} >
 | |
|           {Component => (
 | |
|             <Component
 | |
|               media={mediaAttachments}
 | |
|               sensitive={status.get('sensitive')}
 | |
|               defaultWidth={width}
 | |
|               height={height}
 | |
|               onOpenMedia={noop}
 | |
|             />
 | |
|           )}
 | |
|         </Bundle>
 | |
|       );
 | |
|     }
 | |
|   }
 | |
| 
 | |
| }
 |