DetailedStatus: use StatusMedia component

This commit is contained in:
Alex Gleason 2022-05-31 12:49:24 -05:00
parent 62d432a65d
commit d6a7e38e56
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7

View file

@ -5,18 +5,14 @@ import { FormattedMessage, injectIntl, WrappedComponentProps as IntlProps } from
import { FormattedDate } from 'react-intl'; import { FormattedDate } from 'react-intl';
import Icon from 'soapbox/components/icon'; import Icon from 'soapbox/components/icon';
import MediaGallery from 'soapbox/components/media_gallery'; import StatusMedia from 'soapbox/components/status-media';
import StatusReplyMentions from 'soapbox/components/status-reply-mentions'; import StatusReplyMentions from 'soapbox/components/status-reply-mentions';
import StatusContent from 'soapbox/components/status_content'; import StatusContent from 'soapbox/components/status_content';
import { HStack, Text } from 'soapbox/components/ui'; import { HStack, Text } from 'soapbox/components/ui';
import AccountContainer from 'soapbox/containers/account_container'; import AccountContainer from 'soapbox/containers/account_container';
import QuotedStatus from 'soapbox/features/status/containers/quoted_status_container'; import QuotedStatus from 'soapbox/features/status/containers/quoted_status_container';
import scheduleIdleTask from 'soapbox/features/ui/util/schedule_idle_task';
import Audio from '../../audio';
import scheduleIdleTask from '../../ui/util/schedule_idle_task';
import Video from '../../video';
import Card from './card';
import StatusInteractionBar from './status-interaction-bar'; import StatusInteractionBar from './status-interaction-bar';
import type { List as ImmutableList } from 'immutable'; import type { List as ImmutableList } from 'immutable';
@ -114,90 +110,12 @@ class DetailedStatus extends ImmutablePureComponent<IDetailedStatus, IDetailedSt
const outerStyle: React.CSSProperties = { boxSizing: 'border-box' }; const outerStyle: React.CSSProperties = { boxSizing: 'border-box' };
const { compact } = this.props; const { compact } = this.props;
let media = null;
let statusTypeIcon = null; let statusTypeIcon = null;
if (this.props.measureHeight) { if (this.props.measureHeight) {
outerStyle.height = `${this.state.height}px`; outerStyle.height = `${this.state.height}px`;
} }
const size = status.media_attachments.size;
const firstAttachment = status.media_attachments.get(0);
if (size > 0 && firstAttachment) {
if (size === 1 && firstAttachment.type === 'video') {
const video = firstAttachment;
if (video.external_video_id && status.card?.html) {
const { mediaWrapperWidth } = this.state;
const getHeight = (): number => {
const width = Number(video.meta.getIn(['original', 'width']));
const height = Number(video.meta.getIn(['original', 'height']));
return Number(mediaWrapperWidth) / (width / height);
};
const height = getHeight();
media = (
<div className='status-card horizontal interactive status-card--video'>
<div
ref={this.setRef}
className='status-card-video'
style={{ height }}
dangerouslySetInnerHTML={{ __html: status.card.html }}
/>
</div>
);
} else {
media = (
<Video
preview={video.preview_url}
blurhash={video.blurhash}
src={video.url}
alt={video.description}
aspectRatio={video.meta.getIn(['original', 'aspect'])}
width={300}
height={150}
inline
onOpenVideo={this.handleOpenVideo}
sensitive={status.sensitive}
visible={this.props.showMedia}
onToggleVisibility={this.props.onToggleMediaVisibility}
/>
);
}
} else if (size === 1 && firstAttachment.type === 'audio') {
const attachment = firstAttachment;
media = (
<Audio
src={attachment.url}
alt={attachment.description}
duration={attachment.meta.getIn(['original', 'duration', 0])}
poster={attachment.preview_url !== attachment.url ? attachment.preview_url : account.avatar_static}
backgroundColor={attachment.meta.getIn(['colors', 'background'])}
foregroundColor={attachment.meta.getIn(['colors', 'foreground'])}
accentColor={attachment.meta.getIn(['colors', 'accent'])}
height={150}
/>
);
} else {
media = (
<MediaGallery
standalone
sensitive={status.sensitive}
media={status.media_attachments}
height={300}
onOpenMedia={this.props.onOpenMedia}
visible={this.props.showMedia}
onToggleVisibility={this.props.onToggleMediaVisibility}
/>
);
}
} else if (status.spoiler_text.length === 0 && !status.quote && status.card) {
media = <Card onOpenMedia={this.props.onOpenMedia} card={status.card} />;
}
let quote; let quote;
if (status.quote) { if (status.quote) {
@ -245,7 +163,12 @@ class DetailedStatus extends ImmutablePureComponent<IDetailedStatus, IDetailedSt
onExpandedToggle={this.handleExpandedToggle} onExpandedToggle={this.handleExpandedToggle}
/> />
{media} <StatusMedia
status={status}
showMedia={this.props.showMedia}
onToggleVisibility={this.props.onToggleMediaVisibility}
/>
{quote} {quote}
<HStack justifyContent='between' alignItems='center' className='py-2'> <HStack justifyContent='between' alignItems='center' className='py-2'>