|
|
@ -2,7 +2,7 @@ import React, { PureComponent, Fragment } from 'react'; |
|
|
|
import ReactDOM from 'react-dom'; |
|
|
|
import ReactDOM from 'react-dom'; |
|
|
|
import PropTypes from 'prop-types'; |
|
|
|
import PropTypes from 'prop-types'; |
|
|
|
import { IntlProvider, addLocaleData } from 'react-intl'; |
|
|
|
import { IntlProvider, addLocaleData } from 'react-intl'; |
|
|
|
import { List as ImmutableList, fromJS } from 'immutable'; |
|
|
|
import { fromJS } from 'immutable'; |
|
|
|
import { getLocale } from 'mastodon/locales'; |
|
|
|
import { getLocale } from 'mastodon/locales'; |
|
|
|
import { getScrollbarWidth } from 'flavours/glitch/util/scrollbar'; |
|
|
|
import { getScrollbarWidth } from 'flavours/glitch/util/scrollbar'; |
|
|
|
import MediaGallery from 'flavours/glitch/components/media_gallery'; |
|
|
|
import MediaGallery from 'flavours/glitch/components/media_gallery'; |
|
|
@ -31,6 +31,7 @@ export default class MediaContainer extends PureComponent { |
|
|
|
index: null, |
|
|
|
index: null, |
|
|
|
time: null, |
|
|
|
time: null, |
|
|
|
backgroundColor: null, |
|
|
|
backgroundColor: null, |
|
|
|
|
|
|
|
options: null, |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
handleOpenMedia = (media, index) => { |
|
|
|
handleOpenMedia = (media, index) => { |
|
|
@ -40,13 +41,15 @@ export default class MediaContainer extends PureComponent { |
|
|
|
this.setState({ media, index }); |
|
|
|
this.setState({ media, index }); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
handleOpenVideo = (video, time) => { |
|
|
|
handleOpenVideo = (options) => { |
|
|
|
const media = ImmutableList([video]); |
|
|
|
const { components } = this.props; |
|
|
|
|
|
|
|
const { media } = JSON.parse(components[options.componetIndex].getAttribute('data-props')); |
|
|
|
|
|
|
|
const mediaList = fromJS(media); |
|
|
|
|
|
|
|
|
|
|
|
document.body.classList.add('with-modals--active'); |
|
|
|
document.body.classList.add('with-modals--active'); |
|
|
|
document.documentElement.style.marginRight = `${getScrollbarWidth()}px`; |
|
|
|
document.documentElement.style.marginRight = `${getScrollbarWidth()}px`; |
|
|
|
|
|
|
|
|
|
|
|
this.setState({ media, time }); |
|
|
|
this.setState({ media: mediaList, options }); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
handleCloseMedia = () => { |
|
|
|
handleCloseMedia = () => { |
|
|
@ -58,6 +61,7 @@ export default class MediaContainer extends PureComponent { |
|
|
|
index: null, |
|
|
|
index: null, |
|
|
|
time: null, |
|
|
|
time: null, |
|
|
|
backgroundColor: null, |
|
|
|
backgroundColor: null, |
|
|
|
|
|
|
|
options: null, |
|
|
|
}); |
|
|
|
}); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -83,6 +87,7 @@ export default class MediaContainer extends PureComponent { |
|
|
|
...(hashtag ? { hashtag: fromJS(hashtag) } : {}), |
|
|
|
...(hashtag ? { hashtag: fromJS(hashtag) } : {}), |
|
|
|
|
|
|
|
|
|
|
|
...(componentName === 'Video' ? { |
|
|
|
...(componentName === 'Video' ? { |
|
|
|
|
|
|
|
componetIndex: i, |
|
|
|
onOpenVideo: this.handleOpenVideo, |
|
|
|
onOpenVideo: this.handleOpenVideo, |
|
|
|
} : { |
|
|
|
} : { |
|
|
|
onOpenMedia: this.handleOpenMedia, |
|
|
|
onOpenMedia: this.handleOpenMedia, |
|
|
@ -100,7 +105,9 @@ export default class MediaContainer extends PureComponent { |
|
|
|
<MediaModal |
|
|
|
<MediaModal |
|
|
|
media={this.state.media} |
|
|
|
media={this.state.media} |
|
|
|
index={this.state.index || 0} |
|
|
|
index={this.state.index || 0} |
|
|
|
time={this.state.time} |
|
|
|
currentTime={this.state.options?.startTime} |
|
|
|
|
|
|
|
autoPlay={this.state.options?.autoPlay} |
|
|
|
|
|
|
|
volume={this.state.options?.defaultVolume} |
|
|
|
onClose={this.handleCloseMedia} |
|
|
|
onClose={this.handleCloseMedia} |
|
|
|
onChangeBackgroundColor={this.setBackgroundColor} |
|
|
|
onChangeBackgroundColor={this.setBackgroundColor} |
|
|
|
/> |
|
|
|
/> |
|
|
|