|
|
|
@ -7,6 +7,7 @@ import MediaGallery from '../components/media_gallery'; |
|
|
|
|
import Video from '../features/video'; |
|
|
|
|
import Card from '../features/status/components/card'; |
|
|
|
|
import Poll from 'mastodon/components/poll'; |
|
|
|
|
import Hashtag from 'mastodon/components/hashtag'; |
|
|
|
|
import ModalRoot from '../components/modal_root'; |
|
|
|
|
import { getScrollbarWidth } from '../features/ui/components/modal_root'; |
|
|
|
|
import MediaModal from '../features/ui/components/media_modal'; |
|
|
|
@ -15,7 +16,7 @@ import { List as ImmutableList, fromJS } from 'immutable'; |
|
|
|
|
const { localeData, messages } = getLocale(); |
|
|
|
|
addLocaleData(localeData); |
|
|
|
|
|
|
|
|
|
const MEDIA_COMPONENTS = { MediaGallery, Video, Card, Poll }; |
|
|
|
|
const MEDIA_COMPONENTS = { MediaGallery, Video, Card, Poll, Hashtag }; |
|
|
|
|
|
|
|
|
|
export default class MediaContainer extends PureComponent { |
|
|
|
|
|
|
|
|
@ -62,12 +63,13 @@ export default class MediaContainer extends PureComponent { |
|
|
|
|
{[].map.call(components, (component, i) => { |
|
|
|
|
const componentName = component.getAttribute('data-component'); |
|
|
|
|
const Component = MEDIA_COMPONENTS[componentName]; |
|
|
|
|
const { media, card, poll, ...props } = JSON.parse(component.getAttribute('data-props')); |
|
|
|
|
const { media, card, poll, hashtag, ...props } = JSON.parse(component.getAttribute('data-props')); |
|
|
|
|
|
|
|
|
|
Object.assign(props, { |
|
|
|
|
...(media ? { media: fromJS(media) } : {}), |
|
|
|
|
...(card ? { card: fromJS(card) } : {}), |
|
|
|
|
...(poll ? { poll: fromJS(poll) } : {}), |
|
|
|
|
...(media ? { media: fromJS(media) } : {}), |
|
|
|
|
...(card ? { card: fromJS(card) } : {}), |
|
|
|
|
...(poll ? { poll: fromJS(poll) } : {}), |
|
|
|
|
...(hashtag ? { hashtag: fromJS(hashtag) } : {}), |
|
|
|
|
|
|
|
|
|
...(componentName === 'Video' ? { |
|
|
|
|
onOpenVideo: this.handleOpenVideo, |
|
|
|
@ -81,6 +83,7 @@ export default class MediaContainer extends PureComponent { |
|
|
|
|
component, |
|
|
|
|
); |
|
|
|
|
})} |
|
|
|
|
|
|
|
|
|
<ModalRoot onClose={this.handleCloseMedia}> |
|
|
|
|
{this.state.media && ( |
|
|
|
|
<MediaModal |
|
|
|
|